/* ============================================================
   raskl — design tokens
   ============================================================ */
:root{
  --cream:        #f1ebe0;
  --cream-hi:     #faf4ea;
  --peach-1:      #fce7c4;
  --peach-2:      #fad9b0;
  --ink:          #17130d;
  --ink-soft:     #6e6456;
  --muted:        #8a8273;
  --orange:       #f76424;
  --orange-logo:  #ffa43b;
  --line:         rgba(23,19,13,.14);
  --line-soft:    rgba(23,19,13,.08);

  --font: "Plus Jakarta Sans", system-ui, sans-serif;

  --text-kicker: clamp(.66rem,.6rem + .2vw,.78rem);
  --text-body:   clamp(1rem,.95rem + .35vw,1.22rem);
  --text-lead:   clamp(1.4rem,1.1rem + 1.4vw,2.4rem);
  --text-h2:     clamp(2.6rem,1.4rem + 5vw,6.6rem);
  --text-hero:   clamp(3.2rem,1rem + 11vw,11rem);

  --space:       clamp(5rem,3.5rem + 7vw,11rem);
  --gutter:      clamp(1.25rem,1rem + 3vw,5rem);
  --maxw:        1680px;

  --e-expo: cubic-bezier(.16,1,.3,1);
  --e-io:   cubic-bezier(.65,.05,.36,1);
  --d-fast: .35s;
  --d-norm: .7s;
}

/* ============================================================
   reset / base
   ============================================================ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%}
html.lenis,html.lenis body{height:auto}
.lenis.lenis-smooth{scroll-behavior:auto!important}
.lenis.lenis-stopped{overflow:hidden}

body{
  font-family:var(--font);
  font-weight:500;
  color:var(--ink);
  background:var(--cream);
  font-size:var(--text-body);
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  cursor:none;
}
@media (hover:none){ body{cursor:auto} }

img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
em{font-style:italic;font-weight:600}
::selection{background:var(--orange);color:var(--cream-hi)}

.kicker{
  font-size:var(--text-kicker);
  font-weight:700;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--ink-soft);
}
.kicker--accent{color:var(--orange)}
.accent{color:var(--orange)}

/* logo helper */
[class$="__logo"] use,[class$="__mark"] use,[class$="__brand"] use{fill:currentColor}

/* ============================================================
   grain + cursor
   ============================================================ */
.grain{
  position:fixed;inset:-50%;z-index:9000;pointer-events:none;
  opacity:.05;mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  animation:grain 6s steps(6) infinite;
}
@keyframes grain{
  0%{transform:translate(0,0)} 20%{transform:translate(-4%,3%)}
  40%{transform:translate(3%,-5%)} 60%{transform:translate(-2%,4%)}
  80%{transform:translate(5%,2%)} 100%{transform:translate(0,0)}
}
.cursor{
  position:fixed;top:0;left:0;z-index:9500;pointer-events:none;
  width:14px;height:14px;border-radius:50%;
  background:var(--orange);
  transform:translate(-50%,-50%);
  mix-blend-mode:normal;
  transition:width .3s var(--e-expo),height .3s var(--e-expo),background .3s;
  display:grid;place-items:center;
}
.cursor.is-hover{width:84px;height:84px;background:rgba(247,100,36,.16);backdrop-filter:blur(2px)}
.cursor.is-label{width:96px;height:96px;background:var(--orange)}
.cursor__label{
  font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  color:var(--cream-hi);opacity:0;transform:scale(.6);
  transition:opacity .25s,transform .25s var(--e-expo);white-space:nowrap;
}
.cursor.is-label .cursor__label{opacity:1;transform:scale(1)}
@media (hover:none){ .cursor,.grain{display:none} }

/* ============================================================
   preloader
   ============================================================ */
