/* =========================================================
   NANOGROW™ — MonoSkin Palette · Single-pager
   Palette tokens (NO purples / yellows / greens):
     #091F5B Clinical Midnight  · primary
     #344EAD Peptide Blue       · secondary
     #B0D6F9 Hyaluronic Haze    · accent
     #F9F2E8 Epidermal Neutral  · bg
     #F9F9F9 Sterile White      · page
     #E8DFCE Barrier Beige      · panel
     #EFEFEF Microcell Mist     · tertiary
     #1E1E2E text
   ========================================================= */

:root{
  --c-midnight:#091F5B;
  --c-peptide:#344EAD;
  --c-haze:#B0D6F9;
  --c-epidermal:#F9F2E8;
  --c-white:#F9F9F9;
  --c-beige:#E8DFCE;
  --c-mist:#EFEFEF;
  --c-text:#1E1E2E;
  --c-text-2:#3a3a52;
  --c-border:#091F5B22;
  --shadow-deep:0 30px 60px -25px #091F5B40, 0 12px 24px -10px #091F5B22;
  --shadow-soft:0 6px 18px -6px #091F5B20;
  --r-xs:8px; --r-sm:12px; --r-md:18px; --r-lg:24px; --r-xl:32px; --r-pill:999px;
  --easing:cubic-bezier(.2,.7,.2,1);
  --grid:1200px;
  --gutter:clamp(16px,3vw,28px);
}

