/* =========================================================
   Vektra Legacy — page styles
   Tokens come from variables.css (load it first).
   ========================================================= */
* { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  background: var(--space);
  color: var(--star);
  font: 400 17px/1.65 var(--font-body);
  -webkit-font-smoothing: antialiased;
}
a { color: var(--gold); }
:focus-visible { outline: 2px solid var(--gold); outline-offset: 3px; }
.mono { font-family: var(--font-mono); }
.wrap { max-width: var(--wrap-max); margin: 0 auto; padding: 0 var(--gutter); }

/* ---------- header ---------- */
header {
  position: sticky; top: 0; z-index: 10;
  background: rgba(10, 13, 28, .88);
  backdrop-filter: blur(8px);
  border-bottom: 1px solid var(--line);
}
.nav { display: flex; align-items: center; justify-content: space-between; height: 60px; }
.logo {
  font: 700 18px var(--font-display);
  letter-spacing: .14em; text-transform: uppercase;
  color: var(--star); text-decoration: none;
}
.logo b { color: var(--gold); font-weight: 700; }
.nav nav { display: flex; gap: 26px; }
.nav nav a {
  color: var(--dim); text-decoration: none;
  font-size: 13px; letter-spacing: .1em; text-transform: uppercase;
  font-family: var(--font-mono);
}
.nav nav a:hover { color: var(--star); }

/* ---------- hero ---------- */
.hero { position: relative; overflow: hidden; border-bottom: 1px solid var(--line); }
#chart { position: absolute; inset: 0; width: 100%; height: 100%; opacity: .9; }
.scrim {
  position: absolute; inset: 0; pointer-events: none;
  background: linear-gradient(90deg,
    rgba(10, 13, 28, .94) 0%, rgba(10, 13, 28, .6) 48%, rgba(10, 13, 28, 0) 78%);
}
.hero-inner { position: relative; padding: 110px 0 96px; max-width: 640px; }
.eyebrow {
  font-family: var(--font-mono);
  font-size: 12px; letter-spacing: .22em; text-transform: uppercase;
  color: var(--gold); margin-bottom: 18px;
}
h1 {
  font: 700 clamp(44px, 7vw, 76px)/1.02 var(--font-display);
  letter-spacing: .01em; text-transform: uppercase;
}
h1 .alt { color: var(--gold); }
.tagline {
  font: 600 clamp(18px, 2.4vw, 24px)/1.3 var(--font-display);
  color: var(--dim); margin: 18px 0 22px;
  text-transform: uppercase; letter-spacing: .06em;
}
.tagline em { font-style: normal; color: var(--red); }
.lede { color: var(--dim); max-width: 54ch; margin-bottom: 34px; }
.cta-row { display: flex; gap: 14px; flex-wrap: wrap; }
.btn {
  display: inline-block; padding: 13px 26px; text-decoration: none;
  font: 500 13px var(--font-mono);
  letter-spacing: .14em; text-transform: uppercase;
  border: 1px solid var(--gold); color: var(--space); background: var(--gold);
  cursor: pointer;
}
.btn:hover { background: var(--gold-hi); border-color: var(--gold-hi); }
.btn.ghost { background: transparent; color: var(--star); border-color: var(--line); }
.btn.ghost:hover { border-color: var(--dim); }
.chart-cap {
  position: absolute; right: var(--gutter); bottom: 14px;
  font: 400 11px var(--font-mono);
  color: var(--dim); letter-spacing: .08em;
}
.chart-cap i { font-style: normal; color: var(--gold); }

/* ---------- sections ---------- */
section { padding: var(--section-pad) 0; border-bottom: 1px solid var(--line); }
.sec-eyebrow {
  font-family: var(--font-mono);
  font-size: 12px; letter-spacing: .22em; text-transform: uppercase;
  color: var(--dim); margin-bottom: 14px;
}
h2 {
  font: 700 clamp(26px, 3.6vw, 38px)/1.15 var(--font-display);
  text-transform: uppercase; letter-spacing: .02em; margin-bottom: 14px;
}
.sec-lede { color: var(--dim); max-width: 62ch; margin-bottom: 44px; }

/* HUD corner ticks used on every card */
.card { position: relative; background: var(--panel); padding: 30px 28px; }
.card::before, .card::after {
  content: ""; position: absolute; width: 14px; height: 14px; pointer-events: none;
}
.card::before { top: -1px; left: -1px; border-top: 2px solid var(--dim); border-left: 2px solid var(--dim); }
.card::after { bottom: -1px; right: -1px; border-bottom: 2px solid var(--dim); border-right: 2px solid var(--dim); }

