/* ======================================================================
   MLAY T14 — Prototype v2 (Aura + Awwwards patterns)
   ====================================================================== */

:root{
  --navy-900:#0E1B4D; --navy-800:#152255; --navy-700:#1B2C6E; --navy-500:#2C4194;
  --sapphire-500:#4770DB; --sapphire-300:#7FA0F0; --sapphire-100:#C9D5F4;
  --frost-200:#B8C5E8; --cream-100:#F4EDE3; --cream-50:#FAF6F0; --cream-30:#FBF8F3;
  --blush-300:#E8B4B8; --gold-500:#C9A87C; --gold-300:#E0C9A1;
  --charcoal-900:#1A1F2E; --stone-500:#6B7280; --stone-200:#E5E7EB; --white:#FFFFFF;

  --font-display:'Fraunces','Cormorant Garamond',Georgia,serif;
  --font-body:'Inter',-apple-system,system-ui,sans-serif;
  --font-mono:'JetBrains Mono',ui-monospace,monospace;

  --fs-hero:clamp(2.6rem,8vw,7rem);
  --fs-h1:clamp(2rem,5vw,4.4rem);
  --fs-h2:clamp(1.7rem,3.5vw,2.85rem);
  --fs-h3:clamp(1.2rem,2vw,1.55rem);
  --fs-stat:clamp(3.5rem,9vw,7.5rem);
  --fs-body:clamp(.95rem,1.05vw,1.05rem);
  --fs-body-lg:clamp(1.05rem,1.25vw,1.18rem);
  --fs-caption:.78rem;

  --pad-section:clamp(5rem,10vw,9rem);
  --pad-page:clamp(1.25rem,4vw,2.5rem);
  --max-w:1320px;

  --ease-out:cubic-bezier(0.16,1,0.3,1);
  --ease-in-out:cubic-bezier(0.4,0,0.2,1);
}

/* ── Reset ───────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%;text-size-adjust:100%}
html.lenis,html.lenis body{height:auto}
.lenis.lenis-smooth{scroll-behavior:auto !important}
.lenis.lenis-smooth [data-lenis-prevent]{overscroll-behavior:contain}
.lenis.lenis-stopped{overflow:clip}
body{
  font-family:var(--font-body);font-size:var(--fs-body);font-weight:400;
  color:var(--charcoal-900);background:var(--cream-100);
  line-height:1.55;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  overflow-x:hidden;cursor:auto;
}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:0;background:none;color:inherit}
::selection{background:var(--sapphire-500);color:var(--white)}

.wrap{max-width:var(--max-w);margin:0 auto;padding:0 var(--pad-page)}
.eyebrow{display:inline-block;font-family:var(--font-body);font-size:var(--fs-caption);font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--stone-500)}
.serif{font-family:var(--font-display);font-weight:300;letter-spacing:-.02em;line-height:1.05}
.italic{font-family:var(--font-display);font-style:italic;font-weight:300}

/* ── Buttons ─────────────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5em;padding:1em 1.8em;font-size:.92rem;font-weight:500;letter-spacing:.04em;border-radius:999px;transition:background .35s var(--ease-in-out), color .35s, border-color .35s;white-space:nowrap;}
.btn-primary{background:var(--navy-900);color:var(--cream-100)}
.btn-primary:hover{background:var(--sapphire-500)}
.btn-ghost{background:transparent;color:var(--navy-900);border:1px solid currentColor}
.btn-ghost:hover{background:var(--navy-900);color:var(--cream-100)}

/* ── Scroll progress bar (top) ───────────────────────────────── */
.progress{position:fixed;top:0;left:0;right:0;height:2px;z-index:60;pointer-events:none;background:transparent}
.progress__fill{height:100%;background:linear-gradient(90deg,var(--sapphire-500) 0%,var(--gold-500) 100%);transform-origin:0 50%;transform:scaleX(0);}

/* ── Sticky Nav ─────────────────────────────────────────────── */
.nav{position:fixed;top:0;left:0;right:0;z-index:50;display:flex;align-items:center;justify-content:space-between;padding:1.1rem var(--pad-page);transition:background .4s var(--ease-in-out), backdrop-filter .4s, padding .3s;color:var(--navy-900)}
.nav.is-scrolled{background:rgba(244,237,227,.85);-webkit-backdrop-filter:blur(14px) saturate(140%);backdrop-filter:blur(14px) saturate(140%);padding:.7rem var(--pad-page)}
/* When the menu is open, strip any property that would make .nav a containing
   block for its position:fixed descendants (backdrop-filter, filter, transform,
   perspective, will-change, contain) — otherwise .nav__links gets clipped to
   the nav's ~120px box instead of the viewport. Padding reset prevents the
   burger-X from jumping when toggled while scrolled. */
.nav.is-open{
  background:transparent;
  -webkit-backdrop-filter:none;
  backdrop-filter:none;
  padding:1.1rem var(--pad-page);
}
[data-theme="dark"] .nav.is-open{background:transparent}
.nav__brand{font-family:var(--font-display);font-weight:400;font-size:1.4rem;letter-spacing:-.01em;color:inherit}
.nav__brand small{font-family:var(--font-body);font-size:.62rem;letter-spacing:.18em;color:var(--gold-500);display:block;margin-top:-.18rem;text-transform:uppercase}
.nav__links{display:none;gap:2.2rem;font-size:.86rem}
.nav__links a{position:relative;padding:.3rem 0}
.nav__links a::after{content:"";position:absolute;left:0;right:100%;bottom:0;height:1px;background:currentColor;transition:right .35s var(--ease-out)}
.nav__links a:hover::after{right:0}
.nav__cta{font-size:.82rem;padding:.7em 1.3em;background:var(--navy-900);color:var(--cream-100)}
.nav__cta:hover{background:var(--sapphire-500)}
@media(min-width:840px){.nav__links{display:flex}}

/* ── Cursor halo (desktop hover) — no blend mode (perf) ────── */
.cursor{position:fixed;top:0;left:0;width:34px;height:34px;border-radius:50%;border:1px solid var(--sapphire-500);pointer-events:none;z-index:70;transform:translate3d(-100px,-100px,0);transition:width .25s var(--ease-out), height .25s, background .25s, opacity .3s;opacity:0}
.cursor.is-on{opacity:.7}
.cursor.is-hover{width:54px;height:54px;background:rgba(71,112,219,.2);border-color:var(--sapphire-300)}
@media(hover:none),(pointer:coarse){.cursor{display:none}}

/* ── 1. HERO (split layout, Stitch-aligned) ─────────────────── */
.hero{position:relative;min-height:100svh;color:var(--charcoal-900);overflow:hidden;padding:9rem 0 4rem;background:linear-gradient(180deg,var(--cream-100) 0%,var(--cream-50) 55%,var(--frost-200) 100%);display:flex;align-items:center}
.hero__inner{display:grid;grid-template-columns:1fr;gap:3rem;align-items:center;width:100%;position:relative;z-index:3}
@media(min-width:920px){.hero__inner{grid-template-columns:1.05fr 1fr;gap:4rem}}

