/* ============================================================================
   Nexus Signals — Landing (website-v2)
   Compiled stylesheet: design tokens + glass components + page sections.
   Self-contained. Derived faithfully from the Nexus Signals design system:
     tokens/colors.css · typography.css · spacing.css · fonts.css
   Brand law: Trust Blue is the ONE primary. NO GREEN. Mint = "verified win"
   micro-state only. Loss = Cool Gray (measured), never red. Caution = Ember.
   ========================================================================== */

@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&family=Inter:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500;700&display=swap');

/* ---------------------------------------------------------------- tokens -- */
:root {
  /* core brand palette */
  --ns-midnight:   #180B43;
  --ns-midnight-2: #120833;
  --ns-midnight-3: #251463;
  --ns-ink:        #0F172A;
  --ns-trust:      #4D83FF;
  --ns-soft:       #78ADFF;
  --ns-cream:      #F8F6EF;
  --ns-gray:       #B7C1D5;

  /* functional accents (sparing) */
  --ns-mint:  #58E6A3;   /* verified-win micro-state ONLY */
  --ns-ember: #FF7A2F;   /* caution / price-down */

  /* tints / glass scaffolding */
  --ns-soft-04: rgba(120,173,255,0.04);
  --ns-soft-08: rgba(120,173,255,0.08);
  --ns-soft-12: rgba(120,173,255,0.12);
  --ns-soft-16: rgba(120,173,255,0.16);
  --ns-soft-22: rgba(120,173,255,0.22);
  --ns-soft-32: rgba(120,173,255,0.32);
  --ns-cream-04: rgba(255,255,255,0.04);
  --ns-cream-06: rgba(255,255,255,0.06);
  --ns-cream-10: rgba(255,255,255,0.10);

  /* semantic aliases */
  --bg-base: var(--ns-midnight);
  --bg-deep: var(--ns-midnight-2);
  --bg-elevated: var(--ns-midnight-3);
  --surface-card: var(--ns-cream-04);
  --surface-card-hover: var(--ns-cream-06);
  --surface-inset: rgba(0,0,0,0.18);

  --border-subtle: var(--ns-soft-12);
  --border-default: var(--ns-soft-16);
  --border-strong: var(--ns-soft-32);

  --text-primary: var(--ns-cream);
  --text-secondary: #D7DDEC;
  --text-muted: var(--ns-gray);
  --text-on-accent: #FFFFFF;

  --accent: var(--ns-trust);
  --accent-hover: var(--ns-soft);
  --link: var(--ns-trust);

  /* signal / market status */
  --status-win: var(--ns-mint);
  --status-loss: var(--ns-gray);
  --status-pending: var(--ns-soft);
  --price-up: var(--ns-soft);     /* never green */
  --price-down: var(--ns-ember);

  --status-win-bg: rgba(88,230,163,0.14);
  --status-win-border: rgba(88,230,163,0.40);
  --status-loss-bg: rgba(183,193,213,0.14);
  --status-loss-border: rgba(183,193,213,0.40);
  --status-pending-bg: rgba(120,173,255,0.14);
  --status-pending-border: rgba(120,173,255,0.40);
  --ember-bg: rgba(255,122,47,0.12);
  --ember-border: rgba(255,122,47,0.32);

  /* gradients */
  --gradient-bg: linear-gradient(135deg, #221061 0%, #180B43 55%, #0F172A 100%);
  --gradient-bg-radial: radial-gradient(120% 80% at 28% 12%, var(--ns-midnight-3) 0%, var(--ns-midnight) 50%, var(--ns-midnight-2) 100%);
  --gradient-accent: linear-gradient(90deg, var(--ns-soft), var(--ns-trust));
  --glow-shield: radial-gradient(circle, rgba(120,173,255,0.22) 0%, rgba(120,173,255,0) 70%);

  /* type */
  --font-display: 'Space Grotesk','Segoe UI',system-ui,sans-serif;
  --font-body: 'Inter',system-ui,-apple-system,sans-serif;
  --font-mono: 'JetBrains Mono',ui-monospace,'SF Mono',Menlo,monospace;
  --weight-regular: 400;
  --weight-medium: 500;
  --weight-semibold: 600;
  --weight-bold: 700;

  --text-hero: clamp(2.75rem, 6vw, 5rem);
  --text-h1: clamp(2.25rem, 4.5vw, 3.5rem);
  --text-h2: clamp(1.75rem, 3vw, 2.5rem);
  --text-h3: clamp(1.375rem, 2vw, 1.75rem);
  --text-h4: 1.25rem;
  --text-body-lg: 1.125rem;
  --text-body: 1rem;
  --text-sm: 0.875rem;
  --text-xs: 0.75rem;

  --leading-tight: 1.05;
  --leading-snug: 1.2;
  --leading-normal: 1.5;
  --leading-relaxed: 1.65;

  --tracking-display: -0.02em;
  --tracking-tight: -0.01em;
  --tracking-wide: 0.06em;
  --tracking-eyebrow: 0.18em;

  /* spacing (8px grid) */
  --space-1: 4px;  --space-2: 8px;  --space-3: 12px; --space-4: 16px;
  --space-5: 24px; --space-6: 32px; --space-7: 48px; --space-8: 64px;
  --space-9: 96px; --space-10: 128px;
  --section-pad-y: clamp(64px, 9vw, 128px);
  --container-max: 1200px;
  --container-pad: clamp(20px, 5vw, 48px);

  /* radii */
  --radius-xs: 6px; --radius-sm: 8px; --radius-md: 10px;
  --radius-lg: 16px; --radius-xl: 24px; --radius-pill: 999px;

  /* shadows / glow */
  --shadow-sm: 0 1px 2px rgba(0,0,0,0.25);
  --shadow-md: 0 8px 24px rgba(0,0,0,0.35);
  --shadow-lg: 0 24px 60px rgba(0,0,0,0.45);
  --shadow-card: 0 12px 40px rgba(8,4,24,0.45);
  --glow-accent: 0 0 28px rgba(77,131,255,0.30);
  --glow-accent-strong: 0 0 48px rgba(77,131,255,0.45);
  --inset-hairline: inset 0 1px 0 rgba(255,255,255,0.06);
  --blur-glass: 14px;

  /* motion */
  --ease-out: cubic-bezier(0.22,0.61,0.36,1);
  --ease-in-out: cubic-bezier(0.65,0.05,0.36,1);
  --dur-fast: 140ms; --dur-normal: 240ms; --dur-slow: 420ms;

  --z-sticky: 100; --z-overlay: 1000;
}

/* ----------------------------------------------------------------- base -- */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
@media (prefers-reduced-motion: reduce) { html { scroll-behavior: auto; } }

body {
  margin: 0;
  font-family: var(--font-body);
  font-size: var(--text-body);
  line-height: var(--leading-normal);
  color: var(--text-primary);
  background: var(--bg-base);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}

/* fixed atmospheric background layer */
.bg-atmos {
  position: fixed; inset: 0; z-index: -2;
  background: var(--gradient-bg-radial);
}
.bg-grid {
  position: fixed; inset: 0; z-index: -1; pointer-events: none;
  background-image:
    linear-gradient(var(--ns-soft-04) 1px, transparent 1px),
    linear-gradient(90deg, var(--ns-soft-04) 1px, transparent 1px);
  background-size: 64px 64px;
  mask-image: radial-gradient(120% 90% at 50% 0%, #000 0%, transparent 70%);
  -webkit-mask-image: radial-gradient(120% 90% at 50% 0%, #000 0%, transparent 70%);
}

h1,h2,h3,h4 { font-family: var(--font-display); font-weight: var(--weight-semibold); letter-spacing: var(--tracking-display); margin: 0; }
p { margin: 0; }
a { color: var(--link); text-decoration: none; }
a:hover { color: var(--accent-hover); }
img, svg { display: block; max-width: 100%; }
ul { margin: 0; padding: 0; list-style: none; }

:focus-visible {
  outline: 2px solid var(--ns-soft);
  outline-offset: 3px;
  border-radius: var(--radius-xs);
}

.mono { font-family: var(--font-mono); font-variant-numeric: tabular-nums; }
.skip-link {
  position: absolute; left: -999px; top: 0; z-index: var(--z-overlay);
  background: var(--ns-trust); color: #fff; padding: 10px 16px;
  border-radius: 0 0 var(--radius-sm) 0; font-weight: 600;
}
.skip-link:focus { left: 0; color: #fff; }

/* ------------------------------------------------------------- layout --- */
.container { width: 100%; max-width: var(--container-max); margin: 0 auto; padding-inline: var(--container-pad); }
.section { padding-block: var(--section-pad-y); position: relative; }
.section--tight { padding-block: clamp(40px, 6vw, 80px); }

.eyebrow {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: var(--tracking-eyebrow);
  text-transform: uppercase;
  color: var(--ns-soft);
  display: inline-flex; align-items: center; gap: 8px;
}
.eyebrow::before {
  content: ""; width: 22px; height: 1px; background: var(--ns-soft-32);
}
.section-head { max-width: 720px; margin-bottom: var(--space-7); }
.section-head h2 { font-size: var(--text-h2); margin-top: var(--space-3); line-height: var(--leading-snug); }
.section-head p { color: var(--text-secondary); font-size: var(--text-body-lg); margin-top: var(--space-3); line-height: var(--leading-relaxed); }

/* --------------------------------------------------------- components --- */
/* Glass panel */
.glass {
  background: var(--surface-card);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-md);
  box-shadow: var(--inset-hairline), var(--shadow-card);
  -webkit-backdrop-filter: blur(var(--blur-glass));
  backdrop-filter: blur(var(--blur-glass));
}
.glass--glow { box-shadow: var(--inset-hairline), var(--shadow-card), var(--glow-accent); }
.glass--hover { transition: transform var(--dur-normal) var(--ease-out), border-color var(--dur-normal) var(--ease-out), background var(--dur-normal) var(--ease-out); }
.glass--hover:hover { transform: translateY(-3px); border-color: var(--border-strong); background: var(--surface-card-hover); }

/* Buttons */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  font-family: var(--font-body); font-weight: 600; font-size: 15px;
  height: 44px; padding: 0 20px; border-radius: var(--radius-sm);
  border: 1px solid transparent; cursor: pointer; white-space: nowrap;
  text-decoration: none; line-height: 1;
  transition: background var(--dur-fast) var(--ease-out), border-color var(--dur-fast) var(--ease-out),
              transform var(--dur-fast) var(--ease-out), box-shadow var(--dur-normal) var(--ease-out);
}
.btn:active { transform: translateY(1px) scale(0.99); }
.btn--primary { background: var(--ns-trust); color: var(--text-on-accent); box-shadow: var(--glow-accent); }
.btn--primary:hover { background: var(--ns-soft); color: var(--text-on-accent); box-shadow: var(--glow-accent-strong); }
.btn--secondary { background: var(--surface-card); color: var(--text-primary); border-color: var(--border-default); }
.btn--secondary:hover { background: var(--surface-card-hover); border-color: var(--border-strong); color: var(--text-primary); }
.btn--ghost { background: transparent; color: var(--text-secondary); }
.btn--ghost:hover { background: var(--ns-cream-04); color: var(--text-primary); }
.btn--lg { height: 54px; padding: 0 28px; font-size: 16px; }
.btn--sm { height: 36px; padding: 0 14px; font-size: 13px; }
.btn--block { width: 100%; }
.btn svg { width: 18px; height: 18px; }
.btn img { width: 18px; height: 18px; border-radius: 4px; }

/* Badge / pill */
.badge {
  display: inline-flex; align-items: center; gap: 6px;
  font-family: var(--font-mono); font-size: 11px; font-weight: 500;
  letter-spacing: 0.08em; text-transform: uppercase;
  padding: 4px 10px; border-radius: var(--radius-pill);
  line-height: 1.3; white-space: nowrap;
  background: var(--ns-cream-04); border: 1px solid var(--border-default); color: var(--text-muted);
}
.badge .dot { width: 6px; height: 6px; border-radius: 50%; background: var(--ns-gray); flex: none; }
.badge--win    { background: var(--status-win-bg); border-color: var(--status-win-border); color: #8af0c2; }
.badge--win .dot { background: var(--ns-mint); }
.badge--loss   { background: var(--status-loss-bg); border-color: var(--status-loss-border); color: #cdd5e6; }
.badge--loss .dot { background: var(--ns-gray); }
.badge--pending{ background: var(--status-pending-bg); border-color: var(--status-pending-border); color: #a9caff; }
.badge--pending .dot { background: var(--ns-soft); }
.badge--accent { background: var(--ns-soft-12); border-color: var(--ns-soft-32); color: var(--ns-soft); }
.badge--accent .dot { background: var(--ns-trust); }
.badge--caution{ background: var(--ember-bg); border-color: var(--ember-border); color: #ffb894; }
.badge--caution .dot { background: var(--ns-ember); }
.badge--live .dot { animation: pulse-dot 1.8s var(--ease-in-out) infinite; }
@keyframes pulse-dot { 0%,100% { opacity: 1; } 50% { opacity: 0.35; } }

/* Stat block */
.stat { display: flex; flex-direction: column; gap: 6px; }
.stat .stat-val { font-family: var(--font-mono); font-weight: 700; font-size: clamp(2rem, 4vw, 3rem); line-height: 1; letter-spacing: -0.01em; color: var(--text-primary); font-variant-numeric: tabular-nums; }
.stat .stat-val.accent { color: var(--ns-soft); }
.stat .stat-label { font-size: var(--text-sm); color: var(--text-muted); font-weight: 500; }
.stat .stat-sub { font-family: var(--font-mono); font-size: var(--text-xs); color: var(--ns-soft); letter-spacing: 0.04em; }

/* Wallet chip */
.wallet {
  display: inline-flex; align-items: center; gap: 7px;
  font-family: var(--font-mono); font-size: 12px; color: var(--text-secondary);
  background: var(--surface-inset); border: 1px solid var(--border-subtle);
  padding: 3px 9px; border-radius: var(--radius-pill);
}
.wallet .wdot { width: 7px; height: 7px; border-radius: 50%; background: var(--gradient-accent); flex: none; }

/* Price change */
.price { font-family: var(--font-mono); font-variant-numeric: tabular-nums; font-weight: 500; display: inline-flex; align-items: center; gap: 3px; }
.price--up { color: var(--ns-soft); }
.price--down { color: var(--ns-ember); }

/* Signal row (the receipts artifact) */
.signalrow {
  display: grid; grid-template-columns: minmax(0,1fr) auto; gap: 14px 20px; align-items: center;
  padding: 16px 18px; background: var(--surface-card);
  border: 1px solid var(--border-default); border-radius: var(--radius-md);
  box-shadow: var(--inset-hairline);
}
.signalrow .sr-main { min-width: 0; display: flex; flex-direction: column; gap: 8px; }
.signalrow .sr-top { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.signalrow .sr-side { font-family: var(--font-mono); font-size: 11px; font-weight: 700; letter-spacing: 0.06em; }
.signalrow .sr-side.yes { color: var(--ns-soft); }
.signalrow .sr-side.no { color: var(--ns-ember); }
.signalrow .sr-market { font-family: var(--font-display); font-weight: 600; font-size: var(--text-body); color: var(--text-primary); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.signalrow .sr-meta { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.signalrow .sr-logged { font-family: var(--font-mono); font-size: 11px; color: var(--text-muted); letter-spacing: 0.04em; }
.signalrow .sr-right { display: flex; align-items: center; gap: 22px; justify-content: flex-end; }
.signalrow .sr-num { text-align: right; }
.signalrow .sr-num .big { font-family: var(--font-mono); font-size: 15px; color: var(--text-primary); font-variant-numeric: tabular-nums; }
.signalrow .sr-num .cap { font-family: var(--font-mono); font-size: 10px; color: var(--text-muted); letter-spacing: 0.08em; text-transform: uppercase; }

/* ------------------------------------------------------------- header --- */
.site-header {
  position: sticky; top: 0; z-index: var(--z-sticky);
  border-bottom: 1px solid transparent;
  transition: background var(--dur-normal) var(--ease-out), border-color var(--dur-normal) var(--ease-out), backdrop-filter var(--dur-normal);
}
.site-header.scrolled {
  background: rgba(18,8,51,0.72);
  -webkit-backdrop-filter: blur(16px); backdrop-filter: blur(16px);
  border-bottom-color: var(--border-subtle);
}
.nav { display: flex; align-items: center; justify-content: space-between; height: 68px; gap: var(--space-5); }
.brand { display: inline-flex; align-items: center; gap: 11px; color: var(--text-primary); }
.brand svg, .brand img { width: 34px; height: 34px; }
.brand .wordmark { font-family: var(--font-display); font-weight: 600; font-size: 17px; letter-spacing: -0.01em; }
.nav-links { display: flex; align-items: center; gap: var(--space-6); }
.nav-links a { color: var(--text-secondary); font-size: var(--text-sm); font-weight: 500; }
.nav-links a:hover { color: var(--text-primary); }
.nav-actions { display: flex; align-items: center; gap: var(--space-3); }
.nav-toggle { display: none; background: none; border: 0; color: var(--text-primary); cursor: pointer; padding: 6px; }
.nav-toggle svg { width: 26px; height: 26px; }

/* --------------------------------------------------------------- hero --- */
.hero { padding-top: clamp(48px, 7vw, 96px); padding-bottom: clamp(48px, 7vw, 104px); position: relative; overflow: hidden; }
.hero-grid { display: grid; grid-template-columns: 1.05fr 0.95fr; gap: clamp(32px, 5vw, 72px); align-items: center; }
.hero-copy .eyebrow { margin-bottom: var(--space-5); }
.hero h1 {
  font-size: var(--text-hero); line-height: var(--leading-tight);
  letter-spacing: var(--tracking-display); max-width: 14ch;
}
.hero h1 .grad {
  background: linear-gradient(92deg, var(--ns-soft) 0%, var(--ns-trust) 90%);
  -webkit-background-clip: text; background-clip: text; color: transparent;
}
.hero .lede { margin-top: var(--space-5); font-size: var(--text-body-lg); color: var(--text-secondary); line-height: var(--leading-relaxed); max-width: 52ch; }
.hero .lede strong { color: var(--text-primary); font-weight: 600; }
.hero-cta { display: flex; flex-wrap: wrap; gap: var(--space-3); margin-top: var(--space-6); }
.hero-note { margin-top: var(--space-4); font-family: var(--font-mono); font-size: var(--text-xs); color: var(--text-muted); letter-spacing: 0.02em; display: inline-flex; align-items: center; gap: 8px; }
.hero-note .ico { color: var(--ns-soft); }

.hero-strip { display: flex; flex-wrap: wrap; gap: clamp(20px,4vw,44px); margin-top: var(--space-7); padding-top: var(--space-6); border-top: 1px solid var(--border-subtle); }
.hero-strip .hs { display: flex; flex-direction: column; gap: 4px; }
.hero-strip .hs .v { font-family: var(--font-mono); font-size: var(--text-sm); color: var(--ns-soft); letter-spacing: 0.02em; font-weight: 500; }
.hero-strip .hs .l { font-size: var(--text-xs); color: var(--text-muted); text-transform: uppercase; letter-spacing: 0.1em; font-family: var(--font-mono); }

/* hero visual: the receipts ledger (signature element) */
.ledger { padding: 20px; position: relative; }
.ledger-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: var(--space-4); }
.ledger-title { display: inline-flex; align-items: center; gap: 9px; }
.ledger-title .lt { font-family: var(--font-display); font-weight: 600; font-size: var(--text-h4); }
.ledger-rail { position: relative; display: flex; flex-direction: column; gap: 10px; padding-left: 22px; }
.ledger-rail::before { content: ""; position: absolute; left: 6px; top: 6px; bottom: 6px; width: 2px; background: linear-gradient(var(--ns-soft-32), var(--ns-soft-08)); }
.ledger-item { position: relative; }
.ledger-item::before { content: ""; position: absolute; left: -19px; top: 22px; width: 9px; height: 9px; border-radius: 50%; background: var(--ns-midnight-3); border: 2px solid var(--ns-soft); }
.ledger-item.win::before { border-color: var(--ns-mint); }
.ledger-item.loss::before { border-color: var(--ns-gray); }
.ledger-foot { margin-top: var(--space-4); font-family: var(--font-mono); font-size: 10.5px; color: var(--text-muted); letter-spacing: 0.04em; line-height: 1.5; }

/* ambient drifting orbs */
.orbs { position: absolute; inset: 0; z-index: -1; pointer-events: none; overflow: hidden; }
.orb { position: absolute; border-radius: 50%; filter: blur(2px); opacity: 0.5;
  background: radial-gradient(circle at 32% 30%, var(--ns-soft-22), transparent 68%);
  border: 1px solid var(--ns-soft-08); }
.orb.o1 { width: 320px; height: 320px; top: -60px; right: 6%; animation: drift1 22s var(--ease-in-out) infinite; }
.orb.o2 { width: 200px; height: 200px; bottom: 4%; left: -40px; animation: drift2 28s var(--ease-in-out) infinite; }
.orb.o3 { width: 140px; height: 140px; top: 40%; right: 38%; opacity: 0.35; animation: drift1 18s var(--ease-in-out) infinite reverse; }
@keyframes drift1 { 0%,100% { transform: translate(0,0); } 50% { transform: translate(-26px, 34px); } }
@keyframes drift2 { 0%,100% { transform: translate(0,0); } 50% { transform: translate(30px, -28px); } }

/* ------------------------------------------------------------ marquee --- */
.marquee-wrap { border-top: 1px solid var(--border-subtle); border-bottom: 1px solid var(--border-subtle); background: rgba(18,8,51,0.45); overflow: hidden; position: relative; }
.marquee-wrap::before, .marquee-wrap::after { content: ""; position: absolute; top: 0; bottom: 0; width: 90px; z-index: 2; pointer-events: none; }
.marquee-wrap::before { left: 0; background: linear-gradient(90deg, var(--bg-base), transparent); }
.marquee-wrap::after { right: 0; background: linear-gradient(270deg, var(--bg-base), transparent); }
.marquee { display: flex; gap: 0; width: max-content; animation: marquee 38s linear infinite; }
.marquee:hover { animation-play-state: paused; }
.marquee-track { display: flex; align-items: center; }
.tick { display: inline-flex; align-items: center; gap: 10px; padding: 14px 26px; border-right: 1px solid var(--border-subtle); white-space: nowrap; }
.tick .sym { font-family: var(--font-mono); font-weight: 700; font-size: var(--text-sm); letter-spacing: 0.04em; color: var(--text-primary); }
.tick .kind { font-family: var(--font-mono); font-size: 10px; text-transform: uppercase; letter-spacing: 0.12em; color: var(--text-muted); }
@keyframes marquee { from { transform: translateX(0); } to { transform: translateX(-50%); } }

/* -------------------------------------------------------- trust strip --- */
.trust-strip { display: flex; flex-wrap: wrap; align-items: center; justify-content: center; gap: 14px 26px; padding-block: var(--space-6); }
.trust-strip .ti { display: inline-flex; align-items: center; gap: 9px; font-size: var(--text-sm); color: var(--text-secondary); }
.trust-strip .ti svg { width: 17px; height: 17px; color: var(--ns-soft); flex: none; }
.trust-strip .sep { width: 4px; height: 4px; border-radius: 50%; background: var(--ns-soft-32); }

/* ----------------------------------------------------------- features --- */
.feature-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--space-5); }
.feature { padding: var(--space-6); display: flex; flex-direction: column; gap: var(--space-3); }
.feature .ficon { width: 44px; height: 44px; border-radius: var(--radius-sm); display: grid; place-items: center; background: var(--ns-soft-08); border: 1px solid var(--ns-soft-16); color: var(--ns-soft); margin-bottom: var(--space-2); }
.feature .ficon svg { width: 22px; height: 22px; }
.feature h3 { font-size: var(--text-h4); }
.feature p { color: var(--text-secondary); line-height: var(--leading-relaxed); font-size: var(--text-sm); }

/* ----------------------------------------------------------- process --- */
.steps { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-5); counter-reset: step; }
.step { padding: var(--space-6); position: relative; display: flex; flex-direction: column; gap: var(--space-3); }
.step .step-num { font-family: var(--font-mono); font-size: var(--text-sm); font-weight: 700; color: var(--ns-soft); letter-spacing: 0.1em; }
.step .step-rule { height: 1px; background: linear-gradient(90deg, var(--ns-soft-32), transparent); margin-block: var(--space-1); }
.step h3 { font-size: var(--text-h4); }
.step p { color: var(--text-secondary); font-size: var(--text-sm); line-height: var(--leading-relaxed); }

/* --------------------------------------------------------- live look --- */
.alert-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-4); }
.alert { padding: var(--space-5); display: flex; flex-direction: column; gap: var(--space-3); }
.alert-top { display: flex; align-items: center; justify-content: space-between; gap: 10px; }
.alert .a-q { font-family: var(--font-display); font-weight: 600; font-size: var(--text-body); line-height: var(--leading-snug); }
.alert .a-rows { display: flex; flex-direction: column; gap: 7px; padding-block: var(--space-2); border-top: 1px solid var(--border-subtle); border-bottom: 1px solid var(--border-subtle); }
.alert .a-row { display: flex; align-items: center; justify-content: space-between; font-family: var(--font-mono); font-size: 12.5px; }
.alert .a-row .k { color: var(--text-muted); letter-spacing: 0.04em; }
.alert .a-row .v { color: var(--text-primary); font-variant-numeric: tabular-nums; }
.alert .a-risk { font-size: var(--text-xs); color: var(--text-muted); line-height: 1.5; display: flex; gap: 7px; }
.alert .a-risk svg { width: 14px; height: 14px; color: var(--ns-ember); flex: none; margin-top: 2px; }
.foot-note { margin-top: var(--space-5); font-family: var(--font-mono); font-size: var(--text-xs); color: var(--text-muted); letter-spacing: 0.02em; }

/* ---------------------------------------------------------- scorecard --- */
.score-wrap { display: grid; grid-template-columns: 0.85fr 1.15fr; gap: clamp(28px, 4vw, 56px); align-items: start; }
.score-panel { padding: var(--space-6); }
.score-headline { display: flex; align-items: baseline; gap: 12px; flex-wrap: wrap; }
.score-headline .big { font-family: var(--font-mono); font-weight: 700; font-size: clamp(2.6rem, 6vw, 4rem); line-height: 1; color: var(--ns-soft); font-variant-numeric: tabular-nums; }
.score-headline .lbl { font-family: var(--font-mono); font-size: var(--text-sm); color: var(--text-muted); text-transform: uppercase; letter-spacing: 0.08em; }
.score-meta { display: flex; flex-wrap: wrap; gap: 14px 28px; margin-top: var(--space-5); }
.score-meta .sm { display: flex; flex-direction: column; gap: 3px; }
.score-meta .sm .v { font-family: var(--font-mono); font-size: var(--text-h4); font-weight: 700; color: var(--text-primary); font-variant-numeric: tabular-nums; }
.score-meta .sm .l { font-size: var(--text-xs); color: var(--text-muted); text-transform: uppercase; letter-spacing: 0.08em; font-family: var(--font-mono); }
.score-bar { display: flex; height: 10px; border-radius: var(--radius-pill); overflow: hidden; margin-top: var(--space-5); border: 1px solid var(--border-subtle); }
.score-bar .b-win { background: linear-gradient(90deg, var(--ns-soft), var(--ns-trust)); }
.score-bar .b-loss { background: var(--ns-gray); opacity: 0.5; }
.score-bar-legend { display: flex; gap: 18px; margin-top: 10px; font-family: var(--font-mono); font-size: var(--text-xs); color: var(--text-muted); }
.score-bar-legend .lg { display: inline-flex; align-items: center; gap: 6px; }
.score-bar-legend .sw { width: 9px; height: 9px; border-radius: 2px; }
.score-ledger { display: flex; flex-direction: column; gap: 10px; }

/* ----------------------------------------------------------- pricing --- */
.pricing-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-5); align-items: stretch; }
.tier { padding: var(--space-6); display: flex; flex-direction: column; gap: var(--space-4); position: relative; }
.tier--featured { border-color: var(--ns-soft-32); box-shadow: var(--inset-hairline), var(--shadow-card), var(--glow-accent); }
.tier-flag { position: absolute; top: -11px; left: var(--space-6); }
.tier-name { font-family: var(--font-mono); font-size: var(--text-sm); text-transform: uppercase; letter-spacing: 0.12em; color: var(--ns-soft); }
.tier-price { display: flex; align-items: flex-end; gap: 6px; }
.tier-price .amt { font-family: var(--font-mono); font-weight: 700; font-size: clamp(2.2rem, 4vw, 2.8rem); line-height: 1; color: var(--text-primary); font-variant-numeric: tabular-nums; }
.tier-price .per { font-family: var(--font-mono); font-size: var(--text-sm); color: var(--text-muted); padding-bottom: 5px; }
.tier-tag { font-size: var(--text-sm); color: var(--text-secondary); min-height: 2.6em; }
.tier-feats { display: flex; flex-direction: column; gap: 10px; padding-block: var(--space-4); border-top: 1px solid var(--border-subtle); flex: 1; }
.tier-feats li { display: flex; gap: 10px; font-size: var(--text-sm); color: var(--text-secondary); line-height: 1.45; }
.tier-feats li svg { width: 16px; height: 16px; color: var(--ns-soft); flex: none; margin-top: 2px; }
.tier-feats li.lead { color: var(--text-primary); font-weight: 600; }
.tier-feats li.lead svg { color: var(--ns-trust); }
.promo-line { margin-top: var(--space-6); text-align: center; font-size: var(--text-sm); color: var(--text-secondary); }
.promo-code { font-family: var(--font-mono); font-weight: 700; color: var(--ns-soft); background: var(--ns-soft-08); border: 1px dashed var(--ns-soft-32); padding: 3px 9px; border-radius: var(--radius-xs); letter-spacing: 0.06em; }
.pricing-disclaimer { margin-top: var(--space-4); text-align: center; font-family: var(--font-mono); font-size: var(--text-xs); color: var(--text-muted); }

/* --------------------------------------------------------------- faq --- */
.faq-list { display: flex; flex-direction: column; gap: var(--space-3); max-width: 820px; }
.faq-item { border: 1px solid var(--border-default); border-radius: var(--radius-md); background: var(--surface-card); overflow: hidden; }
.faq-q { width: 100%; display: flex; align-items: center; justify-content: space-between; gap: 16px; text-align: left; background: none; border: 0; cursor: pointer; color: var(--text-primary); font-family: var(--font-display); font-weight: 600; font-size: var(--text-h4); padding: var(--space-5); line-height: var(--leading-snug); }
.faq-q .chev { width: 20px; height: 20px; color: var(--ns-soft); flex: none; transition: transform var(--dur-normal) var(--ease-out); }
.faq-item[open] .faq-q .chev, .faq-item.open .faq-q .chev { transform: rotate(180deg); }
.faq-a { padding: 0 var(--space-5) var(--space-5); color: var(--text-secondary); line-height: var(--leading-relaxed); font-size: var(--text-body); max-width: 70ch; }
.faq-a strong { color: var(--text-primary); }

/* ------------------------------------------------------------ cta/cap --- */
.cta-cap { text-align: center; padding: clamp(40px,6vw,72px) clamp(24px,5vw,72px); }
.cta-cap h2 { font-size: var(--text-h1); line-height: var(--leading-tight); max-width: 18ch; margin-inline: auto; }
.cta-cap p { color: var(--text-secondary); font-size: var(--text-body-lg); margin-top: var(--space-4); max-width: 56ch; margin-inline: auto; line-height: var(--leading-relaxed); }
.cta-cap .cta-row { display: flex; flex-wrap: wrap; gap: var(--space-3); justify-content: center; margin-top: var(--space-6); }
.cta-cap .disclaimer { margin-top: var(--space-5); font-family: var(--font-mono); font-size: var(--text-xs); color: var(--text-muted); }

/* ------------------------------------------------------------- footer --- */
.site-footer { border-top: 1px solid var(--border-subtle); padding-block: var(--space-7) var(--space-6); margin-top: var(--space-6); }
.footer-top { display: flex; flex-wrap: wrap; justify-content: space-between; gap: var(--space-6); margin-bottom: var(--space-6); }
.footer-brand { max-width: 360px; }
.footer-brand .brand { margin-bottom: var(--space-3); }
.footer-brand p { color: var(--text-muted); font-size: var(--text-sm); line-height: var(--leading-relaxed); }
.footer-cols { display: flex; gap: clamp(32px,6vw,80px); flex-wrap: wrap; }
.footer-col h4 { font-family: var(--font-mono); font-size: var(--text-xs); text-transform: uppercase; letter-spacing: 0.12em; color: var(--text-muted); margin-bottom: var(--space-3); font-weight: 500; }
.footer-col a { display: block; color: var(--text-secondary); font-size: var(--text-sm); padding-block: 5px; }
.footer-col a:hover { color: var(--text-primary); }
.footer-disclaimer { border-top: 1px solid var(--border-subtle); padding-top: var(--space-5); display: flex; flex-wrap: wrap; justify-content: space-between; gap: var(--space-4); }
.footer-disclaimer p { font-family: var(--font-mono); font-size: var(--text-xs); color: var(--text-muted); line-height: 1.6; max-width: 70ch; }
.footer-disclaimer .copy { color: var(--text-muted); font-size: var(--text-xs); font-family: var(--font-mono); }

/* todo marker (dev visibility for Kian — unobtrusive) */
[data-todo] { position: relative; }

/* -------------------------------------------------------- reveal anim --- */
.reveal { opacity: 0; transform: translateY(22px); transition: opacity var(--dur-slow) var(--ease-out), transform var(--dur-slow) var(--ease-out); }
.reveal.in { opacity: 1; transform: none; }
.reveal.d1 { transition-delay: 70ms; }
.reveal.d2 { transition-delay: 140ms; }
.reveal.d3 { transition-delay: 210ms; }

/* ----------------------------------------------------------- responsive - */
@media (max-width: 1000px) {
  .hero-grid { grid-template-columns: 1fr; }
  .hero-visual { order: -1; }
  .score-wrap { grid-template-columns: 1fr; }
  .alert-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 820px) {
  .nav-links { display: none; }
  .nav-toggle { display: inline-flex; }
  .nav.open .nav-links { display: flex; position: absolute; top: 68px; left: 0; right: 0; flex-direction: column; gap: 0; background: rgba(18,8,51,0.97); -webkit-backdrop-filter: blur(16px); backdrop-filter: blur(16px); border-bottom: 1px solid var(--border-subtle); padding: var(--space-3) var(--container-pad); }
  .nav.open .nav-links a { padding-block: 14px; border-bottom: 1px solid var(--border-subtle); width: 100%; }
  .feature-grid { grid-template-columns: 1fr; }
  .steps { grid-template-columns: 1fr; }
  .pricing-grid { grid-template-columns: 1fr; }
  .alert-grid { grid-template-columns: 1fr; }
  .tier--featured { order: -1; }
}
@media (max-width: 520px) {
  .signalrow { grid-template-columns: 1fr; }
  .signalrow .sr-right { justify-content: space-between; gap: 12px; }
  .hero-strip { gap: 18px 28px; }
  .nav-actions .btn--ghost { display: none; }
}

@media (prefers-reduced-motion: reduce) {
  .reveal { opacity: 1 !important; transform: none !important; transition: none !important; }
  .orb, .marquee, .badge--live .dot { animation: none !important; }
  .marquee { transform: none !important; }
  * { scroll-behavior: auto !important; }
}

/* ------------------------------------------------------------- legal pages -- */
.legal-doc { padding-block: clamp(40px, 7vw, 96px) clamp(48px, 8vw, 110px); }
.legal-doc .container { max-width: 860px; }
.legal-head { margin-bottom: var(--space-7); }
.legal-head h1 {
  font-family: var(--font-display); font-weight: var(--weight-bold);
  font-size: var(--text-h1); line-height: var(--leading-snug);
  letter-spacing: var(--tracking-tight); color: var(--text-primary);
  margin: var(--space-3) 0 var(--space-4);
}
.legal-meta { display: flex; flex-wrap: wrap; gap: 8px 18px; color: var(--text-muted); font-size: var(--text-sm); }
.legal-meta .mono { font-family: var(--font-mono); }
.legal-disclaimer {
  margin-top: var(--space-5); padding: var(--space-4) var(--space-5);
  border: 1px solid var(--ember-border); background: var(--ember-bg);
  border-radius: var(--radius-md); color: var(--text-secondary);
  font-size: var(--text-sm); line-height: var(--leading-relaxed);
}
.legal-disclaimer strong { color: var(--text-primary); }
.legal-body { color: var(--text-secondary); line-height: var(--leading-relaxed); font-size: var(--text-body); }
.legal-body h2 {
  font-family: var(--font-display); font-weight: var(--weight-semibold);
  font-size: var(--text-h3); color: var(--text-primary);
  margin: var(--space-7) 0 var(--space-3); letter-spacing: var(--tracking-tight);
}
.legal-body h3 {
  font-family: var(--font-display); font-weight: var(--weight-semibold);
  font-size: var(--text-h4); color: var(--text-primary); margin: var(--space-5) 0 var(--space-2);
}
.legal-body p { margin: 0 0 var(--space-4); }
.legal-body ul, .legal-body ol { margin: 0 0 var(--space-4); padding-left: var(--space-5); }
.legal-body li { margin-bottom: var(--space-2); }
.legal-body a { color: var(--link); text-decoration: underline; text-underline-offset: 2px; }
.legal-body a:hover { color: var(--accent-hover); }
.legal-body strong { color: var(--text-primary); }
.legal-body .caps { text-transform: none; }
.legal-toc { display: flex; flex-wrap: wrap; gap: 8px 14px; margin: var(--space-5) 0 var(--space-6); }
.legal-toc a { color: var(--text-muted); font-size: var(--text-sm); text-decoration: none; }
.legal-toc a:hover { color: var(--accent-hover); }
.legal-back { display: inline-flex; align-items: center; gap: 8px; color: var(--text-muted); font-size: var(--text-sm); text-decoration: none; margin-bottom: var(--space-5); }
.legal-back:hover { color: var(--accent-hover); }
