/* ==========================================================================
   ESSARDAS GROUP — HOME (flagship)
   Cinematic obsidian + champagne. Sections A–J per implementation §9.1.
   ========================================================================== */

/* ---------- A · HERO ---------------------------------------------------- */
.home-hero {
  position: relative;
  min-height: 100svh;
  display: flex;
  align-items: flex-end;
  background: var(--obsidian);
  color: var(--chalk);
  overflow: hidden;
  isolation: isolate;
}
/* full-bleed photograph of the Rock */
.home-hero__media {
  position: absolute; inset: 0; z-index: -3;
  display: block;
}
.home-hero__media img {
  width: 100%; height: 100%;
  object-fit: cover;
  object-position: 68% 58%;
  animation: heroDrift 22s ease-out forwards;
}
@keyframes heroDrift {
  from { transform: scale(1.08); }
  to   { transform: scale(1); }
}
/* cinematic scrim: dark top (for header) + dark base (for text), Rock revealed upper-right */
.home-hero__scrim {
  position: absolute; inset: 0; z-index: -2;
  background:
    linear-gradient(180deg, rgba(7,7,10,0.78) 0%, rgba(7,7,10,0.10) 20%, rgba(7,7,10,0) 42%, rgba(7,7,10,0.55) 74%, rgba(7,7,10,0.95) 100%),
    linear-gradient(75deg, rgba(7,7,10,0.86) 0%, rgba(7,7,10,0.45) 36%, rgba(7,7,10,0.05) 64%, transparent 82%),
    radial-gradient(120% 80% at 50% 120%, color-mix(in srgb, var(--champagne-deep) 14%, transparent), transparent 60%);
}
/* fine grain overlay */
.home-hero::after {
  content: "";
  position: absolute; inset: 0; z-index: -1;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");
  mix-blend-mode: overlay;
  pointer-events: none;
}

.home-hero .container {
  position: relative; z-index: 2;
  padding-top: var(--header-h);
  padding-bottom: clamp(4.5rem, 11vh, 9rem);
}
.home-hero__inner { max-width: 60ch; }
.home-hero .eyebrow {
  color: var(--champagne-glow);
  margin-bottom: var(--space-4);
  text-shadow: 0 1px 12px rgba(0,0,0,0.7);
}
.home-hero h1 {
  font-size: var(--fs-display);
  line-height: 0.96;
  letter-spacing: -0.01em;
  color: var(--chalk);
  text-wrap: balance;
  text-shadow: 0 2px 30px rgba(0,0,0,0.55), 0 1px 6px rgba(0,0,0,0.4);
}
.home-hero h1 em { font-style: italic; color: var(--champagne-glow); }
.home-hero__lead {
  margin-top: var(--space-5);
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--fs-lead);
  color: var(--chalk);
  max-width: 42ch;
  text-shadow: 0 1px 16px rgba(0,0,0,0.7);
}
.home-hero__cta {
  display: flex; flex-wrap: wrap; gap: 1rem;
  margin-top: var(--space-6);
}
@media (prefers-reduced-motion: reduce) {
  .home-hero__media img { animation: none; transform: none; }
}
.home-hero .scroll-cue {
  position: absolute;
  left: 50%; bottom: clamp(1.5rem, 4vh, 3rem);
  transform: translateX(-50%);
  z-index: 2;
  display: inline-flex; flex-direction: column; align-items: center; gap: 0.6rem;
  font-family: var(--font-ui);
  font-size: 0.62rem; letter-spacing: 0.32em; text-transform: uppercase;
  color: var(--chalk-soft);
}
.home-hero .scroll-cue__line {
  width: 1px; height: 48px;
  background: linear-gradient(180deg, var(--champagne), transparent);
  animation: cue 2.4s ease-in-out infinite;
  transform-origin: top;
}
@keyframes cue { 0%,100% { transform: scaleY(0.4); opacity: 0.4; } 50% { transform: scaleY(1); opacity: 1; } }

/* ---------- B · HERITAGE LINE ------------------------------------------ */
.home-heritage { background: var(--bone); color: var(--ink); text-align: center; }
.home-heritage__statement {
  font-family: var(--font-display);
  font-size: var(--fs-h1);
  line-height: 1.16;
  font-weight: 400;
  max-width: 24ch;
  margin-inline: auto;
  text-wrap: balance;
}
.home-heritage__statement b { font-weight: 500; color: var(--champagne-deep); font-style: italic; }
.counter-row {
  display: flex; justify-content: center; flex-wrap: wrap;
  gap: clamp(2rem, 7vw, 6rem);
  margin-top: var(--space-7);
}
.counter { display: flex; flex-direction: column; gap: 0.4rem; }
.counter__num { font-family: var(--font-display); font-size: clamp(2.6rem, 6vw, 4.4rem); line-height: 1; color: var(--ink); }
.counter__num .suffix { color: var(--champagne-deep); }
.counter__label { font-family: var(--font-ui); font-size: 0.7rem; letter-spacing: 0.22em; text-transform: uppercase; color: var(--ink-soft); }
.home-heritage__cta {
  margin-top: var(--space-8);
  display: flex;
  justify-content: center;
}

