@font-face{font-family:'DM Sans';src:url('/fonts/DMSans.woff2') format('woff2');font-weight:100 1000;font-style:normal;font-display:swap}
@font-face{font-family:'Inter';src:url('/fonts/Inter.woff2') format('woff2');font-weight:100 900;font-style:normal;font-display:swap}
@font-face{font-family:'JetBrains Mono';src:url('/fonts/JetBrainsMono.woff2') format('woff2');font-weight:100 800;font-style:normal;font-display:swap}

.story-hint{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);z-index:3;
  font-family:var(--fm);font-size:11px;letter-spacing:2px;text-transform:uppercase;
  color:rgba(255,255,255,.5);display:flex;flex-direction:column;align-items:center;gap:8px;
  opacity:0;transition:opacity .4s;pointer-events:none}
.story-hint .wheel{width:1px;height:34px;background:rgba(255,255,255,.2);position:relative;overflow:hidden}
.story-hint .wheel::after{content:"";position:absolute;left:0;top:-40%;width:100%;height:40%;
  background:var(--cy);animation:drop 1.8s cubic-bezier(.4,0,.2,1) infinite}
.story-hint.on{opacity:1}

:root{
  --cy:#4FE3D8; --cy-soft:#D9FAF7; --cy-mid:#9FF0E9; --cy-deep:#0FA89B; --cy-ink:#0B7C73;
  --ink:#0B1215; --ink-soft:#5A6770;
  --bg:#FAFCFC; --paper:#FFFFFF; --tint:#F0FAF9;
  --line:#E4EAEA;
  --fd:'DM Sans',sans-serif; --fb:'Inter',sans-serif; --fm:'JetBrains Mono',monospace;
}
*{margin:0;padding:0;box-sizing:border-box}
html,body{overscroll-behavior:none;overflow-x:clip}
body{
  background:var(--bg); color:var(--ink); font-family:var(--fb); font-size:16px;
  line-height:1.55; -webkit-font-smoothing:antialiased;
}
::selection{background:var(--cy);color:var(--ink)}
h1,h2,h3{font-family:var(--fd);letter-spacing:-.028em}

/* ── Preloader ── */
#loader{position:fixed;inset:0;z-index:10001;background:var(--ink);color:#fff;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:14px}
#loader .l-logo{font-family:var(--fd);font-weight:800;font-size:clamp(28px,4vw,40px);overflow:hidden}
#loader .l-logo span{display:inline-block;transform:translateY(110%)}
#loader .l-logo b{color:var(--cy)}
#loader .l-bar{width:200px;height:1px;background:rgba(255,255,255,.15);overflow:hidden}
#loader .l-bar i{display:block;height:100%;width:0;background:var(--cy)}

/* skip link (a11y) */
.skip{
  position:fixed;top:-60px;left:16px;z-index:10002;background:var(--ink);color:#fff;
  padding:10px 18px;border-radius:10px;font-size:14px;text-decoration:none;transition:top .2s;
}
.skip:focus{top:14px}
.btn:focus-visible,.tabs button:focus-visible,.qa button:focus-visible{outline:3px solid var(--cy-deep);outline-offset:3px}

/* ── FAQ (compact, SEO) ── */
.faq-sec{padding:96px 24px;background:var(--bg)}
.faq-sec .f-head{text-align:center;margin-bottom:44px}
.faq-sec h2{font-size:clamp(26px,3.6vw,44px);font-weight:800}
.faq{max-width:720px;margin:0 auto}
.qa{border-bottom:1px solid var(--line)}
.qa>button{
  width:100%;background:none;border:none;cursor:pointer;text-align:left;
  font-family:var(--fd);font-weight:700;font-size:16.5px;color:var(--ink);
  padding:20px 42px 20px 4px;position:relative;
}
.qa>button::after{
  content:"+";position:absolute;right:8px;top:50%;transform:translateY(-50%);
  font-size:24px;font-weight:400;color:var(--cy-deep);transition:transform .3s cubic-bezier(.4,0,.2,1);
}
.qa.open>button::after{transform:translateY(-50%) rotate(45deg)}
.qa .ans{max-height:0;overflow:hidden;transition:max-height .4s cubic-bezier(.4,0,.2,1)}
.qa .ans p{padding:0 4px 20px;color:var(--ink-soft);font-size:15px}

