/* CyberWarden — SOC-MVP styling DNA
   Palette: deep carbon + cool blues/cyans
   Type: DM Sans body, JetBrains Mono for labels/headlines */

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  /* ─── Surfaces ─── */
  --bg-primary: #0a0e17;
  --bg-secondary: #111827;
  --bg-card: #151d2e;
  --bg-card-hover: #1a2540;
  --border: #1e2d4a;

  /* ─── Accents (SOC-MVP DNA) ─── */
  --accent-blue: #3b82f6;
  --accent-blue-2: #2563eb;
  --accent-cyan: #06b6d4;
  --accent-cyan-2: #0891b2;
  --accent-amber: #f59e0b;
  --accent-amber-2: #d97706;
  --accent-green: #10b981;
  --accent-red: #ef4444;
  --accent-purple: #8b5cf6;

  /* ─── Glow halos ─── */
  --glow-blue: rgba(59, 130, 246, 0.15);
  --glow-cyan: rgba(6, 182, 212, 0.12);
  --glow-amber: rgba(245, 158, 11, 0.12);
  --glow-green: rgba(16, 185, 129, 0.12);
  --glow-red: rgba(239, 68, 68, 0.10);

  /* ─── Text ─── */
  --text-primary: #e2e8f0;
  --text-secondary: #94a3b8;
  --text-muted: #475569;

  /* ─── Legacy aliases (so old class names keep working) ─── */
  --navy: var(--accent-blue-2);
  --navy-2: var(--accent-blue);
  --teal: var(--accent-cyan);
  --teal-2: var(--accent-cyan-2);
  --teal-3: var(--accent-cyan);
  --emerald: var(--accent-green);
  --emerald-2: var(--accent-green);
  --amber: var(--accent-amber);
  --amber-2: var(--accent-amber-2);
  --accent: var(--accent-cyan);
  --accent-glow: var(--glow-cyan);
  --border-hover: rgba(59, 130, 246, 0.4);
  --danger: var(--accent-red);

  --radius: 8px;
  --radius-lg: 8px;
}

html { scroll-behavior: smooth; font-size: 16px; }

body {
  font-family: 'DM Sans', system-ui, -apple-system, Segoe UI, sans-serif;
  background: var(--bg-primary);
  color: var(--text-primary);
  overflow-x: hidden;
  line-height: 1.6;
  min-height: 100vh;
}

a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }
button { font-family: inherit; cursor: pointer; }

/* ─── Atmospheric BG (matches SOC-MVP) ─── */
body::before {
  content: '';
  position: fixed; inset: 0; z-index: 0; pointer-events: none;
  background:
    radial-gradient(ellipse 900px 700px at 20% 10%, rgba(59, 130, 246, 0.05) 0%, transparent 70%),
    radial-gradient(ellipse 700px 500px at 80% 80%, rgba(6, 182, 212, 0.04) 0%, transparent 70%);
}

.grid-bg {
  position: fixed; inset: 0; z-index: 0; pointer-events: none;
  background-image:
    linear-gradient(rgba(30, 45, 74, 0.18) 1px, transparent 1px),
    linear-gradient(90deg, rgba(30, 45, 74, 0.18) 1px, transparent 1px);
  background-size: 40px 40px;
}

/* Orbs retired */
.orb { display: none; }

/* Corner watermark (subtle) */
body::after {
  content: ''; position: fixed; z-index: 0; pointer-events: none;
  right: -6vmin; bottom: -8vmin; width: 56vmin; height: 56vmin;
  background-image: url('assets/logo/cyberwarden-symbol.png');
  background-repeat: no-repeat; background-position: center; background-size: contain;
  opacity: .035; filter: saturate(.3) brightness(1.4);
  transform: rotate(-8deg);
}
@media (max-width: 820px) { body::after { width: 80vmin; height: 80vmin; opacity: .045; } }

.container { max-width: 1280px; margin: 0 auto; padding: 0 32px; position: relative; z-index: 1; }
section { position: relative; z-index: 1; }

/* ═════════════ Navigation ═════════════ */
.nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 100;
  padding: 14px 0;
  background: rgba(10, 14, 23, 0.85);
  backdrop-filter: blur(20px);
  border-bottom: 1px solid var(--border);
  transition: all .3s;
}
.nav.scrolled { padding: 10px 0; background: rgba(10, 14, 23, 0.96); }
.nav-inner { display: flex; justify-content: space-between; align-items: center; }
.logo {
  display: flex; align-items: center; gap: 2px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 1rem; font-weight: 700; letter-spacing: -0.5px;
  text-decoration: none;
}
.logo-word {
  font-family: 'JetBrains Mono', monospace;
  font-size: 1.18rem; font-weight: 800; letter-spacing: -0.5px;
  color: var(--accent-cyan); line-height: 1;
}
.logo-word-accent { color: var(--accent-cyan); }
.nav-links { display: flex; align-items: center; gap: 26px; list-style: none; }
.nav-links a {
  font-family: 'JetBrains Mono', monospace;
  font-size: .78rem; font-weight: 500; color: var(--text-secondary);
  text-transform: uppercase; letter-spacing: 1.5px;
  transition: color .2s;
}
.nav-links a:hover, .nav-links a.active { color: var(--accent-cyan); }
.nav-cta {
  background: var(--accent-blue);
  color: #fff !important;
  padding: 9px 18px; border-radius: 5px;
  font-weight: 600 !important; font-size: .76rem !important;
  letter-spacing: 1.2px !important;
  transition: transform .2s, box-shadow .2s, background .2s;
}
.nav-cta:hover { background: var(--accent-blue-2); transform: translateY(-1px);
  box-shadow: 0 8px 24px rgba(59, 130, 246, 0.3); }
.mobile-toggle {
  display: none; background: none; border: none;
  color: var(--text-primary); font-size: 1.4rem; cursor: pointer;
}

/* ═════════════ Logo image ═════════════ */
.logo-img {
  height: 33px; width: auto; display: block;
  filter: drop-shadow(0 4px 14px rgba(6, 182, 212, 0.55));
}
.footer-logo .logo-img { height: 26px; }

/* ═════════════ Hero (text-only fallback) ═════════════ */
.hero { padding: 160px 0 100px; position: relative; }
.hero-inner { max-width: 920px; margin: 0 auto; text-align: center; }

/* Eyebrow */
.eyebrow {
  display: inline-block; padding: 4px 12px;
  border: 1px solid rgba(6, 182, 212, 0.3);
  background: rgba(6, 182, 212, 0.08);
  border-radius: 3px;
  font-family: 'JetBrains Mono', monospace;
  font-size: .72rem; font-weight: 600;
  letter-spacing: 1.6px; text-transform: uppercase;
  color: var(--accent-cyan);
  margin-bottom: 20px;
}

/* Headings — JetBrains Mono per SOC-MVP DNA */
h1, h2, h3, h4, h5 {
  font-family: 'JetBrains Mono', monospace;
  font-weight: 700;
  letter-spacing: -0.5px;
  color: var(--text-primary);
}