/* ---------- C · TWO WORLDS --------------------------------------------- */
.two-worlds { display: grid; grid-template-columns: 1fr 1fr; min-height: clamp(420px, 60vh, 760px); }
.world {
  position: relative;
  display: flex; align-items: flex-end;
  padding: 0;
  overflow: hidden;
  isolation: isolate;
  color: var(--chalk);
  min-height: 380px;
}
.world__media { position: absolute; inset: 0; z-index: -2; }
.world__media img {
  width: 100%; height: 100%; object-fit: cover;
  filter: brightness(0.72) saturate(0.88);
  transition: transform 1.1s var(--ease-out), filter 1.1s var(--ease-out);
}
.world::after {
  content: ""; position: absolute; inset: 0; z-index: -1;
  transition: opacity var(--dur-base);
}
.world--luxury { background: var(--obsidian); }
.world--luxury::after {
  background:
    linear-gradient(180deg, rgba(0,0,0,0.6) 0%, rgba(0,0,0,0.25) 40%, rgba(0,0,0,0.88) 100%),
    linear-gradient(90deg, rgba(0,0,0,0.72) 0%, transparent 60%),
    radial-gradient(120% 80% at 70% 10%, color-mix(in srgb, var(--champagne) 10%, transparent), transparent 55%);
}
.world--lifestyle::after {
  background:
    linear-gradient(180deg, rgba(0,0,0,0.5) 0%, rgba(0,0,0,0.18) 38%, rgba(0,0,0,0.85) 100%),
    linear-gradient(90deg, rgba(0,0,0,0.68) 0%, transparent 58%);
}
.world:hover .world__media img { transform: scale(1.06); filter: brightness(0.78) saturate(0.92); }
.world__body {
  position: relative; z-index: 1;
  width: 100%;
  padding: clamp(1.75rem, 4vw, 3rem) clamp(1.75rem, 5vw, 4.5rem);
  padding-top: clamp(3rem, 10vw, 5rem);
  background: linear-gradient(to top, rgba(0,0,0,0.92) 0%, rgba(0,0,0,0.72) 55%, transparent 100%);
}
.world__eyebrow {
  font-family: var(--font-ui); font-size: 0.68rem; letter-spacing: 0.28em; text-transform: uppercase;
  color: var(--champagne);
  text-shadow: 0 1px 8px rgba(0,0,0,0.9);
}
.world__title {
  font-family: var(--font-display); font-size: clamp(2rem, 4vw, 3.2rem); line-height: 1.05;
  margin-top: 0.6rem; max-width: 14ch;
  color: var(--chalk);
  text-shadow: 0 2px 20px rgba(0,0,0,0.95), 0 1px 4px rgba(0,0,0,0.8);
}
.world__sub {
  font-family: var(--font-display); font-style: italic; font-size: var(--fs-lead);
  color: var(--chalk);
  margin-top: 0.65rem; max-width: 28ch;
  text-shadow: 0 1px 12px rgba(0,0,0,0.9), 0 1px 3px rgba(0,0,0,0.75);
}
.world__more {
  display: inline-flex; align-items: center; gap: 0.6rem; margin-top: var(--space-4);
  font-family: var(--font-ui); font-size: 0.72rem; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--chalk);
  text-shadow: 0 1px 8px rgba(0,0,0,0.9);
}
.world__more::after { content: "→"; transition: transform var(--dur-fast); color: var(--champagne); }
.world:hover .world__more::after { transform: translateX(6px); }

/* ---------- D · MAISONS MARQUEE ---------------------------------------- */
.maisons { background: var(--obsidian); color: var(--chalk); text-align: center; overflow: hidden; }
.maisons .eyebrow { color: var(--champagne); justify-content: center; }
.marquee { position: relative; margin-top: var(--space-6); width: 100%; overflow: hidden; -webkit-mask-image: linear-gradient(90deg, transparent, #000 12%, #000 88%, transparent); mask-image: linear-gradient(90deg, transparent, #000 12%, #000 88%, transparent); }
.marquee__track { display: inline-flex; gap: clamp(2.5rem, 6vw, 6rem); align-items: center; white-space: nowrap; will-change: transform; animation: marquee 42s linear infinite; }
.marquee:hover .marquee__track { animation-play-state: paused; }
.marquee__item { font-family: var(--font-display); font-size: clamp(1.4rem, 3vw, 2.4rem); letter-spacing: 0.02em; color: var(--chalk-soft); opacity: 0.78; transition: color var(--dur-fast), opacity var(--dur-fast); }
.marquee__item:hover { color: var(--champagne); opacity: 1; }
@keyframes marquee { from { transform: translateX(0); } to { transform: translateX(-50%); } }
.maisons .btn { margin-top: var(--space-7); }

/* ---------- E · IN STOCK NOW (rail) ------------------------------------ */
.in-stock { background: var(--bone); color: var(--ink); }
.featured-rail { margin-top: var(--space-6); }
.rail-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--gutter); }
.rail-empty { font-family: var(--font-display); font-style: italic; font-size: var(--fs-lead); color: var(--ink-soft); padding-block: var(--space-6); }