.loader{
  position:fixed;inset:0;z-index:9999;
  background:var(--cream);
  display:grid;place-items:center;
}
.loader__inner{display:flex;flex-direction:column;align-items:center;gap:26px}
.loader__logo{width:140px;height:45px;color:var(--ink);opacity:.12}
.loader__logo .anim{transition:none}
.loader__bar{width:200px;height:2px;background:var(--line);overflow:hidden;border-radius:2px}
.loader__fill{display:block;height:100%;width:0;background:var(--orange)}
.loader__count{font-weight:800;font-size:13px;letter-spacing:.1em;color:var(--ink-soft)}
.loader__unit{color:var(--orange)}
.loader__tag{
  position:absolute;bottom:7vh;left:50%;transform:translateX(-50%);
  font-size:11px;font-weight:700;letter-spacing:.4em;color:var(--ink-soft);
}

/* ============================================================
   nav
   ============================================================ */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:8000;
  display:flex;align-items:center;justify-content:space-between;
  padding:clamp(1rem,.8rem + 1vw,1.6rem) var(--gutter);
  mix-blend-mode:normal;
  transition:transform .5s var(--e-expo),background .4s,backdrop-filter .4s;
}
.nav.is-hidden{transform:translateY(-110%)}
.nav.is-stuck{
  background:rgba(241,235,224,.72);
  backdrop-filter:blur(14px) saturate(1.2);
  border-bottom:1px solid var(--line-soft);
}
.nav__logo{width:78px;height:25px;color:var(--ink);transition:color .3s}
.nav__brand:hover .nav__logo{color:var(--orange)}
.nav__links{display:flex;gap:clamp(1rem,.5rem + 1.4vw,2.4rem)}
.nav__links a{
  position:relative;font-size:.86rem;font-weight:600;color:var(--ink);
  padding:.2em 0;letter-spacing:.01em;
}
.nav__links a::after{
  content:"";position:absolute;left:0;bottom:-2px;width:100%;height:1.5px;
  background:var(--orange);transform:scaleX(0);transform-origin:right;
  transition:transform .45s var(--e-expo);
}
.nav__links a:hover::after{transform:scaleX(1);transform-origin:left}
@media (max-width:860px){ .nav__links{display:none} }

.btn{display:inline-flex;align-items:center;gap:.5em;font-weight:700;font-family:var(--font)}
.btn--pill{
  background:var(--ink);color:var(--cream-hi);
  padding:.7em 1.25em;border-radius:100px;font-size:.84rem;
  transition:background .35s,color .35s,transform .35s var(--e-expo);
}
.btn--pill:hover{background:var(--orange)}
.btn__arrow{width:17px;height:17px;transition:transform .35s var(--e-expo)}
.btn--pill:hover .btn__arrow{transform:translateX(4px)}

/* ============================================================
   section head + shared
   ============================================================ */
section{position:relative}
.section-head{
  display:flex;align-items:center;gap:1rem;
  padding:0 var(--gutter);margin-bottom:clamp(2rem,1rem + 3vw,4rem);
}
.section-head .index{
  font-weight:800;font-size:.8rem;color:var(--orange);
  border:1px solid var(--line);border-radius:100px;padding:.35em .7em;
}
.section-head--light .index{border-color:rgba(255,255,255,.25)}

.line{display:block;overflow:hidden}
.word{display:inline-block}

/* ============================================================
   HERO
   ============================================================ */
