/* =========================================================================
   NICHE — Homepage + section layouts + inner page-heroes
   ========================================================================= */

/* =============================== HERO =================================== */
.hero{ position:relative; isolation:isolate; min-height:100svh; display:flex; align-items:center;
  padding-top:6rem; overflow:hidden }
.hero__poster,#hero-gl{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover }
.hero__poster{ z-index:0; filter:brightness(.55) saturate(1.05) }
#hero-gl{ z-index:1 }
.hero::after{ /* vignette + gradient floor so text always reads */
  content:""; position:absolute; inset:0; z-index:2; pointer-events:none;
  background:
    radial-gradient(120% 80% at 50% 30%, transparent 40%, rgba(11,16,32,.55) 100%),
    linear-gradient(180deg, rgba(11,16,32,.4) 0%, transparent 30%, transparent 55%, var(--midnight) 100%);
}
.hero__content{ position:relative; z-index:3; text-align:center; width:100%; max-width:1000px; margin-inline:auto;
  padding-block:4rem }
.hero__eyebrow{ margin-bottom:1.6rem; justify-content:center }
.hero h1{ font-size:clamp(2.9rem,8vw,7rem); font-weight:500; letter-spacing:.005em }
.hero h1 .line{ display:block; overflow:hidden }
.hero h1 .char{ display:inline-block; will-change:transform }
.hero__sub{ max-width:60ch; margin:1.8rem auto 0; font-size:clamp(1.05rem,1rem + .5vw,1.32rem);
  color:var(--stone); line-height:1.7 }
.hero__cta{ display:flex; gap:1rem; justify-content:center; flex-wrap:wrap; margin-top:2.6rem }
.hero__meta{ display:flex; gap:clamp(1.2rem,4vw,3rem); justify-content:center; flex-wrap:wrap; margin-top:3rem;
  color:var(--muted); font-size:.82rem; letter-spacing:.14em; text-transform:uppercase }
.hero__meta span{ display:inline-flex; align-items:center; gap:.5rem }
.hero__meta .dot{ width:4px; height:4px; border-radius:50%; background:var(--gold); display:inline-block }
.scroll-cue{ position:absolute; left:50%; bottom:2rem; transform:translateX(-50%); z-index:3;
  color:var(--muted); font-size:.68rem; letter-spacing:.24em; text-transform:uppercase; display:flex;
  flex-direction:column; align-items:center; gap:.7rem }
.scroll-cue .bar{ width:1px; height:46px; background:linear-gradient(180deg,var(--gold),transparent);
  animation:cue 2.4s var(--ease) infinite }
@keyframes cue{ 0%{transform:scaleY(0);transform-origin:top} 45%{transform:scaleY(1);transform-origin:top}
  55%{transform:scaleY(1);transform-origin:bottom} 100%{transform:scaleY(0);transform-origin:bottom} }
@media (prefers-reduced-motion:reduce){ .scroll-cue .bar{ animation:none } }

/* =========================== PAGE HERO (inner) ========================== */
.page-hero{ position:relative; isolation:isolate; padding:clamp(9rem,16vw,12rem) 0 clamp(3.5rem,7vw,5.5rem);
  text-align:center; overflow:hidden }
.page-hero::before{ content:""; position:absolute; inset:0; z-index:-1;
  background:radial-gradient(80% 120% at 50% -10%, rgba(91,75,138,.32), transparent 60%) }
.page-hero__img{ position:absolute; inset:0; z-index:-2; object-fit:cover; width:100%; height:100%;
  filter:brightness(.4) saturate(1.05) }
.page-hero.has-img::after{ content:""; position:absolute; inset:0; z-index:-1;
  background:linear-gradient(180deg,rgba(11,16,32,.5),rgba(11,16,32,.82) 70%, var(--midnight)) }
.page-hero h1{ max-width:18ch; margin-inline:auto }
.page-hero p{ max-width:60ch; margin:1.3rem auto 0 }
.page-hero .breadcrumbs{ margin-bottom:1.6rem }
.breadcrumbs{ font-size:.76rem; letter-spacing:.12em; text-transform:uppercase; color:var(--muted) }
.breadcrumbs a:hover{ color:var(--gold-soft) }
.breadcrumbs span{ color:var(--gold) }

