/* ─────────────────────────── Tokens ─────────────────────────── */
:root{
  --paper:        #FAF8F2;
  --paper-2:      #F3EFE5;
  --paper-3:      #ECE7D9;
  --ink:          #0C0C0A;
  --ink-2:        #1C1C19;
  --muted:        #5A5649;
  --muted-2:      #8A8675;
  --line:         #E4DFD0;
  --line-2:       #D8D2BF;

  --brand:        #1B5EFE;
  --brand-2:      #1247D1;
  --brand-soft:   #E6EDFF;

  --green:        #2F7D56;
  --green-soft:   #DDEFE2;
  --amber:        #B57509;
  --amber-soft:   #FBECCC;
  --red:          #B33025;
  --red-soft:     #F8DAD6;

  --shadow-sm:    0 1px 2px rgba(20,16,0,.04);
  --shadow:       0 10px 30px -12px rgba(20,16,0,.15), 0 2px 6px rgba(20,16,0,.04);
  --shadow-lg:    0 40px 80px -30px rgba(20,16,0,.28), 0 8px 24px -6px rgba(20,16,0,.08);
  --shadow-float: 0 60px 120px -30px rgba(20,16,0,.22), 0 12px 24px -8px rgba(20,16,0,.08);

  --radius:       14px;
  --radius-sm:    10px;
  --radius-lg:    22px;

  --display:      "Fraunces", "Fraunces Fallback", ui-serif, Georgia, serif;
  --sans:         "Inter", ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
  --mono:         ui-monospace, "SF Mono", Menlo, Consolas, monospace;

  --step-max:     1160px;
  --gutter:       clamp(18px, 4vw, 40px);

  --ease-out:     cubic-bezier(.2,.8,.2,1);
  --ease-pop:     cubic-bezier(.16,1,.3,1);
}

/* Metric-matched fallback so Fraunces swap has no layout jump */
@font-face{
  font-family:"Fraunces Fallback";
  src:local("Georgia"), local("Times New Roman"), local("serif");
  size-adjust:102%;
  ascent-override:93%;
  descent-override:22%;
  line-gap-override:0%;
}

