/* ============================================================
   Prestige Gentleman Hair Studio — "Gilded Gentleman" design system
   Dark modern-baroque luxe · black + antique gold
   One edit to :root re-themes the whole site.
   ============================================================ */

:root{
  /* — ink / surfaces — */
  --ink:        #0d0d0f;
  --ink-1:      #111114;
  --ink-2:      #16161b;
  --ink-3:      #1d1d23;
  --hair:       #2a2a31;          /* hairline borders */
  --hair-soft:  rgba(200,160,74,.18);

  /* — gold — */
  --gold:       #c8a04a;
  --gold-bright:#e7c56b;
  --gold-deep:  #8a6d2e;
  --gold-glow:  rgba(200,160,74,.35);

  /* — text — */
  --cream:      #f1ece1;
  --cream-dim:  #d8d2c5;
  --muted:      #a39e94;
  --muted-2:    #7b766d;

  /* — fonts — */
  --f-display:  "Bodoni Moda", Georgia, "Times New Roman", serif;
  --f-label:    "Chakra Petch", "Courier New", monospace;
  --f-body:     "Inter", system-ui, -apple-system, "Segoe UI", sans-serif;

  /* — metrics — */
  --container: 1240px;
  --gutter: clamp(20px, 5vw, 64px);
  --radius: 4px;
  --radius-lg: 10px;
  --shadow: 0 24px 60px -20px rgba(0,0,0,.7);
  --shadow-gold: 0 18px 50px -18px rgba(200,160,74,.28);
  --ease: cubic-bezier(.22,.61,.36,1);

  --section-y: clamp(72px, 10vw, 160px);
}

/* ---------- reset ---------- */
*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
html.lenis{ scroll-behavior:auto !important; }
html.lenis, html.lenis body{ height:auto; }
.lenis.lenis-smooth{ scroll-behavior:auto !important; }
body{
  font-family:var(--f-body);
  background:var(--ink);
  color:var(--cream-dim);
  line-height:1.65;
  font-size:17px;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img,svg,video{ max-width:100%; display:block; }
img{ height:auto; }
a{ color:inherit; text-decoration:none; }
ul{ list-style:none; }
button{ font-family:inherit; cursor:pointer; }
:focus-visible{ outline:2px solid var(--gold); outline-offset:3px; border-radius:2px; }
::selection{ background:var(--gold); color:var(--ink); }

/* ---------- typography ---------- */
.display, h1,h2,h3{ font-family:var(--f-display); color:var(--cream); font-weight:600; line-height:1.06; letter-spacing:-.01em; }
h1{ font-size:clamp(2.6rem, 6.4vw, 5.2rem); font-weight:700; }
h2{ font-size:clamp(2rem, 4.4vw, 3.5rem); }
h3{ font-size:clamp(1.3rem, 2.4vw, 1.85rem); }
p{ max-width:68ch; }
strong{ color:var(--cream); font-weight:600; }

.eyebrow{
  font-family:var(--f-label);
  text-transform:uppercase;
  letter-spacing:.34em;
  font-size:.72rem;
  font-weight:600;
  color:var(--gold);
  display:inline-flex; align-items:center; gap:.7em;
}
.eyebrow::before{ content:""; width:26px; height:1px; background:linear-gradient(90deg,transparent,var(--gold)); }
.eyebrow.center::after{ content:""; width:26px; height:1px; background:linear-gradient(90deg,var(--gold),transparent); }
.eyebrow.center{ justify-content:center; }

.lede{ font-size:clamp(1.05rem,1.6vw,1.25rem); color:var(--cream-dim); line-height:1.7; }
.gold{ color:var(--gold); }
.serif-accent{ font-family:var(--f-display); font-style:italic; color:var(--gold-bright); }

/* ---------- layout ---------- */
.container{ width:100%; max-width:var(--container); margin-inline:auto; padding-inline:var(--gutter); }
.section{ padding-block:var(--section-y); position:relative; }
.section--tight{ padding-block:clamp(48px,7vw,90px); }
.center{ text-align:center; }
.stack{ display:flex; flex-direction:column; }
.muted{ color:var(--muted); }
.divider-line{ height:1px; background:linear-gradient(90deg,transparent,var(--hair),transparent); border:0; }

/* ---------- buttons ---------- */
.btn{
  --bg:var(--gold); --fg:var(--ink);
  position:relative; display:inline-flex; align-items:center; justify-content:center; gap:.6em;
  font-family:var(--f-label); font-weight:600; font-size:.82rem;
  text-transform:uppercase; letter-spacing:.16em;
  padding:1.05em 1.9em; border:1px solid var(--bg); border-radius:var(--radius);
  background:var(--bg); color:var(--fg); overflow:hidden;
  transition:transform .35s var(--ease), box-shadow .35s var(--ease), color .35s, background .35s, border-color .35s;
  min-height:48px;
}
.btn::after{ /* sheen */
  content:""; position:absolute; inset:0; transform:translateX(-130%) skewX(-18deg);
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.45),transparent);
  transition:transform .7s var(--ease);
}
.btn:hover{ transform:translateY(-3px); box-shadow:var(--shadow-gold); }
.btn:hover::after{ transform:translateX(130%) skewX(-18deg); }
.btn--ghost{ --bg:transparent; --fg:var(--cream); border-color:var(--hair); }
.btn--ghost:hover{ --fg:var(--gold); border-color:var(--gold); box-shadow:none; }
.btn--ghost::after{ display:none; }
.btn--gold-outline{ --bg:transparent; --fg:var(--gold); border-color:var(--gold); }
.btn--gold-outline:hover{ --bg:var(--gold); --fg:var(--ink); }
.btn--lg{ padding:1.2em 2.4em; font-size:.88rem; }
.btn-row{ display:flex; flex-wrap:wrap; gap:14px; align-items:center; }