/* =========================== SPLIT SECTION ============================== */
.split{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(2rem,5vw,5rem); align-items:center }
.split.reverse .split__media{ order:2 }
.split__media{ position:relative }
.split__media img{ width:100%; border-radius:var(--radius); box-shadow:var(--shadow); aspect-ratio:4/3; object-fit:cover }
.split__media.tall img{ aspect-ratio:4/5 }
.split__media .badge{ position:absolute; bottom:-22px; right:-12px; background:linear-gradient(180deg,var(--indigo),var(--indigo-deep));
  border:1px solid var(--line); border-radius:var(--radius-sm); padding:1rem 1.3rem; box-shadow:var(--shadow); }
.split__media .badge strong{ font-family:var(--font-display); font-size:1.8rem; color:var(--gold-soft); display:block; line-height:1 }
.split__media .badge span{ font-size:.72rem; letter-spacing:.14em; text-transform:uppercase; color:var(--muted) }
.split__body .eyebrow{ margin-bottom:1.2rem }
.split__body h2{ margin-bottom:1.3rem }
.split__body p + p{ margin-top:1rem }
.split__body .btn{ margin-top:1.8rem }
.feature-list{ margin-top:1.6rem; display:grid; gap:.9rem }
.feature-list li{ display:flex; gap:.8rem; align-items:flex-start; color:var(--stone) }
.feature-list li::before{ content:"✦"; color:var(--gold); font-size:.8rem; margin-top:.25rem }

/* =========================== DISH GRID ================================== */
.dish-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.6rem }
.dish{ position:relative; border-radius:var(--radius); overflow:hidden; aspect-ratio:3/4;
  border:1px solid var(--line-soft); }
.dish img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; transition:transform 1s var(--ease); }
.dish:hover img{ transform:scale(1.07) }
.dish__overlay{ position:absolute; inset:0; display:flex; flex-direction:column; justify-content:flex-end;
  padding:1.6rem; background:linear-gradient(180deg,transparent 35%, rgba(8,11,22,.5) 65%, rgba(8,11,22,.92)); z-index:1 }
.dish__overlay .chip{ align-self:flex-start; margin-bottom:.8rem }
.dish__overlay h3{ font-size:1.4rem; margin-bottom:.4rem }
.dish__overlay .price{ font-family:var(--font-display); color:var(--gold-soft); font-size:1.2rem }
.dish__overlay p{ font-size:.9rem; margin-top:.5rem; color:var(--stone) }

/* =========================== STATS BAND ================================= */
.stats{ display:grid; grid-template-columns:repeat(4,1fr); gap:0; border:1px solid var(--line-soft);
  border-radius:var(--radius); overflow:hidden; background:linear-gradient(180deg,var(--indigo),var(--indigo-deep)) }
.stat{ padding:2.4rem 1.4rem; text-align:center; position:relative }
.stat + .stat::before{ content:""; position:absolute; left:0; top:18%; height:64%; width:1px;
  background:linear-gradient(180deg,transparent,var(--line),transparent) }
.stat .num{ font-family:var(--font-display); font-size:clamp(2.4rem,5vw,3.4rem); color:var(--gold-soft); line-height:1 }
.stat .label{ margin-top:.7rem; font-size:.76rem; letter-spacing:.16em; text-transform:uppercase; color:var(--muted) }

/* =========================== TESTIMONIALS =============================== */
.quotes{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.6rem }
.quote{ background:linear-gradient(180deg,var(--indigo),var(--indigo-deep)); border:1px solid var(--line-soft);
  border-radius:var(--radius); padding:2.2rem; position:relative }
.quote .mark{ font-family:var(--font-display); font-size:4rem; line-height:.6; color:var(--gold); opacity:.35; height:1.4rem; display:block }
.quote p{ color:var(--cream); font-size:1.02rem; line-height:1.7; font-style:italic; font-family:var(--font-display) }
.quote .stars{ color:var(--gold); letter-spacing:.18em; margin:1.1rem 0 .9rem; font-size:.85rem }
.quote .who{ font-size:.82rem; letter-spacing:.1em; text-transform:uppercase; color:var(--muted) }
.quote .who strong{ color:var(--stone) }