.hero__media{position:relative;aspect-ratio:1;display:flex;align-items:center;justify-content:center;order:-1}
@media(min-width:920px){.hero__media{order:0}}
.hero__media img{position:relative;z-index:3;max-width:78%;max-height:78%;width:auto;height:auto;object-fit:contain;filter:drop-shadow(0 30px 40px rgba(14,27,77,.35))}
.hero__platform{position:absolute;left:50%;bottom:14%;transform:translateX(-50%);width:72%;aspect-ratio:1;background:radial-gradient(ellipse 60% 50% at 50% 50%,rgba(127,160,240,.55) 0%,rgba(127,160,240,0) 70%);z-index:1;pointer-events:none}
.hero__platform::after{content:"";position:absolute;left:50%;top:62%;transform:translateX(-50%);width:60%;aspect-ratio:3/1;background:radial-gradient(ellipse 50% 50% at 50% 50%,var(--sapphire-300) 0%,rgba(127,160,240,.25) 50%,transparent 70%);opacity:.6}
.hero__sparkle{position:absolute;width:14px;height:14px;z-index:2;pointer-events:none;opacity:.7;animation:twinkle 4s ease-in-out infinite}
.hero__sparkle::before,.hero__sparkle::after{content:"";position:absolute;background:var(--sapphire-500);left:50%;top:50%;border-radius:1px}
.hero__sparkle::before{width:100%;height:1px;transform:translate(-50%,-50%)}
.hero__sparkle::after{width:1px;height:100%;transform:translate(-50%,-50%)}
.hero__sparkle:nth-of-type(1){top:18%;left:14%}
.hero__sparkle:nth-of-type(2){top:32%;right:12%;width:10px;height:10px;animation-delay:.8s}
.hero__sparkle:nth-of-type(3){top:62%;left:8%;width:8px;height:8px;animation-delay:1.6s}
.hero__sparkle:nth-of-type(4){top:78%;right:18%;width:12px;height:12px;animation-delay:2.4s}
.hero__sparkle:nth-of-type(5){top:48%;left:82%;width:7px;height:7px;animation-delay:3.2s;opacity:.5}
@keyframes twinkle{0%,100%{opacity:.25;transform:scale(.6)}50%{opacity:.85;transform:scale(1)}}

/* ambient orbs (Aura pattern) — radial gradient is GPU-cheap, no blur filter */
.orb{position:absolute;border-radius:50%;pointer-events:none;z-index:1;transform:translateZ(0)}
.orb--sapphire{top:-15%;right:-10%;width:55vw;aspect-ratio:1;background:radial-gradient(circle,rgba(127,160,240,.55) 0%,rgba(127,160,240,0) 60%)}
.orb--gold{bottom:-20%;left:-15%;width:50vw;aspect-ratio:1;background:radial-gradient(circle,rgba(201,168,124,.32) 0%,rgba(201,168,124,0) 65%)}
.orb--frost{top:30%;left:40%;width:35vw;aspect-ratio:1;background:radial-gradient(circle,rgba(184,197,232,.28) 0%,rgba(184,197,232,0) 70%)}

/* noise grain — static, no blend mode */
.grain{position:absolute;inset:0;z-index:2;pointer-events:none;opacity:.04;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/></filter><rect width='100%' height='100%' filter='url(%23n)' opacity='.7'/></svg>")}

.hero__content{position:relative;z-index:3;width:100%}
.hero__eyebrow{color:var(--gold-500);margin-bottom:1.4rem;display:inline-block}
.hero h1{font-family:var(--font-display);font-weight:300;font-size:var(--fs-hero);line-height:1.04;letter-spacing:-.025em;max-width:14ch;margin-bottom:1.5rem;color:var(--navy-900)}

.split-line{display:block;overflow:hidden;padding-bottom:.04em}
.split-line>span{display:block;transition:opacity 1.1s var(--ease-out), transform 1.1s var(--ease-out)}
.js [data-text-reveal] .split-line>span{opacity:0;transform:translateY(105%)}
.hero.is-revealed [data-text-reveal] .split-line>span{opacity:1;transform:translateY(0)}
.hero.is-revealed [data-text-reveal] .split-line:nth-child(1)>span{transition-delay:.25s}
.hero.is-revealed [data-text-reveal] .split-line:nth-child(2)>span{transition-delay:.4s}
.hero.is-revealed [data-text-reveal] .split-line:nth-child(3)>span{transition-delay:.55s}

.hero__sub{max-width:38ch;font-size:var(--fs-body-lg);line-height:1.55;color:var(--stone-500);margin-bottom:2.4rem}
.hero__cta{display:flex;flex-wrap:wrap;gap:.9rem}
.hero__cta .btn-primary{background:var(--navy-900);color:var(--cream-100)}
.hero__cta .btn-primary:hover{background:var(--sapphire-500);color:var(--cream-100)}
.hero__cta .btn-ghost{color:var(--navy-900);border-color:var(--navy-900)}
.hero__cta .btn-ghost:hover{background:var(--navy-900);color:var(--cream-100)}

.hero__scroll{position:absolute;left:50%;bottom:1.6rem;transform:translateX(-50%);z-index:4;font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;color:var(--stone-500);display:flex;flex-direction:column;align-items:center;gap:.6rem}
.hero__scroll::after{content:"";width:1px;height:36px;background:linear-gradient(180deg,var(--stone-500),transparent);animation:scroll-pulse 2.4s var(--ease-in-out) infinite}
@keyframes scroll-pulse{0%,100%{transform:scaleY(.4);opacity:.4}50%{transform:scaleY(1);opacity:1}}

/* ── 2. TRUST MARQUEE ────────────────────────────────────────── */
.trust{background:var(--navy-900);color:var(--cream-100);padding:1.6rem 0;overflow:hidden;border-top:1px solid rgba(244,237,227,.08);border-bottom:1px solid rgba(244,237,227,.08)}
.trust__track{display:flex;gap:3rem;animation:marquee 22s linear infinite;width:max-content;font-family:var(--font-display);font-weight:400;font-size:1.1rem;will-change:transform}
.trust:hover .trust__track{animation-play-state:paused}
.trust__track span{display:inline-flex;align-items:center;gap:3rem;white-space:nowrap}
.trust__dot{width:5px;height:5px;border-radius:50%;background:var(--gold-500)}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ── 3. STATS ────────────────────────────────────────────────── */
.stats{padding:var(--pad-section) 0;background:var(--cream-50)}
.stats__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:2.5rem 1.5rem}
.stat{text-align:center;border-top:1px solid var(--stone-200);padding-top:1.5rem}
.stat__num{display:block;font-family:var(--font-mono);font-weight:200;font-size:var(--fs-stat);line-height:.95;letter-spacing:-.04em;color:var(--navy-900)}
.stat__num .unit{font-size:.42em;font-weight:400;color:var(--stone-500);margin-left:.18em;letter-spacing:0}
.stat__label{display:block;margin-top:.7rem;font-size:.85rem;color:var(--stone-500);letter-spacing:.04em}

/* ── 4. SCROLL VIDEO (Apple-style scrub) ─────────────────────── */
.scrubvideo{position:relative;height:350vh;background:var(--navy-900)}
.scrubvideo__sticky{position:sticky;top:0;height:100vh;display:flex;align-items:center;justify-content:center;overflow:hidden}
.scrubvideo__video{width:100%;height:100%;object-fit:cover;object-position:center}
.scrubvideo__overlay{position:absolute;inset:0;background:radial-gradient(ellipse at center,transparent 30%,rgba(14,27,77,.7) 100%);pointer-events:none}
.scrubvideo__caption{position:absolute;left:0;right:0;bottom:14vh;text-align:center;color:var(--cream-100);z-index:2;padding:0 var(--pad-page);pointer-events:none}
.scrubvideo__caption .eyebrow{color:var(--sapphire-300)}
.scrubvideo__caption h2{font-family:var(--font-display);font-weight:300;font-size:var(--fs-h1);line-height:1.05;letter-spacing:-.02em;margin-top:1rem;max-width:18ch;margin-inline:auto}