.hero h1, .video-hero h1 {
  font-size: clamp(1.75rem, 4.2vw, 2.6rem);
  font-weight: 700; line-height: 1.12;
  letter-spacing: -1px;
  margin-bottom: 22px;
  background: linear-gradient(135deg, var(--text-primary) 0%, var(--accent-cyan) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.hero h1 .accent, .video-hero h1 .accent {
  background: linear-gradient(135deg, var(--accent-blue), var(--accent-cyan));
  -webkit-background-clip: text; background-clip: text;
  color: transparent; -webkit-text-fill-color: transparent;
}
.hero .sub, .video-hero .sub {
  font-family: 'DM Sans', sans-serif;
  font-size: clamp(.92rem, 1.1vw, 1.02rem);
  color: var(--text-secondary);
  max-width: 720px; margin: 0 auto 32px;
  line-height: 1.7;
}
.hero-ctas { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; }

/* ═════════════ Buttons ═════════════ */
.btn {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 11px 22px; border-radius: 5px;
  font-family: 'JetBrains Mono', monospace;
  font-weight: 600; font-size: .8rem;
  letter-spacing: 1.2px; text-transform: uppercase;
  transition: transform .2s, box-shadow .2s, background .2s, border-color .2s;
  border: 1px solid transparent; cursor: pointer;
}
.btn-primary { background: var(--accent-blue); color: #fff; }
.btn-primary:hover {
  background: var(--accent-blue-2); transform: translateY(-1px);
  box-shadow: 0 10px 32px rgba(59, 130, 246, 0.35);
}
.btn-secondary {
  background: transparent; color: var(--text-primary);
  border-color: var(--border);
}
.btn-secondary:hover {
  border-color: var(--accent-cyan); color: var(--accent-cyan);
}
.btn-amber { background: var(--accent-amber); color: #1a1206; }
.btn-amber:hover {
  background: var(--accent-amber-2); transform: translateY(-1px);
  box-shadow: 0 10px 32px rgba(245, 158, 11, 0.3);
}

/* ═════════════ Sections + headings ═════════════ */
.section { padding: 80px 0; }
.section-head { text-align: center; max-width: 820px; margin: 0 auto 56px; }
.section-head .eyebrow { margin-bottom: 16px; }
.section-head h2 {
  font-size: clamp(1.4rem, 2.4vw, 2rem);
  font-weight: 700;
  letter-spacing: -0.8px;
  margin-bottom: 14px;
  line-height: 1.2;
  background: linear-gradient(135deg, var(--text-primary) 0%, var(--accent-cyan) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.section-head p {
  font-family: 'DM Sans', sans-serif;
  color: var(--text-secondary);
  font-size: .98rem; line-height: 1.7;
}

/* ═════════════ Layer label (SOC-MVP DNA) ═════════════ */
.layer-label {
  font-family: 'JetBrains Mono', monospace;
  font-size: .65rem;
  text-transform: uppercase; letter-spacing: 2.5px;
  color: var(--text-muted);
  display: flex; align-items: center; gap: 10px;
  margin-bottom: 18px;
}
.layer-label::after {
  content: ''; flex: 1; height: 1px;
  background: linear-gradient(90deg, var(--border), transparent);
}
.layer-num {
  display: inline-flex; align-items: center; justify-content: center;
  width: 20px; height: 20px;
  border: 1px solid var(--border);
  border-radius: 4px;
  font-size: .62rem; color: var(--text-muted);
  margin-right: 2px;
}

/* ═════════════ Card grid (SOC-MVP DNA) ═════════════ */
.grid { display: grid; gap: 16px; }
.grid-2 { grid-template-columns: 1fr 1fr; }
.grid-3 { grid-template-columns: 1fr 1fr 1fr; }
.grid-4 { grid-template-columns: repeat(4, 1fr); }
@media (max-width: 900px) {
  .grid-3, .grid-4 { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 600px) {
  .grid-2, .grid-3, .grid-4 { grid-template-columns: 1fr; }
}

.card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 22px 24px;
  position: relative; overflow: hidden;
  transition: background .2s, border-color .2s, transform .2s, box-shadow .2s;
}
.card:hover {
  background: var(--bg-card-hover);
  border-color: rgba(59, 130, 246, 0.3);
  transform: translateY(-1px);
}

/* Colored top borders */
.card.accent-blue { border-top: 2px solid var(--accent-blue); }
.card.accent-cyan { border-top: 2px solid var(--accent-cyan); }
.card.accent-amber { border-top: 2px solid var(--accent-amber); }
.card.accent-green { border-top: 2px solid var(--accent-green); }
.card.accent-red { border-top: 2px solid var(--accent-red); }
.card.accent-purple { border-top: 2px solid var(--accent-purple); }

/* Legacy aliases — map old class colors to SOC-MVP equivalents */
.card.navy { border-top: 2px solid var(--accent-blue); }
.card.amber { border-top: 2px solid var(--accent-amber); }

.card.glow-blue { box-shadow: inset 0 1px 0 0 rgba(59,130,246,0.1), 0 0 20px var(--glow-blue); }
.card.glow-cyan { box-shadow: inset 0 1px 0 0 rgba(6,182,212,0.1), 0 0 20px var(--glow-cyan); }
.card.glow-amber { box-shadow: inset 0 1px 0 0 rgba(245,158,11,0.1), 0 0 20px var(--glow-amber); }
.card.glow-green { box-shadow: inset 0 1px 0 0 rgba(16,185,129,0.1), 0 0 20px var(--glow-green); }

.card .icon, .card .card-icon {
  display: flex; align-items: center; justify-content: center;
  width: 38px; height: 38px; border-radius: 6px;
  background: rgba(59, 130, 246, 0.08);
  border: 1px solid rgba(59, 130, 246, 0.18);
  font-family: 'JetBrains Mono', monospace;
  font-size: .82rem; font-weight: 700;
  color: var(--accent-cyan);
  margin-bottom: 14px;
}
.card.amber .icon, .card.amber .card-icon {
  background: rgba(245, 158, 11, 0.08);
  border-color: rgba(245, 158, 11, 0.22);
  color: var(--accent-amber);
}
.card.navy .icon, .card.navy .card-icon {
  background: rgba(59, 130, 246, 0.10);
  border-color: rgba(59, 130, 246, 0.25);
  color: var(--accent-blue);
}
.card.accent-green .icon { color: var(--accent-green); border-color: rgba(16,185,129,.25); background: rgba(16,185,129,.08); }
.card.accent-red .icon { color: var(--accent-red); border-color: rgba(239,68,68,.25); background: rgba(239,68,68,.08); }

.card h3 {
  font-family: 'JetBrains Mono', monospace;
  font-size: .92rem; font-weight: 600;
  margin-bottom: 8px;
  color: var(--text-primary);
  letter-spacing: -.2px;
}
.card p {
  font-family: 'DM Sans', sans-serif;
  font-size: .88rem; line-height: 1.65;
  color: var(--text-secondary);
  margin-bottom: 0;
}
.card ul {
  list-style: none; margin: 12px 0 0; padding: 0;
}
.card ul li {
  display: flex; gap: 8px; align-items: flex-start;
  padding: 5px 0;
  font-family: 'DM Sans', sans-serif;
  color: var(--text-secondary); font-size: .85rem; line-height: 1.55;
}
.card ul li::before {
  content: '▸'; color: var(--accent-cyan);
  font-weight: 700; flex-shrink: 0; margin-top: 1px;
}
.card .card-cta {
  display: inline-flex; align-items: center; gap: 6px;
  margin-top: 14px;
  font-family: 'JetBrains Mono', monospace;
  font-size: .76rem; font-weight: 600;
  letter-spacing: 1px; text-transform: uppercase;
  color: var(--accent-cyan); transition: color .2s, gap .2s;
}
.card .card-cta:hover { color: var(--accent-amber); gap: 10px; }

/* Card detail block */
.card .detail {
  font-family: 'JetBrains Mono', monospace;
  font-size: .68rem; line-height: 1.7;
  color: var(--text-muted);
  margin-top: 12px; padding-top: 10px;
  border-top: 1px solid var(--border);
}
.card .detail span { color: var(--text-secondary); }

/* Badges (SOC-MVP DNA) */
.badge {
  display: inline-block;
  padding: 2px 7px; border-radius: 3px;
  font-family: 'JetBrains Mono', monospace;
  font-size: .62rem; font-weight: 600;
  text-transform: uppercase; letter-spacing: 1px;
  margin-top: 8px;
}
.badge.read-only { color: var(--accent-cyan); border: 1px solid rgba(6,182,212,0.3); background: rgba(6,182,212,0.08); }
.badge.vendor { color: var(--accent-green); border: 1px solid rgba(16,185,129,0.3); background: rgba(16,185,129,0.08); }
.badge.self-built { color: var(--accent-amber); border: 1px solid rgba(245,158,11,0.3); background: rgba(245,158,11,0.08); }
.badge.guardrail { color: var(--accent-red); border: 1px solid rgba(239,68,68,0.3); background: rgba(239,68,68,0.08); }
.badge.mvp { color: var(--accent-blue); border: 1px solid rgba(59,130,246,0.3); background: rgba(59,130,246,0.08); }
.badge.future { color: var(--text-muted); border: 1px solid var(--border); background: rgba(71,85,105,0.08); }

/* Sub-items (chip row inside a card) */
.sub-items { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 10px; }
.sub-item {
  padding: 5px 10px; border: 1px solid var(--border);
  border-radius: 4px;
  font-family: 'JetBrains Mono', monospace;
  font-size: .68rem; color: var(--text-secondary);
  background: rgba(255,255,255,0.02);
  transition: border-color .2s;
}
.sub-item:hover { border-color: var(--accent-blue); }
.sub-item .sub-label {
  display: block; font-size: .58rem;
  color: var(--text-muted);
  margin-bottom: 2px;
  text-transform: uppercase; letter-spacing: 0.5px;
}

/* Flow connector (between layers) */
.flow-connector {
  display: flex; align-items: center; justify-content: center;
  padding: 4px 0;
}
.flow-connector .arrow {
  display: flex; flex-direction: column; align-items: center; gap: 2px;
}
.flow-connector .arrow-line {
  width: 2px; height: 18px;
  background: linear-gradient(180deg, var(--accent-blue), var(--accent-cyan));
  border-radius: 1px;
}
.flow-connector .arrow-head {
  width: 0; height: 0;
  border-left: 5px solid transparent;
  border-right: 5px solid transparent;
  border-top: 6px solid var(--accent-cyan);
}
.flow-connector .flow-label {
  font-family: 'JetBrains Mono', monospace;
  font-size: .6rem; color: var(--text-muted);
  text-transform: uppercase; letter-spacing: 1.5px;
  margin-left: 14px;
}

/* ═════════════ Stats strip ═════════════ */
.stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; margin: 36px 0; }
@media(max-width: 900px) { .stats { grid-template-columns: repeat(2, 1fr); } }
.stat {
  text-align: center; padding: 22px 14px;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  border-top: 2px solid var(--accent-cyan);
  transition: transform .2s, border-color .2s;
}
.stat:hover { transform: translateY(-2px); border-color: rgba(59,130,246,.3); }
.stat .num {
  font-family: 'JetBrains Mono', monospace;
  font-size: 1.9rem; font-weight: 700;
  letter-spacing: -1px; line-height: 1;
  background: linear-gradient(135deg, var(--accent-cyan), var(--accent-blue));
  -webkit-background-clip: text; background-clip: text;
  color: transparent;
  -webkit-text-fill-color: transparent;
}
.stat .lbl {
  font-family: 'JetBrains Mono', monospace;
  font-size: .65rem; color: var(--text-secondary);
  margin-top: 8px; text-transform: uppercase; letter-spacing: 1px;
  font-weight: 600;
}

/* ═════════════ Pillar block (kept for ai-maturity legacy) ═════════════ */
.pillar {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 28px;
  margin-bottom: 16px;
}
.pillar-head { display: flex; gap: 14px; align-items: center; margin-bottom: 14px; }
.pillar-badge {
  width: 44px; height: 44px;
  display: flex; align-items: center; justify-content: center;
  font-family: 'JetBrains Mono', monospace;
  font-weight: 700; font-size: .92rem;
  border-radius: 6px;
}
.pillar.protect .pillar-badge { background: rgba(59,130,246,.15); color: var(--accent-blue); border: 1px solid rgba(59,130,246,.32); }
.pillar.utilize .pillar-badge { background: rgba(245,158,11,.15); color: var(--accent-amber); border: 1px solid rgba(245,158,11,.32); }
.pillar.govern .pillar-badge { background: rgba(6,182,212,.15); color: var(--accent-cyan); border: 1px solid rgba(6,182,212,.32); }
.pillar h3 {
  font-family: 'JetBrains Mono', monospace;
  font-size: 1.1rem; font-weight: 700; letter-spacing: -.3px;
}
.pillar .pillar-sub {
  font-family: 'DM Sans', sans-serif;
  color: var(--text-secondary); font-size: .88rem; margin-top: 2px;
}
.pillar-body {
  font-family: 'DM Sans', sans-serif;
  color: var(--text-secondary);
  margin-bottom: 14px; line-height: 1.65;
}
.pillar-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; margin-top: 6px; }
@media(max-width: 900px) { .pillar-grid { grid-template-columns: 1fr; } }
.pillar-item {
  background: rgba(10,14,23,.5);
  border: 1px solid var(--border);
  border-radius: 6px; padding: 16px;
}
.pillar-item h4 {
  font-family: 'JetBrains Mono', monospace;
  font-size: .85rem; font-weight: 600;
  margin-bottom: 6px; letter-spacing: -.2px;
}
.pillar-item p {
  font-family: 'DM Sans', sans-serif;
  color: var(--text-secondary); font-size: .82rem; line-height: 1.55;
}

/* ═════════════ Tier (engagement sizing) ═════════════ */
.tier-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
@media(max-width: 900px) { .tier-grid { grid-template-columns: 1fr; } }
.tier {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 26px;
  position: relative;
  border-top: 2px solid var(--accent-blue);
  transition: transform .2s, border-color .2s, box-shadow .2s;
}
.tier:hover { transform: translateY(-2px); border-color: rgba(59,130,246,.4); }
.tier.featured {
  border-top: 2px solid var(--accent-cyan);
  box-shadow: 0 0 0 1px rgba(6,182,212,.4), 0 20px 60px rgba(6,182,212,.12);
}
.tier .tier-name {
  font-family: 'JetBrains Mono', monospace;
  font-size: .68rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: 1.6px;
  color: var(--text-muted); margin-bottom: 6px;
}
.tier .tier-tag {
  display: inline-block; padding: 3px 8px;
  border-radius: 3px;
  background: rgba(6,182,212,.12);
  border: 1px solid rgba(6,182,212,.3);
  color: var(--accent-cyan);
  font-family: 'JetBrains Mono', monospace;
  font-size: .58rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: 1.2px;
  margin-bottom: 14px;
}
.tier h3 {
  font-family: 'JetBrains Mono', monospace;
  font-size: 1.15rem; font-weight: 700; letter-spacing: -.4px;
  margin-bottom: 6px;
}
.tier .tier-price {
  font-family: 'DM Sans', sans-serif;
  font-size: .88rem; color: var(--text-secondary); margin-bottom: 16px;
}
.tier ul { list-style: none; padding: 0; margin: 0 0 18px; }
.tier ul li {
  display: flex; gap: 8px; align-items: flex-start;
  padding: 5px 0;
  font-family: 'DM Sans', sans-serif;
  color: var(--text-secondary); font-size: .84rem; line-height: 1.5;
}
.tier ul li::before {
  content: '▸'; color: var(--accent-cyan); font-weight: 700; flex-shrink: 0;
}
.tier .btn { width: 100%; justify-content: center; }

/* ═════════════ Contact form ═════════════ */
.contact-section { padding: 80px 0 100px; position: relative; }
.contact-wrap {
  display: grid; grid-template-columns: 1fr 1fr; gap: 40px; align-items: start;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 36px;
  border-top: 2px solid var(--accent-cyan);
}
@media(max-width: 900px) { .contact-wrap { grid-template-columns: 1fr; padding: 26px; } }
.contact-intro h2 {
  font-family: 'JetBrains Mono', monospace;
  font-size: 1.4rem; font-weight: 700;
  letter-spacing: -.5px; margin-bottom: 14px; line-height: 1.25;
}
.contact-intro p {
  font-family: 'DM Sans', sans-serif;
  color: var(--text-secondary); margin-bottom: 18px; line-height: 1.7;
}
.contact-intro .benefits { list-style: none; padding: 0; margin: 18px 0 0; }
.contact-intro .benefits li {
  display: flex; gap: 8px; align-items: flex-start;
  padding: 5px 0;
  font-family: 'DM Sans', sans-serif;
  color: var(--text-secondary); font-size: .9rem;
}
.contact-intro .benefits li::before { content: '▸'; color: var(--accent-cyan); font-weight: 700; flex-shrink: 0; }

.form { display: flex; flex-direction: column; gap: 12px; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
@media(max-width: 600px) { .form-row { grid-template-columns: 1fr; } }
.field label {
  display: block;
  font-family: 'JetBrains Mono', monospace;
  font-size: .65rem; font-weight: 600;
  color: var(--text-muted);
  margin-bottom: 5px;
  letter-spacing: 1.4px; text-transform: uppercase;
}
.field input, .field select, .field textarea {
  width: 100%; padding: 10px 12px;
  background: rgba(10,14,23,.6);
  border: 1px solid var(--border);
  border-radius: 5px;
  color: var(--text-primary);
  font-family: 'DM Sans', sans-serif;
  font-size: .9rem;
  transition: border-color .2s, background .2s;
}
.field input:focus, .field select:focus, .field textarea:focus {
  outline: none; border-color: var(--accent-cyan);
  background: rgba(10,14,23,.85);
  box-shadow: 0 0 0 3px rgba(6,182,212,.12);
}
.field textarea { resize: vertical; min-height: 90px; }
.field-services { display: flex; flex-direction: column; gap: 6px; margin-top: 4px; }
.service-option {
  display: flex; gap: 10px; align-items: center;
  padding: 8px 12px;
  background: rgba(10,14,23,.5);
  border: 1px solid var(--border);
  border-radius: 5px;
  cursor: pointer;
  font-family: 'DM Sans', sans-serif;
  font-size: .86rem;
  transition: border-color .2s, background .2s;
}
.service-option:hover { border-color: rgba(59,130,246,.4); background: rgba(59,130,246,.04); }
.service-option input { width: auto; margin: 0; accent-color: var(--accent-cyan); }
.form-submit {
  background: var(--accent-blue);
  color: #fff; border: none;
  padding: 13px;
  border-radius: 5px;
  font-family: 'JetBrains Mono', monospace;
  font-weight: 700; font-size: .82rem;
  letter-spacing: 1.4px; text-transform: uppercase;
  cursor: pointer;
  transition: transform .2s, box-shadow .2s, background .2s;
  margin-top: 8px;
}
.form-submit:hover:not(:disabled) {
  background: var(--accent-blue-2); transform: translateY(-1px);
  box-shadow: 0 10px 30px rgba(59,130,246,.3);
}
.form-submit:disabled { opacity: .65; cursor: not-allowed; }
.form-note {
  font-family: 'JetBrains Mono', monospace;
  color: var(--text-muted); font-size: .68rem; text-align: center;
  margin-top: 4px; letter-spacing: 0.5px;
}

/* ═════════════ Footer ═════════════ */
.footer {
  padding: 40px 0 28px; border-top: 1px solid var(--border);
  background: rgba(10,14,23,.6);
  position: relative; z-index: 1; margin-top: 60px;
}
.footer-grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1.1fr;
  gap: 32px;
  margin-bottom: 28px;
}
@media (max-width: 820px) { .footer-grid { grid-template-columns: 1fr; gap: 26px; } }
.footer-brand { display: flex; gap: 12px; align-items: flex-start; }
.footer-brand .logo-img { flex-shrink: 0; }
.footer-brand-meta { display: flex; flex-direction: column; gap: 10px; }
.footer-name {
  font-family: 'JetBrains Mono', monospace;
  font-size: .82rem; font-weight: 700; color: var(--text-primary);
  letter-spacing: -.2px;
}
.footer-tagline {
  font-family: 'DM Sans', sans-serif;
  font-size: .78rem; color: var(--text-muted); line-height: 1.55;
}
.footer-col-head {
  font-family: 'JetBrains Mono', monospace;
  font-size: .62rem; font-weight: 700;
  letter-spacing: 1.8px; text-transform: uppercase;
  color: var(--text-muted); margin-bottom: 12px;
}
.footer-links {
  display: flex; flex-direction: column; gap: 8px;
}
.footer-links a {
  font-family: 'JetBrains Mono', monospace;
  color: var(--text-secondary); font-size: .72rem;
  text-transform: uppercase; letter-spacing: 1.4px;
  transition: color .2s, transform .2s;
  display: inline-flex; align-items: center;
}
.footer-links a:hover { color: var(--accent-cyan); transform: translateX(2px); }
.footer-contact {
  display: flex; flex-direction: column; gap: 6px;
  font-family: 'DM Sans', sans-serif;
  font-size: .82rem; color: var(--text-secondary); line-height: 1.6;
}
.footer-contact .addr-line {
  font-family: 'DM Sans', sans-serif;
  font-size: .82rem; color: var(--text-secondary); line-height: 1.55;
}
.footer-contact a {
  font-family: 'JetBrains Mono', monospace;
  font-size: .76rem;
  color: var(--text-secondary);
  transition: color .2s;
  letter-spacing: .4px;
}
.footer-contact a:hover { color: var(--accent-cyan); }
.footer-contact .pipe { color: var(--text-muted); margin: 0 6px; }
.footer-bottom {
  display: flex; justify-content: space-between; align-items: center;
  padding-top: 22px;
  border-top: 1px solid var(--border);
  flex-wrap: wrap; gap: 12px;
}
.footer-copy {
  font-family: 'JetBrains Mono', monospace;
  color: var(--text-muted); font-size: .68rem; letter-spacing: 0.6px;
}
.footer-fineprint {
  font-family: 'JetBrains Mono', monospace;
  color: var(--text-muted); font-size: .62rem; letter-spacing: 1px;
  text-transform: uppercase;
}

/* Legacy footer-inner kept for backward-compat where used */
.footer-inner { display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 16px; }
.footer-logo {
  display: flex; align-items: center; gap: 10px;
  font-family: 'JetBrains Mono', monospace;
  font-size: .85rem; font-weight: 600;
}

/* Mobile nav */
@media(max-width: 820px) {
  .nav-links { display: none; }
  .mobile-toggle { display: block; }
  .nav-links.open {
    display: flex; position: absolute; top: 100%; left: 0; right: 0;
    background: rgba(10,14,23,.98); flex-direction: column; align-items: flex-start;
    padding: 18px 24px; gap: 14px; border-bottom: 1px solid var(--border);
  }
}

/* ═════════════ Reveal animations ═════════════ */
@keyframes fadeUp {
  from { opacity: 0; transform: translateY(12px); }
  to { opacity: 1; transform: translateY(0); }
}
.reveal { opacity: 0; transform: translateY(16px); transition: opacity .5s, transform .5s; }
.reveal.visible { opacity: 1; transform: translateY(0); }
.reveal.delay-1 { transition-delay: .06s; }
.reveal.delay-2 { transition-delay: .12s; }
.reveal.delay-3 { transition-delay: .18s; }
.reveal.delay-4 { transition-delay: .24s; }
.reveal.from-left { transform: translateX(-20px); }
.reveal.from-right { transform: translateX(20px); }
.reveal.from-left.visible, .reveal.from-right.visible { transform: translateX(0); }
.reveal.zoom { transform: scale(.96); }
.reveal.zoom.visible { transform: scale(1); }

/* ═════════════ "Protect" rotator strip (kept) ═════════════ */
.protect-strip {
  position: relative; padding: 24px 0;
  background: linear-gradient(180deg, rgba(6,182,212,.06), transparent);
  border-block: 1px solid var(--border); text-align: center;
}
.protect-strip .lead {
  font-family: 'JetBrains Mono', monospace;
  color: var(--accent-cyan); font-weight: 600;
  font-size: .68rem; letter-spacing: 2px;
  text-transform: uppercase; margin-bottom: 10px;
}
.protect-strip h3 {
  font-family: 'JetBrains Mono', monospace;
  font-size: clamp(1.2rem, 2.2vw, 1.7rem); font-weight: 700;
  letter-spacing: -.5px;
}
.protect-strip h3 .rot {
  color: var(--accent-amber);
  display: inline-block; min-width: 0;
  font-family: 'JetBrains Mono', monospace;
  font-weight: 700;
}
.protect-strip .domains {
  margin-top: 12px;
  font-family: 'JetBrains Mono', monospace;
  color: var(--text-secondary);
  font-size: .68rem; letter-spacing: 1.6px; text-transform: uppercase;
}
.protect-strip .domains span { color: var(--accent-cyan); margin: 0 6px; }

/* ═════════════ Service grid (foundational catalog) ═════════════ */
.svc-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
@media(max-width: 900px) { .svc-grid { grid-template-columns: 1fr 1fr; } }
@media(max-width: 600px) { .svc-grid { grid-template-columns: 1fr; } }
.svc {
  position: relative;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 20px 22px;
  overflow: hidden;
  transition: border-color .2s, transform .2s, background .2s;
}
.svc::before {
  content: ''; position: absolute; top: 0; left: 0;
  width: 3px; height: 100%;
  background: linear-gradient(180deg, var(--accent-blue), var(--accent-cyan));
}
.svc:hover {
  transform: translateY(-2px);
  border-color: rgba(59,130,246,.3);
  background: var(--bg-card-hover);
}
.svc-num {
  font-family: 'JetBrains Mono', monospace;
  font-size: .62rem; color: var(--accent-cyan);
  letter-spacing: 1.8px; text-transform: uppercase; font-weight: 700;
}
.svc h4 {
  font-family: 'JetBrains Mono', monospace;
  font-size: .92rem; font-weight: 700;
  margin: 8px 0 8px; letter-spacing: -.2px;
}
.svc p {
  font-family: 'DM Sans', sans-serif;
  color: var(--text-secondary); font-size: .85rem; line-height: 1.6;
}
.svc-cta {
  display: inline-flex; align-items: center; gap: 5px;
  margin-top: 12px;
  font-family: 'JetBrains Mono', monospace;
  font-size: .68rem; font-weight: 600;
  letter-spacing: 1.2px; text-transform: uppercase;
  color: var(--accent-cyan); transition: color .2s, gap .2s;
}
.svc-cta:hover { color: var(--accent-amber); gap: 8px; }

/* Trust strip */
.trust-strip {
  display: flex; flex-wrap: wrap; align-items: center; justify-content: center;
  gap: 24px; padding: 16px 0; margin-top: 26px;
  border-block: 1px solid var(--border);
  background: rgba(10,14,23,.5);
}
.trust-strip .lbl {
  font-family: 'JetBrains Mono', monospace;
  font-size: .62rem; letter-spacing: 2px;
  text-transform: uppercase; color: var(--text-muted);
}
.trust-strip .name {
  font-family: 'JetBrains Mono', monospace;
  color: var(--text-secondary); font-weight: 600; font-size: .8rem;
  letter-spacing: 1px;
}

/* ═════════════ Video hero (kept, restyled overlay) ═════════════ */
.video-hero {
  position: relative; min-height: 80vh;
  padding: 140px 0 80px;
  display: flex; align-items: center; overflow: hidden;
}
.video-hero .video-bg {
  position: absolute; inset: 0;
  width: 100%; height: 100%; object-fit: cover;
  z-index: 0; opacity: .32;
  filter: saturate(.7) contrast(1.05) hue-rotate(5deg);
}
.video-hero::before {
  content: ''; position: absolute; inset: 0; z-index: 1; pointer-events: none;
  background:
    radial-gradient(ellipse at 30% 20%, rgba(6,182,212,.16), transparent 55%),
    radial-gradient(ellipse at 75% 80%, rgba(59,130,246,.18), transparent 60%),
    linear-gradient(180deg, rgba(10,14,23,.65) 0%, rgba(10,14,23,.92) 100%);
}
.video-hero .container { position: relative; z-index: 2; width: 100%; }
.video-hero h1 {
  font-size: clamp(1.8rem, 4.4vw, 2.8rem);
  text-shadow: 0 4px 30px rgba(0,0,0,.4);
}
.video-hero .sub { color: #cbd5e1; max-width: 760px; margin: 0 auto 28px; }
.video-hero .hero-inner { max-width: 920px; margin: 0 auto; text-align: center; }

/* Video tile */
.video-tile {
  position: relative; border-radius: var(--radius); overflow: hidden;
  border: 1px solid var(--border);
  border-top: 2px solid var(--accent-cyan);
  box-shadow: 0 30px 80px rgba(0,0,0,.4);
}
.video-tile video { width: 100%; height: auto; display: block; }
.video-tile::after {
  content: ''; position: absolute; inset: 0; pointer-events: none;
  background: linear-gradient(180deg, transparent 60%, rgba(10,14,23,.55) 100%);
}

/* ═════════════ Ticker ═════════════ */
.ticker {
  position: relative; overflow: hidden;
  border-block: 1px solid var(--border);
  background: rgba(10,14,23,.6);
  padding: 14px 0; margin-top: 8px;
}
.ticker-track {
  display: flex; gap: 48px; width: max-content;
  animation: tickerSlide 38s linear infinite;
  font-family: 'JetBrains Mono', monospace;
  color: var(--text-secondary);
  font-size: .76rem; letter-spacing: 1.4px; text-transform: uppercase;
}
.ticker-track span { display: inline-flex; align-items: center; gap: 10px; white-space: nowrap; }
.ticker-track span::before { content: '●'; color: var(--accent-cyan); font-size: .55rem; }
@keyframes tickerSlide {
  from { transform: translateX(0); }
  to { transform: translateX(-50%); }
}

/* Glow pulse */
@keyframes pulseGlow {
  0%, 100% { box-shadow: 0 0 0 0 rgba(6,182,212,.35); }
  50% { box-shadow: 0 0 0 18px rgba(6,182,212,0); }
}
.pulse { animation: pulseGlow 2.2s ease-out infinite; }

/* Kinetic gradient */
@keyframes hueShift {
  0%, 100% { filter: hue-rotate(0deg); }
  50% { filter: hue-rotate(-12deg); }
}
.kinetic { animation: hueShift 9s ease-in-out infinite; }

/* ═════════════ Tech tag (SOC-MVP style) ═════════════ */
.tech-tag {
  display: inline-block;
  padding: 3px 10px;
  border: 1px solid rgba(6,182,212,.32);
  background: rgba(6,182,212,.07);
  border-radius: 3px;
  font-family: 'JetBrains Mono', monospace;
  font-size: .62rem; font-weight: 600;
  letter-spacing: 1.6px; text-transform: uppercase;
  color: var(--accent-cyan);
}
.tech-tag.amber { border-color: rgba(245,158,11,.32); background: rgba(245,158,11,.07); color: var(--accent-amber); }
.tech-tag.emerald { border-color: rgba(16,185,129,.32); background: rgba(16,185,129,.07); color: var(--accent-green); }

/* ═════════════ Tech block (kept) ═════════════ */
.tech-block {
  background: linear-gradient(180deg, rgba(21,29,46,.7), rgba(10,14,23,.4));
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 22px 24px;
  position: relative; overflow: hidden;
}
.tech-block::before {
  content: ''; position: absolute; top: 0; left: 0;
  width: 3px; height: 100%;
  background: linear-gradient(180deg, var(--accent-blue), var(--accent-cyan));
}
.tech-block.amber::before { background: linear-gradient(180deg, var(--accent-amber), var(--accent-amber-2)); }
.tech-block.emerald::before { background: linear-gradient(180deg, var(--accent-green), #059669); }
.tech-block h4 {
  font-family: 'JetBrains Mono', monospace;
  font-size: .72rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: 1.8px;
  color: var(--accent-cyan); margin-bottom: 12px;
}
.tech-block.amber h4 { color: var(--accent-amber); }
.tech-block.emerald h4 { color: var(--accent-green); }
.tech-block p {
  font-family: 'DM Sans', sans-serif;
  color: var(--text-secondary); font-size: .88rem; line-height: 1.7;
}

/* Platform pill row */
.platform-strip {
  display: flex; flex-wrap: wrap; gap: 8px;
  justify-content: center; margin: 24px 0 8px;
}
.platform-pill {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 6px 12px; border-radius: 4px;
  background: rgba(10,14,23,.6);
  border: 1px solid var(--border);
  font-family: 'JetBrains Mono', monospace;
  font-size: .7rem; letter-spacing: 1px; color: var(--text-secondary);
  transition: border-color .2s, color .2s, transform .2s;
}
.platform-pill:hover { border-color: rgba(6,182,212,.5); color: var(--accent-cyan); transform: translateY(-2px); }
.platform-pill .dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--accent-cyan); box-shadow: 0 0 10px var(--accent-cyan);
}

/* ═════════════ Dilemma split (image + body) ═════════════ */
.dilemma-wrap {
  display: grid; grid-template-columns: .85fr 1.4fr; gap: 28px;
  align-items: stretch;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  border-top: 2px solid var(--accent-cyan);
  overflow: hidden;
}
@media(max-width: 900px) { .dilemma-wrap { grid-template-columns: 1fr; } }
.dilemma-img { position: relative; min-height: 320px; overflow: hidden; }
.dilemma-img img { width: 100%; height: 100%; object-fit: cover; opacity: .55; }
.dilemma-img::after {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(135deg, rgba(10,14,23,.5), rgba(59,130,246,.25));
  mix-blend-mode: overlay;
}
.dilemma-body { padding: 28px 32px 28px 0; }
@media(max-width: 900px) { .dilemma-body { padding: 22px; } }
.dilemma-body h2 {
  font-family: 'JetBrains Mono', monospace;
  font-size: clamp(1.1rem, 2vw, 1.5rem);
  font-weight: 700; letter-spacing: -.4px;
  line-height: 1.25; margin: 12px 0 18px;
}
.dilemma-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 22px; }
@media(max-width: 700px) { .dilemma-grid { grid-template-columns: 1fr; } }
.dilemma-col h4 {
  font-family: 'JetBrains Mono', monospace;
  font-size: .68rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: 1.8px;
  color: var(--accent-cyan); margin-bottom: 10px;
}
.dilemma-list { list-style: none; padding: 0; margin: 0; }
.dilemma-list li {
  position: relative; padding: 6px 0 6px 16px;
  font-family: 'DM Sans', sans-serif;
  color: var(--text-secondary); font-size: .86rem; line-height: 1.55;
}
.dilemma-list li::before {
  content: ''; position: absolute; left: 0; top: 13px;
  width: 5px; height: 5px; border-radius: 50%;
  background: var(--accent-cyan);
}
.dilemma-list.amber li::before { background: var(--accent-amber); }

/* ═════════════ Stage strip (Protect/Utilize/Govern) ═════════════ */
.stage-strip {
  display: grid; grid-template-columns: 1fr auto 1fr auto 1fr; gap: 14px;
  align-items: stretch; margin: 32px 0 12px;
}
@media(max-width: 900px) {
  .stage-strip { grid-template-columns: 1fr; }
  .stage-arrow { display: none; }
}
.stage-card {
  position: relative; padding: 22px 22px;
  border-radius: var(--radius);
  border: 1px solid var(--border);
  background: var(--bg-card);
  transition: transform .25s, border-color .25s, box-shadow .25s;
}
.stage-card:hover { transform: translateY(-2px); box-shadow: 0 18px 50px rgba(0,0,0,.35); }
.stage-card .stage-num {
  font-family: 'JetBrains Mono', monospace;
  font-size: .62rem; font-weight: 700;
  letter-spacing: 1.8px; text-transform: uppercase;
  color: var(--text-muted);
}
.stage-card h3 {
  font-family: 'JetBrains Mono', monospace;
  font-size: 1.2rem; font-weight: 700;
  margin: 6px 0 8px; letter-spacing: -.4px;
}
.stage-card p {
  font-family: 'DM Sans', sans-serif;
  color: var(--text-secondary); font-size: .88rem; line-height: 1.55;
}
.stage-card.protect { border-top: 2px solid var(--accent-blue); }
.stage-card.utilize { border-top: 2px solid var(--accent-amber); }
.stage-card.govern { border-top: 2px solid var(--accent-cyan); }
.stage-card.utilize .stage-tag {
  display: inline-block; margin-top: 10px;
  padding: 3px 8px; border-radius: 3px;
  background: rgba(245,158,11,.12);
  border: 1px solid rgba(245,158,11,.3);
  color: var(--accent-amber);
  font-family: 'JetBrains Mono', monospace;
  font-size: .56rem; font-weight: 700;
  letter-spacing: 1.4px; text-transform: uppercase;
}
.stage-arrow {
  align-self: center; color: var(--accent-cyan);
  font-size: 1.3rem; font-weight: 700;
}
.stage-caption {
  text-align: center; color: var(--text-muted);
  font-family: 'JetBrains Mono', monospace;
  font-size: .65rem; letter-spacing: 1.4px;
  text-transform: uppercase; margin-top: 16px;
}

/* ═════════════ Pillar feature (media + body) ═════════════ */
.pillar-feature {
  display: grid; grid-template-columns: .95fr 1.4fr; gap: 0;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  overflow: hidden;
  margin-bottom: 22px;
}
.pillar-feature.flipped { grid-template-columns: 1.4fr .95fr; }
.pillar-feature.flipped .pillar-feature-media { order: 2; }
.pillar-feature.flipped .pillar-feature-body { order: 1; }
@media(max-width: 900px) {
  .pillar-feature, .pillar-feature.flipped { grid-template-columns: 1fr; }
  .pillar-feature.flipped .pillar-feature-media { order: 0; }
  .pillar-feature.flipped .pillar-feature-body { order: 1; }
}
.pillar-feature-media { position: relative; min-height: 320px; overflow: hidden; }
.pillar-feature-media img { width: 100%; height: 100%; object-fit: cover; opacity: .55; }
.pillar-feature-media::after {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(135deg, rgba(10,14,23,.55), rgba(59,130,246,.15));
}
.pillar-feature-badge {
  position: absolute; top: 16px; left: 16px; z-index: 2;
  padding: 4px 10px; border-radius: 3px;
  font-family: 'JetBrains Mono', monospace;
  font-size: .62rem; font-weight: 700;
  letter-spacing: 1.6px; text-transform: uppercase;
}
.pillar-feature-badge.protect { background: rgba(59,130,246,.18); color: var(--accent-blue); border: 1px solid rgba(59,130,246,.4); }
.pillar-feature-badge.utilize { background: rgba(245,158,11,.2); color: var(--accent-amber); border: 1px solid rgba(245,158,11,.4); }
.pillar-feature-badge.govern { background: rgba(6,182,212,.2); color: var(--accent-cyan); border: 1px solid rgba(6,182,212,.4); }
.pillar-feature-flag {
  position: absolute; top: 16px; right: 16px; z-index: 2;
  padding: 3px 8px; border-radius: 3px;
  background: rgba(245,158,11,.15);
  border: 1px solid rgba(245,158,11,.4);
  color: var(--accent-amber);
  font-family: 'JetBrains Mono', monospace;
  font-size: .55rem; font-weight: 700;
  letter-spacing: 1.4px; text-transform: uppercase;
}
.pillar-feature-body { padding: 30px 32px; }
@media(max-width: 600px) { .pillar-feature-body { padding: 22px; } }
.pillar-feature-body h2, .pillar-feature-body h3 {
  font-family: 'JetBrains Mono', monospace;
  font-size: clamp(1.15rem, 2.2vw, 1.5rem);
  font-weight: 700; letter-spacing: -.5px;
  line-height: 1.2; margin-bottom: 12px;
}
.pillar-feature-body .lead {
  font-family: 'DM Sans', sans-serif;
  color: var(--text-secondary); font-size: .94rem;
  margin-bottom: 20px; line-height: 1.7;
}
.what-good { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
@media(max-width: 600px) { .what-good { grid-template-columns: 1fr; } }
.wg-item {
  background: rgba(10,14,23,.5);
  border: 1px solid var(--border);
  border-radius: 5px;
  padding: 12px 14px;
}
.wg-item h4 {
  font-family: 'JetBrains Mono', monospace;
  font-size: .82rem; font-weight: 600;
  margin-bottom: 4px; letter-spacing: -.2px;
}
.wg-item p {
  font-family: 'DM Sans', sans-serif;
  color: var(--text-secondary); font-size: .78rem; line-height: 1.55;
}

/* Framework strip */
.framework-strip {
  display: flex; flex-wrap: wrap; align-items: center; justify-content: center;
  gap: 18px; padding: 16px 22px; margin-top: 24px;
  border: 1px solid var(--border);
  background: rgba(10,14,23,.5);
  border-radius: var(--radius);
}
.framework-strip .lbl {
  font-family: 'JetBrains Mono', monospace;
  font-size: .62rem; letter-spacing: 2px;
  text-transform: uppercase; color: var(--text-muted);
}
.framework-strip .name {
  font-family: 'JetBrains Mono', monospace;
  color: var(--text-secondary); font-weight: 600; font-size: .76rem;
  padding: 4px 10px; border-radius: 3px;
  background: rgba(6,182,212,.08);
  border: 1px solid rgba(6,182,212,.22);
}

/* ═════════════ Maturity heatmap ═════════════ */
.heatmap {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  border-top: 2px solid var(--accent-cyan);
  padding: 24px; overflow-x: auto;
}
.heatmap-head, .heatmap-row {
  display: grid; grid-template-columns: 1.2fr 1fr 1fr 1fr; gap: 8px;
}
.heatmap-head {
  font-family: 'JetBrains Mono', monospace;
  font-size: .65rem; letter-spacing: 1.6px;
  text-transform: uppercase; color: var(--text-muted);
  padding-bottom: 12px; border-bottom: 1px solid var(--border); margin-bottom: 8px;
}
.heatmap-head > div { text-align: center; font-weight: 700; }
.heatmap-head > div:first-child { text-align: left; }
.heatmap-row { margin-bottom: 8px; align-items: stretch; }
.rowlbl {
  display: flex; align-items: center;
  font-family: 'JetBrains Mono', monospace;
  font-size: .75rem; letter-spacing: 1.2px;
  text-transform: uppercase; color: var(--text-secondary); font-weight: 600;
}
.heatmap .cell {
  display: flex; align-items: center; justify-content: center;
  border-radius: 6px;
  padding: 16px 6px;
  font-family: 'JetBrains Mono', monospace;
  font-weight: 700; font-size: 1.1rem;
  letter-spacing: -.4px;
  border: 1px solid var(--border);
  transition: transform .2s;
}
.heatmap .cell:hover { transform: scale(1.04); }
.heatmap .c-1 { background: rgba(6,182,212,.08); color: var(--accent-cyan); border-color: rgba(6,182,212,.22); }
.heatmap .c-2 { background: rgba(6,182,212,.18); color: #7dd3fc; border-color: rgba(6,182,212,.34); }
.heatmap .c-3 { background: rgba(245,158,11,.16); color: var(--accent-amber); border-color: rgba(245,158,11,.34); }
.heatmap .c-4 { background: rgba(239,68,68,.16); color: #fca5a5; border-color: rgba(239,68,68,.36); }
.heatmap-foot {
  font-family: 'JetBrains Mono', monospace;
  color: var(--text-muted); font-size: .68rem;
  margin-top: 14px; text-align: center;
  letter-spacing: .6px;
}

/* ═════════════ Phases ═════════════ */
.phase-row, .phase-line { display: grid; gap: 14px; }
.phase-row { grid-template-columns: repeat(3, 1fr); }
.phase-line { grid-template-columns: repeat(5, 1fr); }
@media(max-width: 900px) { .phase-row, .phase-line { grid-template-columns: 1fr; } }
.phase, .phase-step {
  position: relative;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  border-top: 2px solid var(--accent-blue);
  padding: 22px;
  transition: transform .2s, border-color .2s, box-shadow .2s;
}
.phase:hover, .phase-step:hover {
  transform: translateY(-2px);
  border-color: rgba(59,130,246,.4);
  box-shadow: 0 18px 40px rgba(0,0,0,.3);
}
.phase-num {
  display: inline-flex; align-items: center; justify-content: center;
  width: 34px; height: 34px;
  border-radius: 6px;
  background: rgba(59,130,246,.12);
  border: 1px solid rgba(59,130,246,.3);
  color: var(--accent-blue);
  font-family: 'JetBrains Mono', monospace;
  font-weight: 700; font-size: .82rem;
  margin-bottom: 12px;
}
.phase h4, .phase-step h4 {
  font-family: 'JetBrains Mono', monospace;
  font-size: 1rem; font-weight: 700;
  margin-bottom: 4px; letter-spacing: -.3px;
}
.phase .phase-time, .phase-step .phase-time {
  font-family: 'JetBrains Mono', monospace;
  font-size: .62rem; letter-spacing: 1.6px;
  text-transform: uppercase; color: var(--accent-cyan);
  font-weight: 700; margin-bottom: 8px;
}
.phase p, .phase-step p {
  font-family: 'DM Sans', sans-serif;
  color: var(--text-secondary); font-size: .84rem; line-height: 1.55;
}
.deliverable-note {
  margin-top: 22px; padding: 16px 20px;
  border-radius: var(--radius);
  background: rgba(245,158,11,.06);
  border: 1px solid rgba(245,158,11,.24);
  border-left: 2px solid var(--accent-amber);
  color: var(--text-secondary);
  font-family: 'DM Sans', sans-serif;
  font-size: .9rem; text-align: center;
}
.deliverable-note strong {
  color: var(--accent-amber);
  font-family: 'JetBrains Mono', monospace;
  font-size: .68rem;
  letter-spacing: 1.6px; text-transform: uppercase; margin-right: 8px;
}

/* ═════════════ Reference build cards ═════════════ */
.ref-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
@media(max-width: 900px) { .ref-grid { grid-template-columns: 1fr; } }
.ref-card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  border-top: 2px solid var(--accent-blue);
  overflow: hidden;
  transition: transform .2s, border-color .2s, box-shadow .2s;
}
.ref-card:hover {
  transform: translateY(-2px); border-color: rgba(59,130,246,.4);
  box-shadow: 0 22px 60px rgba(0,0,0,.4);
}
.ref-media { position: relative; height: 200px; overflow: hidden; }
.ref-media img { width: 100%; height: 100%; object-fit: cover; opacity: .55; }
.ref-media::after {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(10,14,23,.1) 0%, rgba(10,14,23,.7) 100%);
}
.ref-num {
  position: absolute; top: 12px; left: 12px; z-index: 2;
  padding: 4px 9px; border-radius: 3px;
  background: rgba(59,130,246,.18);
  border: 1px solid rgba(59,130,246,.4);
  color: var(--accent-blue);
  font-family: 'JetBrains Mono', monospace;
  font-size: .58rem; font-weight: 700;
  letter-spacing: 1.4px; text-transform: uppercase;
}
.ref-body { padding: 22px 24px; }
.ref-body h3 {
  font-family: 'JetBrains Mono', monospace;
  font-size: 1.05rem; font-weight: 700;
  letter-spacing: -.4px; margin-bottom: 10px;
}
.ref-body p {
  font-family: 'DM Sans', sans-serif;
  color: var(--text-secondary); font-size: .88rem;
  line-height: 1.65; margin-bottom: 12px;
}
.ref-bullets { list-style: none; margin: 6px 0 0; padding: 0; }
.ref-bullets li {
  display: flex; gap: 8px; align-items: flex-start;
  padding: 5px 0;
  font-family: 'DM Sans', sans-serif;
  color: var(--text-secondary); font-size: .84rem; line-height: 1.5;
}
.ref-bullets li::before { content: '▸'; color: var(--accent-cyan); font-weight: 700; flex-shrink: 0; margin-top: 1px; }
.ref-bullets li strong { color: var(--text-primary); }

/* ═════════════ Track cards (cohort tracks) ═════════════ */
.track-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; margin-top: 8px; }
@media(max-width: 900px) { .track-grid { grid-template-columns: 1fr; } }
.track-card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  border-top: 2px solid var(--accent-cyan);
  overflow: hidden;
  transition: transform .2s, border-color .2s, box-shadow .2s;
}
.track-card:hover { transform: translateY(-2px); border-color: rgba(6,182,212,.4); box-shadow: 0 18px 50px rgba(0,0,0,.35); }
.track-media { position: relative; height: 160px; overflow: hidden; }
.track-media img { width: 100%; height: 100%; object-fit: cover; opacity: .55; }
.track-media::after {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(135deg, rgba(6,182,212,.2), rgba(10,14,23,.6));
}
.track-body { padding: 20px 22px 24px; }
.track-num {
  font-family: 'JetBrains Mono', monospace;
  font-size: .62rem; letter-spacing: 1.8px;
  text-transform: uppercase; color: var(--accent-cyan); font-weight: 700;
}
.track-body h3 {
  font-family: 'JetBrains Mono', monospace;
  font-size: 1.1rem; font-weight: 700;
  letter-spacing: -.4px; margin: 6px 0 8px;
}
.track-body p {
  font-family: 'DM Sans', sans-serif;
  color: var(--text-secondary); font-size: .86rem;
  line-height: 1.55; margin-bottom: 10px;
}

/* Cohort facts strip */
.cohort-footer {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; margin-top: 28px;
  padding: 16px;
  border: 1px solid var(--border); border-radius: var(--radius);
  background: rgba(10,14,23,.45);
}
@media(max-width: 900px) { .cohort-footer { grid-template-columns: 1fr 1fr; } }
@media(max-width: 600px) { .cohort-footer { grid-template-columns: 1fr; } }
.cohort-fact { display: flex; flex-direction: column; gap: 4px; padding: 6px 10px; }
.cohort-fact strong {
  font-family: 'JetBrains Mono', monospace;
  color: var(--accent-cyan); font-size: .78rem;
  letter-spacing: 1.2px; text-transform: uppercase; font-weight: 700;
}
.cohort-fact span {
  font-family: 'DM Sans', sans-serif;
  color: var(--text-secondary); font-size: .82rem;
}

/* Tier CTA row */
.tier-cta-row { display: flex; align-items: center; gap: 14px; flex-wrap: wrap; margin-top: 22px; }
.tier-price-pill {
  display: inline-block; padding: 6px 12px; border-radius: 3px;
  background: rgba(6,182,212,.1);
  color: var(--accent-cyan);
  font-family: 'JetBrains Mono', monospace;
  font-size: .68rem; letter-spacing: 1.2px;
  text-transform: uppercase; font-weight: 700;
  border: 1px solid rgba(6,182,212,.28);
}

/* ═════════════ CCA-F perk panel ═════════════ */
.perk-section { background: linear-gradient(180deg, rgba(245,158,11,.04), transparent); }
.perk-wrap {
  display: grid; grid-template-columns: .7fr 1.6fr; gap: 30px;
  align-items: center;
  background: var(--bg-card);
  border: 1px solid rgba(245,158,11,.3);
  border-top: 2px solid var(--accent-amber);
  border-radius: var(--radius);
  padding: 32px;
  box-shadow: 0 30px 80px rgba(245,158,11,.06);
}
@media(max-width: 900px) { .perk-wrap { grid-template-columns: 1fr; text-align: center; padding: 24px; } }
.perk-badge {
  display: flex; align-items: center; justify-content: center;
  background: radial-gradient(circle at 30% 30%, rgba(245,158,11,.14), rgba(6,182,212,.04));
  border-radius: var(--radius);
  padding: 22px;
  border: 1px solid var(--border);
}
.perk-badge img { max-width: 180px; height: auto; filter: drop-shadow(0 8px 28px rgba(245,158,11,.4)); }
.amber-eyebrow {
  background: rgba(245,158,11,.10) !important;
  color: var(--accent-amber) !important;
  border-color: rgba(245,158,11,.32) !important;
}
.perk-body h2 {
  font-family: 'JetBrains Mono', monospace;
  font-size: clamp(1.15rem, 2.2vw, 1.6rem);
  font-weight: 700; letter-spacing: -.5px;
  line-height: 1.2; margin: 10px 0 12px;
}
.perk-body > p {
  font-family: 'DM Sans', sans-serif;
  color: var(--text-secondary); font-size: .92rem;
  line-height: 1.65; margin-bottom: 20px;
}
.perk-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; }
@media(max-width: 700px) { .perk-grid { grid-template-columns: 1fr; } }
.perk-item {
  background: rgba(10,14,23,.5);
  border: 1px solid var(--border);
  border-radius: 5px;
  padding: 14px;
}
.perk-num {
  font-family: 'JetBrains Mono', monospace;
  font-size: .62rem; letter-spacing: 1.6px;
  text-transform: uppercase; color: var(--accent-amber); font-weight: 700;
}
.perk-item h4 {
  font-family: 'JetBrains Mono', monospace;
  font-size: .85rem; font-weight: 700;
  margin: 4px 0 6px;
}
.perk-item p {
  font-family: 'DM Sans', sans-serif;
  color: var(--text-secondary); font-size: .78rem; line-height: 1.5;
}

/* ═════════════ Persona / "Find your fit" ═════════════ */
.persona-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
@media(max-width: 900px) { .persona-grid { grid-template-columns: 1fr; } }
.persona-card {
  position: relative; display: flex; flex-direction: column;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  border-top: 2px solid var(--accent-cyan);
  padding: 26px;
  overflow: hidden;
  transition: transform .2s, border-color .2s, background .2s, box-shadow .2s;
}
.persona-card.amber-top { border-top-color: var(--accent-amber); }
.persona-card.navy-top { border-top-color: var(--accent-blue); }
.persona-card:hover {
  transform: translateY(-3px);
  background: var(--bg-card-hover);
  border-color: rgba(59,130,246,.3);
  box-shadow: 0 22px 60px rgba(0,0,0,.4);
}
.persona-tag {
  display: inline-block; padding: 4px 10px; border-radius: 3px;
  background: rgba(6,182,212,.12);
  color: var(--accent-cyan);
  font-family: 'JetBrains Mono', monospace;
  font-size: .58rem; font-weight: 700;
  letter-spacing: 1.6px; text-transform: uppercase;
  border: 1px solid rgba(6,182,212,.28);
  align-self: flex-start; margin-bottom: 14px;
}
.persona-tag.amber { background: rgba(245,158,11,.12); color: var(--accent-amber); border-color: rgba(245,158,11,.32); }
.persona-tag.navy { background: rgba(59,130,246,.14); color: #93c5fd; border-color: rgba(59,130,246,.36); }
.persona-card h3 {
  font-family: 'JetBrains Mono', monospace;
  font-size: 1.15rem; font-weight: 700;
  letter-spacing: -.4px; margin-bottom: 10px;
}
.persona-card p {
  font-family: 'DM Sans', sans-serif;
  color: var(--text-secondary); font-size: .88rem;
  line-height: 1.6; margin-bottom: 16px; flex: 1;
}
.persona-meta {
  font-family: 'JetBrains Mono', monospace;
  font-size: .62rem; letter-spacing: 1.4px;
  text-transform: uppercase; color: var(--text-muted);
  padding: 10px 0; border-top: 1px dashed var(--border); margin-bottom: 12px;
}
.persona-cta {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: 'JetBrains Mono', monospace;
  font-size: .72rem; font-weight: 700;
  letter-spacing: 1.4px; text-transform: uppercase;
  color: var(--accent-cyan); transition: color .2s, gap .2s;
}
.persona-card:hover .persona-cta { color: var(--accent-amber); gap: 12px; }

/* Persona card with media header */
.persona-card.has-media { padding: 0; overflow: hidden; }
.persona-card.has-media .persona-media {
  position: relative; height: 160px; overflow: hidden;
}
.persona-card.has-media .persona-media img {
  width: 100%; height: 100%; object-fit: cover; opacity: .58;
  transition: transform .4s, opacity .3s;
}
.persona-card.has-media:hover .persona-media img { transform: scale(1.04); opacity: .65; }
.persona-card.has-media .persona-media::after {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(10,14,23,.15) 0%, rgba(10,14,23,.75) 100%);
}
.persona-card.has-media .persona-media .persona-tag {
  position: absolute; top: 14px; left: 14px; z-index: 2; margin-bottom: 0;
}
.persona-card.has-media .persona-body { padding: 22px 24px 24px; display: flex; flex-direction: column; flex: 1; }

/* ─── Collapsible services (details/summary) ─── */
.field details.services-collapsible {
  background: rgba(10,14,23,.4);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  overflow: hidden;
  transition: border-color .2s;
}
.field details.services-collapsible[open] { border-color: rgba(6,182,212,.35); }
.field details.services-collapsible summary {
  display: flex; align-items: center; justify-content: space-between;
  padding: 12px 14px; cursor: pointer; list-style: none;
  font-family: 'JetBrains Mono', monospace;
  font-size: .78rem; font-weight: 600;
  color: var(--text-secondary);
  letter-spacing: .8px;
  transition: color .2s, background .2s;
}
.field details.services-collapsible summary:hover {
  color: var(--accent-cyan); background: rgba(6,182,212,.04);
}
.field details.services-collapsible summary::-webkit-details-marker { display: none; }
.field details.services-collapsible summary::after {
  content: '+';
  font-family: 'JetBrains Mono', monospace;
  font-size: 1.1rem; font-weight: 700;
  color: var(--accent-cyan);
  transition: transform .25s;
  margin-left: 12px;
}
.field details.services-collapsible[open] summary::after { content: '−'; }
.field details.services-collapsible summary .hint {
  font-family: 'DM Sans', sans-serif;
  font-size: .72rem;
  font-weight: 400;
  color: var(--text-muted);
  margin-left: 10px;
  letter-spacing: .2px;
  text-transform: none;
}
.field details.services-collapsible .field-services { padding: 4px 10px 12px; margin-top: 0; }
.field details.services-collapsible[open] summary { border-bottom: 1px solid var(--border); }


/* ═════════════ FAQ ═════════════ */
.faq-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
@media(max-width: 900px) { .faq-grid { grid-template-columns: 1fr; } }
.faq-item {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 20px 22px;
  transition: border-color .2s, transform .2s, background .2s;
}
.faq-item:hover {
  border-color: rgba(6,182,212,.4);
  transform: translateY(-2px);
  background: var(--bg-card-hover);
}
.faq-item h4 {
  font-family: 'JetBrains Mono', monospace;
  font-size: .92rem; font-weight: 700;
  margin-bottom: 8px; letter-spacing: -.2px;
  line-height: 1.4;
}
.faq-item h4::before {
  content: 'Q.';
  color: var(--accent-cyan);
  font-family: 'JetBrains Mono', monospace;
  font-size: .68rem; font-weight: 700;
  letter-spacing: 1.4px; margin-right: 8px;
}
.faq-item p {
  font-family: 'DM Sans', sans-serif;
  color: var(--text-secondary); font-size: .86rem; line-height: 1.65;
}

/* ═════════════ Industries row ═════════════ */
.industries-strip {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  border-top: 2px solid var(--accent-cyan);
  padding: 28px 30px;
}
.industries-strip .eyebrow { margin-bottom: 18px; }
.industries-row { display: grid; grid-template-columns: repeat(6, 1fr); gap: 12px; }
@media(max-width: 900px) { .industries-row { grid-template-columns: repeat(3, 1fr); } }
@media(max-width: 500px) { .industries-row { grid-template-columns: repeat(2, 1fr); } }
.industry {
  display: flex; flex-direction: column; align-items: center; gap: 8px;
  padding: 16px 12px; border-radius: 6px;
  background: rgba(10,14,23,.5);
  border: 1px solid var(--border);
  transition: border-color .2s, transform .2s, background .2s;
}
.industry:hover {
  border-color: var(--accent-cyan); transform: translateY(-2px);
  background: rgba(6,182,212,.05);
}
.industry-icon {
  display: flex; align-items: center; justify-content: center;
  width: 40px; height: 40px; border-radius: 6px;
  background: rgba(6,182,212,.12);
  color: var(--accent-cyan); font-size: 1.3rem;
  border: 1px solid rgba(6,182,212,.3);
}
.industry-name {
  font-family: 'JetBrains Mono', monospace;
  font-size: .65rem; font-weight: 700;
  letter-spacing: 1.2px; text-transform: uppercase;
  color: var(--text-secondary); text-align: center;
}

/* ═════════════ Off-ramp ═════════════ */
.offramp {
  display: flex; gap: 26px; align-items: center; justify-content: space-between;
  flex-wrap: wrap;
  background: linear-gradient(135deg, rgba(59,130,246,.14), rgba(6,182,212,.06));
  border: 1px solid rgba(59,130,246,.28);
  border-top: 2px solid var(--accent-blue);
  border-radius: var(--radius);
  padding: 26px 30px;
}
.offramp h3 {
  font-family: 'JetBrains Mono', monospace;
  font-size: 1.2rem; font-weight: 700;
  letter-spacing: -.4px; margin: 6px 0 6px;
}
.offramp p {
  font-family: 'DM Sans', sans-serif;
  color: var(--text-secondary); font-size: .9rem; max-width: 560px;
}
.offramp .btn { flex-shrink: 0; }

/* ═════════════ Journey row ═════════════ */
.journey-row { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; position: relative; }
@media(max-width: 900px) { .journey-row { grid-template-columns: 1fr; } }
.journey-card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  border-top: 2px solid var(--accent-cyan);
  padding: 24px;
  transition: transform .2s, border-color .2s, box-shadow .2s;
}
.journey-card:hover {
  transform: translateY(-2px); border-color: rgba(6,182,212,.4);
  box-shadow: 0 18px 50px rgba(0,0,0,.32);
}
.journey-day {
  font-family: 'JetBrains Mono', monospace;
  font-size: .66rem; letter-spacing: 1.8px;
  text-transform: uppercase; font-weight: 700;
  color: var(--accent-cyan);
}
.journey-card h4 {
  font-family: 'JetBrains Mono', monospace;
  font-size: 1rem; font-weight: 700;
  letter-spacing: -.3px; margin: 6px 0 10px;
}
.journey-card p {
  font-family: 'DM Sans', sans-serif;
  color: var(--text-secondary); font-size: .86rem;
  line-height: 1.55; margin-bottom: 10px;
}
.journey-card ul { list-style: none; padding: 0; margin: 0; }
.journey-card ul li {
  position: relative; padding: 5px 0 5px 16px;
  font-family: 'DM Sans', sans-serif;
  color: var(--text-secondary); font-size: .82rem; line-height: 1.5;
}
.journey-card ul li::before {
  content: ''; position: absolute; left: 0; top: 12px;
  width: 5px; height: 5px; border-radius: 50%;
  background: var(--accent-cyan);
}

/* Foundational note */
.foundational-note {
  text-align: center;
  font-family: 'JetBrains Mono', monospace;
  color: var(--text-muted);
  font-size: .68rem; letter-spacing: 1.4px;
  text-transform: uppercase; margin-bottom: 18px;
}

/* ═════════════ Reduced motion ═════════════ */
@media(prefers-reduced-motion: reduce) {
  .ticker-track, .pulse, .kinetic { animation: none !important; }
  .video-hero .video-bg { display: none; }
  .video-hero::before {
    background: linear-gradient(180deg, var(--bg-primary), var(--bg-secondary));
  }
  .reveal { opacity: 1; transform: none; }
}

/* ═════════════ Print ═════════════ */
@media print {
  body { background: #fff; color: #111; }
  .grid-bg, body::before { display: none; }
  .card, .pillar, .tier, .stat, .faq-item, .journey-card {
    border-color: #ddd; background: #f9f9f9;
  }
  .card h3, .section-head h2, .pillar h3, .tier h3 {
    color: #111; -webkit-text-fill-color: #111;
  }
  .card p, .section-head p, .stat .lbl { color: #444; }
}
