/* Self-contained over HTTP: a synced copy of web/src/styles/tokens.css (brand
   lockstep D2 — guarded by a test) + locally self-hosted brand fonts. The old
   "../web/src/..." import 404'd when served from /welcome, which killed the dark
   palette and --font-ui (→ serif fallback). */
@import url("tokens.css");
@import url("fonts.css");

/* ============================================================================
   tghub — marketing landing · structural tokens
   COLOR tokens + both [data-theme] palettes are inherited from the imported
   ../web/src/styles/tokens.css (brand lockstep, decision D2). Only the
   structural / non-color tokens live here (radii, eases, max width, mono font)
   — copied verbatim from the prototype :root, since tokens.css does not carry
   them (they live in the app index.css).
   ============================================================================ */
:root{
  --font-mono:"IBM Plex Mono",ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;
  --r-xs:7px; --r-sm:10px; --r:13px; --r-lg:18px; --r-xl:24px;
  --ease:cubic-bezier(.22,.61,.36,1);
  --ease-out:cubic-bezier(.16,1,.3,1);
  --maxw:1240px;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:var(--font-ui); background:var(--bg); color:var(--ink);
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
  letter-spacing:-.011em; line-height:1.5; overflow-x:hidden;
}
body::before{ /* blueprint grid */
  content:""; position:fixed; inset:0; z-index:0; pointer-events:none;
  background-image:linear-gradient(var(--grid) 1px,transparent 1px),
                   linear-gradient(90deg,var(--grid) 1px,transparent 1px);
  background-size:46px 46px; mask:radial-gradient(120% 90% at 50% 0%,#000 55%,transparent 100%);
}
::selection{background:var(--accent-glow); color:var(--ink)}
a{color:inherit;text-decoration:none}
.mono{font-family:var(--font-mono); font-variant-numeric:tabular-nums; letter-spacing:-.02em}
.num{font-variant-numeric:tabular-nums}
.faint{color:var(--ink-3)}
.eyebrow{font-family:var(--font-mono); font-size:11px; letter-spacing:.18em; text-transform:uppercase; color:var(--eyebrow); font-weight:500}
button{font-family:inherit; cursor:pointer; border:0; background:none; color:inherit}
:focus-visible{outline:2px solid var(--accent); outline-offset:2px; border-radius:6px}
/* skip-link: visually hidden until focused, then pinned top-left over the bar */
.skip-link{position:fixed;left:8px;top:-60px;z-index:120;padding:9px 14px;border-radius:var(--r-sm);
  background:var(--panel);color:var(--ink);border:1px solid var(--line-2);box-shadow:var(--shadow);
  font-size:13px;font-weight:600;transition:top .16s var(--ease)}
.skip-link:focus{top:8px}

/* ---- shared atoms ---- */
.btn{display:inline-flex; align-items:center; gap:8px; height:42px; padding:0 18px;
  border-radius:var(--r-sm); font-weight:600; font-size:14px; transition:.18s var(--ease);
  border:1px solid transparent; white-space:nowrap}
.btn-pri{background:linear-gradient(180deg,var(--accent-2),var(--accent)); color:var(--on-accent);
  box-shadow:0 8px 24px -10px var(--accent-glow), inset 0 1px 0 rgba(255,255,255,.35)}
.btn-pri:hover{transform:translateY(-1px); box-shadow:0 14px 30px -10px var(--accent-glow), inset 0 1px 0 rgba(255,255,255,.45)}
.btn-ghost{background:var(--glass); border-color:var(--line-2); color:var(--ink)}
.btn-ghost:hover{border-color:var(--accent); color:var(--accent); background:var(--accent-faint)}
.btn-sm{height:34px; padding:0 13px; font-size:13px}
.dot{width:7px;height:7px;border-radius:50%;display:inline-block;background:var(--accent);
  box-shadow:0 0 0 0 var(--accent-glow)}
.dot.live{animation:pulse 2.2s var(--ease) infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 var(--accent-glow)}70%{box-shadow:0 0 0 7px transparent}100%{box-shadow:0 0 0 0 transparent}}
.pill{display:inline-flex;align-items:center;gap:6px;height:23px;padding:0 9px;border-radius:999px;
  font-family:var(--font-mono);font-size:11px;font-weight:500;letter-spacing:.02em;
  border:1px solid var(--line-2);background:var(--panel-2);color:var(--ink-2)}
