/* ============================================================
   SparkVela — design system v3 "Premium Editorial"
   Fraunces (serif display) + Inter (body) · refined deep navy + antique gold.
   Gold is a JEWEL accent. Primary button is navy on light, gold on dark.
   ============================================================ */
:root{
  /* blue — one hue, deepened & slightly desaturated */
  --navy:#16223F; --indigo:#243B6B; --indigo-bright:#3A52A0; --indigo-700:#1B2C52; --navy-ink:#0E1A3A;
  /* gold — antique; bright gold only for micro-accents */
  --gold:#C99A3C; --deep-gold:#A87C24; --gold-bright:#E7BE62; --gold-on-light:#7A5A14;
  --gold-soft:#F3E4C4; --gold-faint:#FBF4E4;
  /* surfaces — warm, monotemperature (no pure white at rest) */
  --cream:#F7F3EA; --cream-100:#FBF8F1; --surface:#FFFDF9; --surface-alt:#EFE9DC; --surface-blue:#EEF1F7; --white:#FFFFFF;
  /* text — warm unified ramp */
  --charcoal:#171A22; --ink-700:#2A2A33; --ink-500:#57606A; --ink-400:#7C8590;
  /* lines / overlay */
  --line:rgba(22,34,63,.10); --line-strong:rgba(22,34,63,.18); --line-warm:#E7DFCF; --overlay:rgba(14,26,58,.60);

  /* type */
  --font-head:"Fraunces","Georgia",serif;
  --font-serif:"Fraunces","Georgia",serif;
  --font-body:"Inter","Segoe UI",system-ui,-apple-system,sans-serif;
  --fs-display:clamp(2.6rem, 1.2rem + 5.6vw, 4.6rem);
  --fs-h1:clamp(2.15rem, 1.3rem + 2.9vw, 3.4rem);
  --fs-h2:clamp(1.8rem, 1.15rem + 2.2vw, 2.7rem);
  --fs-h3:clamp(1.3rem, 1.05rem + 1vw, 1.6rem);
  --fs-lead:clamp(1.16rem, 1.02rem + .55vw, 1.4rem);
  --fs-body:clamp(1.0625rem, 1rem + .25vw, 1.125rem);

  /* spacing (fluid) */
  --sp-4:16px; --sp-5:24px; --sp-6:32px; --sp-7:clamp(36px,5vw,48px);
  --sp-8:clamp(44px,6vw,64px); --sp-9:clamp(56px,8vw,96px); --sp-10:clamp(72px,10vw,120px);
  --r-sm:10px; --r-md:14px; --r-lg:20px; --r-xl:28px; --r-pill:999px; --r-tile:22px;
  --sh-sm:0 1px 2px rgba(22,34,63,.05),0 4px 14px rgba(22,34,63,.05);
  --sh-md:0 2px 6px rgba(22,34,63,.06),0 14px 38px rgba(22,34,63,.09);
  --sh-lg:0 4px 10px rgba(22,34,63,.06),0 26px 64px rgba(22,34,63,.12);
  --glow-gold:0 10px 28px rgba(201,154,60,.26);
  --ease:cubic-bezier(.22,.61,.36,1);
  --focus:0 0 0 3px rgba(201,154,60,.5);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;scroll-padding-top:92px}
body{font-family:var(--font-body);font-size:var(--fs-body);line-height:1.7;color:var(--charcoal);
  background:var(--cream);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;font-optical-sizing:auto}
h1,h2,h3,h4{font-family:var(--font-head);font-weight:600;line-height:1.1;text-wrap:balance;color:var(--navy);font-optical-sizing:auto}
h1{font-size:var(--fs-h1);letter-spacing:-.018em} h2{font-size:var(--fs-h2);letter-spacing:-.016em} h3{font-size:var(--fs-h3);line-height:1.22;letter-spacing:-.01em}
p{max-width:66ch;text-wrap:pretty}
a{color:var(--indigo);text-decoration:none;background-image:linear-gradient(var(--gold),var(--gold));
  background-size:0% 1.5px;background-position:0 100%;background-repeat:no-repeat;
  transition:background-size .3s var(--ease),color .2s}