/* arrow link */
.arrow-link{ font-family:var(--f-label); text-transform:uppercase; letter-spacing:.14em; font-size:.78rem; font-weight:600; color:var(--gold);
  display:inline-flex; align-items:center; gap:.55em; }
.arrow-link svg{ width:18px; transition:transform .3s var(--ease); }
.arrow-link:hover svg{ transform:translateX(5px); }

/* ---------- header ---------- */
.site-header{
  position:fixed; inset:0 0 auto 0; z-index:200;
  display:flex; align-items:center; justify-content:space-between;
  padding:18px var(--gutter);
  transition:background .4s var(--ease), padding .4s var(--ease), border-color .4s;
  border-bottom:1px solid transparent;
}
.site-header.scrolled{
  background:rgba(13,13,15,.82); backdrop-filter:blur(14px) saturate(120%);
  border-bottom-color:var(--hair); padding-block:12px;
}
.brand{ display:flex; align-items:center; gap:12px; z-index:2; }
.brand img{ height:38px; width:auto; transition:height .4s var(--ease); }
.scrolled .brand img{ height:32px; }
.nav{ display:flex; align-items:center; gap:34px; }
.nav a{
  font-family:var(--f-label); text-transform:uppercase; letter-spacing:.14em;
  font-size:.76rem; font-weight:500; color:var(--cream-dim); position:relative; padding:6px 0;
  transition:color .3s;
}
.nav a::after{ content:""; position:absolute; left:0; bottom:0; height:1px; width:0; background:var(--gold); transition:width .35s var(--ease); }
.nav a:hover, .nav a[aria-current="page"]{ color:var(--gold); }
.nav a:hover::after, .nav a[aria-current="page"]::after{ width:100%; }
.header-cta{ display:flex; align-items:center; gap:18px; }
.header-phone{ font-family:var(--f-label); font-size:.8rem; letter-spacing:.06em; color:var(--cream); display:inline-flex; align-items:center; gap:.5em; }
.header-phone:hover{ color:var(--gold); }

.burger{ display:none; flex-direction:column; gap:5px; background:none; border:0; padding:8px; z-index:300; }
.burger span{ width:26px; height:2px; background:var(--cream); transition:.3s var(--ease); }
.burger[aria-expanded="true"] span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.burger[aria-expanded="true"] span:nth-child(2){ opacity:0; }
.burger[aria-expanded="true"] span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

/* mobile drawer */
.drawer{
  position:fixed; inset:0; z-index:250; background:rgba(10,10,12,.98);
  display:flex; flex-direction:column; justify-content:center; align-items:center; gap:8px;
  opacity:0; visibility:hidden; transition:opacity .4s var(--ease), visibility .4s;
}
.drawer.open{ opacity:1; visibility:visible; }
.drawer a{ font-family:var(--f-display); font-size:2rem; color:var(--cream); padding:10px 0; }
.drawer a:hover{ color:var(--gold); }
.drawer .btn{ margin-top:18px; font-family:var(--f-label); font-size:.9rem; }

