/* ============================================================
   ODFinity™ — Bold scroll experience
   magenta #E8004C · yellow #F5F24A · periwinkle #6B75C8
   light pink #F5C5D0 · ink
   Type: Clash Display (display) · Satoshi (body)
   ============================================================ */

:root{
  --magenta:#E8004C;
  --magenta-2:#ff2d72;
  --magenta-deep:#c4003f;
  --yellow:#F5F24A;
  --peri:#6B75C8;
  --pink:#F5C5D0;
  --ink:#190912;
  --plum:#1a0a14;

  --font-display:"Clash Display","Satoshi",system-ui,sans-serif;
  --font-body:"Satoshi",system-ui,sans-serif;
  --soft:cubic-bezier(.19,1,.22,1);
}

*{margin:0;padding:0;box-sizing:border-box}
html,body{width:100%}
body{font-family:var(--font-body);background:var(--magenta);color:#fff;overflow-x:hidden;-webkit-font-smoothing:antialiased}
body::-webkit-scrollbar{width:0}
a{color:inherit;text-decoration:none}
sup{font-size:.5em;vertical-align:super}
em{font-style:normal}

.eyebrow{display:inline-block;font-size:.74rem;letter-spacing:.28em;text-transform:uppercase;font-weight:700;color:var(--yellow);margin-bottom:1.1rem}
.eyebrow--light{color:rgba(255,255,255,.8)}

.btn{display:inline-block;margin-top:2.2rem;padding:1.05rem 2.4rem;background:#fff;color:var(--magenta);
  font-weight:700;border-radius:100px;font-size:1.05rem;transition:transform .5s var(--soft),box-shadow .5s var(--soft);
  box-shadow:0 16px 40px -14px rgba(0,0,0,.45)}
.btn:hover{transform:translateY(-4px) scale(1.02)}

/* ---------- PRELOADER ---------- */
.preloader{position:fixed;inset:0;z-index:1000;background:var(--magenta);display:flex;align-items:center;justify-content:center}
.preloader__mark{font-family:var(--font-display);font-weight:600;font-size:clamp(2rem,6vw,4rem);color:#fff;letter-spacing:-.02em;opacity:0}
.preloader__mark span{color:var(--yellow);font-size:.4em;vertical-align:super}

/* ---------- NAV ---------- */
.nav{position:fixed;top:0;left:0;right:0;z-index:99;display:flex;align-items:center;justify-content:space-between;
  height:11vh;padding:0 clamp(1.2rem,6vw,6vw);opacity:0}
.nav__logo{font-family:var(--font-display);font-weight:600;font-size:1.4rem;letter-spacing:-.02em}
.nav__center{display:flex;gap:2.4vw}
.nav__center a{font-size:.95rem;font-weight:500;opacity:.9;transition:opacity .3s}
.nav__center a:hover{opacity:1}
.nav__cta{font-size:.9rem;font-weight:700;border:1.5px solid rgba(255,255,255,.5);padding:.55rem 1.2rem;border-radius:100px;transition:.3s}
.nav__cta:hover{background:#fff;color:var(--magenta);border-color:#fff}

/* ============================================================
   SECTION ONE · HERO
   ============================================================ */
.one{position:relative;width:100%;height:100vh;display:flex;align-items:center;justify-content:center;overflow:hidden;
  background:radial-gradient(120% 120% at 70% 10%, var(--magenta-2), var(--magenta) 55%, var(--magenta-deep));}
.hero__kicker{position:absolute;top:13vh;left:50%;transform:translateX(-50%);z-index:6;
  font-size:.82rem;letter-spacing:.34em;text-transform:uppercase;font-weight:700;color:rgba(255,255,255,.85)}
.hero__word{font-family:var(--font-display);font-weight:700;color:#fff;font-size:clamp(4rem,21vw,20rem);
  line-height:.9;letter-spacing:-.03em;z-index:1;text-shadow:0 30px 80px rgba(120,0,40,.35);user-select:none}

/* film strips (hero) */
.strip{position:absolute;display:flex;flex-direction:column;justify-content:flex-end;gap:.15rem;
  border-radius:18px;padding:14px 16px;will-change:transform;
  box-shadow:0 30px 60px -18px rgba(60,0,25,.55), inset 0 1px 0 rgba(255,255,255,.5), inset 0 -20px 30px -18px rgba(0,0,0,.35);
  overflow:hidden;backdrop-filter:saturate(1.1)}
.strip::after{content:"";position:absolute;inset:0;background:linear-gradient(115deg,transparent 38%,rgba(255,255,255,.55) 50%,transparent 60%);mix-blend-mode:screen}
.strip__brand{font-family:var(--font-display);font-weight:600;font-size:.92rem;color:#fff;letter-spacing:-.01em;position:relative;z-index:2}
.strip__type{font-size:.6rem;letter-spacing:.08em;text-transform:uppercase;color:rgba(255,255,255,.85);position:relative;z-index:2}
.strip--hero{width:clamp(150px,15vw,230px);aspect-ratio:3/4;top:50%;left:50%;transform:translate(-50%,-50%) rotate(-8deg);z-index:5;
  background:linear-gradient(150deg,#ff4f86,var(--magenta) 55%,#a8003a)}
.strip--yellow{width:clamp(90px,9vw,150px);aspect-ratio:3/4;top:24%;left:20%;transform:rotate(-18deg);z-index:4;
  background:linear-gradient(150deg,#fff89a,var(--yellow) 60%,#c9c500)}
.strip--yellow .strip__brand{color:#3f3d00}
.strip--peri{width:clamp(90px,9vw,150px);aspect-ratio:3/4;top:58%;left:14%;transform:rotate(12deg);z-index:6;
  background:linear-gradient(150deg,#9aa3e6,var(--peri) 60%,#4a539e)}
.strip--pink{width:clamp(80px,8vw,130px);aspect-ratio:3/4;top:22%;right:16%;left:auto;transform:rotate(16deg);z-index:4;
  background:linear-gradient(150deg,#fff,var(--pink) 60%,#e79fb1)}
.strip--pink .strip__brand{color:#7c3a4c}
.strip--magenta{width:clamp(90px,9vw,150px);aspect-ratio:3/4;top:60%;right:18%;left:auto;transform:rotate(-14deg);z-index:5;
  background:linear-gradient(150deg,#ff4f86,var(--magenta) 55%,#a8003a)}

.spark{position:absolute;border-radius:50%;background:#fff;opacity:.7;z-index:2}
.spark--1{width:10px;height:10px;top:30%;left:42%}
.spark--2{width:7px;height:7px;top:66%;left:60%;background:var(--yellow)}
.spark--3{width:12px;height:12px;top:20%;right:30%}
.spark--4{width:6px;height:6px;top:72%;left:34%}

.hero__hint{position:absolute;bottom:4vh;left:50%;transform:translateX(-50%);z-index:7;display:flex;flex-direction:column;align-items:center;gap:.5rem;
  font-size:.68rem;letter-spacing:.24em;text-transform:uppercase;color:rgba(255,255,255,.85)}
.hero__hint i{width:1px;height:42px;background:rgba(255,255,255,.4);position:relative;overflow:hidden}
.hero__hint i::after{content:"";position:absolute;top:-50%;left:0;width:1px;height:50%;background:#fff;animation:run 1.8s var(--soft) infinite}
@keyframes run{to{top:100%}}

/* ============================================================
   SECTION TWO · SCIENCE (standalone box, films emerge a bit)
   ============================================================ */
.two{position:relative;width:100%;min-height:100vh;display:flex;align-items:center;gap:4vw;
  padding:14vh clamp(1.4rem,7vw,7vw);overflow:hidden;
  background:radial-gradient(100% 100% at 20% 0%, #2a0e1d, var(--plum) 70%)}

/* the box */
.pbox{position:relative;width:46%;max-width:460px;height:clamp(320px,46vh,460px);display:flex;align-items:flex-end;justify-content:center;margin:0 auto}
.pbox__back{position:absolute;left:6%;right:6%;bottom:0;height:62%;border-radius:16px;
  background:linear-gradient(160deg,#3a1322,#1f0a12);box-shadow:inset 0 16px 36px -14px rgba(0,0,0,.7)}
.pbox__films{position:absolute;left:0;right:0;bottom:18%;height:80%;display:flex;align-items:flex-end;justify-content:center;z-index:2}
.pfilm{position:absolute;bottom:0;width:clamp(78px,9vw,118px);aspect-ratio:3/4;border-radius:12px;
  display:flex;align-items:flex-end;justify-content:center;padding-bottom:10px;will-change:transform;
  box-shadow:0 18px 36px -14px rgba(60,0,25,.6), inset 0 1px 0 rgba(255,255,255,.5)}
.pfilm::after{content:"";position:absolute;inset:0;border-radius:12px;background:linear-gradient(115deg,transparent 38%,rgba(255,255,255,.5) 50%,transparent 62%);mix-blend-mode:screen}
.pfilm span{font-family:var(--font-display);font-weight:600;font-size:.66rem;color:#fff;position:relative;z-index:2}
.pfilm--mint{background:linear-gradient(150deg,#8fe0c4,#37b48a 58%,#1d8a66)}
.pfilm--rasp{background:linear-gradient(150deg,#ff4f86,var(--magenta) 55%,#a8003a)}
.pfilm--citrus{background:linear-gradient(150deg,#ffd27a,#ff9f1c 60%,#e07a00)}
.pfilm--citrus span{color:#5a3500}
.pfilm--peri{background:linear-gradient(150deg,#9aa3e6,var(--peri) 60%,#4a539e)}
.pfilm--pink{background:linear-gradient(150deg,#fff,var(--pink) 58%,#e79fb1)}
/* front wall of the box (covers the films' lower half) */
.pbox__front{position:absolute;left:4%;right:4%;bottom:0;height:42%;border-radius:16px;z-index:5;
  background:linear-gradient(160deg,#ff4f86,var(--magenta) 60%,#8a0030);
  box-shadow:0 26px 50px -18px rgba(232,0,76,.6), inset 0 1px 0 rgba(255,255,255,.5);
  display:flex;align-items:flex-end;justify-content:center;padding-bottom:14px}
.pbox__front::after{content:"";position:absolute;inset:0;border-radius:16px;background:linear-gradient(115deg,transparent 40%,rgba(255,255,255,.4) 50%,transparent 60%);mix-blend-mode:screen}
.pbox__front span{font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.92);font-weight:700;position:relative;z-index:2}

/* copy */
.two__copy{width:54%;max-width:560px}
.two__copy .eyebrow{color:var(--yellow)}
.two__copy h2{font-family:var(--font-display);font-weight:600;font-size:clamp(2.2rem,5.4vw,4.4rem);line-height:1;letter-spacing:-.03em;margin-bottom:1.4rem}
.two__copy h2 em{color:var(--magenta-2)}
.two__counter{display:flex;align-items:baseline;gap:1rem;margin-bottom:1.4rem}
.two__counter b{font-family:var(--font-display);font-weight:700;font-size:clamp(3rem,7vw,5.5rem);line-height:.85;color:#fff}
.two__counter span{font-size:.95rem;color:rgba(255,255,255,.8);line-height:1.4}
.two__copy p{font-size:clamp(1rem,1.3vw,1.15rem);line-height:1.6;color:rgba(255,255,255,.78)}
.two__copy p strong{color:#fff;font-weight:700}

/* ============================================================
   SECTION THREE · FLAVOURS
   ============================================================ */
.three{position:relative;width:100%;min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5vh;
  padding:14vh clamp(1.4rem,6vw,6vw);overflow:hidden;
  background:radial-gradient(120% 90% at 50% 0%, #8b94de, var(--peri) 60%, #565fa8)}
.three__title{font-family:var(--font-display);font-weight:600;font-size:clamp(2.4rem,7vw,5.5rem);letter-spacing:-.03em;text-align:center}
.three__title em{color:var(--yellow)}
.cards{display:flex;gap:clamp(1rem,2.5vw,2.5rem);flex-wrap:wrap;justify-content:center}
.card{position:relative;display:flex;flex-direction:column;align-items:center;gap:.5rem;
  width:clamp(220px,24vw,300px);height:64vh;min-height:420px;border-radius:28px;background:#fff;color:var(--ink);
  padding:2rem;padding-top:38%;box-shadow:0 40px 70px -28px rgba(40,10,40,.45)}
.card--lift{transform:translateY(-26px)}
.card__strip{position:absolute;top:-14%;left:50%;transform:translateX(-50%) rotate(-6deg);
  width:46%;aspect-ratio:3/4;border-radius:16px;display:flex;align-items:flex-end;justify-content:center;padding-bottom:12px;
  box-shadow:0 26px 50px -18px rgba(60,0,30,.5), inset 0 1px 0 rgba(255,255,255,.5);will-change:transform}
.card__strip span{font-family:var(--font-display);font-weight:600;font-size:.85rem;color:#fff}
.card__strip--mint{background:linear-gradient(150deg,#8fe0c4,#37b48a 60%,#1d8a66)}
.card__strip--magenta{background:linear-gradient(150deg,#ff4f86,var(--magenta) 55%,#a8003a)}
.card__strip--citrus{background:linear-gradient(150deg,#ffd27a,#ff9f1c 60%,#e07a00);color:#5a3500}
.card__strip--citrus span{color:#5a3500}
.card h3{font-family:var(--font-display);font-weight:600;font-size:1.7rem;margin-top:auto}
.card p{font-size:.92rem;color:#7c6470}
.card button{margin-top:.4rem;font-size:.9rem;font-weight:700;color:#fff;background:var(--magenta);border:none;border-radius:100px;padding:.7rem 1.6rem;cursor:pointer;transition:transform .4s var(--soft)}
.card button:hover{transform:scale(1.05)}

/* ============================================================
   PARTNER + FOOTER
   ============================================================ */
.partner{position:relative;text-align:center;padding:18vh clamp(1.4rem,6vw,6vw) 14vh;
  background:radial-gradient(110% 100% at 50% 0%, var(--magenta-2), var(--magenta) 55%, var(--magenta-deep))}
.partner__title{font-family:var(--font-display);font-weight:600;font-size:clamp(2.4rem,7vw,5.5rem);letter-spacing:-.03em}
.partner__lede{max-width:600px;margin:1.3rem auto 0;color:rgba(255,255,255,.85);font-size:clamp(1rem,1.6vw,1.2rem);line-height:1.55}
.accred{display:flex;flex-wrap:wrap;gap:.6rem;justify-content:center;margin:6vh auto 0;max-width:760px}
.accred span{font-size:.74rem;letter-spacing:.06em;padding:.5rem 1.05rem;border-radius:100px;border:1px solid rgba(255,255,255,.4);color:#fff}

.footer{background:var(--plum);color:rgba(255,255,255,.6);padding:6vh clamp(1.4rem,6vw,6vw);display:flex;flex-direction:column;gap:.5rem;font-size:.85rem}
.footer__brand{font-family:var(--font-display);font-weight:600;color:#fff;font-size:1.05rem}
.footer a{color:var(--yellow)}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:900px){
  .two{flex-direction:column;justify-content:center;gap:5vh;padding-top:16vh;padding-bottom:10vh}
  .pbox,.two__copy{width:100%}
  .nav__center{display:none}
  .cards{flex-direction:column;align-items:center}
  .card{height:auto;min-height:0;padding-top:30%;padding-bottom:2.4rem}
  .card--lift{transform:none}
}
@media (max-width:520px){
  .strip--yellow,.strip--pink{display:none}
  .hero__word{font-size:26vw}
}

/* ---------- reduced motion ---------- */
@media (prefers-reduced-motion:reduce){
  .hero__hint{display:none}
}

/* ============================================================
   FULL HOME PAGE SECTIONS (from content brief)
   ============================================================ */
.sec{position:relative;padding:15vh clamp(1.4rem,6vw,6vw)}
.wrap{max-width:1180px;margin:0 auto}
.sec--cream{background:#f4ede2;color:#1d140f}
.sec--ink{background:radial-gradient(120% 90% at 15% 0%,#2a0e1d,var(--plum) 70%);color:#fff}
.sec--peri{background:radial-gradient(120% 100% at 50% 0%,#8b94de,var(--peri) 62%,#535ca6);color:#fff}

.display{font-family:var(--font-display);font-weight:600;font-size:clamp(2rem,5vw,3.8rem);line-height:1.02;letter-spacing:-.03em;margin:1.1rem 0}
.display em{font-style:normal;color:var(--magenta)}
.sec--ink .display em{color:var(--magenta-2)}
.sec--peri .display em{color:var(--yellow)}
.lede{font-size:clamp(1.05rem,1.5vw,1.3rem);line-height:1.6;max-width:680px;color:#5b4a44}
.lede--light{color:rgba(255,255,255,.8)}
.sec--peri .lede{color:rgba(255,255,255,.85)}

.eyebrow--ink{color:var(--ink)!important}
.sec--cream .eyebrow{color:var(--magenta)}

.link-cta{display:inline-block;margin-top:2rem;font-weight:700;font-size:1rem;color:inherit;border-bottom:2px solid var(--magenta);padding-bottom:.25rem;transition:gap .3s,opacity .3s}
.link-cta:hover{opacity:.7}
.link-cta--light{border-color:#fff}

/* reveal: visible by default; JS animates in */
.reveal{will-change:transform,opacity}

/* — Trust strip — */
.big-line{font-family:var(--font-display);font-weight:600;font-size:clamp(1.8rem,4.4vw,3.4rem);line-height:1.06;letter-spacing:-.02em;max-width:18ch}
.big-line em{font-style:normal;color:var(--magenta)}
.sec--cream .lede{margin-top:1.4rem}
.trust{display:grid;grid-template-columns:repeat(4,1fr);gap:1.4rem;margin:6vh 0 4vh;border-top:1px solid rgba(29,20,15,.15);padding-top:4vh}
.trust__item b{display:block;font-family:var(--font-display);font-weight:700;font-size:clamp(2.2rem,4vw,3.2rem);color:var(--magenta);line-height:1}
.trust__item span{display:block;margin-top:.5rem;font-size:.92rem;color:#6b5a54;line-height:1.4}
.marquee{display:flex;align-items:center;gap:1.1rem;flex-wrap:wrap;font-family:var(--font-display);font-weight:600;font-size:clamp(1.1rem,2vw,1.6rem);color:#1d140f}
.marquee i{color:var(--magenta)}
.marquee__more{font-family:var(--font-body);font-weight:500;font-size:.9rem;color:#6b5a54}

/* — Fast/Flavourful/Functional — */
.oneroof{margin-top:3vh;font-family:var(--font-display);font-weight:500;font-size:clamp(1.2rem,2.2vw,1.7rem);color:#fff}
.fff{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem;margin-top:5vh}
.fff__item{padding:2rem 1.6rem;border:1px solid rgba(255,255,255,.16);border-radius:18px;background:rgba(255,255,255,.03)}
.fff__k{font-family:var(--font-display);font-weight:600;font-size:1.6rem;color:var(--yellow)}
.fff__item p{margin-top:.7rem;color:rgba(255,255,255,.72);line-height:1.5}

/* — Why partner proof blocks — */
.proof{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:rgba(29,20,15,.14);border:1px solid rgba(29,20,15,.14);margin:6vh 0;border-radius:6px;overflow:hidden}
.proof__b{background:#f4ede2;padding:2.2rem 1.8rem;min-height:200px;display:flex;flex-direction:column}
.proof__b span{font-family:var(--font-display);color:var(--magenta);font-weight:600}
.proof__b h3{font-family:var(--font-display);font-weight:600;font-size:1.3rem;margin:.5rem 0 .6rem}
.proof__b p{color:#6b5a54;line-height:1.5;font-size:.95rem;margin-top:auto}
.credit{font-family:var(--font-display);font-weight:500;font-size:clamp(1.1rem,2vw,1.5rem);color:#1d140f;padding:1.6rem 0;border-top:1px solid rgba(29,20,15,.14);border-bottom:1px solid rgba(29,20,15,.14)}
.credit strong{color:var(--magenta)}
.caps{margin-top:5vh}
.caps__h{font-family:var(--font-display);font-weight:600;font-size:clamp(1.3rem,2.4vw,1.9rem);margin-bottom:1.8rem}
.caps__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.7rem}
.caps__grid span{padding:1rem 1.1rem;border-radius:12px;background:#fff;border:1px solid rgba(29,20,15,.08);font-weight:600;font-size:.92rem;text-align:center;color:#1d140f}

/* — Therapeutic range — */
.range{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem;margin:6vh 0 0}
.range__c{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.22);border-radius:20px;padding:1.8rem;min-height:210px;display:flex;flex-direction:column;backdrop-filter:blur(4px)}
.range__tag{align-self:flex-start;font-size:.7rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;background:var(--yellow);color:#3f3d00;padding:.3rem .7rem;border-radius:100px}
.range__c h3{font-family:var(--font-display);font-weight:600;font-size:1.25rem;margin:1.2rem 0 .5rem}
.range__c p{color:rgba(255,255,255,.82);font-size:.92rem;line-height:1.45;margin-top:auto}

/* — Shilpa — */
.shilpa{display:grid;grid-template-columns:1.3fr .7fr;gap:4vw;align-items:center}
.shilpa__r{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.vert{aspect-ratio:1/.7;border:1px solid rgba(255,255,255,.18);border-radius:16px;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,.04)}
.vert b{font-family:var(--font-display);font-weight:600;font-size:1.2rem;color:#fff}

/* — Blog — */
.posts{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem;margin:6vh 0 0}
.post{background:#fff;border:1px solid rgba(29,20,15,.08);border-radius:20px;padding:1.8rem;min-height:220px;display:flex;flex-direction:column;transition:transform .4s var(--soft),box-shadow .4s var(--soft)}
.post:hover{transform:translateY(-5px);box-shadow:0 24px 50px -24px rgba(40,10,40,.3)}
.post__date{font-size:.78rem;letter-spacing:.08em;text-transform:uppercase;color:var(--magenta);font-weight:700}
.post h3{font-family:var(--font-display);font-weight:600;font-size:1.25rem;line-height:1.2;margin:1rem 0}
.post__more{margin-top:auto;font-weight:700;font-size:.92rem;color:#1d140f}

/* partner title em + footer */
.partner__title em{color:var(--yellow);font-style:normal}
.footer{display:block}
.footer__top{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;padding-bottom:4vh;border-bottom:1px solid rgba(255,255,255,.12)}
.footer__brand{font-family:var(--font-display);font-weight:600;font-size:2rem;color:#fff}
.footer__nav{display:flex;gap:1.6rem}
.footer__nav a{color:rgba(255,255,255,.7);font-size:.92rem}
.footer__nav a:hover{color:#fff}
.footer__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.6rem;padding:5vh 0;font-size:.9rem}
.footer__grid div{display:flex;flex-direction:column;gap:.45rem;color:rgba(255,255,255,.6)}
.footer__h{color:#fff;font-weight:700;letter-spacing:.04em;text-transform:uppercase;font-size:.74rem;margin-bottom:.3rem}
.footer__grid a:hover{color:var(--yellow)}
.footer__fine{font-size:.78rem;color:rgba(255,255,255,.4);padding-top:3vh;border-top:1px solid rgba(255,255,255,.12)}

@media (max-width:900px){
  .trust,.fff,.proof,.caps__grid,.range,.posts{grid-template-columns:1fr 1fr}
  .shilpa{grid-template-columns:1fr;gap:4vh}
  .footer__grid{grid-template-columns:1fr}
}
@media (max-width:520px){
  .trust,.fff,.proof,.caps__grid,.range,.posts{grid-template-columns:1fr}
}

/* nav adapts to light (cream) sections */
.nav--dark .nav__logo,.nav--dark .nav__center a,.nav--dark .nav__cta{color:var(--ink)}
.nav--dark .nav__center a{opacity:.65}
.nav--dark .nav__center a:hover{opacity:1}
.nav--dark .nav__cta{border-color:rgba(25,9,18,.28)}
.nav--dark .nav__cta:hover{background:var(--ink);color:#fff;border-color:var(--ink)}

/* ============================================================
   #trust — interactive THEN / NOW + highlighter + marquee
   ============================================================ */
/* highlighter sweep on "Not anymore." */
.sec--cream .big-line em.hl{color:var(--ink);position:relative;z-index:0;font-style:normal;white-space:nowrap}
.big-line em.hl::before{content:"";position:absolute;left:-.08em;right:-.08em;bottom:.05em;height:.42em;background:var(--yellow);z-index:-1;border-radius:4px;transform:scaleX(0);transform-origin:left;transition:transform .8s var(--soft)}
.big-line em.hl.is-on::before{transform:scaleX(1)}

/* comparison slider */
.cmp{--pos:50%;position:relative;width:100%;height:clamp(360px,56vh,520px);margin:6vh 0;border-radius:28px;overflow:hidden;
  cursor:ew-resize;user-select:none;touch-action:none;box-shadow:0 50px 90px -40px rgba(40,10,40,.5);outline:none}
.cmp__panel{position:absolute;inset:0;overflow:hidden}
.cmp__now{background:radial-gradient(120% 120% at 72% 18%, var(--magenta-2), var(--magenta) 58%, var(--magenta-deep))}
.cmp__then{background:linear-gradient(160deg,#45424e,#26242e 72%);z-index:2;clip-path:inset(0 calc(100% - var(--pos)) 0 0)}

.cmp__tag{position:absolute;top:1.5rem;font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;font-weight:700;padding:.42rem .95rem;border-radius:100px}
.cmp__tag--then{left:1.7rem;background:rgba(255,255,255,.1);color:rgba(255,255,255,.78)}
.cmp__tag--now{right:1.7rem;background:rgba(255,255,255,.18);color:#fff}
.cmp__say{position:absolute;bottom:1.7rem;font-family:var(--font-display);font-weight:600;font-size:clamp(1.05rem,2vw,1.7rem);line-height:1.08}
.cmp__say--then{left:1.7rem;color:rgba(255,255,255,.85)}
.cmp__say--now{right:1.7rem;text-align:right;color:#fff}

.cmp__pill{position:absolute;top:50%;left:30%;transform:translate(-50%,-50%) rotate(-8deg);
  width:clamp(94px,11vw,148px);height:clamp(94px,11vw,148px);border-radius:50%;
  background:radial-gradient(circle at 38% 30%, #f4f2f5, #cdc8d2 58%, #a097ab);
  box-shadow:0 26px 50px -18px rgba(0,0,0,.6), inset 0 -12px 22px -12px rgba(0,0,0,.4), inset 0 6px 10px rgba(255,255,255,.7)}
.cmp__pill::after{content:"";position:absolute;top:50%;left:15%;right:15%;height:3px;transform:translateY(-50%);background:rgba(80,74,92,.5);border-radius:3px}
.cmp__film{position:absolute;top:50%;left:70%;transform:translate(-50%,-50%) rotate(-8deg);
  width:clamp(108px,12vw,160px);aspect-ratio:3/4;border-radius:16px;overflow:hidden;
  background:linear-gradient(150deg,#ff7aa6,var(--magenta) 55%,#a8003a);
  box-shadow:0 30px 60px -18px rgba(120,0,40,.6), inset 0 1px 0 rgba(255,255,255,.6);
  display:flex;align-items:flex-end;justify-content:center;padding-bottom:12px}
.cmp__film::after{content:"";position:absolute;inset:0;background:linear-gradient(115deg,transparent 38%,rgba(255,255,255,.55) 50%,transparent 62%);mix-blend-mode:screen}
.cmp__film span{font-family:var(--font-display);font-weight:600;font-size:.8rem;color:#fff;position:relative;z-index:2}

.cmp__divider{position:absolute;top:0;bottom:0;left:var(--pos);width:2px;background:rgba(255,255,255,.92);transform:translateX(-50%);z-index:6;pointer-events:none}
.cmp__grip{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:54px;height:54px;border-radius:50%;background:#fff;
  display:flex;align-items:center;justify-content:center;gap:1px;box-shadow:0 12px 30px -8px rgba(0,0,0,.55)}
.cmp__grip i{font-style:normal;font-weight:800;color:var(--magenta);font-size:1.1rem;line-height:1}
.cmp__hint{position:absolute;left:var(--pos);top:calc(50% + 46px);transform:translateX(-50%);z-index:6;pointer-events:none;
  font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;font-weight:700;color:#fff;background:rgba(0,0,0,.35);
  padding:.35rem .8rem;border-radius:100px;white-space:nowrap;transition:opacity .4s}
.cmp.is-touched .cmp__hint{opacity:0}

/* stats hover */
.trust__item{transition:transform .4s var(--soft)}
.trust__item:hover{transform:translateY(-5px)}

/* infinite marquee (overrides earlier static .marquee) */
.marquee-wrap{overflow:hidden;margin-top:6vh;border-top:1px solid rgba(29,20,15,.15);padding-top:3.5vh;
  -webkit-mask:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent);mask:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent)}
.marquee{display:inline-flex;align-items:center;gap:1.4rem;width:max-content;animation:marq 28s linear infinite;
  font-family:var(--font-display);font-weight:600;font-size:clamp(1.1rem,2vw,1.7rem);color:#1d140f}
.marquee i{color:var(--magenta)}
@keyframes marq{from{transform:translateX(0)}to{transform:translateX(-50%)}}

@media (max-width:560px){
  .cmp__say{font-size:1rem}
  .cmp__pill{left:26%}.cmp__film{left:74%}
}
@media (prefers-reduced-motion:reduce){ .marquee{animation:none} .big-line em.hl::before{transform:scaleX(1)} }

/* ============================================================
   PARALLAX layers (wrappers — keep film/box assets swappable)
   ============================================================ */
.hero__wordwrap{position:relative;z-index:1;display:flex;align-items:center;justify-content:center;will-change:transform}
.hero__layers{position:absolute;inset:0;z-index:3;pointer-events:none;will-change:transform}

/* ============================================================
   NAV — frosted adaptive header (legible over any section)
   ============================================================ */
.nav{transition:height .4s var(--soft),background .4s var(--soft),backdrop-filter .4s var(--soft),box-shadow .4s var(--soft)}
.nav.is-scrolled{height:8.5vh;background:rgba(22,8,14,.55);
  -webkit-backdrop-filter:blur(16px) saturate(1.25);backdrop-filter:blur(16px) saturate(1.25);
  box-shadow:inset 0 -1px 0 rgba(255,255,255,.08)}
.nav.is-scrolled.nav--dark{background:rgba(244,237,226,.72);box-shadow:inset 0 -1px 0 rgba(25,9,18,.08)}

/* ============================================================
   CERTIFICATION / PARTNER LOGO CHIPS
   ============================================================ */
.cert{flex:0 0 auto;height:66px;background:#fff;border-radius:14px;display:flex;align-items:center;justify-content:center;
  padding:0 22px;box-shadow:0 16px 34px -20px rgba(40,10,40,.35)}
.cert img{height:34px;width:auto;max-width:172px;object-fit:contain;display:block}
.cert--text span{font-weight:700;color:#1d140f;font-size:.95rem;letter-spacing:.02em;white-space:nowrap}
/* marquee now carries chips, not text */
.marquee{gap:1.2rem}
/* partner band chips */
.accred{align-items:center}
@media (max-width:560px){ .cert{height:56px;padding:0 16px} .cert img{height:28px;max-width:130px} }

/* trust stats — centered + larger, more readable labels */
.trust{text-align:center}
.trust__item{text-align:center}
.trust__item b{font-size:clamp(2.8rem,5vw,4rem)}
.trust__item span{font-size:clamp(1rem,1.25vw,1.2rem);color:#473932;max-width:15rem;margin:.65rem auto 0;line-height:1.45}

/* letter / word reveal helpers */
.hero__word .hl-ch{display:inline-block;will-change:transform}
.two__copy h2 .w{display:inline-block;will-change:transform}

/* ============================================================
   PARTNER / CLOSING — tighter spacing + uniform cert chips
   ============================================================ */
.partner{padding:12vh clamp(1.4rem,6vw,6vw) 10vh}
.partner__title{font-size:clamp(2.2rem,5.6vw,4.4rem);line-height:1.04;max-width:16ch;margin-left:auto;margin-right:auto}
.partner__lede{margin-top:1.1rem;max-width:560px}
.partner .btn{margin-top:1.8rem}
.accred{gap:.7rem;margin:4.5vh auto 0;max-width:660px}
.accred .cert{width:clamp(112px,13vw,148px);height:58px;padding:0 12px}
.accred .cert img{height:28px;max-width:100%}
.accred .cert--text span{font-size:.9rem}

/* partner CTA button → clean centered block with guaranteed gap to chips */
.partner .btn{display:block;width:max-content;margin:2.4rem auto 0}
.accred{margin-top:6vh}

/* guaranteed gap between CTA button and cert chips (collapse-proof) */
.accred{margin-top:0;padding-top:58px}

/* film-disintegration particle canvas (over the panels, under labels/divider) */
.cmp__dust{position:absolute;inset:0;z-index:3;pointer-events:none}
.cmp__say,.cmp__tag{z-index:4}

/* ============================================================
   MORPH — scroll-driven pill → particles → film metamorphosis
   ============================================================ */
.morph{position:relative;width:100%;height:clamp(380px,60vh,560px);margin:6vh 0;border-radius:28px;overflow:hidden;
  background:linear-gradient(160deg,#45424e,#26242e 72%);box-shadow:0 50px 90px -40px rgba(40,10,40,.5)}
.morph__bg{position:absolute;inset:0}
.morph__bg--new{background:radial-gradient(120% 120% at 50% 38%, #ff2d72, var(--magenta) 58%, var(--magenta-deep));opacity:0}
.morph__tag{position:absolute;top:1.7rem;left:1.8rem;z-index:5;font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;font-weight:700;padding:.42rem .95rem;border-radius:100px}
.morph__tag--old{background:rgba(255,255,255,.1);color:rgba(255,255,255,.8)}
.morph__tag--new{background:rgba(255,255,255,.2);color:#fff;opacity:0}
.morph__pill{position:absolute;top:42%;left:50%;transform:translate(-50%,-50%);z-index:3;
  width:clamp(110px,12vw,150px);height:clamp(110px,12vw,150px);border-radius:50%;
  background:radial-gradient(circle at 38% 30%, #f4f2f5, #cdc8d2 58%, #a097ab);
  box-shadow:0 26px 50px -18px rgba(0,0,0,.6), inset 0 -12px 22px -12px rgba(0,0,0,.4), inset 0 6px 10px rgba(255,255,255,.7)}
.morph__pill::after{content:"";position:absolute;top:50%;left:15%;right:15%;height:3px;transform:translateY(-50%);background:rgba(80,74,92,.5);border-radius:3px}
.morph__film{position:absolute;top:42%;left:50%;transform:translate(-50%,-50%) rotate(-8deg);z-index:3;opacity:0;
  width:clamp(118px,13vw,162px);aspect-ratio:3/4;border-radius:16px;overflow:hidden;
  background:linear-gradient(150deg,#ff7aa6,var(--magenta) 55%,#a8003a);
  box-shadow:0 30px 60px -18px rgba(120,0,40,.6), inset 0 1px 0 rgba(255,255,255,.6);
  display:flex;align-items:flex-end;justify-content:center;padding-bottom:12px}
.morph__film::after{content:"";position:absolute;inset:0;background:linear-gradient(115deg,transparent 38%,rgba(255,255,255,.55) 50%,transparent 62%);mix-blend-mode:screen}
.morph__film span{font-family:var(--font-display);font-weight:600;font-size:.8rem;color:#fff;position:relative;z-index:2}
.morph__dust{position:absolute;inset:0;z-index:4;pointer-events:none}
.morph__say{position:absolute;bottom:1.9rem;left:1.8rem;z-index:5;font-family:var(--font-display);font-weight:600;
  font-size:clamp(1.05rem,2vw,1.7rem);line-height:1.08;color:#fff}
.morph__say--new{opacity:0}
.morph__hint{position:absolute;bottom:1.9rem;right:1.8rem;z-index:5;font-size:.66rem;letter-spacing:.18em;text-transform:uppercase;font-weight:700;color:rgba(255,255,255,.6)}

/* ============================================================
   ONSET-OF-ACTION GRAPH (scroll-drawn): tablet ~40min vs ODF seconds
   ============================================================ */
.graph{position:relative;width:100%;height:clamp(390px,58vh,540px);margin:6vh 0;border-radius:28px;overflow:hidden;
  display:flex;flex-direction:column;padding:1.8rem 2rem;
  background:radial-gradient(120% 100% at 18% 0%, #2a0e1d, #190912 75%);box-shadow:0 50px 90px -40px rgba(40,10,40,.5)}
.graph__head{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap}
.graph__title{font-family:var(--font-display);font-weight:600;color:#fff;font-size:1.15rem}
.graph__legend{display:flex;gap:1.3rem;font-size:.82rem}
.lg{display:flex;align-items:center;gap:.45rem;color:rgba(255,255,255,.7);font-weight:600}
.lg::before{content:"";width:16px;height:4px;border-radius:3px;background:currentColor}
.lg--odf{color:var(--magenta-2)}
.lg--tab{color:rgba(255,255,255,.45)}
.graph__svg{flex:1;width:100%;min-height:0;margin-top:.6rem}
.g-grid line{stroke:rgba(255,255,255,.16);stroke-width:1.5}
.g-grid .g-grid-faint{stroke:rgba(255,255,255,.06)}
.g-ticks text{fill:rgba(255,255,255,.45);font-size:18px;font-family:var(--font-body);text-anchor:middle}
.g-axis-y{fill:rgba(255,255,255,.45);font-size:18px;font-family:var(--font-body)}
.g-line{fill:none;stroke-width:5;stroke-linecap:round;stroke-linejoin:round}
.g-line--tab{stroke:rgba(255,255,255,.5)}
.g-line--odf{stroke:var(--magenta);filter:drop-shadow(0 0 10px rgba(232,0,76,.65))}
.g-mark{opacity:0}
.g-mark-line{stroke:rgba(255,255,255,.32);stroke-width:1.5;stroke-dasharray:4 6}
.g-dot{stroke:#190912;stroke-width:2}
.g-dot--odf{fill:var(--magenta)}
.g-dot--tab{fill:#fff}
.g-mark-lbl{fill:rgba(255,255,255,.82);font-size:18px;font-weight:700;text-anchor:middle;font-family:var(--font-body)}
.g-mark-lbl--odf{fill:#ff5e92;text-anchor:start}
.g-play{stroke:rgba(255,255,255,.5);stroke-width:1.5;stroke-dasharray:3 5}

/* ============================================================
   RACE — scroll-driven journey: tablet (~40 min) vs film (seconds)
   ============================================================ */
.race{position:relative;width:100%;border-radius:28px;overflow:hidden;margin:6vh 0;
  padding:clamp(2rem,4vw,3.2rem) clamp(2rem,5vw,4rem);
  background:radial-gradient(120% 100% at 18% 0%, #2a0e1d, #190912 75%);box-shadow:0 50px 90px -40px rgba(40,10,40,.5);
  display:flex;flex-direction:column;gap:clamp(3rem,7vw,5rem)}
.lane{position:relative}
.lane__top{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:2.6rem}
.lane__name{font-family:var(--font-display);font-weight:600;color:#fff;font-size:clamp(1.1rem,1.6vw,1.4rem)}
.lane__time{font-family:var(--font-display);font-weight:700;font-size:clamp(1.6rem,3vw,2.6rem);color:rgba(255,255,255,.5)}
.lane--odf .lane__time{color:var(--magenta-2)}
.lane__track{position:relative;height:56px;margin:0 14px}
.lane__rail{position:absolute;left:0;right:0;top:14px;height:3px;border-radius:3px;background:rgba(255,255,255,.14)}
.lane__fill{position:absolute;left:0;top:14px;height:3px;width:0;border-radius:3px;background:rgba(255,255,255,.5)}
.lane__fill--odf{background:var(--magenta);box-shadow:0 0 12px rgba(232,0,76,.6)}
.node{position:absolute;top:14px;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center}
.node i{width:13px;height:13px;border-radius:50%;background:#241019;border:2px solid rgba(255,255,255,.32);transform:translateY(-50%);transition:background .3s,border-color .3s,box-shadow .3s}
.node b{position:absolute;top:16px;white-space:nowrap;font-size:.74rem;font-weight:600;color:rgba(255,255,255,.5);transition:color .3s}
.node.is-on i{background:#fff;border-color:#fff}
.node.is-on b{color:rgba(255,255,255,.88)}
.node--loss.is-on i{background:#ff6b6b;border-color:#ff6b6b}
.lane--odf .node.is-on i{background:var(--magenta);border-color:var(--magenta);box-shadow:0 0 10px rgba(232,0,76,.7)}
.lane--odf .node.is-on b{color:#fff}
.tok{position:absolute;top:14px;left:0;transform:translate(-50%,-50%);z-index:3}
.tok--pill{width:28px;height:28px;border-radius:50%;background:radial-gradient(circle at 36% 30%,#f4f2f5,#cdc8d2 60%,#a097ab);box-shadow:0 8px 20px -6px rgba(0,0,0,.6)}
.tok--pill::after{content:"";position:absolute;top:50%;left:18%;right:18%;height:2px;background:rgba(80,74,92,.5);transform:translateY(-50%)}
.tok--film{width:24px;height:30px;border-radius:6px;background:linear-gradient(150deg,#ff7aa6,var(--magenta) 55%,#a8003a);box-shadow:0 0 16px rgba(232,0,76,.7), inset 0 1px 0 rgba(255,255,255,.5)}
.lane__note{margin-top:2.8rem;font-size:.92rem;color:rgba(255,255,255,.55);line-height:1.5;max-width:540px}
@media (max-width:560px){ .node b{font-size:.6rem} .lane__track{margin:0 8px} }

/* ---- RACE v2: icon badges + glossy film + potency flag ---- */
.lane__track{height:96px;margin:0 22px}
.lane__rail,.lane__fill{top:24px}
.node{top:24px}
.node__badge{width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  transform:translateY(-50%);background:rgba(255,255,255,.05);border:1.5px solid rgba(255,255,255,.18);
  color:rgba(255,255,255,.4);transition:background .35s,border-color .35s,color .35s,box-shadow .35s}
.node__badge svg{width:21px;height:21px}
.node.is-on .node__badge{background:#fff;border-color:#fff;color:#241019}
.node--loss.is-on .node__badge{background:#ff6b6b;border-color:#ff6b6b;color:#3a0c0c}
.lane--odf .node.is-on .node__badge{background:var(--magenta);border-color:var(--magenta);color:#fff;box-shadow:0 0 16px rgba(232,0,76,.65)}
.node__lbl{position:absolute;top:34px;white-space:nowrap;font-size:.74rem;font-weight:600;color:rgba(255,255,255,.5);transition:color .3s}
.node.is-on .node__lbl{color:rgba(255,255,255,.9)}
.lane--odf .node.is-on .node__lbl{color:#fff}
.node__flag{position:absolute;top:-22px;left:50%;transform:translateX(-50%);white-space:nowrap;font-size:.62rem;font-weight:800;
  letter-spacing:.06em;text-transform:uppercase;color:#ff6b6b;opacity:0;transition:opacity .35s}
.node--loss.is-on .node__flag{opacity:1}
.tok{top:24px}
.tok--pill{width:30px;height:30px}
.tok--film{width:26px;height:33px;border-radius:7px;overflow:hidden}
.tok--film .tok__sheen{position:absolute;inset:0;background:linear-gradient(115deg,transparent 38%,rgba(255,255,255,.65) 50%,transparent 62%);mix-blend-mode:screen}
@media (max-width:600px){ .node__lbl{font-size:.58rem} .node__badge{width:34px;height:34px} .node__badge svg{width:17px;height:17px} }

/* ---- RACE v3: film dissolve particles + liveliness ---- */
.lane__track{overflow:visible}
.node{z-index:1}
.lane__dust{position:absolute;inset:0;z-index:2;pointer-events:none;overflow:visible}
.tok{z-index:3}
/* film badge pulses while active */
@keyframes filmPulse{0%,100%{box-shadow:0 0 14px rgba(232,0,76,.5)}50%{box-shadow:0 0 24px rgba(232,0,76,.95)}}
.lane--odf .node.is-on .node__badge{animation:filmPulse 1.9s ease-in-out infinite}
/* shimmer travelling along the film fill */
.lane__fill--odf{position:absolute;overflow:hidden}
.lane__fill--odf::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.55),transparent);background-size:45% 100%;background-repeat:no-repeat;animation:flowShimmer 1.7s linear infinite}
@keyframes flowShimmer{0%{background-position:-50% 0}100%{background-position:160% 0}}
/* the slow tablet trudges with a faint bob */
@keyframes pillBob{0%,100%{margin-top:0}50%{margin-top:-2px}}
.tok--pill{animation:pillBob 1.3s ease-in-out infinite}

/* compact Fast/Flavourful/Functional row inside the box section copy */
.fff-row{display:flex;flex-wrap:wrap;gap:1rem 1.4rem;margin:1.7rem 0 .4rem}
.fff-row span{flex:1;min-width:128px;display:flex;flex-direction:column;gap:.25rem;font-size:.82rem;color:rgba(255,255,255,.6);line-height:1.35}
.fff-row b{font-family:var(--font-display);font-weight:600;font-size:1.2rem;color:var(--yellow)}
/* big science stat in the (text) science section */
.sci-stat{display:flex;align-items:baseline;gap:1.1rem;margin:1.9rem 0}
.sci-stat b{font-family:var(--font-display);font-weight:700;font-size:clamp(3rem,7vw,6rem);line-height:.82;color:var(--magenta-2)}
.sci-stat span{font-size:.98rem;color:rgba(255,255,255,.78);line-height:1.4}

/* science section: text (left) + onset graph (right) */
.science-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,5rem);align-items:center;max-width:var(--maxw);margin:0 auto}
.science-graph .graph{height:clamp(330px,46vh,460px);margin:0}
@media (max-width:900px){ .science-grid{grid-template-columns:1fr;gap:3rem} }

/* science section fills the viewport so the pin has no gap */
#science{min-height:100vh;display:flex;align-items:center}
#science .wrap{width:100%}

/* video in the "What is ODFinity" section (left) */
.vidwrap{position:relative;width:48%;max-width:540px;aspect-ratio:16/9;border-radius:22px;overflow:hidden;
  box-shadow:0 40px 80px -30px rgba(40,10,40,.55), inset 0 0 0 1px rgba(255,255,255,.06);background:#1a0a12}
.vid{width:100%;height:100%;object-fit:cover;display:block}
@media (max-width:900px){ .vidwrap{width:100%;max-width:none} }

/* ============================================================
   SECTION-TO-SECTION TRANSITIONS — rounded panels overlapping the one above
   (so the rounded corners reveal the previous section's colour, not the body)
   ============================================================ */
.two, .sec, .partner, .footer{
  position:relative;
  --seam:clamp(26px,3.4vw,46px);
  border-top-left-radius:var(--seam);
  border-top-right-radius:var(--seam);
  margin-top:calc(-1 * var(--seam));
  box-shadow:0 -20px 45px -26px rgba(15,4,10,.4);
}
.sec{padding-top:max(15vh, calc(var(--seam) + 9vh))}

/* these sections use flat (square) top corners instead of the rounded curve */
#science, #why, #range, #shilpa, #insights, #partner{
  border-top-left-radius:0;
  border-top-right-radius:0;
}

/* science section v3: copy (left) + tablet-vs-film journey (right), compacted to fit the column */
.science-grid{grid-template-columns:0.82fr 1.18fr;gap:clamp(2rem,4vw,3.6rem)}
.science-copy{max-width:46ch}
/* sticky pin: the section is taller than the viewport; the inner sticks to the top
   while you scroll through it (driving the comparison), then releases and scrolls away */
#science{position:relative;height:215vh;min-height:auto;display:block;padding-top:0;padding-bottom:0}
.science-sticky{position:sticky;top:0;height:100vh;display:flex;align-items:center}
.science-sticky .wrap{width:100%}
.race--sci{margin:0;padding:clamp(1.5rem,2.4vw,2.4rem) clamp(1.3rem,1.9vw,2.1rem);gap:clamp(2.1rem,3.6vw,3rem)}
.race--sci .lane__top{margin-bottom:2.1rem}
.race--sci .lane__name{font-size:clamp(.92rem,1.05vw,1.1rem)}
.race--sci .lane__time{font-size:clamp(1.35rem,2vw,1.95rem)}
.race--sci .lane__track{height:74px;margin:0 14px}
.race--sci .node__badge{width:34px;height:34px}
.race--sci .node__badge svg{width:17px;height:17px}
.race--sci .node__lbl{font-size:.62rem;top:30px}
.race--sci .node__flag{font-size:.54rem;top:-34px;padding:.2em .5em;border-radius:999px;
  background:rgba(58,12,12,.92);border:1px solid rgba(255,107,107,.45);line-height:1;z-index:4}
.race--sci .lane__note{margin-top:1.9rem;font-size:.82rem;max-width:none}
.race--sci .tok--pill{width:24px;height:24px}
.race--sci .tok--film{width:21px;height:27px}
@media (max-width:900px){ .science-grid{grid-template-columns:1fr} .race--sci{max-width:640px} }

/* ---- science v4: clear outcome storytelling (film → green ✓, tablet → amber "slow") ---- */
.race__cap{font-size:.72rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  color:rgba(255,255,255,.42);margin:-.4rem 0 1.6rem}
.lane__top-right{display:inline-flex;align-items:center;gap:clamp(.6rem,1vw,1rem)}
/* film: green "Absorbed" badge that pops in the instant it dissolves */
.lane__done{display:inline-flex;align-items:center;gap:.35em;font-family:var(--font-display);font-weight:700;
  font-size:clamp(.92rem,1.2vw,1.18rem);color:#2fd986;white-space:nowrap;opacity:0;
  padding:.28em .7em;border-radius:999px;background:rgba(47,217,134,.13);border:1px solid rgba(47,217,134,.4)}
.lane__done svg{width:1.05em;height:1.05em}
/* tablet: amber "still dissolving" tag while it slowly crawls */
.lane__slow{display:inline-flex;align-items:center;gap:.35em;font-size:.72rem;font-weight:700;
  letter-spacing:.05em;text-transform:uppercase;color:#ffb454;white-space:nowrap;opacity:0;
  padding:.3em .65em;border-radius:999px;background:rgba(255,180,84,.1);border:1px solid rgba(255,180,84,.32)}
.lane__slow svg{width:1.05em;height:1.05em}
/* film bloodstream node flips drop → green check when absorbed */
.node--end .node__badge{position:relative}
.node--end .ic{position:absolute;transition:opacity .3s ease,transform .3s ease}
.node--end .ic-check{opacity:0;transform:scale(.4)}
.race--sci .node--end .ic{width:17px;height:17px}
.node--end.is-done .node__badge{background:#2fd986 !important;border-color:#2fd986 !important;
  color:#06371f !important;box-shadow:0 0 20px rgba(47,217,134,.75) !important;animation:none !important}
.node--end.is-done .ic-main{opacity:0;transform:scale(.4)}
.node--end.is-done .ic-check{opacity:1;transform:scale(1)}
.node--end.is-done .node__lbl{color:#2fd986 !important}