a:hover{color:var(--deep-gold);background-size:100% 1.5px}
.btn,.nav__links a,.textlink,.footer a,.brand{background-image:none}
.on-dark a:not(.btn){color:var(--gold-bright)}
em{font-style:italic}
::selection{background:var(--gold-soft);color:var(--navy)}
.wrap{width:min(1160px,100% - 44px);margin-inline:auto}
.narrow{max-width:780px;margin-inline:auto}
.section{padding:var(--sp-10) 0}
.section--tight{padding:var(--sp-8) 0}
.eyebrow{font-family:var(--font-body);font-weight:600;font-size:.8125rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--gold-on-light);display:inline-flex;align-items:center;gap:10px;margin-bottom:16px}
.eyebrow::before{content:"";width:22px;height:1.5px;background:currentColor;display:inline-block;opacity:.85;flex:none}
.center .eyebrow{justify-content:center}
.band .eyebrow{color:var(--gold)}
.lead{font-size:var(--fs-lead);color:var(--ink-700);line-height:1.6;max-width:60ch}
.center{text-align:center}.center p,.center .lead{margin-inline:auto}
.num-xl{font-family:var(--font-serif);font-style:italic;font-weight:300;font-size:clamp(2.4rem, 1.5rem + 4vw, 4rem);line-height:1;color:var(--indigo)}
:where(a,button,input,select,textarea,summary,[tabindex]):focus-visible{outline:none;box-shadow:var(--focus);border-radius:6px}

/* ---------- buttons ---------- */
.btn{position:relative;overflow:hidden;font-family:var(--font-body);font-weight:600;font-size:1rem;letter-spacing:-.01em;
  display:inline-flex;align-items:center;gap:9px;padding:15px 28px;border:1.5px solid transparent;border-radius:var(--r-pill);
  cursor:pointer;text-decoration:none;will-change:transform;
  transition:transform .25s var(--ease),box-shadow .25s var(--ease),background .2s,color .2s,border-color .2s}