/* ---------- hero ---------- */
.hero{ position:relative; min-height:100svh; display:flex; align-items:flex-end; overflow:hidden; }
.hero__media{ position:absolute; inset:0; z-index:0; }
.hero__media img{ width:100%; height:100%; object-fit:cover; }
.hero__canvas{ position:absolute; inset:0; z-index:1; pointer-events:none; }
.hero__scrim{ position:absolute; inset:0; z-index:2;
  background:
    radial-gradient(120% 80% at 75% 30%, rgba(200,160,74,.10), transparent 55%),
    linear-gradient(180deg, rgba(13,13,15,.55) 0%, rgba(13,13,15,.35) 38%, rgba(13,13,15,.82) 78%, var(--ink) 100%);
}
.hero__inner{ position:relative; z-index:3; width:100%; padding-bottom:clamp(56px,9vh,120px); padding-top:140px; }
.hero h1{ margin:.28em 0 .35em; }
.hero h1 .line{ display:block; overflow:hidden; }
.hero h1 .line > span{ display:block; }
.hero__sub{ max-width:46ch; color:var(--cream-dim); font-size:clamp(1.02rem,1.5vw,1.2rem); }
.hero__meta{ display:flex; flex-wrap:wrap; gap:26px; margin-top:30px; padding-top:24px; border-top:1px solid var(--hair); }
.hero__meta .mi{ display:flex; flex-direction:column; gap:3px; }
.hero__meta .mi b{ font-family:var(--f-label); color:var(--gold); font-size:.74rem; letter-spacing:.18em; text-transform:uppercase; font-weight:600; }
.hero__meta .mi span{ color:var(--cream); font-size:.96rem; }
.scroll-cue{ position:absolute; bottom:24px; left:50%; transform:translateX(-50%); z-index:3; color:var(--muted);
  font-family:var(--f-label); font-size:.62rem; letter-spacing:.3em; text-transform:uppercase; display:flex; flex-direction:column; align-items:center; gap:8px; }
.scroll-cue i{ width:1px; height:42px; background:linear-gradient(var(--gold),transparent); animation:cue 2.2s 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} }

/* ---------- page hero (inner) ---------- */
.page-hero{ position:relative; padding:170px 0 clamp(48px,7vw,84px); overflow:hidden; border-bottom:1px solid var(--hair); }
.page-hero::before{ content:""; position:absolute; inset:0; z-index:-1;
  background:radial-gradient(90% 120% at 80% -10%, rgba(200,160,74,.12), transparent 60%), var(--ink-1); }
.page-hero__filigree{ position:absolute; top:-30px; right:-40px; width:340px; color:var(--gold); opacity:.10; z-index:-1; }
.page-hero h1{ font-size:clamp(2.4rem,5.4vw,4.4rem); margin:.2em 0 .25em; }
.breadcrumbs{ font-family:var(--f-label); font-size:.72rem; text-transform:uppercase; letter-spacing:.16em; color:var(--muted-2); display:flex; gap:.6em; }
.breadcrumbs a:hover{ color:var(--gold); }

/* ---------- marquee ---------- */
.marquee{ border-block:1px solid var(--hair); background:var(--ink-1); padding:22px 0; overflow:hidden; white-space:nowrap; }
.marquee__track{ display:inline-flex; gap:0; will-change:transform; }
.marquee__track span{ font-family:var(--f-display); font-style:italic; font-size:clamp(1.4rem,3vw,2.4rem); color:var(--cream); padding:0 1.2rem; }
.marquee__track span::after{ content:"✦"; color:var(--gold); font-style:normal; font-size:.7em; margin-left:1.4rem; vertical-align:middle; }

/* ---------- cards / services ---------- */
.grid{ display:grid; gap:22px; }
.grid-2{ grid-template-columns:repeat(2,1fr); }
.grid-3{ grid-template-columns:repeat(3,1fr); }
.grid-4{ grid-template-columns:repeat(4,1fr); }