.pill .dt{width:6px;height:6px;border-radius:50%}
.pill.run{color:var(--ok);border-color:var(--ok-faint);background:var(--ok-faint)} .pill.run .dt{background:var(--ok)}
.pill.warn{color:var(--warn);border-color:var(--warn-faint);background:var(--warn-faint)} .pill.warn .dt{background:var(--warn)}
.pill.err{color:var(--err);border-color:var(--err-faint);background:var(--err-faint)} .pill.err .dt{background:var(--err)}
.pill.info{color:var(--info);border-color:var(--info-faint);background:var(--info-faint)} .pill.info .dt{background:var(--info)}
.pill.idle{color:var(--ink-3)} .pill.idle .dt{background:var(--ink-3)}

/* progress / bars */
.track{height:5px;border-radius:999px;background:var(--panel-3);overflow:hidden;position:relative}
.track>i{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,var(--accent-deep),var(--accent));
  position:relative;transition:width 1.1s var(--ease-out)}
.track.warn>i{background:linear-gradient(90deg,var(--warn-deep),var(--warn))}
.track.info>i{background:linear-gradient(90deg,var(--info-deep),var(--info))}
.track.err>i{background:linear-gradient(90deg,var(--err-deep),var(--err))}

/* ============================ TOP BAR ============================ */
.modebar{position:fixed;top:0;left:0;right:0;height:46px;z-index:80;display:flex;align-items:center;
  gap:14px;padding:0 16px;background:color-mix(in srgb,var(--bg) 78%,transparent);
  backdrop-filter:blur(14px) saturate(1.2);border-bottom:1px solid var(--line)}
.modebar .brandmini{display:flex;align-items:center;gap:9px;font-weight:700;letter-spacing:-.02em}
.logo{width:24px;height:24px;border-radius:7px;background:linear-gradient(150deg,var(--accent-2),var(--accent-deep));
  display:grid;place-items:center;box-shadow:0 0 0 1px var(--edge),0 6px 16px -6px var(--accent-glow);position:relative;flex:none}
.logo::after{content:"";position:absolute;width:9px;height:9px;border-radius:3px;background:var(--bg);
  box-shadow:inset 0 0 0 2px var(--accent)}
.modebar .spacer{flex:1}
.iconbtn{width:34px;height:34px;border-radius:9px;border:1px solid var(--line);background:var(--glass);
  display:grid;place-items:center;color:var(--ink-2);transition:.16s}
.iconbtn:hover{color:var(--accent);border-color:var(--accent);background:var(--accent-faint)}
.tag-concept{font-family:var(--font-mono);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--ink-3);border:1px dashed var(--line-2);border-radius:999px;padding:4px 10px}

/* page wrapper */
#landing{position:relative;z-index:1}

/* ============================ LANDING ============================ */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
.lnav{position:sticky;top:46px;z-index:60;backdrop-filter:blur(12px);
  background:color-mix(in srgb,var(--bg) 70%,transparent);border-bottom:1px solid var(--line)}
.lnav .row{display:flex;align-items:center;gap:26px;height:64px}
.lnav .brand{display:flex;align-items:center;gap:11px;font-weight:800;font-size:18px;letter-spacing:-.03em}
.lnav nav{display:flex;gap:26px;margin-left:14px}
.lnav nav a{font-size:14px;color:var(--ink-2);font-weight:500;transition:.15s}
.lnav nav a:hover{color:var(--ink)}
.lnav .spacer{flex:1}
@media(max-width:880px){.lnav nav{display:none}}

.hero{position:relative;padding:84px 0 36px;overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;background:var(--hero-glow);pointer-events:none}
.hero .grid2{display:grid;grid-template-columns:1.02fr 1.15fr;gap:54px;align-items:center;position:relative}
@media(max-width:1000px){.hero .grid2{grid-template-columns:1fr;gap:34px}}
.hero h1{font-size:clamp(34px,4.4vw,58px);line-height:1.03;letter-spacing:-.035em;font-weight:800;margin:18px 0 0}
.hero h1 .hl{background:linear-gradient(120deg,var(--accent-2),var(--iris));-webkit-background-clip:text;background-clip:text;color:transparent}
.hero p.lead{font-size:18px;line-height:1.6;color:var(--ink-2);margin:20px 0 28px;max-width:540px}
.hero .cta{display:flex;gap:12px;flex-wrap:wrap}
.badge-row{display:flex;gap:9px;flex-wrap:wrap;margin-top:26px}
.minibadge{display:inline-flex;align-items:center;gap:7px;font-size:12.5px;color:var(--ink-2);
  border:1px solid var(--line);background:var(--glass);border-radius:999px;padding:6px 12px}