.hero{
  position:relative;min-height:100svh;overflow:hidden;
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:0 var(--gutter) clamp(2rem,1rem + 3vw,4rem);
}
.hero__bg{
  position:absolute;inset:0;z-index:-3;
  background:
    radial-gradient(95% 80% at 52% 4%, var(--peach-1) 0%, rgba(252,231,196,0) 50%),
    radial-gradient(90% 70% at 18% 100%, #f6e3cf 0%, rgba(246,227,207,0) 60%),
    linear-gradient(180deg,#fbeacb 0%, var(--cream) 60%);
}
.hero__canvas{position:absolute;inset:0;z-index:-1;pointer-events:none}
.hero__iv{
  position:absolute;z-index:-2;
  top:clamp(4.5rem,3rem + 4.5vw,7.5rem);
  right:clamp(6%,9vw,13%);left:auto;
  width:clamp(140px,15vw,212px);
  transform:none;
  /* one soft, natural drop-shadow grounds the bag without a hard outline */
  filter:drop-shadow(0 26px 40px rgba(74,42,10,.16))
         drop-shadow(0 6px 14px rgba(74,42,10,.10));
  will-change:transform;
}
/* very soft contrast lift directly behind the translucent top so it reads
   against the peach glow — kept low and tight so there is no visible halo */
.hero__iv::before{
  content:"";position:absolute;inset:-6% -10% -4%;z-index:-1;pointer-events:none;
  background:radial-gradient(72% 58% at 50% 30%, rgba(120,84,40,.12), rgba(120,84,40,0) 72%);
}
.hero__iv img{display:block;position:relative;width:100%;height:auto}
@media (max-width:900px){
  .hero__iv{top:auto;bottom:54%;right:auto;left:50%;
    width:clamp(120px,34vw,170px);transform:translateX(-50%)}
}

/* page-long IV tube + descending serum (placed/sized by JS) */
.iv-line{position:absolute;top:0;left:0;width:40px;height:0;z-index:-1;
  transform:translateX(-50%);pointer-events:none;opacity:0;transition:opacity .4s ease}
.iv-line.is-ready{opacity:1}
.iv-line__svg{position:absolute;inset:0;width:100%;height:100%;overflow:visible}
/* soft shadow wall + translucent glass body = a clear medical tube, not metal */
.iv-line__wall{stroke:rgba(70,52,28,.10);stroke-width:11;stroke-linecap:round;
  filter:drop-shadow(0 2px 3px rgba(60,40,10,.12))}
.iv-line__glass{stroke:rgba(255,255,255,.5);stroke-width:9;stroke-linecap:round}
/* serum fills the glass body (no travelling bead) */
.iv-line__serum{stroke:url(#ivSerumGrad);stroke-width:7;stroke-linecap:round;
  filter:drop-shadow(0 0 6px rgba(247,100,36,.4))}
@media (prefers-reduced-motion:reduce){ .iv-line{display:none} }
@media (max-width:900px){ .iv-line{display:none} }

.hero__meta{position:absolute;top:clamp(5.5rem,5rem + 3vw,8rem);display:flex;flex-direction:column;gap:.45em}
.hero__meta--l{left:var(--gutter)}
.kicker--dim{color:var(--ink-soft);opacity:.7}
@media (max-width:680px){ .hero__meta{display:none} }

.hero__head{
  position:relative;z-index:2;
  font-size:var(--text-hero);
  font-weight:800;line-height:.86;letter-spacing:-.03em;
  text-transform:none;
  margin-bottom:clamp(1rem,.5rem + 2vw,2rem);
  mix-blend-mode:multiply;
}
@media (min-width:901px){ .hero__head{max-width:min(64vw,56rem)} }
.hero__head .accent i{font-style:normal;color:var(--orange)}
.hero__head .word{will-change:transform}

.hero__sub{
  position:relative;z-index:2;max-width:46ch;
  font-size:var(--text-lead);font-weight:500;line-height:1.28;
  color:var(--ink);letter-spacing:-.01em;
}
@media (min-width:900px){ .hero__sub{font-size:clamp(1.4rem,.9rem + 1vw,1.85rem);max-width:40ch} }

.hero__cue{
  position:absolute;right:var(--gutter);bottom:clamp(2rem,1rem + 3vw,4rem);
  display:flex;flex-direction:column;align-items:center;gap:.7em;
  font-size:.72rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-soft);
}
.hero__cueline{width:1px;height:54px;background:var(--ink-soft);transform-origin:top;
  animation:cue 1.8s var(--e-io) infinite}
@keyframes cue{0%{transform:scaleY(0);opacity:0}40%{transform:scaleY(1);opacity:1}100%{transform:scaleY(1) translateY(54px);opacity:0}}
@media (max-width:1024px){ .hero__cue{display:none} }

/* ============================================================
   MARQUEE
   ============================================================ */
.marquee{
  position:relative;overflow:hidden;border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  padding:clamp(.7rem,.5rem + .6vw,1.1rem) 0;background:transparent;
}
.marquee::before{content:"";position:absolute;inset:0;background:var(--cream-hi);z-index:-2;pointer-events:none}
.marquee__track{display:flex;gap:0;white-space:nowrap;width:max-content;will-change:transform}
.marquee__track span{
  font-size:clamp(1.6rem,1rem + 3vw,3.4rem);font-weight:800;letter-spacing:-.02em;
  padding-right:.4em;text-transform:uppercase;color:var(--ink);
}
.marquee__track i{color:var(--orange);font-style:normal;padding:0 .15em}

/* ============================================================
   PROOF — why brands choose raskl
   ============================================================ */
.proof{
  position:relative;display:grid;grid-template-columns:repeat(4,1fr);gap:1px;
  background:transparent;border-bottom:1px solid var(--line);
}
.proof::before{content:"";position:absolute;inset:0;background:var(--line);z-index:-3;pointer-events:none}
.proof__item{
  position:relative;background:transparent;
  padding:clamp(1.9rem,1.4rem + 1.6vw,3rem) clamp(1.2rem,.9rem + 1vw,2rem);
  display:flex;flex-direction:column;gap:.85rem;
}
.proof__item::before{content:"";position:absolute;inset:0;background:var(--cream-hi);z-index:-2;pointer-events:none}
.proof__item b{
  display:flex;flex-direction:column;
  font-size:clamp(2.1rem,1.3rem + 2.6vw,3.5rem);font-weight:800;line-height:.9;letter-spacing:-.035em;color:var(--ink);
}
.proof__item b i{
  font-style:normal;font-size:.3em;font-weight:700;text-transform:uppercase;letter-spacing:.14em;
  color:var(--orange);margin-top:.7em;
}
.proof__item span{font-size:.92rem;line-height:1.4;color:var(--ink-soft);max-width:26ch}
@media (max-width:860px){ .proof{grid-template-columns:repeat(2,1fr)} }
@media (max-width:480px){ .proof{grid-template-columns:1fr} }

/* ============================================================
   DIAGNOSIS
   ============================================================ */
.diagnosis{padding:var(--space) 0}
.diagnosis__problem{
  padding:0 var(--gutter);margin-bottom:1.6rem;
  font-weight:700;text-transform:uppercase;letter-spacing:.1em;font-size:.84rem;color:var(--orange);
  display:flex;align-items:center;gap:.7em;
}
.diagnosis__problem .dot{width:9px;height:9px;border-radius:50%;background:var(--orange);
  box-shadow:0 0 0 0 rgba(247,100,36,.5);animation:pulse 2s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(247,100,36,.5)}70%{box-shadow:0 0 0 16px rgba(247,100,36,0)}100%{box-shadow:0 0 0 0 rgba(247,100,36,0)}}

.big-statement{
  padding:0 var(--gutter);max-width:24ch;
  font-size:var(--text-h2);font-weight:700;line-height:1.02;letter-spacing:-.025em;
}
.big-statement em{color:var(--orange);font-style:italic}
.big-statement .w{display:inline-block;overflow:hidden;padding-bottom:.12em;margin-bottom:-.12em}
.big-statement .w i{display:inline-block;font-style:inherit;will-change:transform}

.diagnosis__rx{
  margin-top:clamp(3rem,2rem + 4vw,6rem);padding:0 var(--gutter);
  display:flex;gap:clamp(1rem,.5rem + 2vw,2.4rem);align-items:flex-start;flex-wrap:wrap;
}
.diagnosis__mark{width:clamp(120px,16vw,230px);height:auto;aspect-ratio:650/210.64;color:var(--orange);flex:none}
.diagnosis__cure{
  flex:1 1 480px;font-size:var(--text-lead);font-weight:500;line-height:1.22;letter-spacing:-.015em;
  padding-top:.1em;
}
.diagnosis__cure strong{color:var(--orange);font-weight:700}

/* ============================================================
   CAPABILITY
   ============================================================ */
.cap{padding:var(--space) 0}
.cap__title{
  padding:0 var(--gutter);font-size:var(--text-h2);font-weight:800;line-height:.92;
  letter-spacing:-.03em;margin-bottom:clamp(1rem,.6rem + .8vw,1.6rem);
}
.cap__lead{
  padding:0 var(--gutter);max-width:42ch;
  margin-bottom:clamp(2.5rem,1.5rem + 3vw,5rem);
  font-size:var(--text-lead);font-weight:500;line-height:1.3;letter-spacing:-.01em;color:var(--ink-soft);
}
.cap__grid{display:grid;grid-template-columns:minmax(220px,1fr) 2.4fr;gap:clamp(2rem,1rem + 3vw,5rem);padding:0 var(--gutter)}
@media (max-width:900px){ .cap__grid{grid-template-columns:1fr} }
.cap__serve .kicker,.cap__do .kicker{display:block;margin-bottom:1.4rem;padding-bottom:.7rem;border-bottom:1px solid var(--line)}
.serve{list-style:none;display:flex;flex-direction:column;gap:1.6rem}
.serve li{display:flex;flex-direction:column;gap:.25rem}
.serve b{font-size:clamp(1.5rem,1rem + 1.4vw,2.1rem);font-weight:700;letter-spacing:-.02em}
.serve span{color:var(--ink-soft);font-size:.95rem}

.bento{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(.7rem,.4rem + 1vw,1.3rem)}
@media (max-width:760px){ .bento{grid-template-columns:repeat(2,1fr)} }
@media (max-width:460px){ .bento{grid-template-columns:1fr} }
.card{
  position:relative;background:var(--cream-hi);border:1px solid var(--line-soft);
  border-radius:18px;padding:clamp(1.2rem,1rem + 1vw,1.9rem);overflow:hidden;
  min-height:clamp(200px,14vw,250px);
  display:flex;flex-direction:column;justify-content:flex-end;gap:.5rem;
  transition:transform .5s var(--e-expo),box-shadow .5s var(--e-expo),border-color .5s;
  transform-style:preserve-3d;will-change:transform;
}
.card::before{
  content:"";position:absolute;inset:0;border-radius:inherit;
  background:radial-gradient(140% 120% at 80% 0,color-mix(in srgb,var(--fruit) 26%,transparent),transparent 60%);
  opacity:0;transition:opacity .5s;
}
.card:hover{box-shadow:0 28px 50px -22px rgba(40,20,0,.32);border-color:color-mix(in srgb,var(--fruit) 50%,transparent)}
.card:hover::before{opacity:1}
.card__fruit{position:absolute;top:clamp(1rem,.8rem + .8vw,1.6rem);left:clamp(1rem,.8rem + .8vw,1.6rem);
  font-size:clamp(1.6rem,1.2rem + 1vw,2.2rem);filter:saturate(1.1);
  transition:transform .55s var(--e-expo)}
.card:hover .card__fruit{transform:scale(1.18) rotate(-8deg)}
.card h3{font-size:clamp(1.05rem,.9rem + .5vw,1.32rem);font-weight:700;letter-spacing:-.01em}
.card p{font-size:.9rem;color:var(--ink-soft);line-height:1.35}
.card__no{position:absolute;top:clamp(1rem,.8rem + .8vw,1.6rem);right:clamp(1rem,.8rem + .8vw,1.4rem);
  font-size:.72rem;font-weight:800;color:var(--muted);letter-spacing:.05em}

/* ============================================================
   METHOD (pinned)
   ============================================================ */
.method{position:relative;background:transparent}
.method::before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,var(--cream) 0%,var(--cream-hi) 100%);z-index:-2;pointer-events:none}
.method__sticky{
  min-height:100svh;display:grid;grid-template-columns:1fr 1fr;align-items:center;
  gap:clamp(2rem,1rem + 3vw,5rem);padding:clamp(6rem,5rem + 4vw,9rem) var(--gutter);
}
@media (max-width:900px){ .method__sticky{grid-template-columns:1fr;gap:2.5rem;min-height:auto;padding-block:var(--space)} }
.method__big{font-size:clamp(3rem,1.5rem + 7vw,8rem);font-weight:800;line-height:.86;letter-spacing:-.03em;margin:1.5rem 0}
.method__word{display:block;transition:opacity .4s,filter .4s}
.method__word i{font-style:normal;color:var(--orange)}
.method__word.accent{color:var(--orange)}
.method__word.accent i{color:var(--ink)}
.method__note{max-width:42ch;color:var(--ink-soft);font-size:1.02rem;line-height:1.5}
.method__mark{display:inline-block;width:62px;height:20px;color:var(--orange);vertical-align:-.18em;margin:0 .1em}
.method__drip{display:flex;align-items:center;gap:1rem;margin-top:clamp(2rem,1rem + 3vw,3.5rem)}
.method__tube{position:relative;width:160px;height:10px;border-radius:100px;background:var(--line);overflow:hidden}
.method__tube i{position:absolute;inset:0;width:25%;background:linear-gradient(90deg,var(--orange-logo),var(--orange));border-radius:100px;transition:width .2s linear}
.method__pct{font-weight:800;font-size:.82rem;color:var(--orange)}