/* =========================== EXPERIENCE CARDS =========================== */
.exp-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.6rem }
.exp{ display:flex; flex-direction:column }
.exp .ic{ width:54px; height:54px; border-radius:50%; display:grid; place-items:center; margin-bottom:1.3rem;
  border:1px solid var(--line); color:var(--gold); background:rgba(201,162,75,.06); font-size:1.3rem }
.exp h3{ font-size:1.35rem; margin-bottom:.7rem }
.exp p{ font-size:.95rem }
.exp .link-underline{ margin-top:1.2rem; align-self:flex-start; font-size:.84rem }

/* =========================== FAQ ======================================== */
.faqs{ max-width:820px; margin-inline:auto }
.faqs details{ border-bottom:1px solid var(--line-soft); padding:1.3rem 0 }
.faqs summary{ display:flex; justify-content:space-between; align-items:center; gap:1rem; cursor:pointer;
  font-family:var(--font-display); font-size:clamp(1.15rem,2vw,1.45rem); color:var(--cream); list-style:none }
.faqs summary::-webkit-details-marker{ display:none }
.faqs summary .pm{ flex-shrink:0; width:30px; height:30px; border:1px solid var(--line); border-radius:50%;
  display:grid; place-items:center; color:var(--gold); transition:transform .4s var(--ease), background .3s }
.faqs details[open] summary .pm{ transform:rotate(45deg); background:rgba(201,162,75,.1) }
.faqs details p{ margin-top:1rem; color:var(--muted); max-width:68ch }

/* =========================== CTA / MAILING ============================== */
.cta-band{ position:relative; text-align:center; border-radius:var(--radius); overflow:hidden;
  padding:clamp(3.5rem,8vw,6rem) var(--gutter);
  background:linear-gradient(180deg,var(--indigo),var(--indigo-deep)); border:1px solid var(--line-soft) }
.cta-band::before{ content:""; position:absolute; inset:0; z-index:0; opacity:.5;
  background:radial-gradient(70% 120% at 50% 0%, rgba(91,75,138,.45), transparent 60%) }
.cta-band > *{ position:relative; z-index:1 }
.cta-band h2{ max-width:18ch; margin-inline:auto }
.cta-band p{ max-width:54ch; margin:1.2rem auto 0 }
.cta-band .btn{ margin-top:2rem }
.mailing{ display:flex; gap:.8rem; max-width:440px; margin:1.8rem auto 0; flex-wrap:wrap }
.mailing input{ flex:1; min-width:200px; padding:.95rem 1.1rem; background:rgba(244,241,233,.05);
  border:1px solid var(--line-soft); border-radius:999px; color:var(--cream); font-family:var(--font-body) }
.mailing input:focus{ outline:none; border-color:var(--gold) }

/* =========================== MENU PAGE ================================== */
.menu-nav{ display:flex; gap:.7rem; justify-content:center; flex-wrap:wrap; margin-bottom:clamp(2.5rem,5vw,4rem) }
.menu-nav a{ padding:.5rem 1.2rem; border:1px solid var(--line); border-radius:999px; font-size:.76rem;
  letter-spacing:.14em; text-transform:uppercase; color:var(--stone); transition:.3s }
.menu-nav a:hover{ border-color:var(--gold); color:var(--gold-soft); background:rgba(201,162,75,.06) }
.menu-section{ margin-bottom:clamp(3rem,6vw,5rem) }
.menu-section__head{ text-align:center; margin-bottom:2.6rem }
.menu-section__head h2{ margin-bottom:.6rem }
.menu-list{ display:grid; grid-template-columns:1fr 1fr; gap:1.6rem 3.5rem; max-width:1080px; margin-inline:auto }
.menu-item{ border-bottom:1px dotted var(--line-soft); padding-bottom:1.3rem }
.menu-item__top{ display:flex; justify-content:space-between; align-items:baseline; gap:1rem }
.menu-item__top h3{ font-size:1.3rem; color:var(--cream) }
.menu-item__price{ font-family:var(--font-display); font-size:1.3rem; color:var(--gold-soft); white-space:nowrap }
.menu-item__top .leader{ flex:1; border-bottom:1px dotted var(--line); transform:translateY(-4px) }
.menu-item p{ margin-top:.5rem; font-size:.92rem; color:var(--muted) }
.menu-item .tag{ font-size:.66rem; letter-spacing:.14em; text-transform:uppercase; color:var(--gold);
  border:1px solid var(--line); border-radius:999px; padding:.12rem .5rem; margin-left:.5rem; white-space:nowrap }