/* ── 5. PRODUCT SHOWCASE (sticky + bg-removed device) ───────── */
.product{padding:var(--pad-section) 0;background:linear-gradient(180deg,var(--cream-100) 0%,var(--cream-50) 100%);position:relative;overflow:hidden}
.product__inner{display:grid;grid-template-columns:1fr;gap:3rem;align-items:start;position:relative}
@media(min-width:920px){.product__inner{grid-template-columns:1.05fr 1fr;gap:5rem}}
.product__media{position:relative;aspect-ratio:4/5;background:radial-gradient(circle at 50% 40%,var(--frost-200) 0%,var(--cream-50) 60%);border-radius:24px;overflow:hidden;display:flex;align-items:center;justify-content:center}
@media(min-width:920px){.product__media{position:sticky;top:5rem}}
.product__device-wrap{position:absolute;inset:0;display:flex;align-items:center;justify-content:center}
.product__device{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;padding:8% 10%;opacity:0;transition:opacity .7s var(--ease-out), transform .7s var(--ease-out), filter .7s var(--ease-out);transform:scale(.94) translateY(20px);filter:blur(3px);will-change:opacity,transform,filter}
.product__device.is-active{opacity:1;transform:scale(1) translateY(0);filter:blur(0)}
.product__halo{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:90%;aspect-ratio:1;background:radial-gradient(circle,rgba(71,112,219,.22) 0%,rgba(71,112,219,0) 60%);z-index:0;pointer-events:none;transition:transform .6s var(--ease-out)}
.product__media.is-swapping .product__halo{animation:productHaloPulse .6s ease-out}
@keyframes productHaloPulse{0%{transform:translate(-50%,-50%) scale(1);background:radial-gradient(circle,rgba(71,112,219,.22) 0%,rgba(71,112,219,0) 60%)}50%{transform:translate(-50%,-50%) scale(1.18);background:radial-gradient(circle,rgba(71,112,219,.42) 0%,rgba(71,112,219,0) 65%)}100%{transform:translate(-50%,-50%) scale(1);background:radial-gradient(circle,rgba(71,112,219,.22) 0%,rgba(71,112,219,0) 60%)}}
.product__swatches{position:absolute;left:50%;bottom:1.4rem;transform:translateX(-50%);display:flex;gap:.6rem;z-index:3;background:rgba(255,255,255,.6);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:.55rem .8rem;border-radius:999px}
.swatch{width:24px;height:24px;border-radius:50%;background:var(--c);border:1px solid rgba(0,0,0,.08);cursor:pointer;transition:transform .25s;position:relative}
.swatch::after{content:"";position:absolute;inset:-4px;border:1px solid var(--navy-900);border-radius:50%;opacity:0;transition:opacity .25s}
.swatch.is-active::after{opacity:1}
.swatch:hover{transform:scale(1.12)}
.product__heading h2{font-family:var(--font-display);font-weight:300;font-size:var(--fs-h1);line-height:1.05;letter-spacing:-.02em;color:var(--navy-900);margin:1rem 0 1.5rem;max-width:14ch}
.product__heading p{font-size:var(--fs-body-lg);color:var(--charcoal-900);max-width:48ch;margin-bottom:2rem}
.product__features{list-style:none;display:grid;gap:1rem;border-top:1px solid var(--stone-200);padding-top:2rem}
.product__features li{display:grid;grid-template-columns:auto 1fr;gap:1rem;align-items:start;font-size:1rem}
.product__features li::before{content:"";width:18px;height:1px;background:var(--gold-500);margin-top:.78em}

/* ── 6. ICE (sapphire glow + bg-removed lamp) ──────────────── */
.ice{background:linear-gradient(180deg,var(--navy-900) 0%,var(--navy-700) 100%);color:var(--cream-100);padding:var(--pad-section) 0;position:relative;overflow:hidden}
.ice .orb--sapphire{top:-25%;right:-15%;width:70vw;background:radial-gradient(circle,rgba(127,160,240,.45) 0%,rgba(127,160,240,0) 60%)}
.ice__inner{display:grid;grid-template-columns:1fr;gap:3rem;align-items:center;position:relative;z-index:2}
@media(min-width:920px){.ice__inner{grid-template-columns:1fr 1fr;gap:5rem}}
.ice__media{aspect-ratio:1;display:flex;align-items:center;justify-content:center;position:relative}
.ice__media img{width:100%;height:100%;object-fit:contain;filter:drop-shadow(0 30px 60px rgba(127,160,240,.35));}
.ice__heading .eyebrow{color:var(--sapphire-300)}
.ice__heading h2{font-family:var(--font-display);font-weight:300;font-size:var(--fs-h1);line-height:1.05;letter-spacing:-.02em;margin:1rem 0 1.5rem;max-width:14ch}
.ice__heading p{font-size:var(--fs-body-lg);color:rgba(244,237,227,.78);margin-bottom:2.5rem;max-width:46ch}
.ice__numlist{list-style:none;display:grid;gap:1.5rem}
.ice__numlist li{display:grid;grid-template-columns:auto 1fr;gap:1.5rem;align-items:baseline;border-top:1px solid rgba(244,237,227,.15);padding-top:1.2rem}
.ice__numlist .num{font-family:var(--font-mono);font-weight:200;font-size:2.6rem;color:var(--sapphire-300);line-height:1;letter-spacing:-.03em;min-width:3.5ch}
.ice__numlist span:last-child{color:rgba(244,237,227,.82);font-size:.95rem;line-height:1.5}

/* ── 7. SCIENCE TIMELINE (native scroll-snap, no JS pin) ───── */
.science{background:var(--cream-100);position:relative;padding:var(--pad-section) 0;overflow:hidden}
.science__head{padding:0 var(--pad-page);max-width:var(--max-w);margin:0 auto 3rem;width:100%;display:flex;align-items:flex-end;justify-content:space-between;gap:2rem}
.science__head h2{font-family:var(--font-display);font-weight:300;font-size:var(--fs-h1);line-height:1.05;letter-spacing:-.02em;color:var(--navy-900);max-width:14ch;margin-top:.8rem}
.science__progress{font-family:var(--font-mono);font-size:.9rem;color:var(--stone-500);letter-spacing:.04em;white-space:nowrap}
.science__track{display:flex;gap:2rem;padding:0 var(--pad-page) 1rem;overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;scrollbar-width:none;-ms-overflow-style:none}
.science__track::-webkit-scrollbar{display:none}
.science__card{flex:0 0 min(560px,calc(100vw - 3rem));scroll-snap-align:start;background:var(--white);border-radius:24px;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 30px 60px -30px rgba(14,27,77,.18);transform:translateZ(0)}
.science__card .media{aspect-ratio:4/3;overflow:hidden;background:var(--cream-100);position:relative}
.science__card .media img,.science__card .media svg{width:100%;height:100%;object-fit:cover;display:block;transition:transform 1.4s var(--ease-out)}
.science__card:hover .media img,.science__card:hover .media svg{transform:scale(1.04)}
.science__card .body{padding:2rem 2.2rem 2.4rem;display:flex;flex-direction:column;gap:1rem}
.science__card .week{font-family:var(--font-mono);font-size:.78rem;color:var(--gold-500);letter-spacing:.18em;text-transform:uppercase}
.science__card h3{font-family:var(--font-display);font-weight:400;font-size:var(--fs-h3);color:var(--navy-900)}
.science__card p{color:var(--stone-500);font-size:.95rem}
@media(max-width:768px){.science__head{flex-direction:column;align-items:flex-start;margin-bottom:2.5rem}}