.method__steps{list-style:none;display:flex;flex-direction:column}
.step{
  display:flex;gap:clamp(1rem,.5rem + 1.5vw,2.2rem);align-items:baseline;
  padding:clamp(1.2rem,1rem + 1.4vw,2.2rem) 0;border-top:1px solid var(--line);
  opacity:.32;transition:opacity .5s var(--e-expo),transform .5s var(--e-expo);
}
.step:last-child{border-bottom:1px solid var(--line)}
.step.is-active{opacity:1}
.step.is-active .step__no{color:var(--orange)}
.step__no{font-weight:800;font-size:.8rem;color:var(--muted);width:2em;flex:none;transition:color .4s}
.step__body h3{font-size:clamp(1.6rem,1.1rem + 2vw,2.8rem);font-weight:700;letter-spacing:-.02em;line-height:1}
.step__body p{margin-top:.5rem;color:var(--ink-soft);font-size:1rem;max-width:42ch;
  max-height:0;opacity:0;overflow:hidden;transition:max-height .5s var(--e-expo),opacity .4s,margin .4s}
.step.is-active .step__body p{max-height:6em;opacity:1}

/* ============================================================
   IN THE WILD
   ============================================================ */
.wild{position:relative;padding:var(--space) 0;background:transparent;overflow:hidden}
/* background sits below the descending IV line (z:-1) so the tube reads behind the content */
.wild::before{content:"";position:absolute;inset:0;background:var(--cream-hi);z-index:-2;pointer-events:none}
.wild__title{padding:0 var(--gutter);font-size:var(--text-h2);font-weight:800;letter-spacing:-.03em;line-height:.95;
  margin-bottom:clamp(2.5rem,1.5rem + 3vw,5rem)}
