/* ============================================================= TOKENS */
:root{
  --accent: #00d4aa;
  --accent-2: #7af5d4;
  --accent-deep: #0a8e75;
  --warn: #ffb020;
  --crit: #ff4d4d;

  --bg-0: #08080c;
  --bg-1: #0a0a0f;
  --bg-2: #0f1016;
  --bg-3: #141621;
  --bg-4: #1a1d2b;

  --ink-0: #eef1f7;
  --ink-1: #c9cdd8;
  --ink-2: #8e94a5;
  --ink-3: #5b6173;
  --ink-4: #2a2f3d;

  --line: rgba(255,255,255,.06);
  --line-strong: rgba(255,255,255,.12);

  --scanlines-alpha: .35;

  --font-sans: 'IBM Plex Sans', ui-sans-serif, system-ui, sans-serif;
  --font-mono: 'JetBrains Mono', ui-monospace, SFMono-Regular, Menlo, monospace;

  --r-xs: 6px;
  --r-sm: 10px;
  --r-md: 14px;
  --r-lg: 22px;
  --r-xl: 28px;

  --pad-x: clamp(20px, 4vw, 80px);
  --maxw: 1280px;
}

*{ box-sizing: border-box; }
html,body{ margin:0; padding:0; }
html{ scroll-behavior:smooth; }
body{
  font-family: var(--font-sans);
  color: var(--ink-0);
  background: var(--bg-1);
  font-feature-settings: "ss01","cv11";
  -webkit-font-smoothing: antialiased;
  line-height: 1.5;
  overflow-x: hidden;
}
a{ color: inherit; text-decoration: none; }
code{ font-family: var(--font-mono); font-size: .9em; }
strong{ font-weight: 600; }
.muted{ color: var(--ink-2); }

/* selection */
::selection{ background: color-mix(in oklab, var(--accent) 50%, transparent); color: #001912; }

/* ============================================================= NAV */
.nav{
  position: sticky; top: 0; z-index: 50;
  backdrop-filter: blur(14px) saturate(140%);
  -webkit-backdrop-filter: blur(14px) saturate(140%);
  background: color-mix(in oklab, var(--bg-1) 72%, transparent);
  border-bottom: 1px solid var(--line);
}
.nav__inner{
  max-width: var(--maxw);
  margin: 0 auto;
  padding: 14px var(--pad-x);
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 24px;
}
.logo{ display: inline-flex; align-items: center; gap: 8px; color: var(--ink-0); }
.logo__mark{ width: 26px; height: 26px; color: var(--accent); }
.logo__word{ font-weight: 700; letter-spacing: -.01em; font-size: 17px; }
.logo__ver{ color: var(--ink-2); font-family: var(--font-mono); font-size: 11px; padding: 2px 6px; border: 1px solid var(--line-strong); border-radius: 4px; }

.nav__links{ display: flex; gap: 26px; justify-content: center; }
.nav__links a{
  color: var(--ink-1); font-size: 14px; font-weight: 500;
  position: relative; padding: 6px 2px;
}
.nav__links a:hover{ color: var(--ink-0); }
.nav__links a::after{
  content: ""; position: absolute; left: 0; right: 0; bottom: -2px; height: 1px;
  background: var(--accent); transform: scaleX(0); transform-origin: left;
  transition: transform .25s;
}
.nav__links a:hover::after{ transform: scaleX(1); }

.nav__actions{ display: flex; gap: 14px; align-items: center; }

.persona-toggle{
  display: inline-flex;
  background: var(--bg-3);
  border: 1px solid var(--line-strong);
  border-radius: 999px;
  padding: 3px;
  position: relative;
}
.persona-toggle button{
  appearance: none; border: 0; background: transparent; color: var(--ink-2);
  font: 500 12.5px var(--font-sans); letter-spacing: .02em;
  padding: 6px 12px; border-radius: 999px; cursor: pointer;
  transition: color .2s;
}
.persona-toggle button[aria-selected="true"]{
  color: #001912;
  background: var(--accent);
  box-shadow: 0 0 0 1px color-mix(in oklab, var(--accent) 60%, transparent),
              0 0 20px -4px color-mix(in oklab, var(--accent) 70%, transparent);
}

/* ============================================================= BUTTONS */
.btn{
  display: inline-flex; align-items: center; gap: 8px;
  padding: 11px 18px;
  font: 600 14px/1 var(--font-sans);
  border-radius: 999px;
  cursor: pointer; user-select: none;
  transition: transform .18s ease, box-shadow .25s ease, background .18s;
  border: 1px solid transparent;
  white-space: nowrap;
}
.btn svg{ width: 14px; height: 14px; }
.btn--primary{
  background: var(--accent);
  color: #001912;
  box-shadow: 0 0 0 1px color-mix(in oklab, var(--accent) 70%, transparent),
              0 8px 24px -6px color-mix(in oklab, var(--accent) 60%, transparent),
              inset 0 1px 0 rgba(255,255,255,.3);
}
.btn--primary:hover{
  transform: translateY(-1px);
  box-shadow: 0 0 0 1px var(--accent),
              0 16px 36px -8px color-mix(in oklab, var(--accent) 70%, transparent),
              inset 0 1px 0 rgba(255,255,255,.4);
}
.btn--ghost{
  background: transparent;
  color: var(--ink-0);
  border-color: var(--line-strong);
}
.btn--ghost:hover{ background: var(--bg-3); border-color: var(--ink-4); }
.btn--block{ width: 100%; justify-content: center; padding: 14px 18px; }
.play-dot{
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--accent);
  box-shadow: 0 0 0 3px color-mix(in oklab, var(--accent) 30%, transparent);
}