.btn:hover{text-decoration:none}
.btn .arr{transition:transform .25s var(--ease)}
.btn:hover .arr{transform:translateX(4px)}
.btn:active{transform:scale(.97)}
/* primary = navy on light (gold arrow), with a subtle sheen */
.btn--primary{background:var(--navy);color:#fff;box-shadow:var(--sh-sm)}
.btn--primary:hover{background:var(--navy-ink);color:#fff;transform:translateY(-2px);box-shadow:var(--sh-md)}
.btn--primary .arr{color:var(--gold-bright)}
.btn--primary::before{content:"";position:absolute;inset:0;border-radius:inherit;pointer-events:none;
  background:linear-gradient(110deg,transparent 30%,rgba(255,255,255,.22) 50%,transparent 70%);
  transform:translateX(-120%);transition:transform .6s var(--ease)}
.btn--primary:hover::before{transform:translateX(120%)}
/* on dark backgrounds, primary flips to gold so it pops */
.on-dark .btn--primary,.band .btn--primary,.cta .btn--primary,.mcta .btn--primary{background:var(--gold);color:var(--navy);box-shadow:var(--sh-sm)}
.on-dark .btn--primary:hover,.band .btn--primary:hover,.cta .btn--primary:hover,.mcta .btn--primary:hover{background:var(--gold-bright);color:var(--navy);box-shadow:var(--glow-gold)}
.on-dark .btn--primary .arr,.band .btn--primary .arr,.cta .btn--primary .arr,.mcta .btn--primary .arr{color:var(--navy)}
.on-dark .btn--primary::before,.band .btn--primary::before,.cta .btn--primary::before,.mcta .btn--primary::before{background:linear-gradient(110deg,transparent 30%,rgba(255,255,255,.4) 50%,transparent 70%)}
.btn--secondary{background:transparent;color:var(--indigo);border-color:var(--line-strong)}
.btn--secondary:hover{border-color:var(--indigo);transform:translateY(-2px)}
.btn--lg{padding:18px 34px;font-size:1.0625rem}
.on-dark .btn--secondary{color:#fff;border-color:rgba(255,255,255,.5)}
.on-dark .btn--secondary:hover{background:#fff;color:var(--navy)}
.textlink{font-family:var(--font-body);font-weight:600;font-size:.95rem;color:var(--ink-700);border-bottom:1.5px solid var(--line-strong);padding-bottom:2px;transition:color .2s,border-color .2s}
.textlink:hover{color:var(--indigo);border-color:var(--gold);text-decoration:none}

/* ---------- nav ---------- */
.nav{position:sticky;top:0;z-index:90;background:rgba(247,243,234,.82);backdrop-filter:saturate(1.6) blur(14px);
  border-bottom:1px solid transparent;transition:border-color .3s,background .3s}
.nav.scrolled{border-bottom-color:var(--line);background:rgba(247,243,234,.94)}
.nav__bar{display:flex;align-items:center;gap:18px;height:74px}
.brand{display:flex;align-items:center;gap:11px;font-family:var(--font-body);font-weight:700;font-size:1.3rem;letter-spacing:-.02em;color:var(--navy)}
.brand:hover{text-decoration:none}
.brand .gold{color:var(--gold);font-family:var(--font-serif);font-style:italic;font-weight:500}
.brand__mark{transition:transform .5s var(--ease)}
.brand:hover .brand__mark{transform:rotate(45deg)}
.status{display:inline-flex;align-items:center;gap:8px;margin-left:6px;padding:6px 13px;border-radius:var(--r-pill);
  background:var(--gold-faint);border:1px solid var(--gold-soft);color:var(--deep-gold);font-family:var(--font-body);font-weight:600;font-size:.78rem;white-space:nowrap}
.status .dot{width:8px;height:8px;border-radius:50%;background:var(--gold);animation:ping 2.2s infinite}
@keyframes ping{0%{box-shadow:0 0 0 0 rgba(201,154,60,.5)}70%{box-shadow:0 0 0 8px rgba(201,154,60,0)}100%{box-shadow:0 0 0 0 rgba(201,154,60,0)}}
.nav__spacer{flex:1}
.nav__links{display:flex;align-items:center;gap:24px;list-style:none}
.nav__links a:not(.btn){position:relative;font-family:var(--font-body);font-weight:500;letter-spacing:-.01em;color:var(--navy);font-size:1rem}
.nav__links a:not(.btn):hover{text-decoration:none;color:var(--indigo)}
.nav__links a:not(.btn)::after{content:"";position:absolute;left:0;bottom:-4px;width:100%;height:1.5px;background:var(--gold);transform:scaleX(0);transform-origin:right;transition:transform .3s var(--ease)}
.nav__links a:not(.btn):hover::after,.nav__links a[aria-current="page"]::after{transform:scaleX(1);transform-origin:left}
.nav__toggle{display:none;background:none;border:0;cursor:pointer;color:var(--navy);padding:11px}
.nav__toggle svg{width:28px;height:28px}

/* ---------- marquee ---------- */
.marquee{overflow:hidden;display:flex;border-block:1px solid var(--line);background:var(--cream-100)}
.marquee-track{display:flex;flex-shrink:0;gap:46px;padding-right:46px;white-space:nowrap;animation:scroll 36s linear infinite}
.marquee:hover .marquee-track{animation-play-state:paused}
.marquee-item{font-family:var(--font-body);font-weight:600;font-size:.92rem;letter-spacing:.04em;color:var(--ink-700);display:inline-flex;align-items:center;gap:46px;padding:15px 0}
.marquee-item .sp{color:var(--gold)}
@keyframes scroll{to{transform:translateX(-100%)}}

/* ---------- hero ---------- */
.hero{position:relative;overflow:hidden}
.hero--light{background:var(--cream)}
.hero__spark{position:absolute;top:-70px;right:-50px;width:360px;opacity:.07;pointer-events:none}
.hero__grid{display:grid;grid-template-columns:1.05fr .95fr;gap:var(--sp-8);align-items:center;padding:clamp(48px,7vw,96px) 0 clamp(40px,5vw,64px)}
.hero h1{font-size:var(--fs-display);font-weight:600;line-height:1.04;letter-spacing:-.022em;font-variation-settings:"opsz" 144}
.hero .u-spark{font-family:var(--font-serif);font-style:italic;font-weight:500;color:var(--deep-gold)}
.hero__cta{display:flex;flex-wrap:wrap;gap:16px;align-items:center;margin-top:var(--sp-6)}
.hero__skip{margin-top:18px;font-size:.95rem;color:var(--ink-500)}
.hero__media{border-radius:var(--r-xl);box-shadow:var(--sh-lg);aspect-ratio:4/3;position:relative;overflow:hidden;
  background:linear-gradient(135deg,var(--indigo-700),var(--navy-ink));display:grid;place-items:center;rotate:1.1deg;
  transition:rotate .4s var(--ease),transform .4s var(--ease)}
.hero__media:hover{rotate:0deg;transform:translateY(-4px)}
.media-emblem{width:128px;height:128px;opacity:.9}
.media-cap{position:absolute;bottom:18px;left:0;right:0;text-align:center;color:rgba(247,243,234,.55);font-family:var(--font-body);font-size:.82rem;letter-spacing:.04em}
.hero__chips{display:flex;flex-wrap:wrap;gap:10px;margin-top:var(--sp-6)}

/* ---------- chips ---------- */
.chip{display:inline-flex;align-items:center;gap:8px;padding:9px 16px;border-radius:var(--r-pill);background:var(--surface);
  border:1px solid var(--line-warm);box-shadow:var(--sh-sm);font-family:var(--font-body);font-weight:600;font-size:.85rem;color:var(--navy)}
.chip .d{width:7px;height:7px;border-radius:50%;background:var(--gold)}
.hero__chips .chip{opacity:0;transform:translateY(8px);animation:chipIn .5s var(--ease) forwards}
.hero__chips .chip:nth-child(1){animation-delay:.15s}.hero__chips .chip:nth-child(2){animation-delay:.27s}.hero__chips .chip:nth-child(3){animation-delay:.39s}
@keyframes chipIn{to{opacity:1;transform:none}}
.on-dark .chip{background:rgba(255,255,255,.07);border-color:rgba(255,255,255,.16);color:#fff}

/* ---------- trust strip ---------- */
.trust{border-top:1px solid var(--line);background:var(--cream-100)}
.trust__row{display:flex;flex-wrap:wrap;gap:10px 36px;justify-content:center;padding:20px 0;font-family:var(--font-body);font-weight:600;color:var(--navy);font-size:.98rem}
.trust__row span{display:inline-flex;align-items:center;gap:8px}
.trust .s{color:var(--deep-gold)}

/* ---------- bands ---------- */
.band{background:var(--indigo);color:#fff;position:relative}
.band h2,.band h3{color:#fff}
.band .lead{color:rgba(247,243,234,.86)}
.band--navy{background:var(--navy)}
.band--alt{background:var(--surface-alt)}

/* ---------- grids / cards ---------- */
.grid{display:grid;gap:var(--sp-5)}
.grid--3{grid-template-columns:repeat(3,1fr)}
.grid--2{grid-template-columns:repeat(2,1fr)}
.card{position:relative;background:var(--surface);border:1px solid var(--line-warm);border-radius:var(--r-lg);padding:var(--sp-6);
  box-shadow:var(--sh-sm);transition:transform .35s var(--ease),box-shadow .35s var(--ease),border-color .35s}
.card:hover{transform:translateY(-6px);box-shadow:var(--sh-md);border-color:var(--line-strong)}
.card::after{content:"";position:absolute;left:var(--sp-6);right:var(--sp-6);top:0;height:3px;border-radius:0 0 4px 4px;
  background:linear-gradient(90deg,var(--gold),var(--deep-gold));transform:scaleX(0);transform-origin:left;transition:transform .4s var(--ease)}
.card:hover::after{transform:scaleX(1)}
.card h3{margin-bottom:8px}
.card p{color:var(--ink-700);font-size:1rem}
.card .kn{font-family:var(--font-serif);font-style:italic;font-weight:300;font-size:clamp(2.2rem, 1.4rem + 2vw, 2.8rem);color:var(--indigo);line-height:1;display:block;margin-bottom:8px;letter-spacing:-.01em}
.chip-ic{width:52px;height:52px;border-radius:var(--r-tile);display:grid;place-items:center;background:var(--gold-faint);border:1px solid var(--gold-soft);color:var(--deep-gold);margin-bottom:var(--sp-4)}
.chip-ic svg{width:26px;height:26px}
.band .card{background:rgba(255,255,255,.055);border-color:rgba(255,255,255,.14)}
.band .card h3{color:#fff}.band .card p{color:rgba(247,243,234,.82)}
.band .card .kn{color:var(--gold)}
.band .chip-ic{background:rgba(201,154,60,.16);border-color:rgba(201,154,60,.4);color:var(--gold-bright)}

/* ---------- method steps ---------- */
.steps{display:grid;gap:var(--sp-5)}
.step{display:grid;grid-template-columns:auto 1fr;gap:var(--sp-5);align-items:start;background:rgba(255,255,255,.055);
  border:1px solid rgba(255,255,255,.14);border-radius:var(--r-lg);padding:var(--sp-5) var(--sp-6);transition:transform .35s var(--ease),border-color .35s}
.step:hover{transform:translateY(-4px);border-color:rgba(201,154,60,.5)}
.step__n{width:50px;height:50px;border-radius:var(--r-tile);background:var(--gold);color:var(--navy);font-family:var(--font-body);font-weight:700;font-size:1.3rem;display:grid;place-items:center}
.step h3{color:#fff;margin-bottom:6px}
.step .why{color:var(--gold);font-style:italic;font-family:var(--font-serif);font-size:1rem;margin-top:10px;display:block}
.step p{color:rgba(247,243,234,.85);font-size:1rem}

/* ---------- stats ---------- */
.stats{display:flex;flex-wrap:wrap;gap:var(--sp-8);justify-content:center;text-align:center}
.stat__n{font-family:var(--font-serif);font-style:italic;font-weight:400;font-size:clamp(2.6rem, 1.5rem + 3vw, 3.8rem);color:var(--gold);line-height:1;letter-spacing:-.02em}
.stat__l{color:rgba(247,243,234,.85);font-size:.98rem;margin-top:10px;max-width:18ch;margin-inline:auto}

/* ---------- testimonials / proof ---------- */
.tcard{background:var(--surface);border:1px solid var(--line-warm);border-radius:var(--r-xl);padding:var(--sp-6);box-shadow:var(--sh-md)}
.tcard .stars{color:var(--deep-gold);letter-spacing:2px;font-size:1.05rem}
.tcard blockquote{font-family:var(--font-head);font-weight:400;font-size:1.22rem;color:var(--charcoal);margin:12px 0 18px;line-height:1.5;letter-spacing:-.01em}
.tcard .who{display:flex;align-items:center;gap:12px}
.tcard .av{width:46px;height:46px;border-radius:50%;background:var(--navy);color:var(--gold-bright);display:grid;place-items:center;font-family:var(--font-body);font-weight:600}
.tcard .nm{font-family:var(--font-body);font-weight:600;color:var(--navy);font-size:1rem}
.tcard .mt{color:var(--ink-500);font-size:.9rem}
.ph-note{font-size:.85rem;color:var(--ink-500);font-style:italic;margin-top:14px}
.proof{max-width:760px;margin-inline:auto;text-align:center}
.proof .card{text-align:left}

/* ---------- founder ---------- */
.founder{display:grid;grid-template-columns:.85fr 1.15fr;gap:var(--sp-8);align-items:center}
.founder__photo{position:relative;border-radius:var(--r-xl);box-shadow:var(--sh-lg);aspect-ratio:4/5;
  background:linear-gradient(135deg,var(--indigo-700),var(--navy-ink));display:grid;place-items:center;rotate:-1.4deg;transition:rotate .4s var(--ease),transform .4s var(--ease)}
.founder__photo:hover{rotate:0deg;transform:translateY(-4px)}

/* ---------- CTA band ---------- */
.cta{background:var(--navy);color:#fff;text-align:center;border-radius:var(--r-xl);padding:var(--sp-9) var(--sp-7);position:relative;overflow:hidden}
.cta::before{content:"";position:absolute;inset:0;background:radial-gradient(closest-side at 80% 0%,rgba(201,154,60,.16),transparent 70%);pointer-events:none}
.cta h2{color:#fff;margin-bottom:12px;position:relative}
.cta .lead{color:rgba(247,243,234,.9);margin:0 auto 24px;position:relative}
.cta .btn{position:relative}
.cta .eyebrow{color:var(--gold)}

/* ---------- FAQ ---------- */
.faq{max-width:820px;margin-inline:auto}
.faq details{background:var(--surface);border:1px solid var(--line-warm);border-radius:var(--r-md);padding:20px 24px;margin-bottom:12px;transition:border-color .25s,box-shadow .25s}
.faq details[open]{border-color:var(--line-strong);box-shadow:var(--sh-sm)}
.faq summary{font-family:var(--font-head);font-weight:600;color:var(--navy);cursor:pointer;list-style:none;display:flex;justify-content:space-between;gap:16px;align-items:center;font-size:1.1rem;letter-spacing:-.015em}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";flex:none;width:30px;height:30px;border:1px solid var(--line-strong);border-radius:50%;display:grid;place-items:center;color:var(--deep-gold);font-size:1.25rem;line-height:1;transition:transform .3s var(--ease),background .2s}
.faq details[open] summary::after{transform:rotate(45deg);background:var(--gold-soft)}
.faq details p{margin-top:14px;color:var(--ink-700);font-size:1rem}

/* ---------- forms ---------- */
.form{display:grid;gap:16px;max-width:560px}
.field{display:flex;flex-direction:column;gap:6px}
.field label{font-family:var(--font-body);font-weight:600;color:var(--navy);font-size:.95rem}
.field input,.field select,.field textarea{font-family:var(--font-body);font-size:1rem;color:var(--charcoal);background:var(--surface);border:1.5px solid var(--line-strong);border-radius:var(--r-sm);padding:12px 14px;min-height:48px;transition:border-color .2s,box-shadow .2s}
.field textarea{min-height:120px;resize:vertical}
.field input:focus-visible,.field select:focus-visible,.field textarea:focus-visible{border-color:var(--indigo-bright);box-shadow:0 0 0 3px rgba(58,82,160,.18)}
.privacy{font-size:.85rem;color:var(--ink-500)}

/* ---------- booking placeholder ---------- */
.calbox{border:1px solid var(--line-warm);border-radius:var(--r-lg);background:var(--surface);padding:var(--sp-7);text-align:center;color:var(--ink-700);box-shadow:var(--sh-sm)}
.calbox h3{margin-bottom:8px}

/* ---------- divider ---------- */
.div-spark{display:flex;align-items:center;justify-content:center;gap:16px;color:var(--deep-gold);font-size:1.1rem}
.div-spark::before,.div-spark::after{content:"";height:1px;width:80px;background:var(--line-strong)}

/* ---------- footer ---------- */
.footer{background:var(--navy-ink);color:rgba(247,243,234,.78);padding:var(--sp-9) 0 var(--sp-6)}
.footer__grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:var(--sp-7)}
.footer a{color:rgba(247,243,234,.78);transition:color .15s}
.footer a:hover{color:var(--gold);text-decoration:none}
.footer h4{font-family:var(--font-body);color:#fff;font-size:.8rem;text-transform:uppercase;letter-spacing:.12em;margin-bottom:16px}
.footer ul{list-style:none;display:grid;gap:9px}
.footer .brand{color:#fff;margin-bottom:12px}
.footer__legal{border-top:1px solid rgba(255,255,255,.12);margin-top:var(--sp-7);padding-top:var(--sp-5);font-size:.85rem;color:rgba(247,243,234,.55);display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px}
.footer__sig{display:block;text-align:center;color:rgba(247,243,234,.6);font-family:var(--font-serif);font-style:italic;font-size:1rem;margin-top:18px}
.footer__sig .sp{color:var(--gold)}

/* ---------- sticky mobile CTA ---------- */
.mcta{display:none;position:fixed;bottom:0;left:0;right:0;z-index:80;padding:10px 16px calc(10px + env(safe-area-inset-bottom));background:rgba(14,26,58,.96);backdrop-filter:blur(8px);box-shadow:0 -4px 20px rgba(0,0,0,.2)}
.mcta .btn{width:100%;justify-content:center}

/* ---------- reveal ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.in{opacity:1;transform:none}
.d1{transition-delay:.08s}.d2{transition-delay:.16s}.d3{transition-delay:.24s}.d4{transition-delay:.32s}

/* ---------- utilities ---------- */
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:var(--sp-8);align-items:start}
.skip:focus{left:16px!important;top:12px;z-index:100;background:var(--navy);color:#fff;padding:10px 16px;border-radius:8px}

/* ---------- responsive ---------- */
@media(max-width:1100px){
  .wrap{width:min(1100px,100% - 40px)}
  .grid--3{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:880px){
  .hero__grid,.founder,.split{grid-template-columns:1fr;gap:var(--sp-6)}
  .founder__photo{position:static!important;rotate:0deg;aspect-ratio:4/3;max-width:480px;margin-inline:auto;width:100%}
  .hero__media{order:-1;aspect-ratio:16/9;rotate:0deg;max-width:520px;margin-inline:auto;width:100%}
  .grid--3,.grid--2,.footer__grid{grid-template-columns:1fr}
  .split{gap:var(--sp-6)}
  .status{display:none}
  .nav__links{position:absolute;top:74px;left:0;right:0;background:var(--cream);flex-direction:column;align-items:flex-start;gap:0;padding:8px 6%;border-bottom:1px solid var(--line);box-shadow:var(--sh-md);display:none;opacity:0;transform:translateY(-6px);transition:opacity .25s var(--ease),transform .25s var(--ease)}
  .nav__links.open{display:flex;opacity:1;transform:none}
  .nav__links li{width:100%}
  .nav__links li a:not(.btn){display:block;padding:14px 0;width:100%}
  .nav__links li a:not(.btn)::after{display:none}
  .nav__links .btn{margin:10px 0 14px}
  .nav__toggle{display:block}
  .mcta{display:block}
  body.nav-open{overflow:hidden}
  body{padding-bottom:calc(92px + env(safe-area-inset-bottom))}
}
@media(max-width:430px){
  .hero h1{font-size:clamp(2rem,9vw,2.7rem)}
  .hero__cta{flex-direction:column;align-items:stretch}
  .hero__cta .btn{width:100%}
  .card{padding:var(--sp-5)}
  .marquee-item{font-size:.85rem}
}
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none}
  .marquee-track{animation:none}
  .hero__chips .chip{opacity:1;transform:none;animation:none}
  .card:hover,.btn--primary:hover,.step:hover{transform:none}
  .hero__media:hover,.founder__photo:hover{rotate:initial;transform:none}
  .brand:hover .brand__mark{transform:none}
  .btn--primary:hover::before{transform:translateX(-120%)}
}