/* ── 8. HOW TO ───────────────────────────────────────────────── */
.how{padding:var(--pad-section) 0;background:var(--navy-900);color:var(--cream-100);position:relative;overflow:hidden}
.how__heading{text-align:center;margin-bottom:4rem;position:relative;z-index:1}
.how__heading h2{font-family:var(--font-display);font-weight:300;font-size:var(--fs-h1);line-height:1.05;letter-spacing:-.02em;margin-top:.8rem}
.how__steps{display:grid;grid-template-columns:1fr;gap:2rem;counter-reset:step;position:relative;z-index:1}
@media(min-width:768px){.how__steps{grid-template-columns:repeat(4,1fr)}}
.how__step{counter-increment:step;border-top:1px solid rgba(244,237,227,.15);padding-top:1.4rem;position:relative}
.how__step::before{content:"0" counter(step);position:absolute;top:-.8rem;left:0;background:var(--cream-100);color:var(--navy-900);padding:.15rem .55rem;font-family:var(--font-mono);font-size:.7rem;border-radius:999px}
.how__step h3{font-family:var(--font-display);font-weight:400;font-size:1.4rem;margin:.7rem 0 .8rem}
.how__step p{color:rgba(244,237,227,.7);font-size:.95rem}

/* ── 9. SUITABLE FOR ─────────────────────────────────────────── */
.fit{padding:var(--pad-section) 0;background:var(--cream-100)}
.fit__inner{display:grid;grid-template-columns:1fr;gap:3rem;align-items:start}
@media(min-width:920px){.fit__inner{grid-template-columns:1fr 1.2fr;gap:5rem}}
.fit h2{font-family:var(--font-display);font-weight:300;font-size:var(--fs-h1);line-height:1.05;letter-spacing:-.02em;color:var(--navy-900);margin:1rem 0 1.5rem;max-width:12ch}
.fit p.lead{color:var(--stone-500);font-size:var(--fs-body-lg);max-width:42ch}
.fit__table{width:100%;border-collapse:collapse;background:var(--white);border-radius:14px;overflow:hidden;font-size:.95rem}
.fit__table th,.fit__table td{padding:1rem 1.2rem;text-align:left;border-bottom:1px solid var(--stone-200)}
.fit__table th{background:var(--navy-900);color:var(--cream-100);font-weight:500;letter-spacing:.04em;font-size:.78rem;text-transform:uppercase}
.fit__table tr:last-child td{border-bottom:0}
.fit__yes{color:#3F7D5C;font-weight:500}
.fit__no{color:#9A4242;font-weight:500}

/* ── 10. IN THE BOX ──────────────────────────────────────────── */
.box{padding:var(--pad-section) 0;background:var(--cream-50)}
.box__inner{display:flex;flex-direction:column;gap:4rem}
.box__head{text-align:center;max-width:50rem;margin:0 auto}
.box__head h2{font-family:var(--font-display);font-weight:300;font-size:var(--fs-h1);line-height:1.05;letter-spacing:-.02em;color:var(--navy-900);margin:1rem 0 0;max-width:22ch;margin-inline:auto}

.box__stage{position:relative;display:flex;flex-direction:column;align-items:center;padding:2rem 0 1rem;min-height:420px}
.box__podium{position:absolute;left:50%;top:42%;width:520px;height:520px;max-width:88vw;max-height:88vw;border-radius:50%;background:radial-gradient(circle,rgba(71,112,219,.1) 0%,rgba(71,112,219,.04) 38%,transparent 68%);transform:translate(-50%,-50%);pointer-events:none;z-index:1}
.box__shadow{position:absolute;left:50%;top:62%;width:280px;height:34px;max-width:70vw;border-radius:50%;background:radial-gradient(ellipse,rgba(14,27,77,.18) 0%,rgba(14,27,77,0) 70%);transform:translate(-50%,0);filter:blur(10px);pointer-events:none;z-index:1}
.box__device{position:relative;z-index:2;max-width:320px;width:60vw;height:auto;filter:drop-shadow(0 24px 50px rgba(14,27,77,.16))}

.box__pack{max-width:1080px;margin:0 auto;width:100%}
.box-pack__head{display:flex;justify-content:space-between;align-items:baseline;gap:1rem;margin-bottom:2rem;border-bottom:1px solid var(--stone-200);padding-bottom:1.2rem;flex-wrap:wrap}
.box-pack__eyebrow{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--navy-900);font-weight:400}
.box-pack__count{font-family:var(--font-display);font-style:italic;font-weight:300;font-size:1rem;color:var(--stone-500);letter-spacing:-.01em}

.box-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--stone-200)}
@media(min-width:720px){.box-grid{grid-template-columns:repeat(4,1fr)}}
.box-tile{position:relative;background:var(--cream-50);padding:1.8rem 1.4rem 1.4rem;display:flex;flex-direction:column;gap:.7rem;color:var(--stone-500);transition:background .35s,color .35s;min-height:170px}
.box-tile:hover{background:var(--cream-100);color:var(--navy-900)}
.box-tile:hover .box-tile__icon{color:var(--navy-900);transform:translateY(-2px)}
.box-tile__num{font-family:var(--font-mono);font-size:.62rem;letter-spacing:.18em;color:var(--gold-500);font-weight:400}
.box-tile__icon{width:36px;height:36px;color:var(--stone-500);transition:color .35s,transform .5s var(--ease-out);margin-top:.4rem}
.box-tile__name{font-family:var(--font-display);font-weight:400;font-style:italic;font-size:1.1rem;letter-spacing:-.01em;color:var(--navy-900);line-height:1.15;margin-top:.6rem}
.box-tile__qty{font-family:var(--font-mono);font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;color:var(--stone-500);opacity:.8;margin-top:auto;padding-top:.4rem}
.box-pack__head--mt{margin-top:4rem}
.box-grid--photo{grid-template-columns:repeat(2,1fr)}
@media(min-width:720px){.box-grid--photo{grid-template-columns:repeat(3,1fr)}}
.box-grid--photo .box-tile{padding:1.4rem 1.4rem 1.4rem;min-height:230px}
.box-tile--photo .box-tile__photo{aspect-ratio:5/4;background:#E8E5E0;border-radius:4px;overflow:hidden;margin-top:.5rem;display:flex;align-items:center;justify-content:center;transition:background .35s}
.box-tile--photo:hover .box-tile__photo{background:#F2EEE7}
.box-tile--photo .box-tile__photo img{width:100%;height:100%;object-fit:contain;display:block;transition:transform .8s var(--ease-out)}
.box-tile--photo:hover .box-tile__photo img{transform:scale(1.06)}

/* ── 11. FAQ ─────────────────────────────────────────────────── */
.faq{padding:var(--pad-section) 0;background:var(--cream-100)}
.faq__heading{text-align:center;margin-bottom:3.5rem}
.faq__heading h2{font-family:var(--font-display);font-weight:300;font-size:var(--fs-h1);line-height:1.05;letter-spacing:-.02em;color:var(--navy-900);margin-top:.8rem}
.faq__list{max-width:780px;margin:0 auto;display:grid;gap:1px;background:var(--stone-200);border-top:1px solid var(--stone-200);border-bottom:1px solid var(--stone-200)}
.faq__item{background:var(--cream-100)}
.faq__item summary{padding:1.65rem 0;font-family:var(--font-display);font-weight:400;font-size:1.25rem;color:var(--navy-900);list-style:none;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:1.5rem;transition:color .3s}
.faq__item summary::-webkit-details-marker{display:none}
.faq__item summary::after{content:"+";font-family:var(--font-body);font-weight:300;font-size:1.6rem;color:var(--gold-500);transition:transform .35s var(--ease-out)}
.faq__item[open] summary::after{transform:rotate(45deg)}
.faq__item summary:hover{color:var(--sapphire-500)}
.faq__item p{padding:0 0 1.6rem;color:var(--stone-500);font-size:1rem;line-height:1.6;max-width:62ch}

/* ── 12. CTA ─────────────────────────────────────────────────── */
.cta{padding:var(--pad-section) 0;background:var(--navy-900);color:var(--cream-100);text-align:center;position:relative;overflow:hidden}
.cta__inner{position:relative;z-index:2;max-width:680px;margin:0 auto}
.cta h2{font-family:var(--font-display);font-weight:300;font-size:clamp(2.2rem,5.5vw,4.5rem);line-height:1.05;letter-spacing:-.025em;margin-bottom:1.5rem}
.cta p{color:rgba(244,237,227,.78);font-size:var(--fs-body-lg);margin-bottom:2.5rem;max-width:48ch;margin-inline:auto}
.cta .btn-primary{background:var(--cream-100);color:var(--navy-900);padding:1.15em 2.5em;font-size:1rem;display:inline-block;}
.cta .btn-primary:hover{background:var(--sapphire-500);color:var(--cream-100)}
.cta__sub{margin-top:1.5rem;font-size:.82rem;color:rgba(244,237,227,.55);letter-spacing:.04em}

/* ── Footer ──────────────────────────────────────────────────── */
.foot{background:var(--navy-900);color:rgba(244,237,227,.6);padding:3rem 0 2rem;border-top:1px solid rgba(244,237,227,.08);font-size:.85rem;text-align:center}
.foot__brand{font-family:var(--font-display);color:var(--cream-100);font-size:1.2rem;margin-bottom:.4rem}
.foot__sub{font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-500);margin-bottom:1.4rem}

/* ── Pre-paint hide for reveals (prevents CLS / flash) ─────── */
.js section [data-reveal]:not(.hero *),
.js [data-reveal-stagger] > *,
.js .stat, .js .fit__table, .js .faq__list,
.js .hero [data-reveal]{opacity:0}

/* ── Reduced motion ─────────────────────────────────────────── */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}
  .orb,.grain{display:none}
}

