/* ================================================
   Dawn — landing page
   ================================================ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#05060d;
  --bg-card:#0d0d1a;
  --bg-card-2:#11112a;
  --ink:#e9e9f1;
  --ink-soft:#bdbdd0;
  --mute:#8a8aa3;
  --mute-2:#6e6e85;
  --violet:#7c5cff;
  --violet-2:#a98bff;
  --line:rgba(255,255,255,.08);
  --line-2:rgba(255,255,255,.12);

  /* spacing rhythm */
  --gutter: clamp(20px, 4vw, 48px);
  --section-pad-y: clamp(32px, 4vw, 48px);
  --container: 1200px;
}
html,body{background:var(--bg);color:var(--ink);font-family:'Inter',system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
body{min-height:100vh}
/* No overflow-x on html/body — would break position:sticky on iOS Safari < 16
   which falls back from clip to hidden. Specific overflowing elements clip themselves. */
a{color:inherit;text-decoration:none}
img,svg{display:block;max-width:100%}
button{font-family:inherit;cursor:pointer}

/* starfield */
#stars{
  position:fixed;inset:0;width:100%;height:100%;
  z-index:0;pointer-events:none;
  background:radial-gradient(ellipse at 50% 0%, #160c2a 0%, #05060d 55%, #02020a 100%);
}
body > *:not(#stars){position:relative;z-index:1}

/* ================================================
   Topbar — floating elongated pill
   ================================================ */
.topbar{
  position:sticky;top:18px;z-index:50;
  padding:0 var(--gutter);
  display:flex;justify-content:center;
  pointer-events:none;
}
.topbar__pill{
  pointer-events:auto;
  width:100%;max-width:1180px;
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 16px 14px 24px;
  background:rgba(10,10,22,.72);
  border:1px solid rgba(255,255,255,.08);
  border-radius:999px;
  backdrop-filter:blur(18px);
  -webkit-backdrop-filter:blur(18px);
  box-shadow:0 14px 40px rgba(0,0,0,.45);
}
.brand{
  display:flex;align-items:center;
  height:36px;
}
.brand__logo{
  height:36px;width:auto;display:block;
  filter:drop-shadow(0 0 12px rgba(255,255,255,.15));
}
.topnav{display:flex;align-items:center;gap:20px}
.topnav > a:not(.btn){
  font-size:14px;color:#cfcfe0;font-weight:500;
  transition:color .2s;padding:0 4px;
}
.topnav > a:not(.btn):hover{color:#fff}
.btn--sm{padding:10px 22px;font-size:14px}

/* ================================================
   Buttons / pills
   ================================================ */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 26px;border-radius:999px;
  font-weight:600;font-size:15px;
  border:1px solid var(--line);
  transition:transform .15s ease, box-shadow .2s ease;
}
.btn:hover{transform:translateY(-1px)}
.btn--light{
  background:#fff;color:#000;border-color:transparent;
  box-shadow:0 8px 30px rgba(255,255,255,.06);
}
.btn--light:hover{box-shadow:0 12px 36px rgba(255,255,255,.18)}
.pill{
  display:inline-flex;align-items:center;gap:8px;
  padding:8px 18px;border-radius:999px;
  font-size:13px;font-weight:500;
}
.pill--ghost{
  border:1px solid var(--line-2);
  background:rgba(255,255,255,.03);
  color:#fff;
}
.pill--center{display:inline-flex}

/* ================================================
   Hero
   ================================================ */
.hero{
  position:relative;
  padding:80px var(--gutter) 0;
}
.hero__inner{
  max-width:var(--container);margin:0 auto;
  display:grid;grid-template-columns:1fr 1fr;
  gap:32px;align-items:center;
}
.hero__text{display:flex;flex-direction:column;align-items:flex-start;text-align:left}
.hero__art{position:relative;height:440px}

.newfeat{
  display:inline-flex;align-items:center;gap:10px;
  padding:9px 18px;border-radius:999px;
  font-size:13px;color:#c9b8ff;font-weight:500;
  background:rgba(124,92,255,.10);
  border:1px solid rgba(169,139,255,.35);
  box-shadow:0 0 24px rgba(124,92,255,.2);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  margin-bottom:36px;
}
.newfeat__dot{width:7px;height:7px;border-radius:50%;background:#a98bff;box-shadow:0 0 10px #a98bff}

.hero__title{
  font-size:clamp(48px,7vw,88px);
  font-weight:800;line-height:.95;letter-spacing:-.02em;
  color:#cfcfe6;
  text-shadow:0 0 60px rgba(124,92,255,.55), 0 0 140px rgba(124,92,255,.35);
}
.hero__sub{
  margin:20px 0 24px;max-width:420px;
  color:#bfbfd4;font-size:15px;line-height:1.55;
}
.hero__sub--short{display:none}
.newfeat{margin-bottom:24px}

/* phone shell */
.phone{
  width:280px;height:560px;
  border-radius:44px;
  background:linear-gradient(180deg,#1a1a2e,#0d0d1a);
  border:2px solid #1f1f33;
  position:relative;padding:10px;
  box-shadow:0 30px 80px rgba(124,92,255,.25);
  flex-shrink:0;
  opacity:0;
  will-change: transform, opacity;
}

/* phone slide-up entry chained into infinite float */
@keyframes floatEntry{
  0%   { opacity:0; transform: translateY(80px) }
  100% { opacity:1; transform: translateY(0) }
}
@keyframes floatEntryN8{
  0%   { opacity:0; transform: rotate(-8deg) translateY(80px) }
  100% { opacity:1; transform: rotate(-8deg) translateY(0) }
}
@keyframes floatEntry6{
  0%   { opacity:0; transform: rotate(6deg) translateY(80px) }
  100% { opacity:1; transform: rotate(6deg) translateY(0) }
}
@keyframes float{
  0%,100%{ transform: translateY(0) }
  50%   { transform: translateY(-12px) }
}
@keyframes floatN8{
  0%,100%{ transform: rotate(-8deg) translateY(0) }
  50%   { transform: rotate(-8deg) translateY(-14px) }
}
@keyframes float6{
  0%,100%{ transform: rotate(6deg) translateY(0) }
  50%   { transform: rotate(6deg) translateY(-14px) }
}

.phone.in-view{
  opacity:1;
  animation: floatEntry .9s cubic-bezier(.22,.61,.36,1) forwards,
             float 6s ease-in-out infinite .9s;
}
.phone--hero-back.in-view,
.phone--tilt-l.in-view{
  opacity:1;
  animation: floatEntryN8 .9s cubic-bezier(.22,.61,.36,1) forwards,
             floatN8 6.5s ease-in-out infinite .9s;
}
.phone--hero-front.in-view,
.phone--tilt-r.in-view{
  opacity:1;
  animation: floatEntry6 .9s cubic-bezier(.22,.61,.36,1) forwards,
             float6 7.2s ease-in-out infinite 1.05s;
}

/* full-bleed screenshot inside the phone screen */
.phone__screen--shot{padding:0 !important;background:#000}
.phone__shot{
  width:100%;height:100%;display:block;
  object-fit:cover;border-radius:34px;
  user-select:none;-webkit-user-drag:none;pointer-events:none;
}
.phone__notch{
  position:absolute;top:14px;left:50%;transform:translateX(-50%);
  width:120px;height:30px;background:#000;border-radius:18px;z-index:2;
}
.phone__screen{
  width:100%;height:100%;border-radius:34px;
  background:linear-gradient(180deg,#0a0a14,#13132a 60%,#080814);
  overflow:hidden;position:relative;
  padding:42px 14px 14px;
}

/* hero phones (two stacked, tilted) */
.phone--hero-back,
.phone--hero-front{
  position:absolute;
}
.phone--hero-back{
  left:8%;top:0;
  width:200px;height:400px;
  z-index:1;
  animation: floatN8 6.5s ease-in-out infinite;
}
.phone--hero-front{
  right:6%;top:40px;
  width:210px;height:420px;
  z-index:2;
  animation: float6 7.2s ease-in-out infinite -1.6s;
}

/* hero phone interior */
.hphone{display:flex;flex-direction:column;height:100%;color:#fff;font-size:11px;gap:8px}
.hphone__top{display:flex;justify-content:space-between;align-items:center;font-size:12px;font-weight:600;color:#fff;padding:0 8px}
.hphone__signal{width:42px;height:10px;background:linear-gradient(90deg,#fff 70%,rgba(255,255,255,.4) 70%);border-radius:2px;mask:linear-gradient(90deg,#000 60%,rgba(0,0,0,.3) 60%)}
.hphone__head{padding:0 4px}
.hphone__head b{font-size:13px;display:block;margin-bottom:6px}
.hphone__tabs{display:flex;gap:6px;font-size:10px;color:#888}
.hphone__tabs span{padding:4px 12px;border-radius:999px;background:#15152b}
.hphone__tabs .on{background:#fff;color:#000;font-weight:600}
.hphone__hex{align-self:center;width:100%;max-width:220px;margin-top:4px}
.hphone__stats{margin-top:auto;font-size:10px;color:#aaa;padding:8px 4px 0}
.hphone__pills{display:flex;gap:12px;align-items:center;margin-top:6px;color:#fff;font-weight:600}
.hphone__pills .dot{width:10px;height:10px;border-radius:50%;display:inline-block;margin-right:4px}
.dot--red{background:#ff5a4a}
.dot--violet{background:#a98bff}

.hphone__brand{display:flex;justify-content:space-between;align-items:center;padding:0 4px}
.hphone__logo{font-size:14px;letter-spacing:2px;color:#fff;font-weight:800}
.hphone__streak{font-size:11px;color:#ffaa6e;background:rgba(255,170,110,.12);padding:3px 8px;border-radius:999px;font-weight:600}
.hphone__moon{position:relative;align-self:center;width:100%;max-width:220px;margin-top:6px}
.hphone__days{
  position:absolute;left:50%;bottom:-6px;transform:translateX(-50%);
  font-size:36px;font-weight:800;color:#fff;line-height:1;text-shadow:0 0 14px rgba(0,0,0,.5);
}
.hphone__days small{font-size:11px;color:#aaa;margin-left:4px;font-weight:500}
.hphone__progress{margin-top:auto;display:flex;flex-direction:column;gap:8px;padding:8px 4px 0}
.hphone__progress-row{display:flex;justify-content:space-between;font-size:10px;color:#bbb}
.hphone__progress-bar{height:6px;background:#15152b;border-radius:999px;overflow:hidden}
.hphone__progress-bar i{display:block;height:100%;background:linear-gradient(90deg,#a98bff,#5b8bff);border-radius:999px}
.hphone__relapse{
  background:#fff;color:#000;border:none;border-radius:999px;
  padding:9px;font-size:11px;font-weight:600;
}
.hphone__nav{display:flex;justify-content:space-between;padding:6px 4px 0;border-top:1px solid #15152b;margin-top:4px}
.hphone__nav i{width:12px;height:12px;background:#666;border-radius:3px;display:inline-block}

/* mini dashboard */
.dash{display:flex;flex-direction:column;gap:18px;height:100%}
.dash__row{display:flex;justify-content:space-between;font-size:13px;color:#fff}
.dash__row .muted,.muted{color:#888}
.ring{position:relative;align-self:center;width:140px;height:140px}
.ring__num{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  font-weight:700;font-size:32px;color:#fff;
}
.ring__num span{font-size:18px;color:#bbb;margin-left:2px}
.dash__grid{margin-top:auto;display:grid;grid-template-columns:repeat(4,1fr);gap:8px}
.tile{background:#15152b;border:1px solid #20203c;border-radius:10px;padding:10px;text-align:center;font-size:11px;color:#ccc}
.tile small{color:#888}
.dash__bars{display:flex;gap:6px;align-items:flex-end;height:60px;margin-top:auto}
.dash__bars i{flex:1;background:linear-gradient(180deg,#a98bff,#5b8bff);border-radius:3px}
.dash__bars i:nth-child(1){height:30%}
.dash__bars i:nth-child(2){height:55%}
.dash__bars i:nth-child(3){height:40%}
.dash__bars i:nth-child(4){height:75%}
.dash__bars i:nth-child(5){height:60%}
.dash__bars i:nth-child(6){height:90%}
.dash__bars i:nth-child(7){height:70%}
.hex{align-self:center;width:160px;height:160px}
.dash__pills{display:flex;justify-content:space-around;margin-top:auto}
.dash__pills i{background:#2a2a44;border-radius:8px;padding:6px 14px;font-style:normal;font-size:12px;color:#fff}

/* chat */
.chat{display:flex;flex-direction:column;gap:10px;height:100%;font-size:11px;color:#ddd;position:relative}
.chat__head{display:flex;justify-content:space-between;align-items:center;font-size:13px;color:#fff}
.chat__chip{background:#3d2f0a;color:#ffd58a;padding:4px 10px;border-radius:999px;font-size:10px}
.chat__tabs{display:flex;gap:8px;font-size:10px;color:#888;align-items:center}
.chat__tabs .on{background:#3d2f0a;color:#ffd58a;padding:3px 10px;border-radius:999px}
.chat__tabs .online{margin-left:auto;color:#3acc7e}
.chat__msg{border-bottom:1px solid #1a1a2c;padding:6px 0}
.chat__msg b{color:#fff;font-size:11px;margin-right:6px}
.chat__msg small{color:#777;font-size:9px}
.chat__msg p{color:#bbb;margin-top:4px;line-height:1.35;font-size:10px}
.chat__fab{position:absolute;right:6px;bottom:6px;width:36px;height:36px;border-radius:50%;background:#2f7bff;color:#fff;display:flex;align-items:center;justify-content:center;font-size:22px;font-weight:300}

/* blocker phone */
.block{display:flex;flex-direction:column;height:100%;color:#ddd;gap:14px}
.block__head{display:flex;justify-content:space-between;align-items:center;font-size:13px;color:#fff}
.block__head b{font-size:14px}
.block__on{font-size:11px;color:#3acc7e;background:rgba(58,204,126,.12);padding:4px 10px;border-radius:999px;font-weight:600}
.block__shield{align-self:center;position:relative;width:140px;height:140px}
.block__count{position:absolute;left:50%;top:55%;transform:translateX(-50%);text-align:center;font-size:22px;font-weight:800;color:#fff;line-height:1}
.block__count small{display:block;font-size:9px;color:#aaa;font-weight:500;margin-top:3px}
.block__list{list-style:none;display:flex;flex-direction:column;gap:8px;margin-top:auto}
.block__list li{display:flex;justify-content:space-between;align-items:center;background:#15152b;border:1px solid #20203c;border-radius:10px;padding:10px 12px;font-size:11px;color:#ccc}
.sw{width:28px;height:16px;border-radius:999px;background:#333;position:relative}
.sw::after{content:"";position:absolute;top:2px;left:2px;width:12px;height:12px;border-radius:50%;background:#fff;transition:left .2s}
.sw.on{background:#3acc7e}
.sw.on::after{left:14px}

/* panic */
.panic{padding:40px 14px 14px;display:flex;flex-direction:column;gap:10px;color:#ddd}
.panic__top{display:flex;justify-content:space-between;align-items:center;font-size:11px;color:#ff5a4a}
.panic__top .x{color:#fff;font-size:18px}
.panic__title{font-weight:600}
.toggle{width:32px;height:18px;background:#ff3b30;border-radius:999px;position:relative}
.toggle i{position:absolute;right:2px;top:2px;width:14px;height:14px;background:#fff;border-radius:50%}
.panic__msg{font-size:10px;text-align:center;color:#fff;line-height:1.4;margin:8px 0;font-weight:600}
.panic__card{background:#13132a;border-radius:10px;padding:8px;font-size:10px}
.panic__card b{color:#fff;display:block;margin-bottom:2px}
.panic__card small{color:#888;font-size:9px;line-height:1.3}
.panic__red{background:#7a1f1a;color:#fff;border:none;border-radius:10px;padding:10px;font-size:11px;font-weight:600;margin-top:auto}
.panic__white{background:#fff;color:#000;border:none;border-radius:10px;padding:10px;font-size:11px;font-weight:600}

/* ================================================
   Reveal section
   - Desktop (>880px): JS-managed pinning (position: absolute → fixed → absolute)
   - Mobile  (≤880px): CSS position:sticky (avoids iOS position:fixed momentum-scroll
     quirks and renders smoothly on iPhone)
   ================================================ */
.reveal{
  height:220vh;
  height:220svh;
  height:260dvh;       /* slightly more scroll runway on mobile, less sensitive */
  position:relative;
}
.reveal__sticky{
  position:absolute;top:0;left:0;right:0;
  height:100vh;
  height:100svh;
  height:100dvh;       /* matches current visible viewport — content stays centered
                          even when iOS URL bar shows/hides */
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:0 var(--gutter);text-align:center;
  will-change:transform;
}
.reveal__sticky.is-pinned{
  position:fixed;top:0;left:0;right:0;
}
.reveal__sticky.is-end{
  position:absolute;top:auto;bottom:0;
}
@media(max-width:880px){
  .reveal__sticky,
  .reveal__sticky.is-pinned,
  .reveal__sticky.is-end{
    position:sticky;
    top:0;
    bottom:auto;
    left:auto;right:auto;
  }
}
.reveal__wrap{max-width:1000px;width:100%;margin:0 auto}
.reveal__line{
  font-size:clamp(22px,2.8vw,42px);
  font-weight:600;line-height:1.4;letter-spacing:-.01em;
  word-spacing:.02em;
}
.reveal__line + .reveal__line{margin-top:14px}
.reveal__line span{
  color:#2c2c44;
}
.reveal__line span.on{
  color:#fff;
  text-shadow:0 0 18px rgba(255,255,255,.12);
}
.stats{
  display:grid;grid-template-columns:repeat(3,1fr);gap:32px;
  margin:40px auto 0;width:100%;max-width:1100px;
  opacity:0;transform:translateY(20px);
  transition:opacity .6s ease, transform .6s ease;
}
.stats.show{opacity:1;transform:none}
.reveal__cta{
  margin-top:28px;
  opacity:0;transform:translateY(20px);
  transition:opacity .6s ease .15s, transform .6s ease .15s;
}
.reveal__cta.show{opacity:1;transform:none}

/* On mobile, lift stats + CTA out of flex flow so the centered text is
   actually in the middle of the viewport (not the top of a centered group).
   .reveal__sticky already has position:sticky which makes it a containing block
   for the absolutely-positioned children below. When the .is-past class flips
   on (after all words are revealed), the centered text fades out and the stats
   take over the middle of the screen — no overlap. */
@media(max-width:880px){
  .reveal__wrap{
    transition:opacity .4s ease;
  }
  .reveal.is-past .reveal__wrap{
    opacity:0;
  }
  .stats{
    position:absolute;left:0;right:0;
    top:50%;transform:translateY(-50%);
    margin:0;padding:0 var(--gutter);
    grid-template-columns:1fr !important;gap:14px;
  }
  .stats.show{
    transform:translateY(-50%);
  }
  .reveal__cta{
    position:absolute;left:0;right:0;
    bottom:6dvh;
    margin:0;
    display:flex;justify-content:center;
  }
  .reveal__cta.show{transform:none}
}
.stat{display:flex;flex-direction:column;align-items:center;gap:8px}
.stat__num{
  font-size:clamp(36px,4.5vw,68px);font-weight:800;
  background:linear-gradient(180deg,#fff,#a98bff);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.stat__lbl{color:var(--mute);font-size:14px;max-width:240px;line-height:1.4}

/* ================================================
   CTA row
   ================================================ */
.cta-row{display:flex;justify-content:center;padding:14px 0}

/* ================================================
   How it works (panels)
   ================================================ */
.hiw{position:relative}
.hiw__panel{
  min-height:auto;
  display:flex;align-items:center;justify-content:center;
  gap:80px;padding:30px 8vw;
  max-width:var(--container);margin:0 auto;
}
.hiw__panel[data-side="left"]{flex-direction:row-reverse}
.hiw__text{flex:1;max-width:500px}
.hiw__text h2{
  font-size:clamp(36px,4vw,52px);font-weight:800;letter-spacing:-.01em;
  margin-bottom:20px;line-height:1.05;
}
.hiw__text p{color:var(--ink-soft);font-size:17px;line-height:1.65}
.hiw__art{flex:1;display:flex;justify-content:center;position:relative;min-height:560px}
.phone--tilt-l{position:absolute;left:8%;top:0;animation: floatN8 6.8s ease-in-out infinite -.4s}
.phone--tilt-r{position:absolute;right:8%;top:60px;animation: float6 7.4s ease-in-out infinite -2.1s}

/* ================================================
   Testimonials
   ================================================ */
.testimonials{
  padding:var(--section-pad-y) var(--gutter);
  text-align:center;
}
.h2{
  font-size:clamp(40px,5vw,72px);
  font-weight:800;letter-spacing:-.01em;line-height:1.05;
  margin:24px auto 0;color:#cfcfe6;
}
.testimonials .h2{margin-bottom:36px}
.section-sub{
  color:var(--mute);font-size:16px;line-height:1.55;
  max-width:560px;margin:18px auto 0;
}
.tgrid{
  display:grid;gap:24px;
  max-width:1140px;margin:0 auto;
  grid-template-columns:repeat(3,1fr);
}
.tcard{
  background:var(--bg-card);
  border:1px solid var(--line);
  border-radius:18px;padding:26px;
  text-align:left;display:flex;flex-direction:column;gap:18px;
  min-height:260px;
}
.stars{color:#ffb736;letter-spacing:3px;font-size:18px}
.tcard p{color:#cfcfe0;font-size:15px;line-height:1.55;flex:1}
.tuser{display:flex;align-items:center;gap:12px}
.tuser b{display:block;font-size:14px;color:#fff}
.tuser small{color:var(--mute);font-size:12px}
.ava{width:42px;height:42px;border-radius:50%;background:#222;flex-shrink:0}
.ava-1{background:linear-gradient(135deg,#7c5cff,#3a8bff)}
.ava-2{background:linear-gradient(135deg,#3a3a4a,#1a1a2c)}
.ava-3{background:linear-gradient(135deg,#ff8a6e,#ffd58a)}
.ava-4{background:linear-gradient(135deg,#3acc7e,#1a5a3c)}
.ava-5{background:linear-gradient(135deg,#a98bff,#5b3a8a)}

@media(min-width:900px){
  .tgrid{grid-template-columns:repeat(6,1fr)}
  .tgrid > .tcard:nth-child(1){grid-column:1/3}
  .tgrid > .tcard:nth-child(2){grid-column:3/5}
  .tgrid > .tcard:nth-child(3){grid-column:5/7}
  .tgrid > .tcard:nth-child(4){grid-column:2/4}
  .tgrid > .tcard:nth-child(5){grid-column:4/6}
}

/* ================================================
   Trees
   ================================================ */
.trees{
  padding:var(--section-pad-y) 0;
  text-align:center;overflow:hidden;
}
.trees .section-sub{margin:12px auto 28px;padding:0 var(--gutter)}
.trees__viewport{
  width:100%;overflow:hidden;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 10%,#000 90%,transparent);
          mask-image:linear-gradient(90deg,transparent,#000 10%,#000 90%,transparent);
}
.trees__row{
  display:flex;gap:80px;padding:20px 0;
  will-change:transform;
}
.tree{flex:0 0 auto;width:180px;text-align:center;display:flex;flex-direction:column;align-items:center;justify-content:flex-end}
.tree__img{
  width:180px;height:240px;object-fit:contain;
  margin:0 auto;
}
.tree__name{margin-top:14px;color:#cfcfe0;font-size:14px;font-weight:500}

/* ================================================
   Benefits card
   ================================================ */
.benefits{
  padding:var(--section-pad-y) var(--gutter);
  display:flex;justify-content:center;
}
.benefits__card{
  width:100%;max-width:1100px;
  background:linear-gradient(180deg,#0e0e1c,#0a0a16);
  border:1px solid var(--line);
  border-radius:32px;
  padding:clamp(40px,6vw,72px);
  display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;
  position:relative;overflow:hidden;
  box-shadow:0 30px 80px rgba(0,0,0,.4);
}
.benefits__copy h2{
  font-size:clamp(32px,3.8vw,52px);
  font-weight:800;letter-spacing:-.01em;line-height:1.05;
  color:#fff;margin-bottom:20px;
}
.benefits__copy p{color:var(--ink-soft);font-size:16px;line-height:1.6;max-width:380px;margin-bottom:32px}
.benefits__marquee{
  position:relative;
  height:420px;overflow:hidden;
  -webkit-mask-image:linear-gradient(180deg,transparent,#000 18%,#000 82%,transparent);
          mask-image:linear-gradient(180deg,transparent,#000 18%,#000 82%,transparent);
}
.benefits__inner{
  display:flex;flex-direction:column;gap:14px;
  animation:scrollUp 28s linear infinite;
  will-change:transform;
}
.benefits__marquee:hover .benefits__inner{animation-play-state:paused}
@keyframes scrollUp{
  from{transform:translateY(0)}
  to{transform:translateY(-50%)}
}
.bchip{
  display:flex;align-items:center;gap:14px;
  background:#16162a;
  border:1px solid var(--line-2);
  border-radius:14px;
  padding:18px 22px;
  font-size:16px;font-weight:600;color:#fff;
}
.bchip .emoji{font-size:22px}

@media(max-width:880px){
  .benefits__card{grid-template-columns:1fr;gap:40px}
  .benefits__marquee{height:340px}
}

/* ================================================
   FAQ — flat divider list
   ================================================ */
.faq{
  padding:var(--section-pad-y) var(--gutter) calc(var(--section-pad-y) - 20px);
  max-width:920px;margin:0 auto;
  text-align:center;
}
.faq .h2{margin-bottom:32px}
.faq__list{
  text-align:left;
  border-top:1px solid var(--line);
}
.faq details{
  border-bottom:1px solid var(--line);
  padding:22px 6px;
}
.faq summary{
  display:flex;justify-content:space-between;align-items:center;
  cursor:pointer;list-style:none;
  font-size:16px;font-weight:600;color:#fff;
  padding:6px 0;
}
.faq summary::-webkit-details-marker{display:none}
.faq summary::marker{display:none}
.faq summary i{
  font-style:normal;color:#fff;font-size:24px;font-weight:300;
  transition:transform .25s ease;line-height:1;
}
.faq details[open] summary i{transform:rotate(45deg)}
.faq details p{
  margin-top:14px;color:var(--ink-soft);
  line-height:1.65;font-size:15px;max-width:760px;
}

/* ================================================
   Final CTA card
   ================================================ */
.finalcta{
  padding:var(--section-pad-y) var(--gutter);
  display:flex;justify-content:center;
}
.finalcta__card{
  width:100%;max-width:1100px;
  background:linear-gradient(180deg,#0e0e1c,#0a0a16);
  border:1px solid var(--line);
  border-radius:32px;
  padding:clamp(60px,8vw,100px) var(--gutter);
  text-align:center;
  box-shadow:0 30px 80px rgba(0,0,0,.4);
}
.finalcta__card h2{
  font-size:clamp(44px,6vw,84px);
  font-weight:800;letter-spacing:-.02em;line-height:1;
  color:#cfcfe6;
  text-shadow:0 0 80px rgba(124,92,255,.35);
}
.finalcta__card p{
  color:var(--mute);
  margin:24px auto 36px;max-width:520px;
  font-size:16px;line-height:1.55;
}

/* ================================================
   Footer
   ================================================ */
.footer{padding:40px var(--gutter) 36px}
.footer__inner{
  max-width:1100px;margin:0 auto;
  display:grid;grid-template-columns:1fr auto 1fr;
  gap:40px;align-items:start;
}
.footer__copy{color:var(--mute);font-size:13px;align-self:center}
.footer__nav{
  display:flex;flex-direction:column;gap:12px;
  text-align:center;
}
.footer__nav a{color:#cfcfe0;font-size:14px;transition:color .15s}
.footer__nav a:hover{color:#fff}
.footer__social{
  display:flex;gap:14px;justify-content:flex-end;align-items:center;
  align-self:center;
}
.footer__social a{
  width:40px;height:40px;border-radius:50%;
  background:#fff;color:#000;
  display:flex;align-items:center;justify-content:center;
  transition:transform .15s ease;
}
.footer__social a:last-child{background:#000;color:#fff;border:1px solid var(--line-2)}
.footer__social a:hover{transform:translateY(-2px)}

/* ================================================
   Responsive
   ================================================ */

/* Tablet (≤ 980px) — start collapsing 2-column layouts */
@media(max-width:980px){
  .hero__inner{grid-template-columns:1fr;gap:32px}
  .hero__text{align-items:center;text-align:center}
  .hero__sub{margin-left:auto;margin-right:auto}
  .hero__art{height:520px}
  .phone--hero-back{left:50%;margin-left:-280px}
  .phone--hero-front{right:50%;margin-right:-280px}
  .benefits__card{grid-template-columns:1fr;gap:36px}
  .benefits__marquee{height:340px}
}

/* Tablet/Large mobile (≤ 880px) */
@media(max-width:880px){
  .topbar{padding:0 16px;top:12px}
  .topbar__pill{padding:10px 12px 10px 18px}
  .brand{height:30px}
  .brand__logo{height:30px}
  .topnav{gap:14px}

  .hero{padding:100px 20px 30px}

  .hiw__panel{flex-direction:column !important;padding:36px 24px;gap:28px;text-align:center}
  .hiw__text{max-width:100%}

  .stats{grid-template-columns:1fr;gap:18px;margin-top:30px}

  .footer__inner{grid-template-columns:1fr;text-align:center;gap:20px}
  .footer__social{justify-content:center}
  .footer__copy{text-align:center}
  .footer__nav{flex-direction:row;flex-wrap:wrap;justify-content:center;gap:14px 20px}

  .phone--hero-back,.phone--hero-front{width:220px;height:440px}
  .phone--hero-back{left:50%;margin-left:-230px;top:0}
  .phone--hero-front{right:50%;margin-right:-230px;top:30px}
}

/* Mobile primary (≤ 600px) */
@media(max-width:600px){
  /* Topbar — keep all controls but compress */
  .topbar__pill{padding:9px 10px 9px 16px}
  .brand{height:28px}
  .brand__logo{height:28px}
  .topnav{gap:10px}
  .topnav > a:not(.btn){font-size:13px;padding:0 2px}
  .btn--sm{padding:8px 14px;font-size:13px}

  /* Hero typography */
  .hero{padding:90px 20px 24px}
  .hero__title{font-size:clamp(40px,11vw,60px)}
  .hero__sub{font-size:14px;margin:18px 0 24px;max-width:340px}
  .hero__sub--full{display:none}
  .hero__sub--short{display:inline}
  .newfeat{font-size:11px;padding:8px 14px;margin-bottom:20px}

  /* Hero phones — flex side-by-side with overlap, properly sized */
  .hero__art{
    height:auto;
    display:flex;
    justify-content:center;
    align-items:flex-start;
    padding:14px 0 0;
    min-height:340px;
  }
  .phone--hero-back,
  .phone--hero-front{
    position:static;
    margin:0;
    top:auto;left:auto;right:auto;
    width:160px;height:320px;
    border-radius:34px;padding:7px;
  }
  .phone--hero-back{margin-right:-22px}
  .phone--hero-front{margin-left:-22px;margin-top:30px}
  .phone__notch{width:80px;height:22px;top:9px;border-radius:14px}
  .phone__screen{border-radius:28px;padding:0}
  .phone__shot{border-radius:28px}

  /* Reveal */
  .reveal__line{font-size:clamp(18px,5.4vw,28px);line-height:1.4}
  .reveal__line + .reveal__line{margin-top:10px}
  .stat__num{font-size:clamp(34px,9vw,52px)}
  .stat__lbl{font-size:13px;max-width:280px}
  .stats{margin-top:32px}

  /* HIW phones smaller */
  .hiw__panel{padding:30px 20px;gap:24px}
  .hiw__panel .phone{width:230px;height:460px}
  .hiw__art{min-height:auto}

  /* Common section heading */
  .h2{font-size:clamp(32px,8vw,48px)}
  .hiw__text h2{font-size:clamp(28px,7vw,40px);line-height:1.05}
  .hiw__text p{font-size:15px;line-height:1.6}

  /* Testimonials — horizontal swipe carousel with snap */
  .testimonials{padding:var(--section-pad-y) 0}
  .testimonials .pill,
  .testimonials .h2{padding-left:20px;padding-right:20px}
  .tgrid{
    grid-template-columns:none !important;
    display:flex;
    overflow-x:auto;
    overflow-y:hidden;
    scroll-snap-type:x mandatory;
    scroll-behavior:smooth;
    gap:14px;
    padding:0 20px 4px;
    margin:0;
    scrollbar-width:none;
    -webkit-overflow-scrolling:touch;
  }
  .tgrid::-webkit-scrollbar{display:none}
  .tgrid > .tcard,
  .tgrid > .tcard:nth-child(n){
    flex:0 0 calc(100vw - 56px);
    grid-column:auto !important;
    min-height:auto;
    padding:20px;
    gap:14px;
    scroll-snap-align:center;
  }
  .tcard p{font-size:14px;line-height:1.55}
  .stars{font-size:16px;letter-spacing:2px}

  /* Trees */
  .tree{width:130px}
  .tree__img{width:130px;height:180px}
  .tree__name{font-size:13px;margin-top:10px}
  .trees__row{gap:48px;padding:14px 0}
  .trees .section-sub{margin:10px auto 22px;font-size:14px}

  /* Benefits card */
  .benefits{padding:var(--section-pad-y) 16px}
  .benefits__card{padding:32px 22px;border-radius:24px;gap:28px}
  .benefits__copy h2{font-size:clamp(28px,7.5vw,40px)}
  .benefits__copy p{font-size:14px;margin-bottom:24px}
  .benefits__marquee{height:260px}
  .bchip{padding:14px 16px;font-size:14px;border-radius:12px}
  .bchip .emoji{font-size:18px}

  /* FAQ */
  .faq{padding:var(--section-pad-y) 20px}
  .faq summary{font-size:14px;font-weight:600}
  .faq summary i{font-size:22px}
  .faq details{padding:18px 4px}
  .faq details p{font-size:13px;margin-top:10px;line-height:1.6}

  /* Final CTA */
  .finalcta{padding:var(--section-pad-y) 16px}
  .finalcta__card{padding:48px 22px;border-radius:24px}
  .finalcta__card h2{font-size:clamp(36px,10vw,56px)}
  .finalcta__card p{font-size:14px;margin:18px auto 24px}

  /* Footer */
  .footer{padding:32px 20px 28px}
  .footer__nav a{font-size:13px}
  .footer__social a{width:36px;height:36px}
}

/* Compact phones (≤ 380px) — squeeze further */
@media(max-width:380px){
  .topbar__pill{padding:8px 8px 8px 14px}
  .brand{height:24px}
  .brand__logo{height:24px}
  .topnav{gap:8px}
  .topnav > a:not(.btn){font-size:12px}
  .btn--sm{padding:7px 11px;font-size:12px}

  .hero{padding:80px 16px 20px}
  .hero__title{font-size:38px}

  .phone--hero-back,.phone--hero-front{width:140px;height:280px;padding:6px;border-radius:30px}
  .phone__notch{width:70px;height:20px;top:8px}
  .phone__screen{border-radius:24px}
  .phone__shot{border-radius:24px}

  .hiw__panel .phone{width:200px;height:400px}

  .tree{width:110px}
  .tree__img{width:110px;height:150px}
  .trees__row{gap:36px}
}

/* Touch device niceties — disable hover-only effects */
@media(hover:none){
  .btn:hover{transform:none}
  .footer__social a:hover{transform:none}
  .benefits__marquee:hover .benefits__inner{animation-play-state:running}
}

/* Animations on this site are deliberately subtle (gentle float, slow drift,
   marquee, soft fades) so we don't blanket-kill them under prefers-reduced-motion.
   We only ensure no element is left in a hidden initial state. */