.card{
  position:relative; background:var(--ink-2); border:1px solid var(--hair); border-radius:var(--radius-lg);
  padding:30px; overflow:hidden; transition:transform .4s var(--ease), border-color .4s, box-shadow .4s;
}
.card::before{ /* gold hairline top */
  content:""; position:absolute; inset:0 0 auto 0; height:1px;
  background:linear-gradient(90deg,transparent,var(--gold),transparent); opacity:0; transition:opacity .4s;
}
.card:hover{ transform:translateY(-6px); border-color:var(--hair-soft); box-shadow:var(--shadow); }
.card:hover::before{ opacity:1; }
.card .num{ font-family:var(--f-display); font-size:.9rem; color:var(--gold); letter-spacing:.1em; }
.card h3{ margin:.5em 0 .35em; }
.card p{ color:var(--muted); font-size:.96rem; }
.svc-card .price{ font-family:var(--f-display); color:var(--gold-bright); font-size:1.4rem; margin-top:14px; display:block; }
.svc-card .ic{ width:34px; height:34px; color:var(--gold); }

/* services table */
.menu-group{ margin-top:54px; }
.menu-group h3{ display:flex; align-items:baseline; gap:14px; }
.menu-group h3::after{ content:""; flex:1; height:1px; background:linear-gradient(90deg,var(--hair),transparent); }
.menu-list{ margin-top:18px; display:flex; flex-direction:column; }
.menu-item{ display:flex; align-items:baseline; gap:12px; padding:16px 4px; border-bottom:1px solid var(--hair); }
.menu-item .mname{ color:var(--cream); font-weight:500; }
.menu-item .mdesc{ color:var(--muted); font-size:.9rem; }
.menu-item .dots{ flex:1; border-bottom:1px dotted var(--hair); transform:translateY(-4px); min-width:24px; }
.menu-item .mprice{ font-family:var(--f-display); color:var(--gold-bright); font-size:1.2rem; white-space:nowrap; font-variant-numeric:tabular-nums; }

/* ---------- split / image blocks ---------- */
.split{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(30px,5vw,72px); align-items:center; }
.split--reverse .split__media{ order:2; }
.media-frame{ position:relative; border-radius:var(--radius-lg); overflow:hidden; border:1px solid var(--hair); }
.media-frame::after{ content:""; position:absolute; inset:0; border:1px solid var(--hair-soft); border-radius:var(--radius-lg); pointer-events:none; }
.media-frame img{ width:100%; height:100%; object-fit:cover; }
.media-frame.parallax img{ scale:1.12; will-change:transform; }

/* stat row */
.stats{ display:flex; flex-wrap:wrap; gap:0; border:1px solid var(--hair); border-radius:var(--radius-lg); overflow:hidden; }
.stat{ flex:1 1 180px; padding:30px 26px; border-right:1px solid var(--hair); }
.stat:last-child{ border-right:0; }
.stat b{ font-family:var(--f-display); font-size:clamp(2rem,4vw,3rem); color:var(--gold-bright); display:block; line-height:1; }
.stat span{ font-family:var(--f-label); text-transform:uppercase; letter-spacing:.14em; font-size:.68rem; color:var(--muted); margin-top:10px; display:block; }

/* ---------- gallery ---------- */
.gallery-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:16px; grid-auto-flow:dense; }
.gal{ position:relative; overflow:hidden; border-radius:var(--radius-lg); border:1px solid var(--hair); background:var(--ink-2); }
.gal img{ width:100%; height:100%; object-fit:cover; transition:transform .6s var(--ease); aspect-ratio:1/1; }
.gal.tall img{ aspect-ratio:3/4; }
.gal.wide{ grid-column:span 2; }
.gal.wide img{ aspect-ratio:3/2; }
.gal:hover img{ transform:scale(1.06); }
.gal__cap{ position:absolute; left:0; right:0; bottom:0; padding:16px; background:linear-gradient(transparent,rgba(13,13,15,.85));
  font-family:var(--f-label); text-transform:uppercase; letter-spacing:.14em; font-size:.7rem; color:var(--cream); opacity:0; transform:translateY(8px); transition:.4s var(--ease); }
.gal:hover .gal__cap{ opacity:1; transform:none; }
.gal--ph{ display:flex; align-items:center; justify-content:center; min-height:240px; text-align:center; color:var(--muted-2);
  border:1px dashed var(--gold-deep); background:repeating-linear-gradient(135deg,var(--ink-2),var(--ink-2) 14px,var(--ink-1) 14px,var(--ink-1) 28px); }
.gal--ph .ic{ width:30px; color:var(--gold-deep); margin:0 auto 10px; }
.gal--ph small{ font-family:var(--f-label); text-transform:uppercase; letter-spacing:.14em; font-size:.66rem; }