/* ══════════════════════════════════════════════════════════
   ACCESSIBILITY · skip link, focus
══════════════════════════════════════════════════════════ */
.skip-link{position:absolute;top:-100px;left:1rem;padding:.6em 1.1em;background:var(--navy-900);color:var(--cream-100);font-family:var(--font-mono);font-size:.78rem;letter-spacing:.1em;z-index:9999;border-radius:6px;transition:top .2s ease}
.skip-link:focus{top:.75rem}
:focus-visible{outline:2px solid var(--sapphire-500);outline-offset:3px;border-radius:2px}

/* ══════════════════════════════════════════════════════════
   NAV · tools (theme + lang) + mobile burger + drawer
══════════════════════════════════════════════════════════ */
.nav__tools{display:flex;align-items:center;gap:.6rem}
.tool{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;background:transparent;color:inherit;font-family:var(--font-mono);font-size:.7rem;letter-spacing:.06em;font-weight:500;transition:background .25s,color .25s,border-color .25s;border:1px solid currentColor;opacity:.55}
.tool:hover{opacity:1;background:rgba(14,27,77,.08)}
.tool svg{width:16px;height:16px}
#themeToggle .tool__moon{display:none}
[data-theme="dark"] #themeToggle .tool__sun{display:none}
[data-theme="dark"] #themeToggle .tool__moon{display:block}
#langToggle [data-when-lang="ar"]{display:none}
[lang="ar"] #langToggle [data-when-lang="fr"]{display:none}
[lang="ar"] #langToggle [data-when-lang="ar"]{display:inline}

.nav__burger{display:none;width:40px;height:36px;border-radius:6px;background:transparent;border:1px solid currentColor;color:inherit;align-items:center;justify-content:center;flex-direction:column;gap:4px;padding:9px 10px;opacity:.7;transition:opacity .25s}
.nav__burger span{display:block;width:100%;height:1.5px;background:currentColor;transition:transform .35s var(--ease-out),opacity .25s}
.nav__burger:hover{opacity:1}
.nav.is-open .nav__burger span:nth-child(1){transform:translateY(5.5px) rotate(45deg)}
.nav.is-open .nav__burger span:nth-child(2){opacity:0}
.nav.is-open .nav__burger span:nth-child(3){transform:translateY(-5.5px) rotate(-45deg)}
@media(max-width:840px){
  /* Panel is ALWAYS rendered (display:flex) — only its position changes via
     transform. Avoids the display:none → display:flex jump that suppresses
     transitions and was occasionally rendering the panel as a thin strip. */
  .nav__links{
    display:flex;
    flex-direction:column;
    align-items:stretch;
    justify-content:flex-start;
    position:fixed;
    top:64px;right:0;bottom:0;left:0;
    padding:2rem var(--pad-page) 2rem;
    background:rgba(250,246,240,.92);
    -webkit-backdrop-filter:blur(20px);
    backdrop-filter:blur(20px);
    color:var(--navy-900);
    gap:0;
    z-index:48;
    overflow-y:auto;
    -webkit-overflow-scrolling:touch;
    transform:translateX(100%);
    transition:transform .4s var(--ease-out);
    visibility:hidden;
    transition-property:transform,visibility;
    transition-duration:.4s,0s;
    transition-delay:0s,.4s;
  }
  .nav.is-open .nav__links{
    transform:translateX(0);
    visibility:visible;
    transition-delay:0s,0s;
  }
  .nav__links a{
    display:block;
    width:100%;
    color:inherit;
    font-family:var(--font-display);
    font-weight:300;
    font-size:1.8rem;
    letter-spacing:-.02em;
    padding:1.1rem 0;
    border-bottom:1px solid var(--stone-200);
    text-decoration:none;
  }
  .nav__cta{display:none}
  .nav__burger{display:flex}
  [data-theme="dark"] .nav__links{background:rgba(8,15,45,.9);color:#F4EDE3}
  [data-theme="dark"] .nav__links a{border-bottom-color:rgba(244,237,227,.12)}
}
.nav__drawer{position:fixed;inset:0;background:rgba(14,27,77,.4);opacity:0;pointer-events:none;transition:opacity .35s ease;z-index:47}
.nav.is-open ~ .nav__drawer,body.nav-open .nav__drawer{opacity:1;pointer-events:auto}

/* ══════════════════════════════════════════════════════════
   FOOTER (extended 4-col)
══════════════════════════════════════════════════════════ */
.foot{padding:5rem 0 1.5rem}
.foot__inner{display:grid;grid-template-columns:1fr;gap:2.5rem;text-align:left;margin-bottom:3rem}
@media(min-width:720px){.foot__inner{grid-template-columns:1.5fr 1fr 1fr 1fr;gap:3rem}}
.foot__col h4{font-family:var(--font-display);font-weight:400;font-size:1.05rem;color:var(--cream-100);margin-bottom:1rem;letter-spacing:-.01em}
.foot__col ul{list-style:none;display:flex;flex-direction:column;gap:.6rem}
.foot__col a{color:rgba(244,237,227,.65);font-size:.92rem;transition:color .25s}
.foot__col a:hover{color:var(--cream-100)}
.foot__lead{margin-top:1rem;font-size:.9rem;color:rgba(244,237,227,.6);max-width:36ch;line-height:1.55}
.foot__bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;padding-top:1.5rem;border-top:1px solid rgba(244,237,227,.1);font-size:.78rem;color:rgba(244,237,227,.5);letter-spacing:.04em}
.foot__certs{font-family:var(--font-mono);letter-spacing:.18em;color:var(--gold-500)}