#progress{position:fixed;top:0;left:0;height:2.5px;width:100%;background:var(--cy);z-index:10000;transform:scaleX(0);transform-origin:left}

nav{
  position:fixed;top:0;left:0;right:0;z-index:1000;height:66px;
  display:flex;align-items:center;
  padding:0 max(24px,calc((100vw - 1180px)/2 + 24px));
  transition:background .35s,border-color .35s;border-bottom:1px solid transparent;
}
nav.glass{background:rgba(250,252,252,.72);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom-color:var(--line)}
.logo{font-family:var(--fd);font-weight:800;font-size:20px;cursor:pointer;user-select:none}
.logo b{color:var(--cy-deep)}
nav .btn{margin-left:0}
nav .lang-sw:hover{color:var(--ink)}

.btn{
  display:inline-flex;align-items:center;gap:9px;border:none;cursor:pointer;
  font-family:var(--fb);font-weight:600;font-size:15px;text-decoration:none;
  padding:14px 28px;border-radius:100px;
  transition:transform .2s cubic-bezier(.4,0,.2,1),box-shadow .25s,background .2s;
}
.btn-dark{background:var(--ink);color:#fff}
.btn-dark .arr{color:var(--cy)}
.btn-dark:hover{transform:translateY(-2px);box-shadow:0 0 0 3px var(--cy),0 12px 26px rgba(15,168,155,.28)}
.btn-cy{background:var(--cy);color:var(--ink);box-shadow:0 8px 22px rgba(79,227,216,.35)}
.btn-cy:hover{background:#6FEFE5;transform:translateY(-2px);box-shadow:0 14px 30px rgba(79,227,216,.4)}
.btn-line{background:transparent;color:var(--ink);border:1px solid #CBD6D6}
.btn-line:hover{border-color:var(--cy-deep);color:var(--cy-ink);transform:translateY(-2px)}
.btn-sm{padding:10px 20px;font-size:14px}
.arr{transition:transform .25s}
.btn:hover .arr{transform:translateX(4px)}

/* ── Hero: one idea ── */
.hero{
  min-height:100svh;display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;padding:100px 24px 60px;position:relative;overflow:hidden;
}
.hero-glow{
  position:absolute;width:70vw;height:70vw;max-width:820px;max-height:820px;border-radius:50%;
  background:radial-gradient(circle,rgba(79,227,216,.25),transparent 60%);
  top:50%;left:50%;transform:translate(-50%,-42%);pointer-events:none;
}
.hero h1{
  font-size:clamp(48px,9vw,128px);font-weight:800;line-height:.99;max-width:1000px;position:relative;
}
.hero h1 .row{display:block;overflow:hidden;padding-bottom:.1em;margin-bottom:-.1em}
.hero h1 em{font-style:normal;color:var(--cy-deep)}
.hero .sub{font-size:clamp(16px,1.8vw,20px);color:var(--ink-soft);margin:26px 0 38px;opacity:0;position:relative}
.hero .sub b{color:var(--ink);font-weight:600}
.hero-ctas{display:flex;gap:14px;flex-wrap:wrap;justify-content:center;opacity:0;position:relative}
.hero .hint{
  position:absolute;bottom:30px;left:50%;transform:translateX(-50%);
  font-family:var(--fm);font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--ink-soft);
  display:flex;flex-direction:column;align-items:center;gap:9px;opacity:0;
}
.hero .hint .wheel{width:1px;height:38px;background:#CBD6D6;position:relative;overflow:hidden}
.hero .hint .wheel::after{content:"";position:absolute;left:0;top:-40%;width:100%;height:40%;background:var(--cy-deep);animation:drop 1.8s cubic-bezier(.4,0,.2,1) infinite}
@keyframes drop{to{top:110%}}

/* ── Scroll story: pinned phone + captions ── */
.story{position:relative;background:var(--ink)}
.story-pin{
  height:100svh;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;
  gap:clamp(20px,4vw,70px);padding:0 max(24px,calc((100vw - 1180px)/2 + 24px));
  overflow:hidden;position:relative;
}
.story-glow{
  position:absolute;width:60vw;height:60vw;border-radius:50%;
  background:radial-gradient(circle,rgba(79,227,216,.13),transparent 62%);
  top:50%;left:50%;transform:translate(-50%,-50%);pointer-events:none;
}
.captions{position:relative;height:200px;display:flex;align-items:center}
.cap{
  position:absolute;inset:0;display:flex;flex-direction:column;justify-content:center;
  opacity:0;visibility:hidden;
}
.cap .c-time{font-family:var(--fm);font-size:13px;color:var(--cy);letter-spacing:2px;margin-bottom:14px}
.cap h2{font-size:clamp(34px,4.6vw,64px);font-weight:800;color:#fff;line-height:1.02}
.cap p{color:rgba(255,255,255,.55);margin-top:12px;font-size:15.5px;max-width:300px}
.captions.right{text-align:left}

/* phone */
.phone{
  width:min(350px,86vw);background:#101820;border:1px solid rgba(255,255,255,.1);
  border-radius:38px;padding:12px;box-shadow:0 40px 90px rgba(0,0,0,.55),0 0 0 1px rgba(79,227,216,.12);
  position:relative;z-index:2;
}
.phone-screen{background:#0A1014;border-radius:28px;overflow:hidden;display:flex;flex-direction:column;height:min(620px,72svh)}
.chat-head{display:flex;align-items:center;gap:11px;padding:14px 16px;background:#121B22;border-bottom:1px solid rgba(255,255,255,.06)}
.avatar{width:36px;height:36px;border-radius:50%;flex-shrink:0;background:linear-gradient(135deg,var(--cy),var(--cy-deep));display:flex;align-items:center;justify-content:center;font-family:var(--fd);font-weight:800;color:var(--ink);font-size:14px}
.chat-head .name{font-weight:600;font-size:13.5px;color:#fff;line-height:1.2}
.chat-head .status{font-size:11px;color:var(--cy);font-family:var(--fm)}
.chat-body{flex:1;padding:18px 14px;overflow:hidden;position:relative}
.chat-scroll{display:flex;flex-direction:column;gap:10px;position:relative;will-change:transform}
.msg{
  max-width:84%;padding:10px 13px;border-radius:15px;font-size:13.5px;line-height:1.45;color:#E7EDF0;
  opacity:0;transform:translateY(16px) scale(.96);
}
.msg.in{align-self:flex-start;background:#1C262E;border-bottom-left-radius:5px}
.msg.out{align-self:flex-end;background:rgba(79,227,216,.16);border:1px solid rgba(79,227,216,.3);border-bottom-right-radius:5px}
.msg time{display:block;font-size:10px;color:rgba(255,255,255,.4);margin-top:4px;font-family:var(--fm)}
.msg .check{color:var(--cy)}
.phone-badge{
  position:absolute;bottom:-16px;left:50%;transform:translateX(-50%);
  background:var(--ink);border:1px solid rgba(79,227,216,.4);border-radius:100px;
  padding:8px 18px;font-family:var(--fm);font-size:11px;color:var(--cy);white-space:nowrap;
  box-shadow:0 12px 28px rgba(0,0,0,.5);
}

/* ── Agents: one line each ── */
.team{padding:110px max(24px,calc((100vw - 1180px)/2 + 24px));text-align:center}
.team h2{font-size:clamp(32px,5vw,68px);font-weight:800}
.team h2 em{font-style:normal;color:var(--cy-deep)}
.team .sub{color:var(--ink-soft);margin-top:14px;font-size:17px}
.chips{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin-top:46px;max-width:880px;margin-left:auto;margin-right:auto}
.chip{
  display:inline-flex;align-items:center;gap:10px;background:var(--paper);
  border:1px solid var(--line);border-radius:100px;padding:13px 22px;
  font-family:var(--fd);font-weight:700;font-size:15.5px;cursor:default;
  transition:transform .25s cubic-bezier(.4,0,.2,1),box-shadow .25s,border-color .25s;
}
.chip:hover{transform:translateY(-4px) scale(1.04);box-shadow:0 16px 34px rgba(15,168,155,.16);border-color:var(--cy-mid)}
.chip .c-dot{width:8px;height:8px;border-radius:50%;background:var(--cy);flex-shrink:0}
.chip span{font-family:var(--fb);font-weight:400;color:var(--ink-soft);font-size:14px}

/* ── Channels: same brain, every surface ── */
.channels{
  background:var(--ink);color:#fff;padding:110px 24px 90px;
  text-align:center;position:relative;overflow:hidden;
}
.channels .ch-glow{position:absolute;width:70vw;height:70vw;border-radius:50%;top:-30%;right:-20%;background:radial-gradient(circle,rgba(79,227,216,.1),transparent 60%);pointer-events:none}
.channels h2{font-size:clamp(32px,5vw,68px);font-weight:800;position:relative}
.channels h2 em{font-style:normal;color:var(--cy)}
.channels .sub{color:rgba(255,255,255,.55);margin-top:14px;font-size:17px;position:relative}
.tabs{
  display:inline-flex;gap:6px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);
  border-radius:100px;padding:6px;margin-top:42px;position:relative;flex-wrap:wrap;justify-content:center;
}
.tabs button{
  border:none;background:transparent;color:rgba(255,255,255,.55);font-family:var(--fb);
  font-weight:600;font-size:14px;padding:11px 22px;border-radius:100px;cursor:pointer;
  transition:color .25s,background .25s;
}
.tabs button.on{background:var(--cy);color:var(--ink)}
.stage-wrap{
  max-width:560px;margin:44px auto 0;position:relative;min-height:430px;
}
.stage{
  position:absolute;inset:0;opacity:0;visibility:hidden;transform:translateY(16px) scale(.98);
  text-align:left;
}
.stage.on{opacity:1;visibility:visible;transform:none;transition:opacity .45s cubic-bezier(.4,0,.2,1),transform .45s cubic-bezier(.4,0,.2,1)}
.surface{
  background:#101820;border:1px solid rgba(255,255,255,.1);border-radius:20px;overflow:hidden;
  box-shadow:0 30px 70px rgba(0,0,0,.5);
}
.surface .s-bar{
  display:flex;align-items:center;gap:10px;padding:12px 16px;background:#151F28;
  border-bottom:1px solid rgba(255,255,255,.07);font-size:12.5px;color:rgba(255,255,255,.55);
  font-family:var(--fm);
}
.surface .s-bar .dots{display:flex;gap:5px}
.surface .s-bar .dots i{width:9px;height:9px;border-radius:50%;background:rgba(255,255,255,.15)}
.surface .s-body{padding:18px;display:flex;flex-direction:column;gap:10px}
.sb{max-width:86%;padding:10px 13px;border-radius:14px;font-size:13.5px;line-height:1.5;color:#E7EDF0}
.sb.in{align-self:flex-start;background:#1C262E;border-bottom-left-radius:5px}
.sb.out{align-self:flex-end;background:rgba(79,227,216,.16);border:1px solid rgba(79,227,216,.3);border-bottom-right-radius:5px}
.sb time{display:block;font-size:10px;color:rgba(255,255,255,.4);margin-top:4px;font-family:var(--fm)}
/* email skin */
.mail .m-row{font-size:13px;color:rgba(255,255,255,.55);font-family:var(--fm)}
.mail .m-subj{font-weight:700;font-family:var(--fd);font-size:16px;color:#fff;margin:4px 0 10px}
.mail .m-body{font-size:13.5px;color:#C9D3D9;line-height:1.6;border-left:2px solid rgba(255,255,255,.12);padding-left:14px}
.mail .m-reply{
  margin-top:14px;background:rgba(79,227,216,.08);border:1px solid rgba(79,227,216,.25);
  border-radius:12px;padding:14px;font-size:13.5px;color:#E7EDF0;line-height:1.6;
}
.mail .m-tag{display:inline-flex;align-items:center;gap:7px;font-family:var(--fm);font-size:10.5px;color:var(--cy);margin-bottom:8px;letter-spacing:1px}
/* report skin */
.report .r-line{display:flex;justify-content:space-between;align-items:center;padding:11px 0;border-bottom:1px solid rgba(255,255,255,.07);font-size:13.5px;color:#C9D3D9}
.report .r-line:last-child{border:none}
.report .r-line b{font-family:var(--fd);font-size:17px;color:#fff}
.report .r-line .pos{color:var(--cy)}
.report .r-head{font-family:var(--fm);font-size:11px;letter-spacing:1.5px;color:var(--cy);margin-bottom:6px}
.stage .s-cap{
  text-align:center;margin-top:18px;font-size:14px;color:rgba(255,255,255,.5);
}
.stage .s-cap b{color:#fff;font-weight:600}

/* ── Business types marquee ── */
.biz{padding:64px 0;border-top:1px solid rgba(255,255,255,.08);margin-top:80px;overflow:hidden;white-space:nowrap;position:relative}
.biz-track{display:inline-flex;will-change:transform}
.biz-track span{font-family:var(--fd);font-weight:700;font-size:clamp(16px,2vw,23px);padding-right:56px;color:rgba(255,255,255,.85)}
.biz-track span i{font-style:normal;color:rgba(255,255,255,.4);font-family:var(--fb);font-weight:400;font-size:.85em}
.biz-track span b{color:var(--cy)}

/* ── Stats: real production numbers ── */
.numbers{
  background:var(--tint);border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  padding:96px 24px;text-align:center;
}
.numbers .eyebrow-c{
  font-family:var(--fm);font-size:12px;letter-spacing:2.5px;text-transform:uppercase;
  color:var(--cy-ink);margin-bottom:50px;
}
.numbers-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:24px;
  max-width:1100px;margin:0 auto;
}
.num .n{
  font-family:var(--fd);font-weight:800;font-size:clamp(48px,6.8vw,96px);line-height:1;
  letter-spacing:-.035em;font-variant-numeric:tabular-nums;
}
.num .n b{color:var(--cy-deep)}
.num .l{margin-top:10px;color:var(--ink-soft);font-size:15px;max-width:280px;margin-left:auto;margin-right:auto}
.numbers .upsell-card{
  margin:60px auto 0;max-width:820px;background:var(--ink);color:#fff;
  border-radius:24px;padding:46px 40px;position:relative;overflow:hidden;
  text-align:center;box-shadow:0 30px 70px rgba(11,18,21,.25);
}
.numbers .upsell-card::before{
  content:"";position:absolute;width:60%;height:140%;top:-20%;right:-15%;border-radius:50%;
  background:radial-gradient(circle,rgba(79,227,216,.18),transparent 65%);pointer-events:none;
}
.upsell-card .u-tag{
  font-family:var(--fm);font-size:11.5px;letter-spacing:2px;text-transform:uppercase;
  color:var(--cy);margin-bottom:18px;position:relative;
}
.upsell-card .u-num{
  font-family:var(--fd);font-weight:800;font-size:clamp(54px,8vw,108px);line-height:1;
  letter-spacing:-.035em;position:relative;font-variant-numeric:tabular-nums;
}
.upsell-card .u-num b{color:var(--cy)}
.upsell-card .u-sub{
  margin-top:14px;font-size:clamp(15px,1.8vw,18px);color:rgba(255,255,255,.7);
  max-width:520px;margin-left:auto;margin-right:auto;position:relative;
}
.upsell-card .u-sub b{color:#fff}
.upsell-card .u-meta{
  display:flex;justify-content:center;gap:34px;margin-top:26px;position:relative;flex-wrap:wrap;
}
.upsell-card .u-meta span{font-family:var(--fm);font-size:12.5px;color:rgba(255,255,255,.55)}
.upsell-card .u-meta b{color:var(--cy);font-size:17px;font-family:var(--fd);display:block;margin-bottom:2px}
.numbers .src{
  margin-top:26px;font-family:var(--fm);font-size:11.5px;letter-spacing:1.5px;
  text-transform:uppercase;color:var(--ink-soft);
}

/* ── Voices: real client messages ── */
.voices{padding:84px 0;overflow:hidden;background:var(--paper);border-bottom:1px solid var(--line)}
.voices .v-head{text-align:center;margin-bottom:42px;padding:0 24px}
.voices h2{font-size:clamp(26px,3.6vw,44px);font-weight:800}
.voices h2 em{font-style:normal;color:var(--cy-deep)}
.voices .v-sub{font-family:var(--fm);font-size:11.5px;letter-spacing:1.5px;text-transform:uppercase;color:var(--ink-soft);margin-top:12px}
.v-row{display:flex;width:max-content;will-change:transform;margin-bottom:16px}
.vb{
  background:var(--tint);border:1px solid var(--line);border-radius:18px 18px 18px 5px;
  padding:13px 18px;font-size:14.5px;color:var(--ink);margin-right:14px;white-space:nowrap;
}
.v-row.rev .vb{border-radius:18px 18px 5px 18px;background:var(--cy-soft);border-color:var(--cy-mid)}

/* ── CTA: the demo is the CTA ── */
.cta{
  background:var(--ink);color:#fff;text-align:center;position:relative;overflow:hidden;
  padding:130px 24px 110px;
}
.cta-glow{position:absolute;width:80vw;height:50vh;bottom:-25vh;left:10vw;border-radius:50%;background:radial-gradient(ellipse,rgba(79,227,216,.22),transparent 65%);pointer-events:none}
.cta h2{font-size:clamp(40px,7.5vw,104px);font-weight:800;line-height:1;max-width:900px;margin:0 auto}
.cta h2 .row{display:block;overflow:hidden;padding-bottom:.1em;margin-bottom:-.1em}
.cta h2 em{font-style:normal;color:var(--cy)}
.cta p{color:rgba(255,255,255,.6);margin:24px auto 40px;position:relative;font-size:17px}
.cta p b{color:#fff}
.cta .micro{font-family:var(--fm);font-size:12px;color:rgba(255,255,255,.4);margin-top:22px;letter-spacing:1px}

footer.site{background:var(--ink);border-top:1px solid rgba(255,255,255,.08);padding:32px 24px;color:rgba(255,255,255,.45)}
.f-inner{max-width:1180px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px}
.f-inner p{font-size:13px}
.f-inner .f353{cursor:pointer;font-weight:600;color:rgba(255,255,255,.75);transition:color .2s}
.f-inner .f353:hover{color:var(--cy)}
.f-links{display:flex;gap:18px}
.f-links a{font-size:13px;color:rgba(255,255,255,.45);text-decoration:none}
.f-links a:hover{color:#fff}

#confetti{position:fixed;inset:0;z-index:9400;pointer-events:none}
#toast{
  position:fixed;bottom:26px;left:50%;transform:translateX(-50%) translateY(100px);
  background:#fff;color:var(--ink);border-radius:14px;padding:14px 26px;
  font-size:14px;font-weight:500;z-index:9600;transition:transform .45s cubic-bezier(.34,1.56,.64,1);
  box-shadow:0 24px 56px rgba(0,0,0,.35);max-width:90vw;text-align:center;
}
#toast.on{transform:translateX(-50%) translateY(0)}

@media (max-width:900px){
  .story-pin{grid-template-columns:1fr;justify-items:center;gap:26px;padding-top:80px;padding-bottom:60px;height:auto;min-height:100svh}
  .captions{height:130px;text-align:center;width:100%}
  .cap{align-items:center}
  .captions.right{display:none}
  .phone-screen{height:min(520px,60svh)}
  .numbers-grid{grid-template-columns:1fr;gap:48px}
}
@media (prefers-reduced-motion:reduce){
  #loader{display:none}
  .hero .sub,.hero-ctas,.hero .hint{opacity:1}
  .msg{opacity:1;transform:none}
  .cap:first-child{opacity:1;visibility:visible}
  .hero .hint .wheel::after{animation:none}
}

/* PT runs longer — tighten the chat so the full stack always fits */
html[lang="pt-BR"] .chat-scroll{gap:8px}

/* ── Mobile hardening ── */
@media (max-width:900px){
  .captions{height:150px}
  .cap h2{font-size:clamp(24px,6.5vw,36px)}
  .cap p{font-size:13.5px;max-width:280px;margin-left:auto;margin-right:auto}
  .cap .c-time{margin-bottom:8px}
  .story-pin{padding-top:70px;padding-bottom:52px;gap:16px}
  .story-hint{bottom:6px;font-size:10px}
  .story-hint .wheel{height:24px}
  /* channels: stages flow naturally instead of fixed-height overlay */
  .stage-wrap{min-height:0}
  .stage{display:none;position:static;opacity:1;visibility:visible;transform:none}
  .stage.on{display:block}
}
/* short phones: shrink the phone so the pinned scene fits 100svh */
@media (max-width:900px) and (max-height:720px){
  .phone-screen{height:min(400px,48svh)}
  .captions{height:120px}
  .cap h2{font-size:clamp(21px,6vw,30px)}
}

/* ── Safari compositor diet — backdrop-filter + huge blurred glows are
   the main jank sources on WebKit; trade them for cheaper equivalents ── */
.is-safari nav.glass {
  background: rgba(250, 252, 252, 0.96);
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
}
.is-safari .hero-glow,
.is-safari .story-glow,
.is-safari .ch-glow,
.is-safari .cta-glow {
  opacity: 0.55;
}
.is-safari .phone {
  box-shadow: 0 24px 50px rgba(0, 0, 0, 0.45);
}