.wild__grid{display:grid;grid-template-columns:1.4fr 1fr .8fr;gap:clamp(1rem,.5rem + 2vw,2.6rem);
  padding:0 var(--gutter);align-items:start}
@media (max-width:960px){ .wild__grid{grid-template-columns:1fr 1fr} .surface--web{grid-column:1/-1} }
@media (max-width:600px){ .wild__grid{grid-template-columns:1fr} .surface--web{grid-column:auto} }
.surface{will-change:transform}
.surface__cap{margin-top:1.1rem;display:flex;flex-direction:column;gap:.2rem}
.surface__cap b{font-size:.72rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--orange)}
.surface__cap span{color:var(--ink-soft);font-size:.92rem}

/* browser surface */
.browser{border-radius:16px;overflow:hidden;background:#fff;box-shadow:0 30px 60px -28px rgba(40,20,0,.4);
  border:1px solid var(--line-soft)}
.browser__bar{display:flex;align-items:center;gap:7px;padding:.7rem 1rem;background:#efe9df;border-bottom:1px solid var(--line-soft)}
.browser__bar i{width:10px;height:10px;border-radius:50%;background:#cfc6b6}
.browser__bar i:first-child{background:#f76424}
.browser__bar b{margin-left:1rem;font-size:.72rem;font-weight:600;color:var(--muted);letter-spacing:.04em}
.browser__view{aspect-ratio:16/10.5;padding:clamp(1.4rem,1rem + 2vw,2.6rem);display:flex;flex-direction:column;justify-content:center;gap:.5rem;
  background:radial-gradient(120% 100% at 80% 0,var(--peach-1),#fff 60%)}
.browser__kick{font-size:clamp(.8rem,.6rem + .6vw,1rem);font-weight:600;color:var(--ink-soft)}
.browser__head{font-size:clamp(2.2rem,1rem + 5vw,4.4rem);font-weight:800;letter-spacing:-.03em;line-height:.9;color:var(--ink)}
.browser__head .cursorblink{color:var(--orange);animation:blink 1s steps(1) infinite}
@keyframes blink{50%{opacity:0}}
.browser__cta{margin-top:.8rem;align-self:flex-start;background:var(--ink);color:var(--cream-hi);
  padding:.55em 1em;border-radius:100px;font-size:.8rem;font-weight:700}

/* OOH board */
.surface--ooh .board{position:relative;padding-bottom:34px}
.board__panel{aspect-ratio:16/10;border-radius:12px;background:linear-gradient(135deg,var(--orange) 0%,#ff8a3d 100%);
  box-shadow:0 30px 60px -28px rgba(180,70,0,.55);padding:clamp(1.2rem,1rem + 2vw,2.2rem);
  display:flex;flex-direction:column;justify-content:space-between;overflow:hidden}
.board__logo{width:clamp(80px,9vw,130px);height:auto;aspect-ratio:650/210.64;color:var(--cream-hi)}
.board__line{font-size:clamp(1.3rem,.9rem + 1.8vw,2.4rem);font-weight:800;line-height:.98;color:var(--cream-hi);letter-spacing:-.02em}
.board__pole{position:absolute;left:50%;bottom:0;width:10px;height:34px;background:#d8cdbb;transform:translateX(-50%);border-radius:0 0 3px 3px}

/* CRM email */
.mail{border-radius:16px;background:#fff;border:1px solid var(--line-soft);overflow:hidden;
  box-shadow:0 30px 60px -28px rgba(40,20,0,.35);padding:clamp(1.2rem,1rem + 1.5vw,1.8rem);
  display:flex;flex-direction:column;gap:.7rem}
.mail__from{font-size:.7rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--orange)}
.mail__from i{font-style:normal}
.mail__subj{font-size:clamp(1.1rem,.9rem + .8vw,1.5rem);font-weight:700;letter-spacing:-.01em}
.mail__rule{height:1px;background:var(--line-soft)}
.mail__body{font-size:.92rem;color:var(--ink-soft);line-height:1.45}
.mail__btn{align-self:flex-start;margin-top:.3rem;background:var(--orange);color:var(--cream-hi);
  padding:.5em .95em;border-radius:8px;font-size:.78rem;font-weight:700}

/* ============================================================
   REFILL / CTA
   ============================================================ */
.refill{position:relative;padding:var(--space) 0 clamp(4rem,3rem + 4vw,7rem);background:transparent;color:var(--cream-hi);overflow:hidden}
/* background sits below the descending IV line (z:-1) so the serum reads behind the content */
.refill::before{content:"";position:absolute;inset:0;background:var(--ink);z-index:-2;pointer-events:none}
.refill .kicker{color:rgba(250,244,234,.55)}
.refill .kicker--accent{color:var(--orange)}
.refill .index{color:var(--orange)}
.refill__halo{position:absolute;z-index:0;top:-30%;right:-10%;width:60vw;height:60vw;border-radius:50%;
  background:radial-gradient(circle,var(--orange) 0%,rgba(247,100,36,0) 60%);opacity:.35;pointer-events:none;filter:blur(20px)}
.refill__grid{position:relative;z-index:1;display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(2rem,1rem + 4vw,6rem);
  padding:0 var(--gutter);align-items:center}
@media (max-width:900px){ .refill__grid{grid-template-columns:1fr;gap:3rem} }
.refill__q{font-size:clamp(2.4rem,1.4rem + 5vw,6rem);font-weight:800;line-height:.94;letter-spacing:-.03em}
.refill__q em{font-style:normal;color:rgba(250,244,234,.55)}

.script{position:relative;background:var(--cream-hi);color:var(--ink);border-radius:20px;
  padding:clamp(1.8rem,1.4rem + 2vw,2.8rem);box-shadow:0 50px 90px -40px rgba(0,0,0,.7);
  display:flex;flex-direction:column;gap:.55rem;transform-style:preserve-3d;will-change:transform}
.script__top{position:absolute;top:0;left:0;right:0;height:7px;background:linear-gradient(90deg,var(--orange),var(--orange-logo));border-radius:20px 20px 0 0}
.script__rx{font-size:.72rem;font-weight:800;letter-spacing:.2em;color:var(--orange);margin-top:.4rem}
.script__logo{width:clamp(120px,15vw,180px);height:auto;aspect-ratio:650/210.64;color:var(--orange);margin:.2rem 0;
  --dose:0;will-change:filter,transform;
  filter:drop-shadow(0 0 calc(var(--dose) * 30px) rgba(247,100,36,calc(var(--dose) * .85)));
  transform:scale(calc(1 + var(--dose) * .05));
  transition:filter .18s linear,transform .18s linear}
.script__tm{position:absolute;font-size:.8rem;font-weight:700;color:var(--orange)}
.script__dose{font-size:.7rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-soft)}
.script__rule{height:1px;background:var(--line);margin:.6rem 0}
.script__dir{font-size:.95rem;color:var(--ink-soft);line-height:1.4}
.script__mail{font-size:clamp(1.2rem,.9rem + 1.2vw,1.7rem);font-weight:800;color:var(--ink);letter-spacing:-.01em;
  align-self:flex-start;transition:color .3s}
.script__mail:hover{color:var(--orange)}
.script__addr{font-size:.74rem;color:var(--muted);line-height:1.5;letter-spacing:.02em}

.refill__shot{position:relative;z-index:1;text-align:center;margin-top:clamp(4rem,3rem + 4vw,7rem);
  padding:0 var(--gutter);font-size:clamp(1.4rem,1rem + 2.4vw,3rem);font-weight:700;letter-spacing:-.02em}
.refill__mark{display:inline-block;width:clamp(70px,8vw,120px);height:auto;aspect-ratio:650/210.64;color:var(--orange);vertical-align:-.12em;margin:0 .15em}

/* ============================================================
   FOOTER
   ============================================================ */
.foot{background:var(--ink);color:var(--cream-hi);padding:clamp(3rem,2rem + 3vw,5rem) var(--gutter) 2.5rem;
  display:grid;grid-template-columns:1fr auto;gap:2rem;align-items:end;border-top:1px solid rgba(255,255,255,.08)}
@media (max-width:760px){ .foot{grid-template-columns:1fr} }
.foot__logo{width:clamp(180px,30vw,360px);height:auto;aspect-ratio:650/210.64;color:var(--cream-hi);grid-column:1/-1}
.foot__cols{display:flex;flex-direction:column;gap:.3rem;color:rgba(250,244,234,.6);font-size:.92rem}
.foot__cols a{font-weight:700;color:var(--cream-hi)}
.foot__copy{font-size:.78rem;color:rgba(250,244,234,.4);letter-spacing:.04em;text-align:right}
@media (max-width:760px){ .foot__copy{text-align:left} }

/* ============================================================
   reveal defaults (JS toggles)
   ============================================================ */
[data-reveal]{opacity:0;transform:translateY(28px);transition:opacity .9s var(--e-expo),transform .9s var(--e-expo)}
[data-reveal].is-in{opacity:1;transform:none}

@media (prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
  .hero__iv{transform:none!important}
  [data-reveal]{opacity:1;transform:none}
}