/* ============================================================= HERO */
.hero{
  position: relative;
  padding: clamp(40px, 6vw, 80px) var(--pad-x) clamp(50px, 7vw, 100px);
  overflow: hidden;
  isolation: isolate;
}
.hero__bg{
  position: absolute; inset: 0; z-index: -1;
  background:
    radial-gradient(1200px 600px at 85% -10%, color-mix(in oklab, var(--accent) 12%, transparent), transparent 60%),
    radial-gradient(900px 700px at -10% 50%, color-mix(in oklab, #6b84ff 10%, transparent), transparent 60%),
    linear-gradient(180deg, #08080c, #0a0a0f 60%);
}
.hero__grid{
  position: absolute; inset: 0;
  background-image:
    linear-gradient(to right, rgba(255,255,255,.04) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(255,255,255,.04) 1px, transparent 1px);
  background-size: 48px 48px;
  mask-image: radial-gradient(ellipse at center, black 30%, transparent 80%);
}
.hero__glow{ position: absolute; border-radius: 50%; filter: blur(80px); opacity: .5; }
.hero__glow--1{ width: 520px; height: 520px; right: -120px; top: -120px; background: color-mix(in oklab, var(--accent) 40%, transparent); }
.hero__glow--2{ width: 420px; height: 420px; left: -120px; bottom: -80px; background: color-mix(in oklab, #7a6bff 40%, transparent); }

.scanlines{
  position: absolute; inset: 0; pointer-events: none;
  background: repeating-linear-gradient(
    to bottom,
    transparent 0 2px,
    rgba(255,255,255,.035) 2px 3px
  );
  opacity: var(--scanlines-alpha);
  mix-blend-mode: overlay;
}

.hero__inner{
  position: relative;
  max-width: var(--maxw);
  margin: 0 auto;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1.1fr);
  gap: clamp(32px, 5vw, 64px);
  align-items: center;
  padding: clamp(24px, 4vw, 56px) 0;
}

.eyebrow{
  display: inline-flex; align-items: center; gap: 8px;
  font: 500 12px var(--font-mono); letter-spacing: .08em;
  color: var(--ink-2); text-transform: uppercase;
  padding: 6px 12px;
  border: 1px solid var(--line-strong);
  border-radius: 999px;
  background: color-mix(in oklab, var(--bg-2) 80%, transparent);
}
.eyebrow__dot{
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--accent);
  box-shadow: 0 0 8px var(--accent);
  animation: pulseDot 2s ease-in-out infinite;
}
.eyebrow--tbd{ color: var(--warn); border-color: color-mix(in oklab, var(--warn) 25%, var(--line-strong)); }
.eyebrow--tbd .eyebrow__dot{ background: var(--warn); box-shadow: 0 0 8px var(--warn); }

@keyframes pulseDot{
  0%, 100%{ transform: scale(1); opacity: 1; }
  50%{ transform: scale(1.6); opacity: .5; }
}

.hero__headline{
  font-size: clamp(42px, 7vw, 84px);
  line-height: .98; letter-spacing: -.035em;
  font-weight: 700;
  margin: 22px 0 18px;
  text-wrap: balance;
}
.hero__headline .line{ display: block; overflow: hidden; }
.hero__accent{
  background: linear-gradient(135deg, var(--accent) 0%, var(--accent-2) 50%, #b5ffe9 100%);
  -webkit-background-clip: text; background-clip: text; color: transparent;
  position: relative;
}
.hero__accent::after{
  content: "_";
  color: var(--accent);
  -webkit-text-fill-color: var(--accent);
  animation: blink 1.1s steps(2) infinite;
  margin-left: 2px;
}
@keyframes blink{ 0%,50%{ opacity: 1; } 50.01%,100%{ opacity: 0; } }

.hero__sub{
  color: var(--ink-1);
  font-size: clamp(16px, 1.3vw, 19px);
  max-width: 52ch;
  margin: 0 0 28px;
  text-wrap: pretty;
}
.hero__ctas{ display: flex; gap: 12px; flex-wrap: wrap; margin-bottom: 36px; }

.hero__meta{
  display: grid; grid-template-columns: repeat(3, auto);
  gap: 32px; padding-top: 28px;
  border-top: 1px dashed var(--line-strong);
  max-width: 500px;
}
.hero__meta strong{
  display: block; font-family: var(--font-mono); font-size: 22px; color: var(--accent); font-weight: 700;
  letter-spacing: -.02em;
}
.hero__meta span{ font-size: 12px; color: var(--ink-2); }

/* ============================================================= INTRO CINEMA */
html.cinema-on{ overflow: hidden; }
html.cinema-on body > *:not(.cinema){ opacity: 0; transition: opacity .8s ease .3s; }
html.cinema-on.cinema-done body > *:not(.cinema){ opacity: 1; }

.cinema{
  position: fixed; inset: 0; z-index: 500;
  background: radial-gradient(1200px 800px at 50% 50%, #0d0e16 0%, #05050a 70%, #000 100%);
  display: grid; place-items: center;
  transition: opacity .8s ease, transform .8s ease;
}
.cinema--done{ opacity: 0; transform: scale(1.15); pointer-events: none; }
.cinema__skip{
  position: absolute; bottom: 22px; right: 22px;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.1);
  color: rgba(255,255,255,.5);
  padding: 7px 14px; border-radius: 999px;
  font: 500 12px var(--font-mono); letter-spacing: .05em;
  cursor: pointer; z-index: 2;
}
.cinema__skip:hover{ color: #fff; border-color: var(--accent); }
.cinema__scene{ position: relative; }

.cinema__laptop{
  position: relative;
  opacity: 0; transform: translateY(40px) scale(.95);
  animation: cinLaptopIn 1s ease .3s forwards;
  filter: drop-shadow(0 40px 80px rgba(0,0,0,.8));
}
@keyframes cinLaptopIn{
  to{ opacity: 1; transform: translateY(0) scale(1); }
}
.lp-lid{
  width: min(520px, 70vw);
  background: #2a2a2e;
  border-radius: 14px 14px 0 0;
  padding: 10px 10px 6px;
  border: 1px solid #444; border-bottom: none;
}
.lp-cam{ width: 6px; height: 6px; border-radius: 50%; background: #555; margin: 0 auto 6px; }
.lp-screen{
  width: 100%; aspect-ratio: 16/10;
  background: #000; border-radius: 4px; overflow: hidden;
  position: relative;
}
.lp-hinge{ width: calc(min(520px, 70vw) + 20px); height: 6px; background: linear-gradient(to bottom, #555, #3a3a3a); margin: 0 auto; }
.lp-base{ width: calc(min(520px, 70vw) + 60px); height: 14px; background: linear-gradient(to bottom, #3a3a3a, #2a2a2e); border-radius: 0 0 10px 10px; border: 1px solid #444; border-top: none; margin: 0 auto; display: flex; align-items: center; justify-content: center; }
.lp-pad{ width: 100px; height: 4px; background: #333; border-radius: 2px; border: 1px solid #444; }

.bsod{
  position: absolute; inset: 0;
  background: #0078d7;
  padding: 26px 32px; color: #fff;
  display: flex; flex-direction: column; justify-content: center;
  transition: opacity .5s ease;
}
.bsod--out{ opacity: 0; }
.bsod__sad{ font-size: 4rem; line-height: 1; margin-bottom: 10px; }
.bsod__msg{ font-size: 14px; line-height: 1.5; margin-bottom: 10px; font-family: var(--font-sans); }
.bsod__stop{ font: 400 10px var(--font-mono); color: rgba(255,255,255,.55); margin-bottom: 14px; }
.bsod__loader{ display: flex; align-items: center; gap: 10px; font-size: 11px; color: rgba(255,255,255,.75); }
.bsod__spin{ width: 18px; height: 18px; border: 2px solid rgba(255,255,255,.3); border-top-color: #fff; border-radius: 50%; animation: cinSpin 1s linear infinite; }
@keyframes cinSpin{ to{ transform: rotate(360deg); } }

.lp-flash{ position: absolute; inset: 0; background: #fff; opacity: 0; pointer-events: none; }
.lp-flash--go{ animation: cinFlicker .6s steps(8); }
@keyframes cinFlicker{
  0%,100%{ opacity: 0; }
  10%{ opacity: .7; } 20%{ opacity: 0; }
  35%{ opacity: .4; } 55%{ opacity: .9; }
  75%{ opacity: .1; } 90%{ opacity: .5; }
}

.cinema__usb{
  position: absolute; display: flex; align-items: center;
  right: -64px; top: 38%;
  transform: translateX(420px) rotate(-3deg); opacity: 0;
  z-index: 10;
}
.cu--fly{ animation: cinUsbFly 1.2s cubic-bezier(.22,1,.36,1) forwards; }
@keyframes cinUsbFly{
  0%  { transform: translateX(420px) rotate(-3deg); opacity: 0; }
  12% { opacity: 1; }
  65% { transform: translateX(10px) rotate(0); }
  80% { transform: translateX(-4px) rotate(0); }
  100%{ transform: translateX(0) rotate(0); opacity: 1; }
}
.cu-plug{ width: 14px; height: 18px; background: linear-gradient(to bottom, #cfcfcf, #8b8b8b); border-radius: 2px 0 0 2px; border: 1px solid #999; border-right: none; }
.cu-body{ width: 64px; height: 26px; background: linear-gradient(to bottom, #1a1a1a, #101016); border-radius: 0 5px 5px 0; border: 1px solid #444; border-left: none; display: flex; align-items: center; padding: 0 7px; position: relative; }
.cu-text{ font: 700 9px var(--font-mono); color: var(--accent); letter-spacing: 1px; }
.cu-led{ position: absolute; right: 6px; top: 50%; transform: translateY(-50%); width: 5px; height: 5px; border-radius: 50%; background: #333; }
.cu-led--on{ background: var(--accent); box-shadow: 0 0 10px var(--accent); animation: cinLed 1.5s ease infinite; }
@keyframes cinLed{ 0%,100%{ box-shadow: 0 0 10px var(--accent); } 50%{ box-shadow: 0 0 3px var(--accent); } }

/* ===== Hero stage (terminal + usb) */
.hero__stage{
  position: relative;
  aspect-ratio: 1 / .95;
  min-height: 420px;
}

/* ===== Terminal */
.terminal{
  position: relative;
  background: linear-gradient(180deg, #0b0d14, #090a10);
  border: 1px solid var(--line-strong);
  border-radius: var(--r-lg);
  box-shadow:
    0 0 0 1px rgba(0,212,170,.05),
    0 30px 80px -24px rgba(0,0,0,.8),
    0 0 80px -20px color-mix(in oklab, var(--accent) 45%, transparent);
  overflow: hidden;
  height: 100%;
  display: flex; flex-direction: column;
}
.terminal::before{
  content: ""; position: absolute; inset: 0; pointer-events: none;
  background: repeating-linear-gradient(to bottom, transparent 0 3px, rgba(255,255,255,.02) 3px 4px);
  opacity: .7;
  mix-blend-mode: overlay;
}
.terminal__chrome{
  display: flex; align-items: center; gap: 8px;
  padding: 10px 14px;
  border-bottom: 1px solid var(--line);
  background: linear-gradient(180deg, #12141d, #0d0f16);
  font: 500 12px var(--font-mono); color: var(--ink-2);
}
.tl{ width: 11px; height: 11px; border-radius: 50%; display: inline-block; }
.tl--r{ background: #ff5f57; }
.tl--y{ background: #febc2e; }
.tl--g{ background: #28c840; }
.terminal__title{ flex: 1; text-align: center; letter-spacing: .02em; }
.terminal__badge{
  font-size: 10px; color: var(--accent); letter-spacing: .12em;
  padding: 3px 8px; border-radius: 999px;
  background: color-mix(in oklab, var(--accent) 12%, transparent);
  border: 1px solid color-mix(in oklab, var(--accent) 30%, transparent);
}
.terminal__body{
  flex: 1;
  padding: 20px 22px;
  font: 400 13.5px/1.65 var(--font-mono);
  color: #cfd3df;
  overflow: hidden;
  position: relative;
}
.term-line{ display: block; white-space: pre-wrap; }
.term-user{ color: var(--accent-2); }
.term-prompt{ color: var(--ink-2); }
.term-dim{ color: var(--ink-3); }
.term-ok{ color: var(--accent); }
.term-warn{ color: var(--warn); }
.term-bad{ color: var(--crit); }
.term-cmd{ color: #bbd0ff; }
.term-head{ color: var(--ink-1); font-weight: 700; letter-spacing: .02em; }
.cursor{
  display: inline-block; width: 8px; height: 1.1em;
  background: var(--accent); vertical-align: -2px; margin-left: 3px;
  animation: blink 1s steps(2) infinite;
}

/* Boot flicker (deprecated) */
.boot{ display: none; }

/* Hero platforms strip */
.hero__platforms{
  position: relative;
  margin: clamp(36px, 5vw, 56px) auto 0;
  max-width: var(--maxw);
  display: flex; flex-wrap: wrap; gap: 10px; align-items: center;
  font: 500 12px var(--font-mono); color: var(--ink-3); letter-spacing: .06em; text-transform: uppercase;
}
.chip{
  padding: 6px 10px;
  border: 1px solid var(--line-strong);
  border-radius: 999px;
  color: var(--ink-1);
  letter-spacing: 0; text-transform: none;
  font: 500 12.5px var(--font-sans);
  background: color-mix(in oklab, var(--bg-2) 80%, transparent);
}
.chip--mint{ border-color: color-mix(in oklab, var(--accent) 35%, var(--line-strong)); color: var(--accent-2); }
.sep{ flex-basis: 100%; height: 0; }

/* ============================================================= STATS BAR */
.stats{ padding: 0 var(--pad-x); margin-top: 40px; }
.stats__inner{
  max-width: var(--maxw); margin: 0 auto;
  display: grid; grid-template-columns: repeat(4, 1fr);
  border: 1px solid var(--line-strong);
  border-radius: var(--r-md);
  background: linear-gradient(180deg, var(--bg-2), var(--bg-1));
  overflow: hidden;
}
.stat{
  padding: 26px 28px;
  border-right: 1px solid var(--line);
}
.stat:last-child{ border-right: 0; }
.stat__n{
  font: 700 clamp(30px, 3.4vw, 44px)/1 var(--font-mono);
  color: var(--ink-0);
  letter-spacing: -.02em;
}
.stat__n span{ color: var(--accent); font-size: .5em; margin-left: 2px; font-weight: 500; letter-spacing: 0; }
.stat__l{ font-size: 13.5px; color: var(--ink-2); margin-top: 8px; }

/* ============================================================= SECTION HEAD */
.section-head{
  max-width: 780px;
  padding: clamp(60px, 9vw, 120px) var(--pad-x) 28px;
  margin: 0 auto;
}
.section-head h2{
  font-size: clamp(30px, 4.2vw, 52px); line-height: 1.05;
  letter-spacing: -.025em; font-weight: 700;
  margin: 16px 0 12px;
  text-wrap: balance;
}
.section-head p{ color: var(--ink-1); font-size: clamp(16px, 1.2vw, 18px); max-width: 56ch; text-wrap: pretty; margin: 0; }
.section-head--inline{
  max-width: var(--maxw);
  display: grid; grid-template-columns: 1fr 1fr; gap: 40px; align-items: end;
}
.section-head--inline p{ justify-self: end; text-align: right; }

/* ============================================================= HEALTH SCORE */
.health{ padding: 0 var(--pad-x) clamp(60px, 8vw, 110px); }
.health__grid{
  max-width: var(--maxw);
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 22px;
}
.health-card{
  position: relative;
  background: linear-gradient(180deg, var(--bg-2), #0b0c13);
  border: 1px solid var(--line-strong);
  border-radius: var(--r-lg);
  padding: 22px;
  overflow: hidden;
  transition: transform .4s, box-shadow .4s;
}
.health-card--good{
  box-shadow: 0 30px 80px -40px rgba(0,0,0,.9), 0 0 0 1px color-mix(in oklab, var(--accent) 10%, transparent);
}
.health-card--good:hover{
  transform: translateY(-4px);
  box-shadow: 0 40px 100px -40px rgba(0,0,0,.9), 0 0 60px -20px color-mix(in oklab, var(--accent) 45%, transparent);
}
.health-card--bad{
  box-shadow: 0 30px 80px -40px rgba(0,0,0,.9), 0 0 0 1px color-mix(in oklab, var(--crit) 14%, transparent);
}
.health-card--bad:hover{
  transform: translateY(-4px);
  box-shadow: 0 40px 100px -40px rgba(0,0,0,.9), 0 0 60px -20px color-mix(in oklab, var(--crit) 35%, transparent);
}
.health-card__head{
  display: flex; align-items: center; justify-content: space-between;
  padding: 6px 10px 16px;
}
.health-card__label{ display: inline-flex; align-items: center; gap: 8px; font-weight: 500; color: var(--ink-1); }
.dot{ width: 8px; height: 8px; border-radius: 50%; }
.dot--mint{ background: var(--accent); box-shadow: 0 0 8px var(--accent); }
.dot--red{ background: var(--crit); box-shadow: 0 0 8px var(--crit); }

.health-card__grade{
  font: 700 42px/1 var(--font-mono);
  letter-spacing: -.03em;
  padding: 8px 16px;
  border-radius: var(--r-sm);
  background: var(--bg-3);
  border: 1px solid var(--line-strong);
}
.health-card--good .health-card__grade{ color: var(--accent); border-color: color-mix(in oklab, var(--accent) 30%, var(--line-strong)); }
.health-card--bad  .health-card__grade{ color: var(--crit); border-color: color-mix(in oklab, var(--crit) 35%, var(--line-strong)); }

.health-card__terminal{
  background: #06070b;
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  padding: 18px;
  font-family: var(--font-mono);
  font-size: 13.5px;
}
.hc-score{
  display: flex; justify-content: space-between; align-items: baseline;
  padding-bottom: 14px; margin-bottom: 14px;
  border-bottom: 1px dashed var(--line-strong);
  color: var(--ink-2); letter-spacing: .06em; text-transform: uppercase; font-size: 11.5px;
}
.hc-score__n{
  font: 700 22px/1 var(--font-mono);
  letter-spacing: -.02em;
}
.health-card--good .hc-score__n{ color: var(--accent); }
.health-card--bad  .hc-score__n{ color: var(--crit); }

.hc-bars{ display: grid; gap: 10px; margin-bottom: 14px; }
.hc-bar{
  display: grid;
  grid-template-columns: 78px 1fr 36px;
  align-items: center; gap: 14px;
  font-size: 12.5px; color: var(--ink-1);
}
.hc-bar em{ font-style: normal; text-align: right; color: var(--ink-2); }
.hc-bar__track{
  height: 10px; border-radius: 3px;
  background: #0e1018;
  border: 1px solid var(--line);
  overflow: hidden;
  position: relative;
}
.hc-bar__fill{
  height: 100%; width: 0%;
  background: linear-gradient(90deg, var(--accent), var(--accent-2));
  box-shadow: 0 0 18px color-mix(in oklab, var(--accent) 55%, transparent);
  transition: width 1.6s cubic-bezier(.2,.8,.2,1);
}
.health-card--bad .hc-bar__fill{
  background: linear-gradient(90deg, var(--crit), #ff8a5a);
  box-shadow: 0 0 18px color-mix(in oklab, var(--crit) 55%, transparent);
}
.health-card--bad .hc-bar[data-pct="79"] .hc-bar__fill,
.health-card--bad .hc-bar[data-pct="58"] .hc-bar__fill{
  background: linear-gradient(90deg, var(--warn), #ffd46a);
  box-shadow: 0 0 18px color-mix(in oklab, var(--warn) 55%, transparent);
}

.hc-details{
  padding-top: 14px; border-top: 1px dashed var(--line-strong);
  display: grid; gap: 6px;
  font-size: 12.5px; color: var(--ink-1);
}
.tok{ display: inline-block; width: 14px; font-weight: 700; }
.tok--ok{ color: var(--accent); }
.tok--warn{ color: var(--warn); }
.tok--bad{ color: var(--crit); }

.health__cta{
  max-width: var(--maxw); margin: 28px auto 0;
  display: flex; align-items: center; gap: 14px; flex-wrap: wrap;
  font-size: 14px;
  color: var(--ink-2);
}
.health__cta code{
  padding: 8px 12px;
  background: var(--bg-2);
  border: 1px solid var(--line-strong);
  border-radius: var(--r-sm);
  color: var(--accent);
  font-size: 13px;
}

/* ============================================================= COMPARE SLIDER */
.compare{ padding: 0 var(--pad-x) clamp(60px, 8vw, 110px); }
.compare__stage{
  position: relative;
  max-width: var(--maxw); margin: 10px auto 0;
  aspect-ratio: 16 / 7.2;
  min-height: 420px;
  border-radius: var(--r-lg);
  overflow: hidden;
  border: 1px solid var(--line-strong);
  background: #06070b;
  user-select: none;
  cursor: ew-resize;
}
.compare__pane{
  position: absolute; inset: 0;
  display: grid; place-items: center;
  padding: 40px;
}
.compare__pane--before{
  background:
    radial-gradient(500px 400px at 30% 40%, color-mix(in oklab, var(--crit) 18%, transparent), transparent 60%),
    linear-gradient(135deg, #16070a, #0a0a0f);
}
.compare__pane--after{
  clip-path: inset(0 0 0 50%);
  background:
    radial-gradient(500px 400px at 70% 40%, color-mix(in oklab, var(--accent) 18%, transparent), transparent 60%),
    linear-gradient(135deg, #06140f, #0a0a0f);
  transition: clip-path 0s;
}
.compare__label{
  position: absolute; top: 16px;
  font: 700 11px/1 var(--font-mono); letter-spacing: .2em;
  padding: 8px 12px;
  border: 1px solid var(--line-strong);
  border-radius: 999px;
  background: color-mix(in oklab, var(--bg-1) 75%, transparent);
  backdrop-filter: blur(6px);
}
.compare__pane--before .compare__label{ left: 20px; color: var(--crit); border-color: color-mix(in oklab, var(--crit) 35%, var(--line-strong)); }
.compare__pane--after  .compare__label{ right: 20px; color: var(--accent); border-color: color-mix(in oklab, var(--accent) 35%, var(--line-strong)); }

.mini-meter{
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 32px;
  align-items: center;
  max-width: 520px;
}
.mini-meter__ring{
  position: relative; width: 180px; height: 180px;
}
.mini-meter__ring svg{ width: 100%; height: 100%; transform: rotate(-90deg); }
.ring-track{ fill: none; stroke: var(--line-strong); stroke-width: 10; }
.ring-fill{ fill: none; stroke-width: 10; stroke-linecap: round; stroke-dasharray: 327; stroke-dashoffset: calc(327 - (327 * var(--pct,0) / 100)); transition: stroke-dashoffset 1.5s cubic-bezier(.2,.8,.2,1); }
.mini-meter--good .ring-fill{ stroke: var(--accent); filter: drop-shadow(0 0 8px var(--accent)); }
.mini-meter--bad  .ring-fill{ stroke: var(--crit);   filter: drop-shadow(0 0 8px var(--crit)); }
.mini-meter__num{
  position: absolute; inset: 0; display: grid; place-content: center;
  font: 700 44px/1 var(--font-mono); letter-spacing: -.02em;
}
.mini-meter--good .mini-meter__num{ color: var(--accent); }
.mini-meter--bad  .mini-meter__num{ color: var(--crit); }
.mini-meter__grade{
  position: absolute; top: -8px; right: -8px;
  font: 700 14px/1 var(--font-mono);
  padding: 4px 8px; border-radius: 6px;
  background: var(--bg-2); border: 1px solid var(--line-strong);
}
.mini-meter--good .mini-meter__grade{ color: var(--accent); }
.mini-meter--bad  .mini-meter__grade{ color: var(--crit); }

.mini-meter ul{ list-style: none; margin: 0; padding: 0; display: grid; gap: 6px; font: 400 13.5px var(--font-mono); }

.compare__handle{
  position: absolute; top: 0; bottom: 0;
  left: 50%; width: 2px;
  background: rgba(255,255,255,.35);
  transform: translateX(-1px);
  pointer-events: none;
  z-index: 3;
}
.compare__line{ position: absolute; inset: 0; background: linear-gradient(180deg, transparent, var(--ink-0) 30% 70%, transparent); opacity: .7; }
.compare__grip{
  position: absolute; top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  width: 48px; height: 48px; border-radius: 50%;
  background: var(--bg-1);
  border: 1px solid var(--line-strong);
  color: var(--ink-0);
  display: grid; place-content: center;
  box-shadow: 0 8px 30px rgba(0,0,0,.5), 0 0 0 4px rgba(0,0,0,.3);
  pointer-events: auto;
  cursor: ew-resize;
}
.compare__grip svg{ width: 22px; height: 22px; }

/* ============================================================= HOW IT WORKS */
.how{ padding: 0 var(--pad-x) clamp(60px, 8vw, 110px); }
.steps{
  max-width: var(--maxw); margin: 10px auto 0;
  list-style: none; padding: 0;
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: 18px;
  counter-reset: step;
}
.step{
  position: relative;
  padding: 26px 22px;
  background: linear-gradient(180deg, var(--bg-2), #0a0b10);
  border: 1px solid var(--line-strong);
  border-radius: var(--r-md);
  transition: transform .35s, border-color .35s;
}
.step:hover{ transform: translateY(-3px); border-color: color-mix(in oklab, var(--accent) 25%, var(--line-strong)); }
.step__n{
  font: 700 12px var(--font-mono);
  color: var(--accent);
  letter-spacing: .15em;
}
.step__icon{
  width: 44px; height: 44px;
  display: grid; place-content: center;
  border: 1px solid var(--line-strong);
  border-radius: var(--r-sm);
  color: var(--accent);
  margin: 14px 0 18px;
  background: var(--bg-3);
}
.step__icon svg{ width: 22px; height: 22px; }
.safety__ico svg{ width: 20px; height: 20px; }
.step h3{ margin: 0 0 6px; font-size: 19px; letter-spacing: -.01em; }
.step p{ margin: 0; color: var(--ink-1); font-size: 14.5px; line-height: 1.6; }
.step p em{ color: var(--accent-2); font-style: italic; font-family: var(--font-mono); font-size: 13px; }
.step code{ color: var(--accent); background: var(--bg-3); padding: 1px 5px; border-radius: 4px; border: 1px solid var(--line); }

/* ============================================================= SAFETY */
.safety{ padding: 0 var(--pad-x) clamp(60px, 8vw, 110px); position: relative; }

.blocked{
  max-width: var(--maxw); margin: 0 auto 36px;
  background: linear-gradient(180deg, #1a0b10, #0a0a0f 80%);
  border: 1px solid color-mix(in oklab, var(--crit) 22%, var(--line-strong));
  border-radius: var(--r-lg);
  padding: 22px;
  overflow: hidden;
  position: relative;
}
.blocked::before{
  content: ""; position: absolute; inset: 0;
  background: repeating-linear-gradient(-45deg, transparent 0 12px, rgba(255,77,77,.03) 12px 13px);
  pointer-events: none;
}
.blocked__head{
  display: flex; justify-content: space-between; align-items: baseline;
  padding: 4px 6px 16px; border-bottom: 1px dashed color-mix(in oklab, var(--crit) 25%, var(--line-strong));
  margin-bottom: 16px;
}
.blocked__title{ font-family: var(--font-mono); font-size: 13px; color: var(--ink-0); letter-spacing: .05em; }
.blocked__counter{ font: 500 12px var(--font-mono); color: var(--ink-2); }
.blocked__counter em{ color: var(--crit); font-style: normal; font-weight: 700; }

.blocked__list{
  list-style: none; margin: 0; padding: 0;
  display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 8px;
  font-family: var(--font-mono); font-size: 13px;
}
.blocked__list li{
  display: flex; align-items: center; gap: 10px;
  padding: 10px 12px;
  background: #0b0c12;
  border: 1px solid var(--line);
  border-radius: var(--r-sm);
  position: relative;
  overflow: hidden;
}
.blocked__list li[data-state="blocked"]{
  border-color: color-mix(in oklab, var(--crit) 30%, var(--line-strong));
  background: linear-gradient(90deg, color-mix(in oklab, var(--crit) 10%, #0b0c12), #0b0c12 60%);
}
.blocked__list li[data-state="blocked"] .blk-cmd{
  color: var(--crit);
  text-decoration: line-through;
  text-decoration-color: color-mix(in oklab, var(--crit) 60%, transparent);
}
.blk-dollar{ color: var(--ink-3); }
.blk-cmd{ color: var(--ink-0); flex: 1; }
.blk-tag{
  font-size: 10px; padding: 2px 6px; border-radius: 4px;
  font-weight: 700; letter-spacing: .1em;
}
.blocked__list li[data-state="pending"] .blk-tag{ background: var(--bg-3); color: var(--ink-2); }
.blocked__list li[data-state="blocked"] .blk-tag{ background: color-mix(in oklab, var(--crit) 25%, transparent); color: var(--crit); }

.safety__grid{
  max-width: var(--maxw); margin: 0 auto;
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px;
}
.safety__card{
  background: linear-gradient(180deg, var(--bg-2), #0b0c13);
  border: 1px solid var(--line-strong);
  border-radius: var(--r-md);
  padding: 22px;
  transition: border-color .3s, transform .3s;
}
.safety__card:hover{ border-color: color-mix(in oklab, var(--accent) 25%, var(--line-strong)); transform: translateY(-2px); }
.safety__ico{
  width: 40px; height: 40px;
  display: grid; place-content: center;
  background: var(--bg-3); border: 1px solid var(--line-strong);
  border-radius: var(--r-sm);
  font-size: 18px;
  margin-bottom: 14px;
}
.safety__card h3{ margin: 0 0 6px; font-size: 17px; letter-spacing: -.01em; }
.safety__card p{ margin: 0; color: var(--ink-1); font-size: 14px; line-height: 1.6; }

/* ============================================================= PRICING */
.pricing{ padding: 0 var(--pad-x) clamp(40px, 6vw, 80px); }
.plans{
  max-width: 960px; margin: 0 auto;
  display: grid; grid-template-columns: 1fr 1fr; gap: 18px;
}
.plan{
  position: relative;
  padding: 28px;
  background: linear-gradient(180deg, var(--bg-2), #0b0c13);
  border: 1px solid var(--line-strong);
  border-radius: var(--r-lg);
  display: flex; flex-direction: column; gap: 20px;
  transition: transform .35s, box-shadow .35s, border-color .35s;
}
.plan:hover{ transform: translateY(-4px); }
.plan--featured{
  border-color: color-mix(in oklab, var(--accent) 45%, transparent);
  background: linear-gradient(180deg, #0a1a16, #0a0c12 75%);
  box-shadow: 0 30px 80px -40px rgba(0,0,0,.9),
              0 0 0 1px color-mix(in oklab, var(--accent) 25%, transparent),
              0 0 80px -20px color-mix(in oklab, var(--accent) 35%, transparent);
}
.plan__ribbon{
  position: absolute; top: -12px; right: 24px;
  background: var(--accent); color: #001912;
  font: 700 11px var(--font-mono); letter-spacing: .1em;
  padding: 5px 10px; border-radius: 999px;
}
.plan__tag{
  display: inline-block;
  font: 500 12px var(--font-mono); color: var(--ink-2);
  letter-spacing: .1em; text-transform: uppercase;
  padding: 4px 10px;
  border: 1px solid var(--line-strong);
  border-radius: 999px;
  margin-bottom: 10px;
}
.plan__price{
  font: 700 clamp(40px, 4.5vw, 58px)/1 var(--font-mono);
  letter-spacing: -.03em;
  display: flex; align-items: baseline;
}
.plan__cur{ font-size: .55em; color: var(--ink-2); margin-right: 4px; font-weight: 500; }
.plan__unit{ font-size: .28em; color: var(--ink-2); margin-left: 10px; font-weight: 500; letter-spacing: .05em; text-transform: uppercase; }
.plan__desc{ color: var(--ink-1); font-size: 14.5px; margin: 12px 0 0; }
.plan ul{
  list-style: none; margin: 0; padding: 12px 0 0;
  border-top: 1px dashed var(--line-strong);
  display: grid; gap: 10px;
  font-size: 14px; color: var(--ink-1);
}
.plan ul li{ display: flex; align-items: start; gap: 10px; }
.plan ul li svg{ width: 14px; height: 14px; color: var(--accent); margin-top: 3px; flex-shrink: 0; }
.plan ul li code{ color: var(--accent); background: var(--bg-3); padding: 1px 5px; border-radius: 4px; border: 1px solid var(--line); }
.pricing__note{
  max-width: 720px; margin: 26px auto 0;
  text-align: center; color: var(--ink-2); font-size: 13.5px;
  padding: 0 var(--pad-x);
}

/* ============================================================= TESTIMONIALS */
.quotes{ padding: 0 var(--pad-x) clamp(60px, 8vw, 110px); }
.quotes__grid{
  max-width: var(--maxw); margin: 0 auto;
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px;
}
.quote{
  margin: 0; padding: 26px;
  background: linear-gradient(180deg, var(--bg-2), #0b0c13);
  border: 1px solid var(--line-strong);
  border-radius: var(--r-md);
  position: relative;
}
.quote::before{
  content: "\201C"; position: absolute; top: 6px; left: 20px;
  font: 700 64px serif; color: var(--accent);
  opacity: .4;
}
.quote blockquote{
  margin: 0 0 20px; padding-top: 20px;
  font-size: 15.5px; line-height: 1.6; color: var(--ink-0);
  text-wrap: pretty;
}
.quote figcaption{ display: flex; align-items: center; gap: 12px; border-top: 1px dashed var(--line-strong); padding-top: 16px; }
.avatar{
  width: 38px; height: 38px; border-radius: 50%;
  display: grid; place-content: center;
  font: 700 12px var(--font-mono);
  background: oklch(.6 .13 calc(var(--h) * 1));
  color: #001912;
  flex-shrink: 0;
}
.quote figcaption strong{ display: block; font-size: 13.5px; }
.quote figcaption span{ font-size: 12.5px; color: var(--ink-2); }

/* ============================================================= FAQ */
.faq{ padding: 0 var(--pad-x) clamp(60px, 8vw, 110px); }
.faq__list{ max-width: 820px; margin: 0 auto; }
.faq details{
  border-bottom: 1px solid var(--line-strong);
  padding: 18px 4px;
}
.faq details[open]{ padding-bottom: 22px; }
.faq summary{
  cursor: pointer; list-style: none;
  display: flex; justify-content: space-between; align-items: center; gap: 18px;
  font-size: 17px; font-weight: 500;
  padding: 4px 0;
  transition: color .2s;
}
.faq summary::-webkit-details-marker{ display: none; }
.faq summary::after{
  content: ""; width: 14px; height: 14px;
  background: linear-gradient(to bottom, var(--ink-2), var(--ink-2)) center/2px 14px no-repeat,
              linear-gradient(to right, var(--ink-2), var(--ink-2)) center/14px 2px no-repeat;
  transition: transform .25s;
  flex-shrink: 0;
}
.faq details[open] summary::after{ transform: rotate(45deg); background: linear-gradient(to right, var(--accent), var(--accent)) center/14px 2px no-repeat; }
.faq summary:hover{ color: var(--accent); }
.faq details p{
  margin: 12px 0 0; color: var(--ink-1); font-size: 15px; line-height: 1.7;
  max-width: 72ch;
}
.faq details code{ color: var(--accent); background: var(--bg-3); padding: 1px 5px; border-radius: 4px; border: 1px solid var(--line); }

/* ============================================================= CTA STRIP */
.cta-strip{ padding: 0 var(--pad-x) clamp(60px, 8vw, 100px); }
.cta-strip__inner{
  max-width: var(--maxw); margin: 0 auto;
  padding: clamp(36px, 5vw, 56px);
  background:
    radial-gradient(600px 300px at 80% 30%, color-mix(in oklab, var(--accent) 22%, transparent), transparent 70%),
    linear-gradient(180deg, #0a1a16, #0a0c12);
  border: 1px solid color-mix(in oklab, var(--accent) 30%, var(--line-strong));
  border-radius: var(--r-xl);
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 30px;
  align-items: center;
  position: relative;
  overflow: hidden;
}
.cta-strip__inner::before{
  content: "FIXSTIX"; position: absolute;
  top: 50%; right: -40px; transform: translateY(-50%);
  font: 900 180px/1 var(--font-mono);
  letter-spacing: -.04em;
  color: color-mix(in oklab, var(--accent) 8%, transparent);
  pointer-events: none;
  white-space: nowrap;
}
.cta-strip h2{ margin: 0; font-size: clamp(26px, 3.2vw, 38px); letter-spacing: -.025em; line-height: 1.1; }
.cta-strip p{ margin: 8px 0 0; color: var(--ink-1); font-size: 16px; }
.cta-strip__buttons{ display: flex; flex-direction: column; gap: 10px; align-items: flex-end; position: relative; z-index: 1; }

/* ============================================================= FOOTER */
.foot{
  padding: clamp(40px, 5vw, 70px) var(--pad-x) 20px;
  border-top: 1px solid var(--line);
  background: var(--bg-0);
}
.foot__inner{
  max-width: var(--maxw); margin: 0 auto;
  display: grid; grid-template-columns: 1.2fr 2fr; gap: 40px;
  padding-bottom: 40px;
}
.foot__brand p{ color: var(--ink-2); font-size: 13.5px; margin: 16px 0 0; max-width: 42ch; }
.foot__brand a{ color: var(--ink-0); border-bottom: 1px dotted var(--ink-3); }
.foot__cols{ display: grid; grid-template-columns: repeat(3, 1fr); gap: 30px; }
.foot__cols h4{ font-size: 12px; color: var(--ink-2); letter-spacing: .12em; text-transform: uppercase; margin: 0 0 14px; font-family: var(--font-mono); font-weight: 500; }
.foot__cols a{ display: block; color: var(--ink-1); font-size: 14px; padding: 4px 0; transition: color .2s; }
.foot__cols a:hover{ color: var(--accent); }
.foot__rule{
  max-width: var(--maxw); margin: 0 auto;
  padding: 18px 0 4px; border-top: 1px solid var(--line);
  display: flex; justify-content: space-between;
  font: 500 12px var(--font-mono); color: var(--ink-3);
}
.foot__status{ display: inline-flex; align-items: center; gap: 8px; }
.pulse{ width: 6px; height: 6px; border-radius: 50%; background: var(--accent); box-shadow: 0 0 8px var(--accent); animation: pulseDot 2s ease-in-out infinite; }

/* ============================================================= REVEAL / ANIM */
.reveal{ opacity: 0; transform: translateY(24px); transition: opacity .8s, transform .8s; }
.reveal.is-in{ opacity: 1; transform: none; }
.reveal[data-stagger]{ transition-delay: calc(var(--i, 0) * 80ms); }

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

/* ============================================================= TWEAKS PANEL */
#tweaksPanel[data-open="true"]{
  position: fixed; right: 18px; bottom: 18px; z-index: 200;
  width: 300px;
  background: linear-gradient(180deg, var(--bg-2), var(--bg-1));
  border: 1px solid var(--line-strong);
  border-radius: var(--r-md);
  padding: 18px;
  box-shadow: 0 30px 80px -20px rgba(0,0,0,.8), 0 0 0 1px color-mix(in oklab, var(--accent) 20%, transparent);
  font-size: 13px;
}
#tweaksPanel h4{ margin: 0 0 14px; font: 600 13px var(--font-mono); color: var(--accent); letter-spacing: .08em; }
#tweaksPanel .tw-row{ display: grid; gap: 6px; margin-bottom: 14px; }
#tweaksPanel label{ color: var(--ink-2); font-size: 12px; text-transform: uppercase; letter-spacing: .08em; font-family: var(--font-mono); }
#tweaksPanel .swatches{ display: flex; gap: 6px; }
#tweaksPanel .sw{
  width: 26px; height: 26px; border-radius: 6px; cursor: pointer;
  border: 1px solid var(--line-strong);
}
#tweaksPanel .sw[aria-selected="true"]{ outline: 2px solid var(--ink-0); outline-offset: 2px; }
#tweaksPanel select, #tweaksPanel input[type=range]{
  width: 100%; padding: 8px; border-radius: 6px;
  background: var(--bg-3); color: var(--ink-0);
  border: 1px solid var(--line-strong);
  font: 500 13px var(--font-sans);
}
#tweaksPanel input[type=range]{ padding: 0; accent-color: var(--accent); }

/* ============================================================= RESPONSIVE */
@media (max-width: 1024px){
  .hero__inner{ grid-template-columns: 1fr; }
  .hero__stage{ min-height: 460px; }
  .health__grid{ grid-template-columns: 1fr; }
  .steps{ grid-template-columns: repeat(2, 1fr); }
  .safety__grid{ grid-template-columns: repeat(2, 1fr); }
  .quotes__grid{ grid-template-columns: 1fr; }
  .foot__inner{ grid-template-columns: 1fr; }
  .stats__inner{ grid-template-columns: repeat(2, 1fr); }
  .stat{ border-bottom: 1px solid var(--line); }
  .stat:nth-child(odd){ border-right: 1px solid var(--line); }
  .stat:nth-last-child(-n+2){ border-bottom: 0; }
  .section-head--inline{ grid-template-columns: 1fr; }
  .section-head--inline p{ justify-self: start; text-align: left; }
  .plans{ grid-template-columns: 1fr; }
  .cta-strip__inner{ grid-template-columns: 1fr; }
  .cta-strip__buttons{ align-items: flex-start; }
  .nav__links{ display: none; }
}
@media (max-width: 640px){
  .hero__meta{ grid-template-columns: 1fr 1fr; gap: 18px; }
  .stats__inner{ grid-template-columns: 1fr; }
  .stat{ border-right: 0 !important; }
  .steps{ grid-template-columns: 1fr; }
  .safety__grid{ grid-template-columns: 1fr; }
  .mini-meter{ grid-template-columns: 1fr; text-align: center; justify-items: center; }
  .mini-meter__ring{ width: 140px; height: 140px; }
  .mini-meter__num{ font-size: 34px; }
  .foot__cols{ grid-template-columns: repeat(2, 1fr); }
  .nav__actions .btn{ display: none; }
  .compare__stage{ aspect-ratio: auto; min-height: 560px; }
}