*,*::before,*::after{box-sizing:border-box;min-width:0}
html,body{margin:0;padding:0;max-width:100vw;overflow-x:clip}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;text-size-adjust:100%}
body{
  font-family:"Manrope",system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;
  color:var(--c-text);
  background:var(--c-white);
  font-size:16px;
  line-height:1.55;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img,svg,video{display:block;max-width:100%;height:auto}
img{user-select:none;-webkit-user-drag:none}
a{color:var(--c-peptide);text-decoration:none;transition:color .2s var(--easing)}
a:hover{color:var(--c-midnight)}
button{font:inherit;color:inherit;border:0;background:transparent;cursor:pointer}
:focus-visible{outline:3px solid var(--c-peptide);outline-offset:3px;border-radius:6px}

h1,h2,h3,h4{font-family:"Funnel Display","Manrope",system-ui,sans-serif;font-weight:700;letter-spacing:-0.02em;color:var(--c-midnight);margin:0 0 .4em}
h1{font-size:clamp(2.4rem,5.6vw,5rem);line-height:.98;letter-spacing:-0.035em}
h2{font-size:clamp(1.8rem,3.6vw,3.1rem);line-height:1.02}
h3{font-size:clamp(1.2rem,2vw,1.6rem)}
.mono{font-family:"Geist Mono",ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;letter-spacing:.02em}

.container{max-width:var(--grid);margin:0 auto;padding-inline:var(--gutter)}
.eyebrow{font-family:"Geist Mono",monospace;font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;color:var(--c-peptide);display:inline-flex;align-items:center;gap:.55rem}
.eyebrow::before{content:"";width:24px;height:1.5px;background:var(--c-peptide);display:inline-block}
.section{padding-block:clamp(64px,9vw,128px);position:relative}

/* =================== TOP NAV =================== */
.nav{position:fixed;inset:0 0 auto 0;z-index:50;backdrop-filter:saturate(160%) blur(10px);-webkit-backdrop-filter:saturate(160%) blur(10px);background:rgba(249,249,249,.82);border-bottom:1px solid var(--c-border);transition:transform .35s var(--easing);width:100%}
.nav.hidden{transform:translateY(-100%)}
.nav .inner{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:14px var(--gutter);max-width:var(--grid);margin:0 auto;width:100%}
.brand{display:flex;align-items:center;gap:10px;font-weight:700;color:var(--c-midnight);font-family:"Funnel Display",sans-serif;font-size:1.05rem;min-width:0;flex:0 1 auto;white-space:nowrap}
.brand-dot{flex:0 0 18px;width:18px;height:18px;border-radius:50%;background:radial-gradient(circle at 30% 30%,var(--c-haze),var(--c-peptide) 60%,var(--c-midnight));box-shadow:0 0 0 4px #B0D6F933,inset 0 0 6px #ffffff66;animation:wobble 5s ease-in-out infinite}
.nav-links{display:flex;gap:24px;font-size:.92rem;color:var(--c-text-2);flex:1 1 auto;justify-content:center}
.nav-links a{color:inherit}
.nav-cta{font-family:"Funnel Display",sans-serif;font-weight:700;background:var(--c-midnight);color:var(--c-white);padding:10px 18px;border-radius:var(--r-pill);font-size:.88rem;transition:transform .25s var(--easing),background .2s;flex:0 0 auto;white-space:nowrap}
.nav-cta:hover{background:var(--c-peptide);color:var(--c-white);transform:translateY(-1px) scale(1.02)}
@media (max-width:760px){
  .nav-links{display:none}
  .nav .inner{padding:11px 14px}
  .nav-cta{padding:9px 14px;font-size:.82rem}
  .nav-cta .navprice{display:none}
  .brand{font-size:1rem}
}

/* =================== HERO =================== */
.hero{
  position:relative;padding-top:calc(64px + clamp(64px,9vw,128px));padding-bottom:clamp(64px,9vw,128px);
  background:
    radial-gradient(900px 600px at 80% 8%, #B0D6F955 0%, transparent 60%),
    radial-gradient(700px 480px at 12% 100%, #B0D6F940 0%, transparent 65%),
    linear-gradient(180deg,var(--c-white) 0%,var(--c-epidermal) 100%);
  overflow:hidden;
  isolation:isolate;
}
.hero-grid{display:grid;grid-template-columns:1.05fr 1fr;gap:clamp(28px,5vw,72px);align-items:center}
@media (max-width:960px){.hero-grid{grid-template-columns:1fr}}
.hero h1 .accent{background:linear-gradient(90deg,var(--c-midnight) 0%,var(--c-peptide) 100%);-webkit-background-clip:text;background-clip:text;color:transparent}
.hero p.lead{font-size:clamp(1.05rem,1.5vw,1.25rem);color:var(--c-text-2);max-width:560px;margin:1.2rem 0 1.6rem}
.hero-claims{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:1.6rem}
.chip{display:inline-flex;align-items:center;gap:6px;background:#fff;border:1px solid var(--c-border);color:var(--c-midnight);padding:6px 12px;border-radius:var(--r-pill);font-size:.78rem;font-weight:600}
.chip::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--c-peptide)}
.cta-row{display:flex;flex-wrap:wrap;gap:12px;align-items:center}
.btn{display:inline-flex;align-items:center;gap:10px;font-family:"Funnel Display",sans-serif;font-weight:700;padding:16px 22px;border-radius:var(--r-pill);font-size:1rem;transition:transform .25s var(--easing),box-shadow .25s var(--easing),background .2s,color .2s;position:relative;overflow:hidden;will-change:transform}
.btn-primary{background:var(--c-midnight);color:var(--c-white);box-shadow:0 14px 32px -12px #091F5B66}
.btn-primary:hover{background:var(--c-peptide);transform:translateY(-2px) scale(1.02);box-shadow:0 18px 36px -10px #091F5B66;color:#fff}
.btn-primary::after{content:"";position:absolute;inset:0;background:linear-gradient(120deg,transparent 0%,#ffffff35 50%,transparent 100%);transform:translateX(-100%);transition:transform .9s var(--easing)}
.btn-primary:hover::after{transform:translateX(100%)}
.btn-ghost{background:transparent;color:var(--c-midnight);border:1.5px solid var(--c-midnight);padding:14px 20px}
.btn-ghost:hover{background:var(--c-midnight);color:var(--c-white);transform:translateY(-2px)}
.btn-tiny{padding:8px 14px;font-size:.85rem;border-radius:var(--r-pill);background:#fff;color:var(--c-midnight);border:1px solid var(--c-border)}
.btn .price{font-family:"Geist Mono",monospace;font-weight:500;font-size:.85rem;opacity:.85;padding-left:8px;border-left:1px solid #ffffff44;margin-left:6px}
.btn-ghost .price{border-left-color:#091F5B33;color:var(--c-text-2)}

.assure{display:flex;gap:18px;color:var(--c-text-2);font-size:.85rem;margin-top:1.1rem;flex-wrap:wrap}
.assure span{display:inline-flex;align-items:center;gap:6px}
.assure span::before{content:"✓";font-weight:700;color:var(--c-peptide)}

/* HERO 3D TUBE */
.hero-tube{
  position:relative;height:clamp(380px,55vw,600px);display:grid;place-items:center;perspective:1400px;max-width:100%;overflow:hidden;
}
.tube-stage{
  position:relative;width:min(78%,420px);aspect-ratio:3/4;
  transform-style:preserve-3d;
  animation:cylinder 14s linear infinite, sky-drop 1.2s var(--easing) both;
  cursor:grab;touch-action:none;
}
.tube-stage:active{cursor:grabbing}
.tube-face{position:absolute;inset:0;border-radius:var(--r-xl);background:#fff center/cover no-repeat;box-shadow:var(--shadow-deep);overflow:hidden;backface-visibility:hidden;-webkit-backface-visibility:hidden}
.tube-face.front{background-image:url('/img/p1')}
/* no back face — never show a mirrored product image */
.tube-glow{position:absolute;inset:-10%;border-radius:50%;background:radial-gradient(closest-side,#B0D6F966,transparent 70%);filter:blur(20px);z-index:-1;animation:wobble 6s ease-in-out infinite}

/* hover loupe */
.loupe{position:absolute;width:180px;height:180px;border-radius:50%;border:2px solid #fff;box-shadow:0 12px 28px -8px #091F5B66,inset 0 0 0 1px #091F5B22;background:#fff center/520% 520% no-repeat;pointer-events:none;opacity:0;transition:opacity .2s var(--easing);z-index:5}
.tube-stage:hover + .loupe{opacity:1}

/* =================== TICKER =================== */
.ticker{background:var(--c-midnight);color:var(--c-white);overflow:hidden;border-block:1px solid #091F5Baa;padding:14px 0;position:relative;z-index:2}
.ticker-track{display:flex;gap:48px;white-space:nowrap;animation:ticker-roll 32s linear infinite;font-family:"Funnel Display",sans-serif;font-weight:600;font-size:1rem;letter-spacing:.04em}
.ticker-track span{display:inline-flex;align-items:center;gap:12px;opacity:.92}
.ticker-track span::after{content:"●";color:var(--c-haze);font-size:.55rem;margin-left:42px}

/* =================== PAIN POINTS · Z-AXIS =================== */
.pain{background:var(--c-epidermal);position:relative}
.pain-stage{position:relative;height:260vh}
.pain-sticky{position:sticky;top:10vh;height:80vh;display:grid;place-items:center;perspective:1400px;perspective-origin:50% 40%}
.pain-card{position:absolute;width:min(78%,560px);background:#fff;border-radius:var(--r-xl);padding:36px 32px;box-shadow:var(--shadow-deep);border:1px solid var(--c-border);transform-style:preserve-3d;will-change:transform,opacity}
.pain-card h3{font-size:clamp(1.4rem,2.4vw,1.9rem)}
.pain-card p{color:var(--c-text-2);font-size:1.02rem;margin:0}
.pain-card .num{font-family:"Geist Mono",monospace;color:var(--c-peptide);font-size:.78rem;letter-spacing:.22em;text-transform:uppercase}
.pain-card .num::before{content:"·  "}
.pain-card.acc-rule{border-left:3px solid var(--c-peptide)}

/* =================== ACNE / VISIBLE-PAIN PORTRAIT =================== */
.portrait{background:var(--c-white);position:relative}
.portrait-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:clamp(28px,4vw,64px);align-items:center}
@media (max-width:880px){.portrait-grid{grid-template-columns:1fr}}
.portrait-figure{position:relative;border-radius:var(--r-xl);overflow:hidden;background:var(--c-beige);box-shadow:var(--shadow-deep);aspect-ratio:4/5}
.portrait-figure img{width:100%;height:100%;object-fit:cover;object-position:center top}
.portrait-figure::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 60%,#091F5Bd9 100%);
  pointer-events:none;
}
.portrait-caption{position:absolute;left:24px;right:24px;bottom:18px;color:#fff;z-index:2;display:flex;justify-content:space-between;align-items:flex-end;gap:12px}
.portrait-caption .tag{font-family:"Geist Mono",monospace;font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;opacity:.85}
.portrait-caption h4{color:#fff;margin:.2rem 0 0;font-size:1.05rem}
.portrait-side .eyebrow{margin-bottom:14px}
.portrait-side ul{list-style:none;padding:0;margin:1rem 0 0;display:flex;flex-direction:column;gap:10px}
.portrait-side ul li{display:flex;gap:12px;align-items:flex-start;color:var(--c-text-2);font-size:.98rem}
.portrait-side ul li::before{content:"";flex:0 0 8px;width:8px;height:8px;border-radius:50%;background:var(--c-peptide);margin-top:9px;box-shadow:0 0 0 4px #B0D6F955}

/* =================== UNDER THE LENS (scroll-driven zoom) =================== */
.lens{background:var(--c-mist);position:relative}
.lens-stage{position:relative;height:240vh}
.lens-sticky{position:sticky;top:0;height:100vh;display:grid;place-items:center;overflow:hidden;background:radial-gradient(circle at 50% 50%,var(--c-haze) 0%,var(--c-mist) 70%)}
.lens-img-wrap{position:relative;width:min(560px,80vw);aspect-ratio:1;border-radius:50%;overflow:hidden;box-shadow:0 30px 60px -20px #091F5B66,inset 0 0 0 4px #fff,inset 0 0 0 6px #091F5B22}
.lens-img{width:100%;height:100%;object-fit:cover;transform:scale(1);transform-origin:50% 50%;transition:transform .15s linear}
.lens-label{position:absolute;left:24px;bottom:24px;color:var(--c-midnight);font-family:"Geist Mono",monospace;font-size:.82rem;letter-spacing:.18em;text-transform:uppercase;background:#ffffffcc;padding:8px 12px;border-radius:var(--r-pill);backdrop-filter:blur(6px)}

/* =================== 180° BEFORE/AFTER HEAD CARD =================== */
.beforeafter{background:var(--c-epidermal);position:relative;overflow:hidden}
.ba-grid{display:grid;grid-template-columns:1fr 1.05fr;gap:clamp(28px,5vw,64px);align-items:center}
@media (max-width:920px){.ba-grid{grid-template-columns:1fr}}
.ba-stage{position:relative;height:clamp(380px,52vw,520px);display:grid;place-items:center;perspective:1600px}
.ba-card{
  position:relative;width:min(80%,420px);aspect-ratio:4/5;border-radius:var(--r-xl);
  transform-style:preserve-3d;
  transition:transform .9s var(--easing);
  box-shadow:var(--shadow-deep);
}
.ba-face{position:absolute;inset:0;border-radius:var(--r-xl);overflow:hidden;backface-visibility:hidden;-webkit-backface-visibility:hidden;background:#fff center/cover no-repeat;box-shadow:inset 0 0 0 1px #ffffff;}
.ba-face.before{background-image:url('/img/p2');background-position:center}
/* after face is pre-rotated 180° so when the card flips 180° the image renders upright (not mirrored) */
.ba-face.after {background-image:url('/img/p3');background-position:center;transform:rotateY(180deg)}
.ba-face .badge{position:absolute;top:14px;left:14px;font-family:"Geist Mono",monospace;font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;background:#091F5Bd9;color:#fff;padding:6px 10px;border-radius:var(--r-pill)}
.ba-face.after .badge{background:var(--c-peptide)}
.ba-range{display:flex;align-items:center;gap:12px;margin-top:18px;max-width:380px}
.ba-range input[type=range]{flex:1;-webkit-appearance:none;height:6px;border-radius:99px;background:linear-gradient(90deg,var(--c-midnight) 0%,var(--c-peptide) 100%);outline:0}
.ba-range input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:22px;height:22px;border-radius:50%;background:#fff;border:3px solid var(--c-midnight);box-shadow:0 4px 12px -4px #091F5B66;cursor:grab}
.ba-range input[type=range]::-moz-range-thumb{width:22px;height:22px;border-radius:50%;background:#fff;border:3px solid var(--c-midnight)}
.ba-range .legend{font-family:"Geist Mono",monospace;font-size:.78rem;color:var(--c-midnight);letter-spacing:.12em}
.ba-side h2 .accent{color:var(--c-peptide)}
.ba-side p{color:var(--c-text-2);font-size:1.05rem}
.ba-metric{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:1.6rem}
.ba-metric div{background:#fff;border:1px solid var(--c-border);border-radius:var(--r-md);padding:16px;text-align:center}
.ba-metric .n{display:block;font-family:"Funnel Display",sans-serif;font-weight:800;font-size:1.7rem;color:var(--c-midnight)}
.ba-metric .l{display:block;font-family:"Geist Mono",monospace;font-size:.7rem;letter-spacing:.18em;color:var(--c-peptide);text-transform:uppercase;margin-top:4px}

/* =================== INGREDIENTS PILLARS · Waterfall =================== */
.pillars{background:var(--c-white)}
.pillars-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px;margin-top:2rem}
@media (max-width:880px){.pillars-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:520px){.pillars-grid{grid-template-columns:1fr}}
.pillar{background:linear-gradient(180deg,#fff 0%,var(--c-epidermal) 100%);border:1px solid var(--c-border);border-radius:var(--r-lg);padding:24px;display:flex;flex-direction:column;gap:10px;transition:transform .35s var(--easing),box-shadow .35s;will-change:transform}
.pillar:hover{transform:translateY(-4px);box-shadow:var(--shadow-soft)}
.pillar .glyph{width:46px;height:46px;display:grid;place-items:center;border-radius:14px;background:var(--c-haze);color:var(--c-midnight)}
.pillar .glyph svg{width:26px;height:26px}
.pillar h3{margin:0;font-size:1.15rem}
.pillar p{color:var(--c-text-2);margin:0;font-size:.95rem}
.pillar .mono{font-size:.72rem;color:var(--c-peptide);letter-spacing:.16em;text-transform:uppercase}

/* =================== SPHERICAL ORBIT (Cetosomes) =================== */
.orbit{background:var(--c-epidermal);position:relative;overflow:hidden}
.orbit-grid{display:grid;grid-template-columns:1fr 1fr;align-items:center;gap:48px}
@media (max-width:920px){.orbit-grid{grid-template-columns:1fr}}
.orbit-stage{position:relative;aspect-ratio:1;max-width:520px;margin-inline:auto;width:100%}
.orbit-core{position:absolute;inset:30%;border-radius:50%;background:radial-gradient(circle at 30% 30%,#fff 0%,var(--c-haze) 40%,var(--c-peptide) 80%,var(--c-midnight) 100%);box-shadow:0 30px 60px -20px #091F5B66,inset 0 0 0 4px #ffffff;display:grid;place-items:center;font-family:"Funnel Display",sans-serif;font-weight:800;color:#fff;font-size:1rem;letter-spacing:.06em;text-align:center;padding:8px}
.orbit-ring{position:absolute;inset:0;border-radius:50%;border:1.5px dashed #091F5B33;animation:spin 24s linear infinite}
.orbit-ring.r2{inset:8%;animation-duration:32s;animation-direction:reverse;border-style:dotted;border-color:#091F5B22}
.orbit-ring.r3{inset:18%;animation-duration:42s;border-style:dashed;border-color:#091F5B55}
.orbit-bead{position:absolute;top:50%;left:50%;width:18px;height:18px;border-radius:50%;background:radial-gradient(circle at 30% 30%,#fff,var(--c-peptide) 70%);box-shadow:0 0 0 4px #B0D6F966,0 6px 12px -4px #091F5B66;transform-origin:0 0}
.orbit-label{position:absolute;font-family:"Geist Mono",monospace;font-size:.72rem;color:var(--c-midnight);letter-spacing:.14em;text-transform:uppercase;background:#ffffffcc;padding:4px 8px;border-radius:99px}

/* =================== PARALLAX BLOCK =================== */
.parallax{position:relative;min-height:80vh;display:grid;place-items:center;color:#fff;overflow:hidden;isolation:isolate}
.parallax::before{
  content:"";position:absolute;inset:-10% -2% -10% -2%;z-index:-2;
  background:url('/img/p7') center/cover no-repeat;
  transform:translate3d(0,var(--py,0),0) scale(1.08);
  will-change:transform;
}
.parallax::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,#091F5Bd9 0%,#091F5Bc4 100%);z-index:-1}
.parallax .container{text-align:center;max-width:840px}
.parallax h2{color:#fff}
.parallax p{font-size:1.1rem;opacity:.9}

/* =================== USAGE / RITUAL STEPS · Waterfall =================== */
.ritual{background:var(--c-white)}
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:2rem;counter-reset:step}
@media (max-width:880px){.steps{grid-template-columns:repeat(2,1fr)}}
@media (max-width:520px){.steps{grid-template-columns:1fr}}
.step{background:var(--c-epidermal);border:1px solid var(--c-border);border-radius:var(--r-lg);padding:22px;display:flex;flex-direction:column;gap:8px;position:relative}
.step::before{counter-increment:step;content:"0" counter(step);font-family:"Funnel Display",sans-serif;font-weight:800;font-size:2.6rem;color:var(--c-peptide);opacity:.15;position:absolute;right:14px;top:6px;letter-spacing:-.04em}
.step h4{font-size:1.05rem;margin:0;color:var(--c-midnight)}
.step p{color:var(--c-text-2);margin:0;font-size:.94rem}

/* =================== SAFETY BAND =================== */
.safety{background:var(--c-beige)}
.safety-row{display:grid;grid-template-columns:1.05fr 1fr;gap:32px;align-items:center}
@media (max-width:880px){.safety-row{grid-template-columns:1fr}}
.safety-row p{color:var(--c-text-2);font-size:1.02rem}
.safety-tag{display:inline-flex;gap:8px;align-items:center;background:#fff;color:var(--c-midnight);border:1px solid var(--c-border);padding:10px 14px;border-radius:99px;font-size:.85rem;font-weight:600;margin-right:8px;margin-bottom:8px}
.safety-tag::before{content:"✓";color:var(--c-peptide);font-weight:800}

/* =================== FAQ =================== */
.faq{background:var(--c-white)}
.faq-list{margin-top:1.6rem;border-top:1px solid var(--c-border)}
.faq-item{border-bottom:1px solid var(--c-border)}
.faq-q{width:100%;text-align:left;padding:22px 0;display:flex;justify-content:space-between;align-items:center;gap:18px;font-family:"Funnel Display",sans-serif;font-weight:700;font-size:1.05rem;color:var(--c-midnight)}
.faq-q .ico{flex:0 0 28px;width:28px;height:28px;border-radius:50%;border:1.5px solid var(--c-midnight);display:grid;place-items:center;font-size:1rem;transition:transform .25s var(--easing),background .2s}
.faq-item.open .faq-q .ico{background:var(--c-midnight);color:#fff;transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .45s var(--easing);color:var(--c-text-2);font-size:.98rem;padding-right:48px}
.faq-item.open .faq-a{padding-bottom:18px}

/* =================== CTA BAND =================== */
.cta-band{background:linear-gradient(135deg,var(--c-midnight) 0%,var(--c-peptide) 100%);color:#fff;text-align:center;padding-block:clamp(64px,9vw,128px);position:relative;overflow:hidden}
.cta-band h2{color:#fff;font-size:clamp(2rem,4.4vw,3.4rem)}
.cta-band p{color:#ffffffd0;max-width:640px;margin:1rem auto 1.6rem}
.cta-band .btn-primary{background:#fff;color:var(--c-midnight)}
.cta-band .btn-primary:hover{background:var(--c-haze);color:var(--c-midnight)}
.cta-band .btn-ghost{border-color:#ffffff;color:#fff}
.cta-band .btn-ghost:hover{background:#fff;color:var(--c-midnight)}
.cta-band::before,.cta-band::after{content:"";position:absolute;border-radius:50%;background:radial-gradient(closest-side,#B0D6F940,transparent 70%);pointer-events:none}
.cta-band::before{width:520px;height:520px;top:-180px;left:-120px;animation:wobble 12s ease-in-out infinite}
.cta-band::after{width:680px;height:680px;bottom:-280px;right:-180px;animation:wobble 14s ease-in-out infinite reverse}

/* =================== FOOTER =================== */
.footer{background:var(--c-mist);color:var(--c-text-2);padding:48px 0 32px;font-size:.92rem}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:32px}
@media (max-width:880px){.footer-grid{grid-template-columns:1fr 1fr}}
@media (max-width:480px){.footer-grid{grid-template-columns:1fr}}
.footer h5{font-family:"Funnel Display",sans-serif;color:var(--c-midnight);margin:0 0 12px;font-size:.95rem}
.footer ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}
.footer ul a{color:var(--c-text-2)}
.footer ul a:hover{color:var(--c-midnight)}
.footer-bottom{border-top:1px solid var(--c-border);margin-top:32px;padding-top:18px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:8px;font-size:.82rem}

/* =================== LEAD MODAL =================== */
.modal{position:fixed;inset:0;background:#091F5Bcc;backdrop-filter:blur(8px);z-index:100;display:none;align-items:center;justify-content:center;padding:20px}
.modal.open{display:flex;animation:zip-in .4s var(--easing) both}
.modal-card{background:#fff;border-radius:var(--r-xl);max-width:480px;width:100%;padding:32px;box-shadow:var(--shadow-deep);position:relative}
.modal-card h3{font-size:1.6rem;margin-bottom:.2em}
.modal-card p.sub{color:var(--c-text-2);margin:0 0 1.2rem}
.modal-card .close{position:absolute;top:14px;right:14px;width:34px;height:34px;border-radius:50%;background:var(--c-mist);display:grid;place-items:center;font-weight:700;color:var(--c-midnight)}
.modal-card label{font-size:.78rem;color:var(--c-peptide);font-family:"Geist Mono",monospace;letter-spacing:.16em;text-transform:uppercase;display:block;margin-bottom:6px}
.modal-card input{width:100%;border:1.5px solid var(--c-border);border-radius:var(--r-md);padding:13px 14px;font-size:1rem;font-family:inherit;background:var(--c-white);color:var(--c-text);margin-bottom:14px;transition:border .2s}
.modal-card input:focus{border-color:var(--c-peptide);outline:none}
.modal-card .err{color:#9c1b1b;font-size:.84rem;min-height:1.2em;margin:-8px 0 8px}
.modal-card .ok{background:linear-gradient(135deg,var(--c-midnight),var(--c-peptide));color:#fff;padding:18px;border-radius:var(--r-md);font-family:"Geist Mono",monospace;letter-spacing:.16em;display:flex;justify-content:space-between;align-items:center}
.modal-card .ok strong{font-size:1.25rem;letter-spacing:.18em}
.modal-card form button[type=submit]{width:100%;background:var(--c-midnight);color:#fff;padding:15px;border-radius:var(--r-pill);font-family:"Funnel Display",sans-serif;font-weight:700;font-size:1rem;transition:background .2s,transform .25s var(--easing)}
.modal-card form button[type=submit]:hover{background:var(--c-peptide);transform:translateY(-1px)}

/* =================== CUSTOM CURSOR (FOLLICLE) =================== */
.cursor{position:fixed;top:0;left:0;width:54px;height:54px;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);transition:transform .12s linear,opacity .2s;mix-blend-mode:multiply}
.cursor svg{width:100%;height:100%;filter:drop-shadow(0 4px 6px #091F5B44)}
@media (pointer:coarse){.cursor{display:none}}
.cursor.hot{transform:translate(-50%,-50%) scale(1.25)}

/* =================== ANIMATIONS =================== */
@keyframes wobble{
  0%,100%{transform:translate(0,0) rotate(0)}
  25%{transform:translate(-3px,2px) rotate(-1.5deg)}
  50%{transform:translate(2px,-3px) rotate(1deg)}
  75%{transform:translate(-2px,1px) rotate(-.6deg)}
}
@keyframes spin{from{transform:rotate(0)}to{transform:rotate(360deg)}}
@keyframes cylinder{
  from{transform:rotateY(-12deg) rotateX(2deg)}
  50%{transform:rotateY(12deg) rotateX(-2deg)}
  to  {transform:rotateY(-12deg) rotateX(2deg)}
}
@keyframes sky-drop{
  0%{transform:translate3d(0,-120px,0) rotate(-6deg);opacity:0}
  60%{transform:translate3d(0,18px,0) rotate(2deg);opacity:1}
  80%{transform:translate3d(0,-8px,0) rotate(-1deg)}
  100%{transform:translate3d(0,0,0) rotate(0);opacity:1}
}
@keyframes zip-slide-r{from{transform:translate3d(-110%,0,0) skewX(-12deg);opacity:0}to{transform:translate3d(0,0,0) skewX(0);opacity:1}}
@keyframes zip-slide-l{from{transform:translate3d(110%,0,0) skewX(12deg);opacity:0}to{transform:translate3d(0,0,0) skewX(0);opacity:1}}
@keyframes rise-up{from{transform:translate3d(0,40px,0);opacity:0}to{transform:translate3d(0,0,0);opacity:1}}
@keyframes ticker-roll{from{transform:translate3d(0,0,0)}to{transform:translate3d(-50%,0,0)}}
@keyframes zip-in{from{transform:scale(.94);opacity:0}to{transform:scale(1);opacity:1}}

/* reveal-on-scroll base */
.reveal{opacity:0;transform:translate3d(0,30px,0);transition:opacity .8s var(--easing),transform .8s var(--easing)}
.reveal.in{opacity:1;transform:translate3d(0,0,0)}
.reveal[data-anim="zip-r"]{transform:translate3d(-80px,0,0) skewX(-8deg)}
.reveal[data-anim="zip-r"].in{transform:translate3d(0,0,0) skewX(0)}
.reveal[data-anim="zip-l"]{transform:translate3d(80px,0,0) skewX(8deg)}
.reveal[data-anim="zip-l"].in{transform:translate3d(0,0,0) skewX(0)}
.reveal[data-anim="drop"]{transform:translate3d(0,-60px,0)}
.reveal[data-anim="drop"].in{transform:translate3d(0,0,0)}
.reveal[data-anim="waterfall"]{transform:translate3d(0,40px,0)}
.reveal.in[data-anim="waterfall"]{animation:rise-up .9s var(--easing) both}
.waterfall > *{opacity:0;transform:translate3d(0,30px,0)}
.waterfall.in > *{animation:rise-up .8s var(--easing) both}
.waterfall.in > *:nth-child(1){animation-delay:0s}
.waterfall.in > *:nth-child(2){animation-delay:.08s}
.waterfall.in > *:nth-child(3){animation-delay:.16s}
.waterfall.in > *:nth-child(4){animation-delay:.24s}
.waterfall.in > *:nth-child(5){animation-delay:.32s}
.waterfall.in > *:nth-child(6){animation-delay:.4s}

/* hover wobble for CTAs */
.btn:hover{animation:wobble 0.6s ease-in-out}

/* reduced motion */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:0s !important;animation-iteration-count:1 !important;transition-duration:.01s !important;scroll-behavior:auto !important}
  .reveal{opacity:1;transform:none}
  .cursor{display:none}
}