.minibadge b{color:var(--ink);font-weight:600}

/* hero device — live mission control mock */
.device{position:relative;border-radius:var(--r-lg);background:linear-gradient(180deg,var(--panel-2),var(--panel));
  border:1px solid var(--line-2);box-shadow:var(--shadow-pop),inset 0 1px 0 var(--edge);overflow:hidden}
.device .chrome{display:flex;align-items:center;gap:8px;padding:11px 14px;border-bottom:1px solid var(--line);
  background:var(--panel-2)}
.device .chrome .tl{display:flex;gap:6px}.device .chrome .tl i{width:10px;height:10px;border-radius:50%;background:var(--line-2)}
.device .chrome .addr{flex:1;text-align:center;font-family:var(--font-mono);font-size:11px;color:var(--ink-3)}
.device .body{padding:14px;display:grid;gap:11px}
.dvc-top{display:flex;align-items:center;justify-content:space-between}
.dvc-top .ttl{font-size:13px;font-weight:700;display:flex;align-items:center;gap:8px}
.dvc-metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:9px}
.mcard{background:var(--panel);border:1px solid var(--line);border-radius:var(--r-sm);padding:11px 12px;position:relative;overflow:hidden}
.mcard .lab{font-family:var(--font-mono);font-size:9.5px;letter-spacing:.13em;text-transform:uppercase;color:var(--ink-3)}
.mcard .val{font-size:23px;font-weight:700;margin-top:3px;font-variant-numeric:tabular-nums;letter-spacing:-.02em}
.mcard .sub{font-size:11px;color:var(--ink-3);margin-top:1px}
.dvc-chart{background:var(--panel);border:1px solid var(--line);border-radius:var(--r-sm);padding:9px 11px}
.dvc-chart .ch-h{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}
.dvc-chart .ch-h .lab{font-family:var(--font-mono);font-size:9.5px;letter-spacing:.13em;text-transform:uppercase;color:var(--ink-3)}
.dvc-chart .ch-h .v{font-family:var(--font-mono);font-size:11px;color:var(--ink-2)}
.dvc-chart svg{display:block;width:100%;height:62px}
.lane{background:var(--panel);border:1px solid var(--line);border-radius:var(--r-sm);padding:10px 11px;display:grid;gap:9px}
.oprow{display:flex;align-items:center;gap:10px}
.oprow .nm{font-size:12.5px;font-weight:600;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.oprow .id{font-family:var(--font-mono);font-size:10.5px;color:var(--ink-3)}
.oprow .tr{width:74px}
.logfeed{font-family:var(--font-mono);font-size:11px;line-height:1.85;color:var(--ink-2);height:84px;overflow:hidden;
  -webkit-mask-image:linear-gradient(180deg,transparent,#000 22%,#000 88%,transparent);
  mask-image:linear-gradient(180deg,transparent,#000 22%,#000 88%,transparent)}
.logfeed b{color:var(--accent);font-weight:500}.logfeed .t{color:var(--ink-4)}
.logline{opacity:0;transform:translateY(6px);animation:logIn .5s var(--ease-out) forwards}
@keyframes logIn{to{opacity:1;transform:none}}
.floaty{position:absolute;border-radius:var(--r);background:var(--panel-2);border:1px solid var(--line-2);
  box-shadow:var(--shadow);padding:11px 13px;display:flex;align-items:center;gap:11px;backdrop-filter:blur(6px)}
.floaty .ico{width:30px;height:30px;border-radius:9px;display:grid;place-items:center;background:var(--ok-faint);color:var(--ok)}
.floaty .k{font-size:11px;color:var(--ink-3)}.floaty .v{font-size:14px;font-weight:700}
.f1{right:-14px;top:64px;animation:float1 7s var(--ease) infinite}
.f2{left:-22px;bottom:48px;animation:float1 8.5s var(--ease) infinite reverse}
@keyframes float1{0%,100%{transform:translateY(0)}50%{transform:translateY(-9px)}}
@media(max-width:1000px){.floaty{display:none}}

/* logos / trust strip */
.trust{padding:30px 0 8px;border-top:1px solid var(--line);margin-top:48px}
.trust .lab{text-align:center;font-family:var(--font-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-3)}
.statline{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:22px}
@media(max-width:760px){.statline{grid-template-columns:repeat(2,1fr)}}
.statbig{text-align:center}
.statbig .n{font-size:32px;font-weight:800;letter-spacing:-.03em;font-variant-numeric:tabular-nums;
  background:linear-gradient(180deg,var(--ink),var(--ink-2));-webkit-background-clip:text;background-clip:text;color:transparent}
.statbig .l{font-size:12.5px;color:var(--ink-3);margin-top:4px}

/* section heading */
.section{padding:78px 0}
.shead{max-width:680px;margin:0 auto 42px;text-align:center}
.shead h2{font-size:clamp(26px,3vw,38px);letter-spacing:-.03em;font-weight:800;margin:12px 0 0;line-height:1.1}
.shead p{color:var(--ink-2);font-size:16px;margin-top:14px;line-height:1.6}

/* feature grid */
.fgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media(max-width:980px){.fgrid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:640px){.fgrid{grid-template-columns:1fr}}
.fcard{position:relative;background:linear-gradient(180deg,var(--panel-2),var(--panel));border:1px solid var(--line);
  border-radius:var(--r-lg);padding:22px;transition:.22s var(--ease);overflow:hidden}
.fcard::before{content:"";position:absolute;inset:0;border-radius:inherit;padding:1px;
  background:linear-gradient(180deg,var(--edge),transparent);-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;opacity:.6;pointer-events:none}
.fcard:hover{transform:translateY(-3px);border-color:var(--line-2);box-shadow:var(--shadow)}
.fcard .fico{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;margin-bottom:15px;
  background:var(--accent-faint);color:var(--accent);border:1px solid var(--accent-faint)}
.fcard h3{font-size:16.5px;font-weight:700;letter-spacing:-.02em;margin:0 0 7px}
.fcard p{font-size:13.5px;color:var(--ink-2);line-height:1.6;margin:0}
.fcard .meta{margin-top:14px;display:flex;gap:7px;flex-wrap:wrap}
.chip{font-family:var(--font-mono);font-size:10.5px;color:var(--ink-3);border:1px solid var(--line);border-radius:6px;padding:3px 7px}

/* antiban split */
.split{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
@media(max-width:940px){.split{grid-template-columns:1fr;gap:30px}}
.checklist{display:grid;gap:14px;margin-top:22px}
.checklist .it{display:flex;gap:13px;align-items:flex-start}
.checklist .ck{width:24px;height:24px;border-radius:8px;flex:none;display:grid;place-items:center;
  background:var(--ok-faint);color:var(--ok);margin-top:1px}
.checklist h4{margin:0 0 3px;font-size:14.5px;font-weight:600}
.checklist p{margin:0;font-size:13px;color:var(--ink-2);line-height:1.55}
.panelcard{background:linear-gradient(180deg,var(--panel-2),var(--panel));border:1px solid var(--line-2);
  border-radius:var(--r-lg);box-shadow:var(--shadow);padding:18px}
.acctgrid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media(max-width:520px){.acctgrid{grid-template-columns:1fr}}
.acct{background:var(--panel);border:1px solid var(--line);border-radius:var(--r);padding:13px;display:grid;gap:10px}
.acct .top{display:flex;align-items:center;gap:10px}
.ring{--p:70;--c:var(--ok);width:38px;height:38px;border-radius:50%;flex:none;display:grid;place-items:center;
  background:conic-gradient(var(--c) calc(var(--p)*1%),var(--panel-3) 0);position:relative}
.ring::after{content:"";position:absolute;inset:4px;border-radius:50%;background:var(--panel)}
.ring b{position:relative;font-family:var(--font-mono);font-size:11px;font-weight:600}
.acct .who{flex:1;min-width:0}
.acct .who .h{font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.acct .who .s{font-family:var(--font-mono);font-size:10.5px;color:var(--ink-3)}
.budget{display:grid;gap:6px}
.budget .br{display:flex;align-items:center;justify-content:space-between;font-size:11px;color:var(--ink-3)}
.budget .br b{color:var(--ink-2);font-family:var(--font-mono)}

/* comparison */
.cmp{border:1px solid var(--line-2);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow)}
.cmp .crow{display:grid;grid-template-columns:1.4fr 1fr 1fr;align-items:center}
.cmp .crow>div{padding:15px 18px;border-bottom:1px solid var(--line)}
.cmp .chd{background:var(--panel-2);font-weight:700;font-size:13.5px}
.cmp .chd .them{color:var(--ink-3)}.cmp .chd .us{color:var(--accent);display:flex;align-items:center;gap:8px}
.cmp .crow .ft{font-size:13.5px;color:var(--ink-2)}
.cmp .crow .vx{font-size:13px;color:var(--ink-3);font-family:var(--font-mono)}
.cmp .crow .vc{font-size:13px;color:var(--ink);font-family:var(--font-mono);display:flex;align-items:center;gap:7px}
.cmp .crow:last-child>div{border-bottom:0}
.vc .yes{color:var(--ok)} .vx .no{color:var(--err)}

/* pricing */
.pgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;align-items:stretch}
@media(max-width:900px){.pgrid{grid-template-columns:1fr;max-width:420px;margin:0 auto}}
.plan{background:linear-gradient(180deg,var(--panel-2),var(--panel));border:1px solid var(--line);
  border-radius:var(--r-lg);padding:24px;display:flex;flex-direction:column;gap:16px;position:relative}
.plan.feat{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent-faint),0 30px 70px -34px var(--accent-glow)}
.plan.feat::before{content:"Рекомендуем";position:absolute;top:-11px;left:24px;font-family:var(--font-mono);
  font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;background:linear-gradient(180deg,var(--accent-2),var(--accent));
  color:var(--on-accent);padding:4px 10px;border-radius:999px;font-weight:600}
.plan .pn{font-family:var(--font-mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-2)}
.plan .pp{font-size:34px;font-weight:800;letter-spacing:-.03em}.plan .pp small{font-size:14px;font-weight:500;color:var(--ink-3)}
.plan .pd{font-size:13px;color:var(--ink-3)}
.plan ul{list-style:none;margin:4px 0 0;padding:0;display:grid;gap:10px}
.plan li{font-size:13.5px;color:var(--ink-2);display:flex;gap:10px;align-items:flex-start}
.plan li svg{color:var(--accent);flex:none;margin-top:2px}
.plan .btn{justify-content:center;margin-top:auto}
.lifetime{margin-top:22px;display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap;
  background:linear-gradient(110deg,var(--accent-faint),transparent 70%);border:1px solid var(--accent-faint);
  border-radius:var(--r-lg);padding:18px 22px}
.lifetime .l b{color:var(--accent)}
.lifetime .price{font-size:26px;font-weight:800}.lifetime .price s{font-size:15px;color:var(--ink-4);font-weight:500;margin-right:8px}

/* cta band */
.ctaband{position:relative;border:1px solid var(--line-2);border-radius:var(--r-xl);overflow:hidden;
  background:linear-gradient(180deg,var(--panel-2),var(--panel));padding:54px 28px;text-align:center;box-shadow:var(--shadow)}
.ctaband::before{content:"";position:absolute;inset:0;background:var(--hero-glow);opacity:.8}
.ctaband h2{position:relative;font-size:clamp(26px,3vw,38px);font-weight:800;letter-spacing:-.03em;margin:0}
.ctaband p{position:relative;color:var(--ink-2);max-width:520px;margin:14px auto 26px;font-size:16px}
.ctaband .cta{position:relative;display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

footer{border-top:1px solid var(--line);margin-top:30px;padding:34px 0 50px;color:var(--ink-3);font-size:13px}
footer .row{display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap;align-items:center}
footer .disc{font-size:11.5px;color:var(--ink-2);max-width:620px;margin-top:14px;line-height:1.5}

/* ============================ scroll-reveal ============================ */
/* Progressive + motion-safe: the hidden start-state applies ONLY when JS has
   marked <html class="reveal-ready"> AND motion is allowed. Without JS, or under
   prefers-reduced-motion, every element stays fully visible (no opacity trap). */
@media (prefers-reduced-motion: no-preference){
  html.reveal-ready .rv{
    opacity:0; transform:translateY(16px);
    transition:opacity .66s var(--ease-out), transform .66s var(--ease-out);
    transition-delay:var(--rv-d,0ms);
  }
  html.reveal-ready .rv.rv-in{opacity:1; transform:none}
}

@media (prefers-reduced-motion: reduce){*{animation:none!important;transition:none!important}}

/* ============================================================================
   PREMIUM-MINIMAL  (Linear / Vercel / Stripe-grade)
   Layered last so it elevates the working layout without rewriting it:
   distinctive Onest display type, a far bigger scale, generous negative space,
   one refined atmosphere (soft glow + fine grain), hairline strokes, restraint.
   ============================================================================ */
:root{ --font-display:"Onest", var(--font-ui); }

/* — atmosphere: calmer grid + a whisper of grain for depth — */
body::before{ background-size:72px 72px; opacity:.55; }
body::after{
  content:""; position:fixed; inset:0; z-index:0; pointer-events:none; opacity:.035;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
/* a hairline accent seam along the very top — a small premium tell */
.modebar{ box-shadow:0 1px 0 var(--line); border-bottom:0; background:color-mix(in srgb,var(--bg) 82%,transparent); }
.modebar::before{ content:""; position:absolute; inset:0 0 auto 0; height:2px;
  background:linear-gradient(90deg,transparent,var(--accent),var(--iris),transparent); opacity:.5; }

/* — display typography: bigger, tighter, more confident — */
.lnav .brand, .modebar .brandmini{ font-family:var(--font-display); letter-spacing:-.04em; }
.hero h1{
  font-family:var(--font-display); font-weight:700;
  font-size:clamp(44px,6.4vw,86px); line-height:.97; letter-spacing:-.045em; margin:26px 0 0;
}
.hero p.lead{ font-size:19.5px; line-height:1.62; max-width:512px; margin:26px 0 34px; }
.shead{ max-width:740px; margin:0 auto 58px; }
.shead h2, .ctaband h2{ font-family:var(--font-display); font-weight:700; letter-spacing:-.04em; }
.shead h2{ font-size:clamp(30px,3.6vw,48px); line-height:1.04; }
.shead p{ font-size:17px; margin-top:16px; }
.fcard h3{ font-family:var(--font-display); font-weight:600; font-size:18px; letter-spacing:-.025em; }
.statbig .n, .plan .pp, .lifetime .price, .ctaband h2{ font-family:var(--font-display); letter-spacing:-.04em; }
.plan .pp{ font-size:38px; }
.statbig .n{ font-size:38px; }

/* — generous negative space — */
.wrap{ padding:0 32px; }
.hero{ padding:132px 0 68px; }
.hero .grid2{ gap:64px; align-items:center; }
.section{ padding:116px 0; }
.fgrid{ gap:20px; }

/* — refined controls — */
.btn{ height:46px; padding:0 21px; font-size:14.5px; border-radius:12px; letter-spacing:-.01em; }
.btn-sm{ height:36px; padding:0 15px; }
.btn-pri{ box-shadow:0 10px 30px -12px var(--accent-glow), inset 0 1px 0 rgba(255,255,255,.28); }
.btn-pri:hover{ transform:translateY(-1px); box-shadow:0 18px 40px -14px var(--accent-glow), inset 0 1px 0 rgba(255,255,255,.4); }

/* — refined surfaces: hairline strokes, softer radii, calmer hover — */
.fcard, .plan, .panelcard, .cmp, .ctaband{ border-radius:20px; }
.fcard{ padding:26px; background:linear-gradient(180deg,color-mix(in srgb,var(--panel-2) 70%,transparent),transparent); }
.fcard:hover{ transform:translateY(-4px); box-shadow:var(--shadow-pop); border-color:var(--accent-faint); }
.minibadge{ padding:7px 13px; }

/* — declutter the hero product shot for minimal calm — */
.floaty{ display:none; }
.device{ border-radius:22px;
  box-shadow:0 60px 120px -45px rgba(0,0,0,.92), 0 0 0 1px var(--line), inset 0 1px 0 var(--edge); }

@media(max-width:1000px){ .hero{ padding:104px 0 52px; } .section{ padding:84px 0; } }