/* ─────────────────────────── Reset ─────────────────────────── */
*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth;scroll-padding-top:72px;-webkit-text-size-adjust:100%}
body{
  font-family:var(--sans);
  font-feature-settings:"ss01","cv11","cv02";
  font-optical-sizing:auto;
  color:var(--ink);
  background:var(--paper);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 200 200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='1.4' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.04 0 0 0 0 0.04 0 0 0 0 0.03 0 0 0 0.03 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
  background-size:200px 200px;
}
img,video,svg{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{margin:0;letter-spacing:-0.02em;line-height:1.08;font-weight:600}
p{margin:0}
ul,ol{margin:0;padding:0;list-style:none}
button{font:inherit}
::selection{background:var(--ink);color:var(--paper)}
:focus-visible{outline:2px solid var(--brand);outline-offset:3px;border-radius:4px}

/* Skip link */
.skip{
  position:absolute;top:-40px;left:12px;z-index:100;
  background:var(--ink);color:var(--paper);
  padding:10px 14px;border-radius:8px;font-size:13px;
  transition:top .15s ease;
}
.skip:focus{top:12px}

/* ─────────────────────────── Primitives ─────────────────────────── */
.container{
  max-width:var(--step-max);
  margin-inline:auto;
  padding-inline:var(--gutter);
}
.eyebrow{
  font-size:12px;
  letter-spacing:0.14em;
  text-transform:uppercase;
  color:var(--muted);
  margin:0 0 14px;
  font-weight:500;
}
.muted{color:var(--muted)}
.small{font-size:13px}
.grad{
  font-family:var(--display);
  font-style:italic;
  font-weight:500;
}
/* Gradient fill: paints on children when split (inline-block breaks parent bg-clip:text). */
.grad, .grad > *{
  background:linear-gradient(105deg, var(--ink) 0%, #2A2A24 28%, var(--brand) 62%, var(--brand-2) 100%);
  background-size:220% 100%;
  background-position:0% 50%;
  -webkit-background-clip:text;background-clip:text;
  color:transparent;
  -webkit-text-fill-color:transparent;
}
.js .grad > *{
  animation:
    word-rise .9s var(--ease-pop) both,
    sheen 9s linear infinite;
  animation-delay:
    calc(80ms * var(--i, 0) + 150ms),
    calc(-1200ms * var(--i, 0));
}
@keyframes sheen{
  0%{background-position:0% 50%}
  100%{background-position:-220% 50%}
}
@media (prefers-reduced-motion: reduce){
  .grad, .grad > *{background-position:0% 50%}
  .js .grad > *{animation:none}
}
.section__title{
  font-family:var(--display);
  font-size:clamp(32px, 5.2vw, 58px);
  letter-spacing:-0.025em;
  font-weight:500;
  margin:0 0 18px;
  line-height:1.05;
}
.section__lede{
  font-size:clamp(16px, 1.6vw, 19px);
  color:var(--muted);
  max-width:54ch;
  margin:0;
}
.btn{
  --pad-y: 11px;
  --pad-x: 18px;
  display:inline-flex;align-items:center;gap:8px;
  padding:var(--pad-y) var(--pad-x);
  border-radius:999px;
  font-weight:500;
  font-size:14px;
  letter-spacing:-0.01em;
  border:1px solid transparent;
  transition:transform .12s ease, background .15s ease, border-color .15s ease, box-shadow .15s ease, color .15s ease;
  cursor:pointer;
  white-space:nowrap;
}
.btn svg{width:16px;height:16px;transition:transform .15s ease}
.btn:hover svg{transform:translateX(2px)}
.btn--primary{background:var(--ink);color:var(--paper);box-shadow:var(--shadow-sm)}
.btn--primary:hover{background:#000;box-shadow:var(--shadow);transform:translateY(-1px)}
.btn--primary:active{transform:translateY(0)}
.btn--ghost{background:transparent;color:var(--ink);border-color:var(--line-2)}
.btn--ghost:hover{background:var(--paper-2);border-color:var(--ink);transform:translateY(-1px)}
.btn--ghost:active{transform:translateY(0)}
.btn--sm{--pad-y:8px;--pad-x:14px;font-size:13px}
.btn--lg{--pad-y:14px;--pad-x:24px;font-size:15px}
.btn--wide{width:100%;justify-content:center}
.btn[disabled]{opacity:.55;cursor:not-allowed;pointer-events:none}
.link-muted{color:var(--muted);font-size:14px}
.link-muted:hover{color:var(--ink)}

.chip{
  display:inline-flex;align-items:center;
  font-size:11.5px;letter-spacing:0.06em;text-transform:uppercase;font-weight:600;
  padding:6px 10px;border-radius:999px;
  background:var(--paper-2);color:var(--ink-2);
  border:1px solid var(--line);
  margin-bottom:18px;
  position:relative;overflow:hidden;
}
.js .pillar.is-in .chip::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(100deg, transparent 30%, rgba(255,255,255,.7) 50%, transparent 70%);
  transform:translateX(-110%);
  animation:shimmer 1.4s var(--ease-out) .4s 1 forwards;
}
@keyframes shimmer{
  to{transform:translateX(110%)}
}
@media (prefers-reduced-motion: reduce){
  .js .pillar.is-in .chip::after{animation:none;display:none}
}
.chip--red{background:var(--red-soft);color:var(--red);border-color:transparent}
.chip--amber{background:var(--amber-soft);color:var(--amber);border-color:transparent}
.chip--blue{background:var(--brand-soft);color:var(--brand-2);border-color:transparent}
.pill{
  display:inline-flex;font-size:12px;letter-spacing:0.02em;
  padding:4px 10px;border-radius:999px;background:var(--paper-2);color:var(--ink-2);
  border:1px solid var(--line);font-weight:500;
}
.pill--warn{background:var(--amber-soft);color:var(--amber);border-color:transparent}

/* Scroll-reveal — JS gated so no-JS users see content */
.js .reveal{
  opacity:0;
  transform:translateY(22px);
  transition:opacity .8s var(--ease-out), transform .8s var(--ease-out);
  will-change:opacity,transform;
}
.js .reveal.is-in{opacity:1;transform:none}
/* Pillar vizzes get a scale flourish */
.js .pillar .pillar__viz{transform:translateY(28px) scale(.97)}
.js .pillar.is-in .pillar__viz{transform:none}
@media (prefers-reduced-motion: reduce){
  .js .reveal, .js .pillar .pillar__viz{opacity:1;transform:none;transition:none}
}

/* ─────────────────────────── Nav ─────────────────────────── */
.nav{
  position:sticky;top:0;z-index:50;
  background:color-mix(in srgb, var(--paper) 78%, transparent);
  backdrop-filter:saturate(160%) blur(14px);
  -webkit-backdrop-filter:saturate(160%) blur(14px);
  border-bottom:1px solid transparent;
  transition:border-color .2s ease, background .2s ease;
}
.nav.is-scrolled{border-bottom-color:var(--line)}
.nav.is-hidden{transform:translateY(-102%);transition:transform .35s var(--ease-out), border-color .2s ease, background .2s ease}
.nav{transition:transform .35s var(--ease-out), border-color .2s ease, background .2s ease}
.nav__inner{
  max-width:var(--step-max);margin-inline:auto;
  padding:14px var(--gutter);
  display:flex;align-items:center;gap:28px;
}
.nav__brand{
  display:inline-flex;align-items:center;gap:10px;
  font-weight:600;letter-spacing:-0.02em;font-size:18px;
}
.nav__symbol{
  display:inline-grid;place-items:center;
  width:30px;height:30px;border-radius:8px;
  background:var(--paper-2);color:var(--ink);
  border:1px solid var(--line);
}
.nav__symbol svg{width:18px;height:18px}
.nav__wordmark{font-family:var(--display);font-weight:500;letter-spacing:-0.025em;font-size:20px}
.nav__links{display:flex;gap:26px;margin-inline:auto;align-items:center}
.nav__links a{
  font-size:14px;color:var(--ink-2);font-weight:500;
  position:relative;
}
.nav__links a:hover{color:var(--ink)}
.nav__links a::after{
  content:"";position:absolute;left:0;right:0;bottom:-6px;height:1px;
  background:var(--ink);transform:scaleX(0);transform-origin:left;
  transition:transform .2s ease;
}
.nav__links a:hover::after{transform:scaleX(1)}
.nav__cta{display:flex;gap:14px;align-items:center}
.nav__toggle{display:none;background:none;border:0;width:40px;height:40px;padding:8px;cursor:pointer}
.nav__toggle span{display:block;height:1.5px;background:var(--ink);margin:5px 0;border-radius:2px}

@media (max-width: 860px){
  .nav__links{display:none}
  .nav__cta .link-muted{display:none}
  .nav__toggle{display:block}
  .nav.is-open .nav__links{
    display:flex;flex-direction:column;gap:0;
    position:absolute;top:100%;left:0;right:0;
    background:var(--paper);border-bottom:1px solid var(--line);
    padding:8px var(--gutter) 18px;margin:0;
  }
  .nav.is-open .nav__links a{padding:12px 0;border-bottom:1px solid var(--line);width:100%}
}

/* ─────────────────────────── Hero ─────────────────────────── */
.hero{
  position:relative;
  padding:clamp(48px, 9vw, 110px) 0 clamp(60px, 8vw, 110px);
  text-align:center;
  overflow:hidden;
}
.hero__glow{
  position:absolute;inset:-20% -10% auto -10%;height:70%;
  background:
    radial-gradient(55% 55% at calc(50% + var(--mx, 0px)) calc(0% + var(--my, 0px)), var(--brand-soft) 0%, transparent 65%),
    radial-gradient(40% 55% at calc(85% + var(--mx, 0px) * 0.5) calc(25% + var(--my, 0px) * 0.5), #FFF6E8 0%, transparent 62%);
  filter:blur(20px);
  pointer-events:none;
  opacity:.7;
  transition:background-position .5s ease-out;
}
.hero__intro{
  display:flex;justify-content:center;
  margin:0 auto 24px;
}
.hero__video{
  width:clamp(80px, 12vw, 140px);
  height:auto;
  border-radius:22px;
  mix-blend-mode:multiply;
}
.hero__eyebrow{
  font-size:12px;letter-spacing:0.14em;text-transform:uppercase;
  color:var(--muted);font-weight:500;margin:0 0 18px;
}
.hero__headline{
  font-family:var(--display);
  font-size:clamp(42px, 7.8vw, 100px);
  font-weight:500;
  letter-spacing:-0.028em;
  line-height:0.98;
  margin:0 auto 22px;
  max-width:14ch;
  display:block;
}
.hero__line{display:block}
.hero__word{
  display:inline-block;
  opacity:0;
  transform:translateY(42%);
  will-change:opacity,transform;
}
.js .hero__word{
  animation:word-rise .9s var(--ease-pop) both;
  animation-delay:calc(80ms * var(--i, 0) + 150ms);
}
.js [data-count]{
  opacity:0;
  transition:opacity .25s ease;
}
.js [data-count].is-in{opacity:1}
@media (prefers-reduced-motion: reduce){
  .js [data-count]{opacity:1}
}
.hero__line:nth-child(1) .hero__word:nth-child(1){--i:0}
.hero__line:nth-child(1) .hero__word:nth-child(2){--i:1}
.hero__line:nth-child(1) .hero__word:nth-child(3){--i:2}
.hero__line:nth-child(2) .hero__word:nth-child(1){--i:3}
.hero__line:nth-child(2) .hero__word:nth-child(2){--i:4}
.hero__line:nth-child(2) .hero__word:nth-child(3){--i:5}
@keyframes word-rise{
  from{opacity:0;transform:translateY(45%) rotateX(35deg)}
  to{opacity:1;transform:none}
}
@media (prefers-reduced-motion: reduce){
  .hero__word{opacity:1;transform:none;animation:none}
}
.hero__sub{
  font-size:clamp(16px, 1.7vw, 19px);
  color:var(--muted);
  max-width:58ch;
  margin:0 auto 30px;
  line-height:1.55;
}
.hero__ctas{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-bottom:16px}
.hero__meta{color:var(--muted);font-size:14px;margin:0 0 clamp(40px,6vw,72px)}
.hero__mock{
  max-width:1040px;margin-inline:auto;
  perspective:1600px;
}

/* Dashboard mock */
.mock{
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow-float);
  overflow:hidden;
  text-align:left;
  transform-origin:50% 50%;
  transition:transform .6s var(--ease-out);
  /* Rotation composed from default rest tilt + cursor offset via custom props */
  --tilt-x: 7deg;
  --tilt-y: 0deg;
  transform:perspective(1400px) rotateX(var(--tilt-x)) rotateY(var(--tilt-y));
}
.mock__chrome{
  display:flex;align-items:center;gap:8px;
  padding:12px 16px;
  background:var(--paper-2);
  border-bottom:1px solid var(--line);
}
.mock__chrome > span{
  width:11px;height:11px;border-radius:50%;background:var(--line-2);
}
.mock__chrome > span:nth-child(1){background:#FF6159}
.mock__chrome > span:nth-child(2){background:#FEBC2D}
.mock__chrome > span:nth-child(3){background:#28C840}
.mock__url{
  margin-left:16px;font-family:var(--mono);font-size:12px;color:var(--muted);
  background:var(--paper);padding:5px 12px;border-radius:999px;border:1px solid var(--line);
}
.mock__body{padding:clamp(20px,3vw,36px);display:grid;gap:28px}

.score{
  display:grid;grid-template-columns:auto 1fr;gap:clamp(20px,4vw,40px);
  align-items:center;
  padding-bottom:24px;border-bottom:1px dashed var(--line);
}
.score__ring{position:relative;width:168px;height:168px}
.score__ring svg{transform:rotate(-90deg);width:100%;height:100%}
.score__track{fill:none;stroke:var(--paper-3);stroke-width:10}
.score__fill{
  fill:none;stroke-width:10;stroke-linecap:round;
  stroke-dasharray:326.7;
  stroke-dashoffset:326.7;
  stroke:var(--amber);
  transition:stroke-dashoffset 1.4s var(--ease-out) .2s;
}
.score__ring.is-in .score__fill{
  stroke-dashoffset:calc(326.7 - (326.7 * var(--val) / 100));
}
@media (prefers-reduced-motion: reduce){
  .score__fill{stroke-dashoffset:calc(326.7 - (326.7 * var(--val) / 100));transition:none}
}
.score__num{
  position:absolute;inset:0;display:grid;place-items:center;text-align:center;
}
.score__num strong{
  font-family:var(--display);font-size:62px;font-weight:500;letter-spacing:-0.03em;line-height:1;
  font-variant-numeric:tabular-nums;
  display:block;
}
.score__num small{
  position:absolute;left:50%;bottom:20%;transform:translateX(-50%);
  color:var(--muted);font-size:12.5px;white-space:nowrap;
}
.score__title{font-size:22px;margin:10px 0 4px;letter-spacing:-0.02em;font-weight:600;color:var(--ink)}
.score__meta p{color:var(--muted);font-size:14px}
.score__delta{
  display:inline-flex;align-items:center;gap:6px;
  margin-top:12px;font-size:13px;color:var(--green);font-weight:500;
  background:var(--green-soft);padding:4px 10px;border-radius:999px;
}
.score__delta svg{width:10px;height:10px}

.tiles{
  display:grid;grid-template-columns:repeat(3,1fr);gap:12px;
}
.tile{
  padding:16px;border:1px solid var(--line);border-radius:var(--radius-sm);
  background:var(--paper);
  transition:transform .18s ease, box-shadow .18s ease;
}
.tile:hover{transform:translateY(-2px);box-shadow:var(--shadow-sm)}
.js .mock .tile{
  opacity:0;
  transform:translateY(14px);
  transition:opacity .55s var(--ease-out), transform .55s var(--ease-out);
}
.js .mock.is-in .tile{opacity:1;transform:none}
.js .mock.is-in .tile:nth-child(1){transition-delay:.30s}
.js .mock.is-in .tile:nth-child(2){transition-delay:.38s}
.js .mock.is-in .tile:nth-child(3){transition-delay:.46s}
.js .mock.is-in .tile:nth-child(4){transition-delay:.54s}
.js .mock.is-in .tile:nth-child(5){transition-delay:.62s}
.js .mock.is-in .tile:nth-child(6){transition-delay:.70s}
.mock .tile:nth-child(1) .bar > span{--bar-delay:.55s}
.mock .tile:nth-child(2) .bar > span{--bar-delay:.63s}
.mock .tile:nth-child(3) .bar > span{--bar-delay:.71s}
.mock .tile:nth-child(4) .bar > span{--bar-delay:.79s}
.mock .tile:nth-child(5) .bar > span{--bar-delay:.87s}
.mock .tile:nth-child(6) .bar > span{--bar-delay:.95s}
@media (prefers-reduced-motion: reduce){
  .js .mock .tile{opacity:1;transform:none;transition:none}
}
.tile header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:10px}
.tile header span{font-size:13px;color:var(--ink-2);font-weight:500}
.tile header strong{font-size:16px;font-weight:600;font-variant-numeric:tabular-nums}
.tile p{margin-top:8px;font-size:12.5px;color:var(--muted)}
.tile--red{background:#FEF3F2;border-color:#F4D2CD}
.tile--red header strong{color:var(--red)}
.tile--amber{background:#FEF9ED;border-color:#F2E1B8}
.tile--amber header strong{color:var(--amber)}
.tile--green{background:#F0F7F2;border-color:#CFE4D6}
.tile--green header strong{color:var(--green)}
.bar{height:6px;background:var(--paper-3);border-radius:99px;overflow:hidden}
.bar > span{
  display:block;height:100%;background:var(--ink-2);border-radius:99px;
  width:var(--bar-w, 0%);
}
.js .mock .bar > span{
  width:0;
  transition:width 1.1s var(--ease-out) var(--bar-delay, .35s);
}
.js .mock.is-in .bar > span{width:var(--bar-w)}
@media (prefers-reduced-motion: reduce){
  .js .mock .bar > span{width:var(--bar-w);transition:none}
}
.tile--red .bar > span{background:var(--red)}
.tile--amber .bar > span{background:var(--amber)}
.tile--green .bar > span{background:var(--green)}

@media (max-width: 760px){
  .score{grid-template-columns:1fr;justify-items:center;text-align:center}
  .tiles{grid-template-columns:repeat(2,1fr)}
}
@media (max-width: 480px){
  .tiles{grid-template-columns:1fr}
}

/* ─────────────────────────── Why now ─────────────────────────── */
.why{
  padding:clamp(60px, 9vw, 120px) 0;
  border-top:1px solid var(--line);
  background:var(--paper-2);
}
.why__grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:28px;
  margin-top:clamp(36px, 6vw, 64px);
}
.why__stat strong{
  font-family:var(--display);font-weight:400;
  display:flex;align-items:baseline;gap:10px;flex-wrap:wrap;
  font-size:clamp(52px, 6.4vw, 78px);letter-spacing:-0.035em;
  line-height:1;margin-bottom:14px;
  background:linear-gradient(180deg, var(--ink) 0%, var(--brand) 160%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  -webkit-text-fill-color:transparent;
}
.why__suf{
  font-family:var(--sans);
  font-size:0.24em;
  letter-spacing:0.02em;
  font-weight:500;
  text-transform:uppercase;
  color:var(--muted);
  background:none;-webkit-text-fill-color:var(--muted);
  padding-left:2px;
}
.why__stat p{color:var(--muted);max-width:34ch;font-size:15.5px}
@media (max-width:760px){.why__grid{grid-template-columns:1fr;gap:30px}}

/* ─────────────────────────── Pillars ─────────────────────────── */
.pillars{padding:clamp(70px, 10vw, 130px) 0}
.pillars .section__title{margin-bottom:clamp(40px,6vw,72px)}

.pillar{
  display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px, 6vw, 70px);
  align-items:center;
  padding:clamp(40px, 6vw, 72px) 0;
  border-bottom:1px solid var(--line);
}
.pillar:last-child{border-bottom:0}
.pillar--reverse .pillar__copy{order:2}
.pillar__copy h3{
  font-family:var(--display);font-weight:500;
  font-size:clamp(26px, 3.4vw, 40px);
  letter-spacing:-0.02em;margin-bottom:14px;line-height:1.1;
}
.pillar__copy p{
  color:var(--muted);font-size:16px;max-width:52ch;margin-bottom:20px;
}
.bullets li{
  padding:10px 0;font-size:14.5px;color:var(--ink-2);
  display:flex;gap:10px;align-items:center;
  border-top:1px solid var(--line);
}
.bullets li:last-child{border-bottom:1px solid var(--line)}
.bullets li::before{
  content:"";width:5px;height:5px;border-radius:50%;background:var(--ink);flex-shrink:0;
}
.pillar__viz{
  background:var(--paper-2);
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  padding:clamp(20px, 3vw, 36px);
  box-shadow:var(--shadow);
  min-height:280px;
  display:grid;
  place-items:center;
  overflow:hidden;
  transition:transform .9s var(--ease-pop), opacity .9s var(--ease-pop);
}

/* Viz: description snippet */
.snippet{
  background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);
  padding:20px;width:100%;max-width:440px;font-size:14px;
  box-shadow:var(--shadow-sm);
}
.snippet header{display:flex;align-items:center;gap:10px;margin-bottom:14px;font-weight:500}
.snippet header .dot{width:8px;height:8px;border-radius:50%;background:var(--line-2)}
.snippet__score{
  margin-left:auto;font-family:var(--mono);font-weight:600;font-size:13px;
  padding:3px 9px;border-radius:6px;
}
.snippet__score--red{background:var(--red-soft);color:var(--red)}
.snippet__score--green{background:var(--green-soft);color:var(--green)}
.snippet__before{
  color:var(--muted);text-decoration:line-through;
  background:#FDF3F2;padding:10px 12px;border-radius:8px;margin:0 0 14px;
}
.snippet__arrow{
  display:flex;align-items:center;gap:8px;color:var(--muted);
  font-size:12px;letter-spacing:0.06em;text-transform:uppercase;margin-bottom:10px;
}
.snippet__arrow svg{width:14px;height:14px}
.snippet__after{
  padding:12px;background:#F1F7F3;border-radius:8px;
  color:var(--ink-2);line-height:1.6;margin:0 0 14px;
}
.snippet__after mark{background:#FFEC9A;padding:0 4px;border-radius:3px}
.snippet footer{display:flex;align-items:center;gap:10px;font-size:13px}

/* Viz: matrix */
.matrix{display:grid;gap:4px;width:100%;max-width:460px;font-size:12.5px}
.matrix__row{
  display:grid;grid-template-columns:1.2fr repeat(5,1fr);
  align-items:center;gap:6px;
}
.matrix__row > span:first-child{
  color:var(--ink-2);font-weight:500;padding:8px 4px;
}
.matrix__row--head > span{
  font-size:10.5px;letter-spacing:0.08em;text-transform:uppercase;
  color:var(--muted);font-weight:500;text-align:center;
}
.matrix__row b{
  display:block;height:22px;border-radius:5px;
}
.c-g{background:#C8E3D2;box-shadow:inset 0 0 0 1px #A5CDB4}
.c-a{background:#F4DEA7;box-shadow:inset 0 0 0 1px #E3C482}
.c-r{background:#F1BFB9;box-shadow:inset 0 0 0 1px #DFA097}

/* Viz: cluster — redesigned */
.cluster{
  width:100%;max-width:460px;background:var(--paper);
  border:1px solid var(--line);border-radius:var(--radius);
  padding:18px 18px 14px;
  box-shadow:var(--shadow-sm);
}
.cluster__head{
  display:flex;align-items:center;gap:12px;margin-bottom:14px;
  padding-bottom:14px;border-bottom:1px dashed var(--line);
}
.cluster__badge{
  width:36px;height:36px;border-radius:10px;
  background:var(--amber-soft);color:var(--amber);
  display:grid;place-items:center;
}
.cluster__badge svg{width:18px;height:18px}
.cluster__title{flex:1;display:grid;gap:2px}
.cluster__title strong{font-size:14px;font-weight:600}
.cluster__chip{
  font-size:10.5px;letter-spacing:0.06em;text-transform:uppercase;font-weight:600;
  background:var(--brand-soft);color:var(--brand-2);
  padding:4px 8px;border-radius:999px;
}
.cluster__item{
  display:flex;align-items:center;gap:10px;
  padding:11px 0;font-size:13.5px;
}
.cluster__item + .cluster__item{border-top:1px dashed var(--line)}
.cluster__dot{
  width:8px;height:8px;border-radius:50%;
  background:var(--ink);flex-shrink:0;
}
.cluster__dot--faint{background:var(--line-2)}
.cluster__row{flex:1;display:grid;gap:2px;min-width:0}
.cluster__row span{font-weight:500;color:var(--ink-2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.cluster__row em{font-style:normal;color:var(--muted);font-family:var(--mono);font-size:11.5px}
.cluster__keep{
  font-size:10.5px;letter-spacing:0.06em;text-transform:uppercase;font-weight:600;
  color:var(--green);background:var(--green-soft);padding:4px 8px;border-radius:999px;
}
.cluster__drop{
  font-size:10.5px;letter-spacing:0.06em;text-transform:uppercase;font-weight:600;
  color:var(--amber);background:var(--amber-soft);padding:4px 8px;border-radius:999px;
}
.cluster__item--primary{background:linear-gradient(90deg, rgba(47,125,86,.05), transparent);margin:0 -6px;padding:11px 6px;border-radius:6px}
.cluster__item--primary + .cluster__item{border-top:0}
.cluster__foot{
  display:flex;gap:8px;justify-content:flex-end;
  padding-top:12px;margin-top:4px;
  border-top:1px dashed var(--line);
}

/* Viz: alt pair */
.alt-pair{display:grid;grid-template-columns:1fr 1fr;gap:14px;width:100%;max-width:460px}
.alt-pair__card{
  background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-sm);padding:14px;
  display:flex;flex-direction:column;gap:10px;
}
.alt-pair__img{
  height:124px;border-radius:8px;
  position:relative;display:grid;place-items:center;
}
.alt-pair__img--missing{
  background:
    repeating-linear-gradient(45deg, #EBE5D3 0 10px, #E0D9C3 10px 20px);
  color:var(--red);
}
.alt-pair__img--missing svg{width:34px;height:34px;opacity:.45}
.alt-pair__miss{
  position:absolute;bottom:8px;right:8px;
  background:var(--red);color:#fff;font-size:10px;font-weight:600;
  padding:3px 7px;border-radius:4px;letter-spacing:0.04em;text-transform:uppercase;
}
.alt-pair__img--ok{
  background:
    radial-gradient(120% 90% at 35% 25%, #F3E9CF 0%, #C6B285 100%);
  color:var(--green);
}
.alt-pair__check{
  width:44px;height:44px;
  background:#fff;border-radius:50%;padding:10px;
  box-shadow:0 4px 10px rgba(0,0,0,.12);
}
.alt-pair__label{
  font-size:12px;color:var(--muted);margin:0;line-height:1.5;
}
.alt-pair__label--bad{color:var(--red)}
.alt-pair__label--bad code{
  background:var(--red-soft);color:var(--red);
  padding:3px 7px;border-radius:5px;font-family:var(--mono);font-size:11.5px;
}
.alt-pair__label--good{color:var(--ink-2);font-size:12.5px}

/* Viz: taxonomy */
.tax{display:grid;gap:14px;place-items:center;width:100%;max-width:440px;text-align:center}
.tax__row{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;align-items:center}
.tax__tag{
  padding:6px 12px;border-radius:999px;font-size:13px;
  background:var(--paper);border:1px solid var(--line);color:var(--muted);
  display:inline-flex;align-items:center;gap:6px;
}
.tax__tag em{font-style:normal;color:var(--muted-2);font-size:11px;font-family:var(--mono)}
.tax__tag--good{
  background:var(--ink);color:var(--paper);border-color:var(--ink);
  display:inline-flex;flex-direction:column;padding:10px 22px;gap:2px;
}
.tax__tag--good small{font-size:11px;opacity:.65}
.tax__funnel{width:200px;height:60px;color:var(--muted-2)}
.tax__funnel svg{width:100%;height:100%}

/* Viz: locales */
.locales{display:grid;gap:12px;width:100%;max-width:440px}
.locales__row{
  display:grid;grid-template-columns:28px 62px 1fr 32px;gap:12px;align-items:center;
  font-size:13px;
}
.locales__row > span:first-child{font-size:20px}
.locales__code{font-family:var(--mono);font-size:12px;color:var(--muted)}
.locales__row b{text-align:right;font-family:var(--mono);font-weight:600;color:var(--ink-2)}
.bar--good > span{background:var(--green)!important}
.bar--amber > span{background:var(--amber)!important}
.bar--bad > span{background:var(--red)!important}

@media (max-width:860px){
  .pillar{grid-template-columns:1fr;gap:24px}
  .pillar--reverse .pillar__copy{order:0}
  .pillar__viz{min-height:220px;order:1;overflow-x:auto}
}
@media (max-width:480px){
  .matrix{font-size:11px}
  .matrix__row > span:first-child{font-size:11.5px;padding:6px 2px}
  .snippet{font-size:13px}
  .alt-pair{grid-template-columns:1fr}
}

/* ─────────────────────────── How ─────────────────────────── */
.how{
  padding:clamp(70px, 10vw, 130px) 0;
  background:var(--paper-2);
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
}
.steps{
  display:grid;grid-template-columns:repeat(3,1fr);gap:18px;
  margin-top:clamp(36px,6vw,64px);
  position:relative;
}
.steps::before{
  content:"";position:absolute;top:56px;left:10%;right:10%;height:1px;
  background:linear-gradient(90deg, transparent 0%, var(--line-2) 20%, var(--line-2) 80%, transparent 100%);
  z-index:0;
}
.step{
  background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:clamp(22px, 3vw, 34px);
  position:relative;z-index:1;
  transition:transform .15s ease, box-shadow .15s ease, border-color .15s ease;
}
.step:hover{transform:translateY(-2px);box-shadow:var(--shadow);border-color:var(--line-2)}
.step__n{
  font-family:var(--mono);font-size:13px;
  display:inline-flex;align-items:center;justify-content:center;
  width:40px;height:40px;
  border-radius:50%;
  background:var(--paper-2);
  color:var(--muted);
  margin-bottom:22px;
  letter-spacing:0.04em;font-weight:600;
  border:1px solid var(--line);
}
.step:nth-child(1) .step__n{color:var(--ink);border-color:var(--ink)}
.step:nth-child(2) .step__n{color:var(--brand);border-color:var(--brand-soft);background:var(--brand-soft)}
.step:nth-child(3) .step__n{color:var(--paper);background:var(--ink);border-color:var(--ink)}
.step h3{font-family:var(--display);font-weight:500;font-size:22px;margin-bottom:10px;letter-spacing:-0.02em}
.step p{color:var(--muted);font-size:15px}
@media (max-width:860px){.steps{grid-template-columns:1fr}.steps::before{display:none}}

/* ─────────────────────────── Founder note ─────────────────────────── */
.founder{padding:clamp(60px,8vw,110px) 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--paper-2)}
.founder__note{
  max-width:820px;margin:0 auto;
  display:grid;gap:20px;
  padding:clamp(24px,4vw,40px) clamp(24px,4vw,44px);
  border-left:3px solid var(--ink);
  background:var(--paper-2);
  border-radius:0 var(--radius) var(--radius) 0;
  position:relative;
}
.founder__mark{
  position:absolute;top:-8px;left:-6px;
  font-family:var(--display);font-size:72px;line-height:1;
  color:var(--line-2);font-weight:400;
  pointer-events:none;
}
.founder blockquote{
  font-family:var(--display);font-weight:400;
  font-size:clamp(20px, 2.4vw, 26px);line-height:1.45;letter-spacing:-0.01em;
  color:var(--ink-2);margin:0;
}
.founder figcaption{
  display:flex;align-items:center;gap:14px;
  padding-top:16px;border-top:1px solid var(--line);
}
.founder__avatar{
  width:44px;height:44px;border-radius:50%;
  background:linear-gradient(135deg, var(--ink) 0%, #2A2A24 100%);
  color:var(--paper);
  display:grid;place-items:center;
  font-weight:600;font-size:14px;letter-spacing:0.02em;
  font-family:var(--sans);
}
.founder figcaption strong{display:block;color:var(--ink-2);font-weight:600;font-size:14.5px}
.founder figcaption span{font-size:13px}

/* ─────────────────────────── Pricing ─────────────────────────── */
.pricing{padding:clamp(70px, 10vw, 130px) 0}
.pricing__roi{
  max-width:620px;margin:clamp(20px,3vw,32px) 0 clamp(32px,5vw,48px);
  padding:18px 22px;
  background:var(--paper-2);border:1px solid var(--line);border-radius:var(--radius);
  font-size:15px;color:var(--ink-2);
}
.pricing__roi strong{color:var(--ink);font-weight:600}
.plans{
  display:grid;grid-template-columns:repeat(3,1fr);gap:16px;
  align-items:stretch;
}
.plan{
  background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:clamp(24px, 3vw, 36px);
  display:flex;flex-direction:column;gap:22px;
  transition:border-color .15s ease, transform .15s ease, box-shadow .15s ease;
  position:relative;
  overflow:hidden;
  isolation:isolate;
}
/* Cursor spotlight — follows pointer via --mx/--my props set by JS */
.plan::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(
    240px circle at var(--mx, 50%) var(--my, 50%),
    rgba(27,94,254,0.14),
    transparent 70%
  );
  opacity:0;
  transition:opacity .25s ease;
  z-index:0;
  border-radius:inherit;
}
.plan > *{position:relative;z-index:1}
.plan:hover::before{opacity:1}
.plan--featured::before{
  background:radial-gradient(
    260px circle at var(--mx, 50%) var(--my, 50%),
    rgba(122,160,255,0.28),
    transparent 70%
  );
}
.plan:hover{border-color:var(--line-2);transform:translateY(-2px);box-shadow:var(--shadow)}
@media (prefers-reduced-motion: reduce){
  .plan::before{display:none}
}
.plan header h3{font-size:18px;font-weight:500;color:var(--muted);letter-spacing:0}
.plan__price{margin:12px 0 6px;display:flex;align-items:baseline;gap:6px}
.plan__price strong{font-family:var(--display);font-size:50px;letter-spacing:-0.035em;font-weight:500;font-variant-numeric:tabular-nums}
.plan__price span{color:var(--muted);font-size:14px}
.plan__for{color:var(--muted);font-size:14px}
.plan ul{display:grid;gap:10px;flex:1;margin:0;padding:18px 0;border-top:1px solid var(--line)}
.plan ul li{
  position:relative;padding-left:22px;font-size:14.5px;color:var(--ink-2);
}
.plan ul li::before{
  content:"";position:absolute;left:0;top:8px;width:10px;height:10px;border-radius:50%;
  background:var(--brand-soft);box-shadow:inset 0 0 0 2px var(--brand);
}
.plan--featured{
  background:var(--ink);color:var(--paper);border-color:var(--ink);
  position:relative;
  overflow:visible;
}
.plan--featured header h3{color:var(--muted-2)}
.plan--featured .plan__price strong{color:var(--paper)}
.plan--featured .plan__price span,
.plan--featured .plan__for{color:#B8B4A7}
.plan--featured ul{border-color:#2A2A24}
.plan--featured ul li{color:#EFEBDD}
.plan--featured ul li::before{background:#2A3A6B;box-shadow:inset 0 0 0 2px #7AA0FF}
.plan--featured .btn--primary{background:var(--paper);color:var(--ink)}
.plan--featured .btn--primary:hover{background:#fff}
.plan__badge{
  position:absolute;top:-12px;left:50%;transform:translateX(-50%);
  background:var(--brand);color:#fff;font-size:11px;letter-spacing:0.08em;text-transform:uppercase;
  padding:5px 12px;border-radius:999px;font-weight:600;
}
.pricing__foot{text-align:center;margin-top:30px;color:var(--muted)}
.pricing__foot a{color:var(--brand);font-weight:500}
.pricing__foot a:hover{text-decoration:underline}
@media (max-width:860px){.plans{grid-template-columns:1fr}}

/* ─────────────────────────── FAQ ─────────────────────────── */
.faq{padding:clamp(56px,7vw,96px) 0}
.faq__list{max-width:780px;margin:clamp(24px,4vw,40px) auto 0;display:grid;gap:8px}
.faq details{
  background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);
  padding:4px 4px;
  transition:border-color .15s ease, background .15s ease;
}
.faq details[open]{border-color:var(--line-2);background:var(--paper-2)}
.faq summary{
  list-style:none;display:flex;justify-content:space-between;align-items:center;
  padding:18px 20px;cursor:pointer;font-size:16px;font-weight:500;
  letter-spacing:-0.01em;
}
.faq summary::-webkit-details-marker{display:none}
.faq summary svg{width:18px;height:18px;transition:transform .2s ease;color:var(--muted);flex-shrink:0;margin-left:16px}
.faq details[open] summary svg{transform:rotate(180deg)}
.faq details p{padding:0 20px 20px;color:var(--muted);font-size:15px;line-height:1.6;max-width:66ch}
.faq details a{color:var(--brand);font-weight:500}

/* ─────────────────────────── CTA / Waitlist ─────────────────────────── */
.cta{
  position:relative;
  padding:clamp(80px,12vw,150px) 0;
  border-top:1px solid var(--line);
  background:
    radial-gradient(80% 80% at 50% 0%, var(--brand-soft) 0%, transparent 60%),
    linear-gradient(180deg, var(--paper) 0%, var(--paper-2) 100%);
  text-align:center;
  overflow:hidden;
}
.cta::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(60% 55% at 50% 0%, var(--brand-soft) 0%, transparent 70%);
  opacity:.9;
  animation:breathe 10s ease-in-out infinite;
}
@keyframes breathe{
  0%,100%{transform:translateY(-8px) scale(1);opacity:.9}
  50%{transform:translateY(6px) scale(1.04);opacity:.6}
}
@media (prefers-reduced-motion: reduce){
  .cta::before{animation:none}
}
.cta > .container{position:relative;z-index:1}
.cta h2{
  font-family:var(--display);
  font-size:clamp(36px, 5.4vw, 68px);
  letter-spacing:-0.03em;line-height:1.08;margin:0 0 32px;
  font-weight:500;
}

/* Waitlist form */
.waitlist{
  max-width:640px;margin:0 auto 18px;
  display:grid;gap:10px;
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  padding:clamp(16px,2.5vw,22px);
  box-shadow:var(--shadow);
  text-align:left;
}
.waitlist__label{
  font-size:12px;letter-spacing:0.1em;text-transform:uppercase;
  color:var(--muted);font-weight:600;padding-left:4px;
}
.waitlist__row{
  display:grid;grid-template-columns:1fr 1fr auto;gap:8px;align-items:stretch;
}
.waitlist__input{
  appearance:none;
  background:var(--paper-2);
  border:1px solid var(--line);
  border-radius:999px;
  padding:12px 18px;
  font:inherit;font-size:14px;color:var(--ink);
  transition:border-color .15s ease, background .15s ease;
  min-width:0;
}
.waitlist__input:focus{
  outline:none;
  border-color:var(--ink);
  background:var(--paper);
}
.waitlist__input::placeholder{color:var(--muted-2)}
.waitlist__note{margin:8px 4px 0;font-size:12.5px;line-height:1.5}
.waitlist__ok{
  margin:10px 4px 0;font-size:14px;color:var(--green);font-weight:500;
  padding:10px 14px;background:var(--green-soft);border-radius:10px;
}
.cta__alt{color:var(--muted);font-size:14px;margin-top:20px}
.cta__alt a{color:var(--brand);font-weight:500;border-bottom:1px solid transparent;transition:border-color .15s}
.cta__alt a:hover{border-bottom-color:var(--brand)}

@media (max-width:680px){
  .waitlist__row{grid-template-columns:1fr;gap:8px}
  .waitlist__row .btn{justify-content:center}
}

/* ─────────────────────────── Footer ─────────────────────────── */
.footer{
  border-top:1px solid var(--line);
  background:var(--paper);
  padding:56px 0 36px;
}
.footer__grid{
  display:grid;grid-template-columns:1.6fr repeat(3,1fr);gap:40px;
  margin-bottom:40px;
}
.footer__brand-link{display:inline-flex;align-items:center;gap:10px;font-weight:600;font-size:18px}
.footer__brand-link span:last-child{font-family:var(--display);font-weight:500;font-size:22px;letter-spacing:-0.025em}
.footer__brand p{margin-top:12px;max-width:24ch;font-size:14px;line-height:1.5}
.footer h4{font-size:13px;letter-spacing:0.06em;text-transform:uppercase;color:var(--muted);margin-bottom:14px;font-weight:500}
.footer ul{display:grid;gap:8px}
.footer ul a{color:var(--ink-2);font-size:14.5px}
.footer ul a:hover{color:var(--brand)}
.footer__foot{
  border-top:1px solid var(--line);padding-top:24px;
  display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px;
}
@media (max-width:760px){.footer__grid{grid-template-columns:1fr 1fr}}
@media (max-width:480px){.footer__grid{grid-template-columns:1fr}}

/* ─────────────────────────── Hero motion ─────────────────────────── */
@media (prefers-reduced-motion: no-preference){
  .hero__video{animation:rise .9s var(--ease-out) both}
  .hero__eyebrow{animation:rise .9s .05s var(--ease-out) both}
  .hero__headline{animation:rise .9s .1s var(--ease-out) both}
  .hero__sub{animation:rise .9s .2s var(--ease-out) both}
  .hero__ctas{animation:rise .9s .3s var(--ease-out) both}
  .hero__meta{animation:rise .9s .35s var(--ease-out) both}
  .hero__mock{animation:rise 1.1s .45s var(--ease-out) both}
  @keyframes rise{
    from{opacity:0;transform:translateY(18px)}
    to{opacity:1;transform:none}
  }
}
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation:none !important;transition:none !important}
}