/* ---------- hours ---------- */
.hours{ border:1px solid var(--hair); border-radius:var(--radius-lg); overflow:hidden; }
.hours .row{ display:flex; justify-content:space-between; padding:15px 22px; border-bottom:1px solid var(--hair); }
.hours .row:last-child{ border-bottom:0; }
.hours .row.today{ background:rgba(200,160,74,.06); }
.hours .d{ font-family:var(--f-label); text-transform:uppercase; letter-spacing:.1em; font-size:.82rem; color:var(--cream); }
.hours .t{ color:var(--muted); font-variant-numeric:tabular-nums; }
.hours .t.closed{ color:var(--muted-2); }

/* key facts table (AEO) */
.key-facts{ width:100%; border-collapse:collapse; border:1px solid var(--hair); border-radius:var(--radius-lg); overflow:hidden; }
.key-facts th,.key-facts td{ text-align:left; padding:14px 18px; border-bottom:1px solid var(--hair); font-size:.95rem; }
.key-facts th{ font-family:var(--f-label); text-transform:uppercase; letter-spacing:.1em; font-size:.72rem; color:var(--gold); width:42%; vertical-align:top; }
.key-facts td{ color:var(--cream-dim); }
.key-facts tr:last-child th,.key-facts tr:last-child td{ border-bottom:0; }

/* quick answer (AEO) */
.quick-answer{ border-left:2px solid var(--gold); background:var(--ink-2); padding:22px 26px; border-radius:0 var(--radius-lg) var(--radius-lg) 0; }
.quick-answer .qa-label{ font-family:var(--f-label); text-transform:uppercase; letter-spacing:.18em; font-size:.68rem; color:var(--gold); margin-bottom:8px; }
.quick-answer p{ color:var(--cream-dim); margin:0; }

/* ---------- FAQ ---------- */
.faqs{ max-width:860px; margin-inline:auto; }
.faqs details{ border-bottom:1px solid var(--hair); padding:6px 0; }
.faqs summary{ list-style:none; cursor:pointer; padding:22px 44px 22px 0; position:relative;
  font-family:var(--f-display); font-size:clamp(1.05rem,1.8vw,1.3rem); color:var(--cream); }
.faqs summary::-webkit-details-marker{ display:none; }
.faqs summary::after{ content:"+"; position:absolute; right:6px; top:50%; transform:translateY(-50%); color:var(--gold); font-size:1.5rem; transition:transform .3s; }
.faqs details[open] summary::after{ transform:translateY(-50%) rotate(45deg); }
.faqs details p{ padding:0 44px 22px 0; color:var(--muted); }

/* testimonial / proof */
.proof{ text-align:center; max-width:820px; margin-inline:auto; }
.stars{ color:var(--gold); letter-spacing:.2em; font-size:1.3rem; }
.proof blockquote{ font-family:var(--f-display); font-style:italic; font-size:clamp(1.4rem,3vw,2.2rem); color:var(--cream); line-height:1.4; margin:18px 0; }

/* ---------- forms ---------- */
.form{ display:grid; gap:18px; }
.field{ display:flex; flex-direction:column; gap:8px; }
.field label{ font-family:var(--f-label); text-transform:uppercase; letter-spacing:.12em; font-size:.72rem; color:var(--gold); }
.field label .req{ color:var(--gold-bright); }
.field input,.field textarea,.field select{
  background:var(--ink-2); border:1px solid var(--hair); border-radius:var(--radius); color:var(--cream);
  padding:14px 16px; font-family:var(--f-body); font-size:1rem; transition:border-color .3s, box-shadow .3s; min-height:48px;
}
.field input:focus,.field textarea:focus,.field select:focus{ outline:none; border-color:var(--gold); box-shadow:0 0 0 3px var(--gold-glow); }
.field textarea{ resize:vertical; min-height:130px; }
.form__note{ font-size:.8rem; color:var(--muted-2); }
.form-success{ display:none; padding:16px; border:1px solid var(--gold); border-radius:var(--radius); color:var(--gold-bright); font-family:var(--f-label); letter-spacing:.06em; }

/* ---------- footer ---------- */
.site-footer{ border-top:1px solid var(--hair); background:var(--ink-1); padding-block:clamp(56px,8vw,90px) 30px; position:relative; overflow:hidden; }
.footer-watermark{ position:absolute; bottom:-3vw; left:50%; transform:translateX(-50%); font-family:var(--f-display); font-weight:700;
  font-size:18vw; color:var(--cream); opacity:.025; white-space:nowrap; pointer-events:none; z-index:0; }