/* ══════════════════════════════════════════════════════════
   WhatsApp floating button
══════════════════════════════════════════════════════════ */
.wa-float{position:fixed;bottom:1.4rem;right:1.4rem;z-index:65;display:inline-flex;align-items:center;gap:.7rem;padding:.85rem 1.1rem .85rem .9rem;border-radius:999px;background:#25D366;color:#fff;font-size:.88rem;font-weight:500;letter-spacing:.01em;box-shadow:0 12px 28px -10px rgba(37,211,102,.55),0 6px 12px -4px rgba(0,0,0,.18);transition:transform .3s var(--ease-out),box-shadow .3s,background .3s}
.wa-float:hover{transform:translateY(-2px) scale(1.02);background:#1FBA5A;box-shadow:0 18px 36px -10px rgba(37,211,102,.7)}
.wa-float svg{flex-shrink:0}
.wa-float__label{display:inline}
@media(max-width:520px){
  .wa-float{padding:.85rem;border-radius:50%}
  .wa-float__label{display:none}
}
/* Mobile: shrink + lower the hero scroll-hint so it doesn't overlap the CTAs */
@media(max-width:768px){
  .hero__scroll{bottom:.4rem;font-size:.6rem;letter-spacing:.18em;gap:.35rem}
  .hero__scroll::after{height:18px}
}
@media(max-width:520px){
  .hero__scroll{display:none}
}
[dir="rtl"] .wa-float{right:auto;left:1.4rem}

/* ══════════════════════════════════════════════════════════
   RTL · Arabic typography + mirroring
══════════════════════════════════════════════════════════ */
[lang="ar"]{font-family:'Noto Naskh Arabic','Inter',sans-serif}
[lang="ar"] .serif,[lang="ar"] .italic,
[lang="ar"] h1,[lang="ar"] h2,[lang="ar"] h3,[lang="ar"] h4{font-family:'Noto Naskh Arabic',serif;font-style:normal !important;letter-spacing:0}
[lang="ar"] .eyebrow,[lang="ar"] .stat__num,[lang="ar"] .ice__numlist .num,[lang="ar"] .box-tile__num,[lang="ar"] .box-tile__qty,[lang="ar"] .foot__certs{font-family:'JetBrains Mono',monospace;letter-spacing:.04em}
[dir="rtl"] .nav__brand small{margin-top:0}
[dir="rtl"] .product__features li::before{margin-right:0;margin-left:1rem}
[dir="rtl"] .faq__item summary::after{content:"+"}
[dir="rtl"] .hero__cta a{flex-direction:row-reverse}
[dir="rtl"] .science__card,[dir="rtl"] .science__track{direction:rtl}
[dir="rtl"] .progress__fill{transform-origin:100% 50%;transform:scaleX(0)}
/* Marquee: force LTR layout so both spans stay in the same visual order
   and the seamless loop works in any locale. Text inside still renders
   per locale via unicode-bidi:plaintext. */
.trust__track{direction:ltr}
.trust__track span{unicode-bidi:plaintext}

/* ══════════════════════════════════════════════════════════
   DARK MODE · adapted from 04-avant (ink + abyss + sapphire)
══════════════════════════════════════════════════════════ */
[data-theme="dark"]{
  --navy-900:#080F2D;
  --navy-800:#0F1A38;
  --navy-700:#152558;
  --sapphire-500:#4770DB;
  --sapphire-300:#7FA0F0;
  --sapphire-100:#A8C0F4;
  --frost-200:rgba(127,160,240,.15);
  --cream-100:#F4EDE3;
  --cream-50:#0F1A38;
  --cream-30:#080F2D;
  --gold-500:#C9A87C;
  --gold-300:#E0C9A1;
  --charcoal-900:#F4EDE3;
  --stone-500:rgba(244,237,227,.65);
  --stone-200:rgba(244,237,227,.12);
  --white:#0F1A38;
  --ink:#080F2D;
  --abyss:#020714;
  --paper:#F4EDE3;
  --paper-dim:rgba(244,237,227,.7);
}
[data-theme="dark"] body{background:var(--ink);color:var(--paper)}
[data-theme="dark"] ::selection{background:var(--sapphire-500);color:var(--paper)}

/* nav (dark) — keep glass blur but on ink */
[data-theme="dark"] .nav{color:var(--paper)}
[data-theme="dark"] .nav.is-scrolled{background:rgba(8,15,45,.78);-webkit-backdrop-filter:blur(14px) saturate(140%);backdrop-filter:blur(14px) saturate(140%)}
[data-theme="dark"] .nav__brand small{color:var(--sapphire-300)}
[data-theme="dark"] .nav__cta{background:var(--paper);color:var(--ink)}
[data-theme="dark"] .nav__cta:hover{background:var(--sapphire-300);color:var(--ink)}
[data-theme="dark"] .tool:hover{background:rgba(244,237,227,.08)}

/* hero (dark) — ink → abyss gradient (04-avant signature) */
[data-theme="dark"] .hero{background:linear-gradient(180deg,var(--ink) 0%,var(--abyss) 100%);color:var(--paper)}
[data-theme="dark"] .hero h1{color:var(--paper)}
[data-theme="dark"] .hero h1 .italic,[data-theme="dark"] .hero h1 em{color:var(--sapphire-300)}
[data-theme="dark"] .hero__sub{color:var(--paper-dim)}
[data-theme="dark"] .hero__eyebrow{color:var(--sapphire-300)}
[data-theme="dark"] .hero__cta .btn-primary{background:var(--paper);color:var(--ink)}
[data-theme="dark"] .hero__cta .btn-primary:hover{background:var(--sapphire-300)}
[data-theme="dark"] .hero__cta .btn-ghost{color:var(--paper);border-color:var(--paper)}
[data-theme="dark"] .hero__cta .btn-ghost:hover{background:var(--paper);color:var(--ink)}
[data-theme="dark"] .hero__platform{background:radial-gradient(ellipse 60% 50% at 50% 50%,rgba(127,160,240,.45) 0%,rgba(127,160,240,0) 70%)}
[data-theme="dark"] .hero__media img{filter:drop-shadow(0 30px 50px rgba(8,15,45,.65)) drop-shadow(0 0 80px rgba(127,160,240,.35))}
[data-theme="dark"] .hero__scroll{color:var(--paper-dim)}

/* trust strip (dark) */
[data-theme="dark"] .trust{background:var(--abyss);color:var(--paper);border-color:rgba(244,237,227,.08)}

/* stats (dark) — abyss → ink with thin sapphire line */
[data-theme="dark"] .stats{background:linear-gradient(180deg,var(--abyss) 0%,var(--ink) 100%)}
[data-theme="dark"] .stat{border-top-color:rgba(244,237,227,.12)}
[data-theme="dark"] .stat__num{color:var(--sapphire-300)}
[data-theme="dark"] .stat__num .unit{color:var(--paper-dim)}
[data-theme="dark"] .stat__label{color:var(--paper-dim)}

/* scrub video caption (dark) — already dark, just nudge */
[data-theme="dark"] .scrubvideo{background:var(--abyss)}

/* product (dark) — ink with sapphire halo */
[data-theme="dark"] .product{background:linear-gradient(180deg,var(--ink) 0%,var(--abyss) 100%)}
[data-theme="dark"] .product__media{background:radial-gradient(circle at 50% 40%,rgba(127,160,240,.18) 0%,var(--ink) 60%);border:1px solid rgba(244,237,227,.06)}
[data-theme="dark"] .product__heading h2{color:var(--paper)}
[data-theme="dark"] .product__heading h2 .italic{color:var(--sapphire-300)}
[data-theme="dark"] .product__heading p{color:var(--paper-dim)}
[data-theme="dark"] .product__features{border-top-color:rgba(244,237,227,.12)}
[data-theme="dark"] .product__features li{color:var(--paper-dim)}
[data-theme="dark"] .product__swatches{background:rgba(8,15,45,.6)}
[data-theme="dark"] .swatch{border-color:rgba(244,237,227,.18)}
[data-theme="dark"] .swatch::after{border-color:var(--paper)}

/* ice (dark) — abyss with sapphire glow top-left */
[data-theme="dark"] .ice{background:linear-gradient(180deg,var(--abyss) 0%,var(--ink) 100%)}
[data-theme="dark"] .ice::before{content:"";position:absolute;left:-10%;top:-15%;width:60%;aspect-ratio:1;background:radial-gradient(circle,rgba(71,112,219,.18) 0%,transparent 65%);pointer-events:none;z-index:0}

/* science (dark) */
[data-theme="dark"] .science{background:linear-gradient(180deg,var(--ink) 0%,var(--abyss) 100%)}
[data-theme="dark"] .science__head h2{color:var(--paper)}
[data-theme="dark"] .science__head h2 .italic{color:var(--sapphire-300)}
[data-theme="dark"] .science__progress{color:var(--paper-dim)}
[data-theme="dark"] .science__card{background:var(--ink);border:1px solid rgba(244,237,227,.06);box-shadow:0 30px 60px -30px rgba(0,0,0,.7)}
[data-theme="dark"] .science__card .body{background:var(--ink)}
[data-theme="dark"] .science__card h3{color:var(--paper)}
[data-theme="dark"] .science__card p{color:var(--paper-dim)}
[data-theme="dark"] .science__card .week{color:var(--sapphire-300)}
[data-theme="dark"] .science__card .media{background:var(--abyss)}

/* how (dark) — already dark, deepen */
[data-theme="dark"] .how{background:linear-gradient(180deg,var(--abyss) 0%,var(--ink) 100%)}
[data-theme="dark"] .how__step::before{background:var(--paper);color:var(--ink)}

/* fit (dark) */
[data-theme="dark"] .fit{background:linear-gradient(180deg,var(--ink) 0%,var(--abyss) 100%)}
[data-theme="dark"] .fit h2{color:var(--paper)}
[data-theme="dark"] .fit p.lead{color:var(--paper-dim)}
[data-theme="dark"] .fit__table{background:var(--ink);border:1px solid rgba(244,237,227,.06);box-shadow:0 24px 60px -30px rgba(0,0,0,.6)}
[data-theme="dark"] .fit__table th{background:var(--abyss);color:var(--sapphire-300)}
[data-theme="dark"] .fit__table td{color:var(--paper);border-bottom-color:rgba(244,237,227,.08)}
[data-theme="dark"] .fit__yes{color:var(--sapphire-300)}
[data-theme="dark"] .fit__no{color:#E27D7D}

/* box (dark) */
[data-theme="dark"] .box{background:linear-gradient(180deg,var(--abyss) 0%,var(--ink) 100%)}
[data-theme="dark"] .box__head h2{color:var(--paper)}
[data-theme="dark"] .box__head h2 .italic{color:var(--sapphire-300)}
[data-theme="dark"] .box-grid{background:rgba(244,237,227,.08)}
[data-theme="dark"] .box-tile{background:var(--ink);color:var(--paper-dim)}
[data-theme="dark"] .box-tile:hover{background:var(--abyss);color:var(--paper)}
[data-theme="dark"] .box-tile__name{color:var(--paper)}
[data-theme="dark"] .box-tile__num{color:var(--gold-500)}
[data-theme="dark"] .box-tile--photo .box-tile__photo{background:var(--abyss)}
[data-theme="dark"] .box-pack__head{border-bottom-color:rgba(244,237,227,.12)}
[data-theme="dark"] .box-pack__eyebrow{color:var(--paper)}
[data-theme="dark"] .box-pack__count{color:var(--paper-dim)}

/* faq (dark) */
[data-theme="dark"] .faq{background:linear-gradient(180deg,var(--ink) 0%,var(--abyss) 100%)}
[data-theme="dark"] .faq__heading h2{color:var(--paper)}
[data-theme="dark"] .faq__heading h2 .italic{color:var(--sapphire-300)}
[data-theme="dark"] .faq__list{background:rgba(244,237,227,.08);border-top-color:rgba(244,237,227,.12);border-bottom-color:rgba(244,237,227,.12)}
[data-theme="dark"] .faq__item{background:var(--ink)}
[data-theme="dark"] .faq__item summary{color:var(--paper)}
[data-theme="dark"] .faq__item p{color:var(--paper-dim)}
[data-theme="dark"] .faq__item summary:hover{color:var(--sapphire-300)}

/* cta (dark) — abyss with radial sapphire glow */
[data-theme="dark"] .cta{background:radial-gradient(ellipse at center,rgba(71,112,219,.12) 0%,var(--abyss) 70%)}
[data-theme="dark"] .cta h2{color:var(--paper)}
[data-theme="dark"] .cta h2 .italic{color:var(--sapphire-300)}
[data-theme="dark"] .cta p{color:var(--paper-dim)}
[data-theme="dark"] .cta .btn-primary{background:var(--paper);color:var(--ink)}
[data-theme="dark"] .cta .btn-primary:hover{background:var(--sapphire-300)}

/* foot (dark) — already dark, just sharpen */
[data-theme="dark"] .foot{background:var(--abyss);border-top:1px solid rgba(244,237,227,.06)}

/* progress bar accent */
[data-theme="dark"] .progress__fill{background:linear-gradient(90deg,var(--sapphire-300) 0%,var(--gold-500) 100%)}
[data-theme="dark"] .cursor{border-color:var(--sapphire-300)}

/* ══════════════════════════════════════════════════════════
   SUB-PAGES (about, contact, legal, etc.) — light + dark
══════════════════════════════════════════════════════════ */
.page-hero{padding:9rem 0 4rem;background:linear-gradient(180deg,var(--cream-100) 0%,var(--cream-50) 100%);position:relative;overflow:hidden;text-align:center}
.page-hero .wrap{position:relative;z-index:2}
.page-hero .eyebrow{color:var(--gold-500);margin-bottom:1rem}
.page-hero h1{font-family:var(--font-display);font-weight:300;font-size:clamp(2.4rem,6vw,4.8rem);line-height:1.05;letter-spacing:-.025em;color:var(--navy-900);max-width:18ch;margin:0 auto 1.2rem}
.page-hero h1 .italic{color:var(--sapphire-500)}
.page-hero p{max-width:54ch;margin:0 auto;font-size:var(--fs-body-lg);color:var(--stone-500);line-height:1.6}
[data-theme="dark"] .page-hero{background:linear-gradient(180deg,var(--ink) 0%,var(--abyss) 100%)}
[data-theme="dark"] .page-hero h1{color:var(--paper)}
[data-theme="dark"] .page-hero h1 .italic{color:var(--sapphire-300)}
[data-theme="dark"] .page-hero p{color:var(--paper-dim)}

.page-body{padding:var(--pad-section) 0;background:var(--cream-100)}
[data-theme="dark"] .page-body{background:var(--abyss)}
.page-body .wrap{max-width:880px}
.page-body h2{font-family:var(--font-display);font-weight:300;font-size:clamp(1.6rem,3vw,2.2rem);letter-spacing:-.015em;color:var(--navy-900);margin:2.5rem 0 1rem}
.page-body h2:first-child{margin-top:0}
[data-theme="dark"] .page-body h2{color:var(--paper)}
.page-body h3{font-family:var(--font-display);font-weight:400;font-size:1.2rem;color:var(--navy-900);margin:1.6rem 0 .6rem}
[data-theme="dark"] .page-body h3{color:var(--paper)}
.page-body p,.page-body li{color:var(--charcoal-900);font-size:1rem;line-height:1.65;margin-bottom:.85rem}
[data-theme="dark"] .page-body p,[data-theme="dark"] .page-body li{color:var(--paper-dim)}
.page-body ul,.page-body ol{padding-left:1.4rem;margin:.5rem 0 1.2rem}
[dir="rtl"] .page-body ul,[dir="rtl"] .page-body ol{padding-left:0;padding-right:1.4rem}
.page-body strong{color:var(--navy-900);font-weight:500}
[data-theme="dark"] .page-body strong{color:var(--paper)}
.page-body a{color:var(--sapphire-500);text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:3px}
[data-theme="dark"] .page-body a{color:var(--sapphire-300)}
.page-body__lead{font-size:var(--fs-body-lg);color:var(--stone-500);margin-bottom:2rem;border-left:2px solid var(--gold-500);padding-left:1rem}
[dir="rtl"] .page-body__lead{border-left:0;border-right:2px solid var(--gold-500);padding-left:0;padding-right:1rem}
[data-theme="dark"] .page-body__lead{color:var(--paper-dim)}

/* about: pillars */
.pillars{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,260px),1fr));gap:1.5rem;margin:3rem 0}
.pillar{padding:1.8rem 1.6rem;border:1px solid var(--stone-200);border-radius:14px;background:var(--cream-50)}
[data-theme="dark"] .pillar{background:var(--ink);border-color:rgba(244,237,227,.08)}
.pillar__num{font-family:var(--font-mono);font-size:.7rem;letter-spacing:.18em;color:var(--gold-500);text-transform:uppercase}
.pillar h3{font-family:var(--font-display);font-weight:300;font-size:1.4rem;color:var(--navy-900);margin:.7rem 0 .8rem;letter-spacing:-.01em}
[data-theme="dark"] .pillar h3{color:var(--paper)}
.pillar p{font-size:.95rem;color:var(--stone-500);line-height:1.55;margin:0}
[data-theme="dark"] .pillar p{color:var(--paper-dim)}