/* ---------- F · SERVICES TEASER ---------------------------------------- */
.svc-teaser { background: var(--obsidian); color: var(--chalk); }
.svc-teaser__grid { display: grid; grid-template-columns: 1.05fr 0.95fr; gap: clamp(2rem, 6vw, 6rem); align-items: center; }
.svc-teaser__media { position: relative; aspect-ratio: 4/3; overflow: hidden; }
.svc-teaser__media img { width: 100%; height: 100%; object-fit: cover; }
.svc-teaser__media::after { content: ""; position: absolute; inset: 0; border: 1px solid color-mix(in srgb, var(--champagne) 22%, transparent); pointer-events: none; }
.svc-teaser__body .eyebrow { color: var(--champagne); }
.svc-teaser__body h2 { font-size: var(--fs-h1); margin-top: var(--space-3); }
.svc-teaser__body p { color: var(--chalk-soft); margin-top: var(--space-4); max-width: 42ch; }
.svc-teaser__body .btn { margin-top: var(--space-6); }

/* ---------- G · TAX-FREE BAND ------------------------------------------ */
.taxfree-band { background: var(--bone); color: var(--ink); }
.taxfree-band__inner { display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between; gap: var(--space-5); border-block: 1px solid var(--line); padding-block: clamp(2rem, 5vw, 3.5rem); }
.taxfree-band__text { font-family: var(--font-display); font-size: clamp(1.5rem, 3vw, 2.4rem); line-height: 1.2; max-width: 28ch; }
.taxfree-band__text b { color: var(--champagne-deep); font-style: italic; font-weight: 500; }

/* ---------- H · BOUTIQUES TEASER --------------------------------------- */
.boutiques-teaser { background: var(--obsidian); color: var(--chalk); }
.boutiques-teaser__intro {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 0.85fr);
  gap: clamp(2rem, 5vw, 4.5rem);
  align-items: end;
  text-align: left;
}
.boutiques-teaser .eyebrow { color: var(--champagne); }
.boutiques-teaser h2 {
  font-size: var(--fs-h1);
  line-height: 1.02;
  margin-top: var(--space-3);
  max-width: 12ch;
}
.boutiques-teaser__lead {
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--fs-lead);
  line-height: 1.45;
  color: var(--chalk-soft);
  max-width: 34ch;
  margin-left: auto;
  padding-bottom: 0.35rem;
}
.boutiques-teaser__map { margin-top: clamp(2.5rem, 5vw, 4rem); }
.boutiques-teaser__cta { margin-top: var(--space-7); }

/* ---------- I · JOURNAL ------------------------------------------------- */
.home-journal { background: var(--bone); color: var(--ink); }
.home-journal .journal-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--gutter);
  margin-top: var(--space-6);
}
/* Portrait cards — image top, copy bottom (override editorial dark stub styles) */
.home-journal .journal-card {
  aspect-ratio: 4 / 5;
  padding: 0;
  border: 1px solid var(--line);
  border-radius: 2px;
  background: var(--ivory);
  color: var(--ink);
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  overflow: hidden;
  transition: border-color var(--dur-fast) var(--ease-luxe), transform var(--dur-fast) var(--ease-luxe);
}
.home-journal .journal-card:hover {
  border-color: var(--champagne);
  transform: translateY(-3px);
}
.home-journal .journal-card__media {
  flex: 1 1 auto;
  min-height: 0;
  overflow: hidden;
  background: var(--parchment);
}
.home-journal .journal-card__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 1.1s var(--ease-out);
}
.home-journal .journal-card:hover .journal-card__media img { transform: scale(1.06); }
.home-journal .journal-card__body {
  flex: none;
  padding: clamp(1.25rem, 2.2vw, 1.75rem);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  background: var(--ivory);
}
.home-journal .journal-card__date {
  font-family: var(--font-ui);
  font-size: 0.66rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-soft);
}
.home-journal .journal-card__title {
  font-family: var(--font-display);
  font-size: var(--fs-h3);
  line-height: 1.18;
  color: var(--ink);
}

/* ---------- responsive -------------------------------------------------- */
@media (max-width: 900px) {
  .two-worlds { grid-template-columns: 1fr; }
  .svc-teaser__grid { grid-template-columns: 1fr; }
  .rail-grid { grid-template-columns: repeat(2, 1fr); }
  .journal-grid { grid-template-columns: 1fr; }
  .boutiques-teaser__intro { grid-template-columns: 1fr; }
  .boutiques-teaser__lead { margin-left: 0; max-width: 42ch; }
}
@media (max-width: 520px) {
  .rail-grid { grid-template-columns: 1fr; }
  .counter-row { gap: 2rem 3rem; }
}