/* =========================== GALLERY =================================== */
.gallery{ columns:3; column-gap:1.2rem }
.gallery img{ width:100%; border-radius:var(--radius-sm); margin-bottom:1.2rem; break-inside:avoid;
  border:1px solid var(--line-soft); transition:transform .5s var(--ease), filter .5s }
.gallery img:hover{ transform:scale(1.02); filter:brightness(1.12) }

/* =========================== CONTACT / MAP ============================== */
.contact-grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(2rem,5vw,4rem); align-items:start }
.info-row{ display:flex; gap:1rem; padding:1.3rem 0; border-bottom:1px solid var(--line-soft) }
.info-row .ic{ flex-shrink:0; width:46px; height:46px; border-radius:50%; display:grid; place-items:center;
  border:1px solid var(--line); color:var(--gold); background:rgba(201,162,75,.05) }
.info-row h4{ font-family:var(--font-body); font-size:.76rem; letter-spacing:.16em; text-transform:uppercase;
  color:var(--muted); margin-bottom:.3rem }
.info-row a,.info-row p{ color:var(--cream); font-size:1.02rem }
.info-row a:hover{ color:var(--gold-soft) }
.map-embed{ border-radius:var(--radius); overflow:hidden; border:1px solid var(--line-soft); margin-top:clamp(3rem,6vw,4.5rem);
  filter:grayscale(.3) brightness(.9) }
.map-embed iframe{ width:100%; height:420px; border:0; display:block }

/* =========================== QUICK ANSWER / KEY FACTS (AEO) ============= */
.quick-answer{ max-width:760px; margin:0 auto clamp(2.5rem,5vw,3.5rem); padding:1.6rem 1.8rem;
  border:1px solid var(--line); border-left:3px solid var(--gold); border-radius:var(--radius-sm);
  background:rgba(201,162,75,.05) }
.quick-answer .qa-label{ font-size:.72rem; letter-spacing:.2em; text-transform:uppercase; color:var(--gold); margin-bottom:.5rem }
.quick-answer p:last-child{ color:var(--stone) }
.key-facts{ width:100%; border-collapse:collapse; max-width:760px; margin:0 auto; }
.key-facts th,.key-facts td{ text-align:left; padding:.95rem 1.1rem; border-bottom:1px solid var(--line-soft); font-size:.96rem }
.key-facts th{ color:var(--muted); font-weight:500; width:38%; letter-spacing:.04em }
.key-facts td{ color:var(--cream) }
.key-facts tr:hover{ background:rgba(201,162,75,.04) }
.updated{ font-size:.8rem; color:var(--muted); margin-top:1.5rem }

/* prose for story/legal pages */
.prose{ max-width:760px; margin-inline:auto }
.prose p{ margin-bottom:1.2rem; color:var(--stone); font-size:1.05rem }
.prose h2{ margin:2.4rem 0 1.1rem } .prose h3{ margin:1.8rem 0 .8rem; color:var(--cream) }
.prose ul{ list-style:none; margin:1.2rem 0; display:grid; gap:.8rem }
.prose ul li{ display:flex; gap:.7rem; color:var(--stone) }
.prose ul li::before{ content:"✦"; color:var(--gold); margin-top:.2rem }

/* =========================== responsive ================================= */
@media (max-width:900px){
  .dish-grid,.quotes,.exp-grid{ grid-template-columns:1fr 1fr }
  .stats{ grid-template-columns:1fr 1fr }
  .stat:nth-child(3)::before{ display:none }
  .menu-list{ grid-template-columns:1fr; gap:1.4rem }
  .gallery{ columns:2 }
}
@media (max-width:720px){
  .split{ grid-template-columns:1fr }
  .split.reverse .split__media{ order:0 }
  .split__media .badge{ right:12px }
  .contact-grid{ grid-template-columns:1fr }
}
@media (max-width:560px){
  .dish-grid,.quotes,.exp-grid{ grid-template-columns:1fr }
  .gallery{ columns:1 }
}