/* contact form */
.contact-grid{display:grid;grid-template-columns:1fr;gap:3rem;margin-top:2rem}
@media(min-width:840px){.contact-grid{grid-template-columns:1.2fr 1fr;gap:4rem}}
.contact-form{display:grid;gap:1rem}
.contact-form .field{display:grid;gap:.4rem}
.contact-form label{font-family:var(--font-mono);font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--stone-500)}
[data-theme="dark"] .contact-form label{color:var(--paper-dim)}
.contact-form input,.contact-form textarea,.contact-form select{padding:.85rem 1rem;border:1px solid var(--stone-200);border-radius:8px;background:var(--cream-50);font:inherit;color:var(--charcoal-900);transition:border-color .25s,background .25s}
[data-theme="dark"] .contact-form input,[data-theme="dark"] .contact-form textarea,[data-theme="dark"] .contact-form select{background:var(--ink);border-color:rgba(244,237,227,.12);color:var(--paper)}
.contact-form input:focus,.contact-form textarea:focus,.contact-form select:focus{outline:none;border-color:var(--sapphire-500);background:var(--white)}
[data-theme="dark"] .contact-form input:focus,[data-theme="dark"] .contact-form textarea:focus,[data-theme="dark"] .contact-form select:focus{background:var(--navy-800)}
.contact-form textarea{min-height:140px;resize:vertical}
.contact-form button{justify-self:start;margin-top:.6rem}
.contact-info{display:flex;flex-direction:column;gap:1.6rem;padding:1.8rem;background:var(--cream-50);border-radius:14px;border:1px solid var(--stone-200);height:fit-content}
[data-theme="dark"] .contact-info{background:var(--ink);border-color:rgba(244,237,227,.08)}
.contact-info__row{display:flex;gap:.9rem;align-items:flex-start}
.contact-info__row svg{flex-shrink:0;color:var(--gold-500);margin-top:.15rem}
.contact-info__row strong{display:block;color:var(--navy-900);font-weight:500;font-size:.92rem;margin-bottom:.2rem}
[data-theme="dark"] .contact-info__row strong{color:var(--paper)}
.contact-info__row span{font-size:.92rem;color:var(--stone-500);line-height:1.5}
[data-theme="dark"] .contact-info__row span{color:var(--paper-dim)}

/* TOC for legal pages */
.toc{position:sticky;top:6rem;padding:1.4rem 1.5rem;background:var(--cream-50);border:1px solid var(--stone-200);border-radius:14px;font-size:.92rem;height:fit-content}
[data-theme="dark"] .toc{background:var(--ink);border-color:rgba(244,237,227,.08)}
.toc h4{font-family:var(--font-mono);font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--stone-500);margin-bottom:.9rem;font-weight:500}
.toc ul{list-style:none;padding:0;display:grid;gap:.4rem}
.toc a{color:var(--charcoal-900);text-decoration:none;transition:color .2s}
.toc a:hover{color:var(--sapphire-500)}
[data-theme="dark"] .toc a{color:var(--paper-dim)}
[data-theme="dark"] .toc a:hover{color:var(--sapphire-300)}
.legal-grid{display:grid;grid-template-columns:1fr;gap:2.5rem}
@media(min-width:920px){.legal-grid{grid-template-columns:240px 1fr;gap:3.5rem}}