/* ---------- two paths ---------- */
.paths { display: grid; grid-template-columns: 1fr 1fr; gap: 22px; }
.path h3 {
  font: 600 20px var(--font-display);
  text-transform: uppercase; letter-spacing: .08em; margin-bottom: 6px;
}
.path .role {
  font: 400 12px var(--font-mono);
  letter-spacing: .18em; text-transform: uppercase; margin-bottom: 18px;
}
.path ul { list-style: none; }
.path li { padding: 10px 0; border-top: 1px solid var(--line); color: var(--dim); font-size: 15.5px; }
.path li b { color: var(--star); font-weight: 500; }
.path.lawful { box-shadow: inset 3px 0 0 var(--gold); background: var(--panel-lawful); }
.path.lawful .role { color: var(--gold); }
.path.lawful::before, .path.lawful::after { border-color: var(--gold); }
.path.outlaw { box-shadow: inset 3px 0 0 var(--red); background: var(--panel-outlaw); }
.path.outlaw .role { color: var(--red); }
.path.outlaw::before, .path.outlaw::after { border-color: var(--red); }
.path-note { margin-top: 20px; color: var(--dim); font-size: 15px; max-width: 70ch; }
.path-note b { color: var(--star); font-weight: 500; }

/* ---------- scan depth ladder ---------- */
.ladder { display: flex; flex-direction: column; }
.rung {
  display: grid; grid-template-columns: 130px 1fr 220px; gap: 18px;
  align-items: center; padding: 16px 0; border-top: 1px solid var(--line);
}
.rung:last-child { border-bottom: 1px solid var(--line); }
.rung .lvl { font: 500 13px var(--font-mono); letter-spacing: .14em; text-transform: uppercase; }
.rung .bar { height: 10px; background: var(--panel); position: relative; }
.rung .bar i { position: absolute; inset: 0; width: var(--w); background: var(--lane); }
.rung:nth-child(4) .bar i,
.rung:nth-child(5) .bar i { background: var(--red); }
.rung .note { font-size: 13.5px; color: var(--dim); font-family: var(--font-mono); }

/* ---------- governments ---------- */
.govs { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; }
.gov { background: var(--panel); padding: 18px; border: 1px solid var(--line); }
.gov h4 {
  font: 600 14px var(--font-display);
  letter-spacing: .1em; text-transform: uppercase; margin-bottom: 6px;
}
.gov p { font-size: 13px; color: var(--dim); line-height: 1.5; }
.gov .sec {
  font: 400 11px var(--font-mono);
  color: var(--gold); letter-spacing: .12em; display: block; margin-top: 10px;
}
.gov.bad .sec { color: var(--red); }

/* ---------- waitlist ---------- */
.signup { padding: 96px 0; text-align: center; border-bottom: none; }
.signup h2 { margin-bottom: 10px; }
.signup p { color: var(--dim); max-width: 52ch; margin: 0 auto 32px; }
.signup form { display: flex; gap: 10px; justify-content: center; flex-wrap: wrap; }
.signup input[type=email] {
  width: min(360px, 80vw); padding: 13px 16px;
  background: var(--panel); border: 1px solid var(--line); color: var(--star);
  font: 400 15px var(--font-mono);
}
.signup input[type=email]::placeholder { color: var(--dim); }
.signup input[type=email]:focus { border-color: var(--gold); outline: none; }
#signup-msg { margin-top: 16px; font: 400 13px var(--font-mono); min-height: 20px; }
#signup-msg.ok { color: var(--gold); }
#signup-msg.err { color: var(--red); }

/* ---------- footer ---------- */
footer {
  border-top: 1px solid var(--line); padding: 30px 0;
  color: var(--dim);
  font: 400 12px var(--font-mono);
  letter-spacing: .1em;
}
.foot { display: flex; justify-content: space-between; flex-wrap: wrap; gap: 10px; }

/* ---------- responsive ---------- */
@media (max-width: 820px) {
  .paths { grid-template-columns: 1fr; }
  .govs { grid-template-columns: repeat(2, 1fr); }
  .rung { grid-template-columns: 96px 1fr; }
  .rung .note { grid-column: 1 / -1; padding-left: 0; }
  .hero-inner { padding: 84px 0 80px; }
}
@media (max-width: 480px) {
  .govs { grid-template-columns: 1fr; }
}
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
}