.footer-grid{ position:relative; z-index:1; display:grid; grid-template-columns:1.6fr 1fr 1fr 1.2fr; gap:40px; }
.footer-brand img{ height:54px; margin-bottom:18px; }
.footer-brand p{ color:var(--muted); font-size:.92rem; max-width:34ch; }
.footer-col h4{ font-family:var(--f-label); text-transform:uppercase; letter-spacing:.16em; font-size:.72rem; color:var(--gold); margin-bottom:16px; }
.footer-col a, .footer-col p{ color:var(--muted); font-size:.94rem; display:block; padding:5px 0; }
.footer-col a:hover{ color:var(--gold); }
.socials{ display:flex; gap:12px; margin-top:16px; }
.socials a{ width:42px; height:42px; display:grid; place-items:center; border:1px solid var(--hair); border-radius:50%; color:var(--cream); transition:.3s var(--ease); }
.socials a:hover{ border-color:var(--gold); color:var(--gold); transform:translateY(-3px); }
.socials svg{ width:18px; }
.footer-bottom{ position:relative; z-index:1; margin-top:50px; padding-top:24px; border-top:1px solid var(--hair); display:flex; flex-wrap:wrap; justify-content:space-between; gap:14px; color:var(--muted-2); font-size:.82rem; }
.footer-bottom a:hover{ color:var(--gold); }

/* ---------- filigree divider ---------- */
.filigree{ display:flex; align-items:center; justify-content:center; gap:18px; color:var(--gold); padding:10px 0; }
.filigree svg{ width:clamp(120px,30vw,260px); opacity:.7; }
.filigree .dot{ width:6px; height:6px; background:var(--gold); transform:rotate(45deg); }

/* ---------- cursor ---------- */
.cursor-dot,.cursor-ring{ position:fixed; top:0; left:0; border-radius:50%; pointer-events:none; z-index:9999; mix-blend-mode:difference; }
.cursor-dot{ width:7px; height:7px; background:var(--gold-bright); transform:translate(-50%,-50%); }
.cursor-ring{ width:34px; height:34px; border:1px solid rgba(231,197,107,.6); transform:translate(-50%,-50%); transition:width .3s,height .3s,background .3s,border-color .3s; }
.cursor-ring.hover{ width:54px; height:54px; background:rgba(200,160,74,.12); border-color:var(--gold); }
@media (hover:none),(pointer:coarse){ .cursor-dot,.cursor-ring{ display:none !important; } }

/* ---------- reveals ---------- */
.reveal{ opacity:0; transform:translateY(28px); transition:opacity .9s var(--ease), transform .9s var(--ease); }
.reveal.in{ opacity:1; transform:none; }
.reveal-d1{ transition-delay:.08s; } .reveal-d2{ transition-delay:.16s; } .reveal-d3{ transition-delay:.24s; } .reveal-d4{ transition-delay:.32s; }
@media (prefers-reduced-motion:reduce){
  .reveal{ opacity:1 !important; transform:none !important; }
  .scroll-cue,.marquee__track{ animation:none !important; }
  *{ scroll-behavior:auto !important; }
}
html.qa .reveal{ opacity:1 !important; transform:none !important; }

/* ---------- responsive ---------- */
@media (max-width:1024px){
  .footer-grid{ grid-template-columns:1fr 1fr; gap:32px; }
  .grid-4{ grid-template-columns:repeat(2,1fr); }
}
@media (max-width:860px){
  .nav, .header-phone{ display:none; }
  .burger{ display:flex; }
  .split, .split--reverse .split__media{ grid-template-columns:1fr; order:0; }
  .split{ gap:34px; }
  .grid-2,.grid-3{ grid-template-columns:1fr; }
  .gallery-grid{ grid-template-columns:repeat(2,1fr); }
  .gal.wide{ grid-column:span 2; }
  .hero__inner{ padding-top:120px; }
}
@media (max-width:520px){
  body{ font-size:16px; }
  .gallery-grid{ grid-template-columns:1fr; }
  .gal.wide{ grid-column:span 1; }
  .stat{ flex:1 1 100%; border-right:0; border-bottom:1px solid var(--hair); }
  .stat:last-child{ border-bottom:0; }
  .menu-item{ flex-wrap:wrap; }
  .menu-item .dots{ display:none; }
}
