:root {
  --font-display: "Orbitron", "Space Grotesk", system-ui, sans-serif;
  --font-body: "Barlow", system-ui, sans-serif;
  --font-mono: "Share Tech Mono", "IBM Plex Mono", monospace;

  /* ── COLOR PALETTE (style guide) ── */
  --void:        #080c0f;
  --deep-space:  #0d1318;
  --hull:        #141d24;
  --grid-line:   #121d22;
  --bulkhead:    #243340;
  --muted:       #4a6070;
  --body-text:   #8faab8;
  --bright:      #c8dde8;
  --white:       #e8f4fa;

  /* Phosphor — primary accent */
  --phosphor:      #00ff88;
  --phosphor-dim:  #00cc6a;
  --phosphor-glow: 0 0 8px rgba(0, 255, 136, 0.5), 0 0 24px rgba(0, 255, 136, 0.2);

  /* Amber — secondary / seller */
  --amber:      #ffb830;
  --amber-dim:  #cc8f1a;
  --amber-glow: 0 0 8px rgba(255, 184, 48, 0.5), 0 0 24px rgba(255, 184, 48, 0.2);

  /* CRT blue — data / links / buyer */
  --crt-blue:      #4dc8ff;
  --crt-blue-dim:  #2a8ab8;
  --crt-blue-glow: 0 0 8px rgba(77, 200, 255, 0.5), 0 0 24px rgba(77, 200, 255, 0.2);

  /* Semantic */
  --danger:  #ff4060;
  --success: #7df0ad;
  --warning: var(--amber);

  /* RGB triplets for rgba() composition */
  --bg-rgb:        8, 12, 15;
  --accent-rgb:    0, 255, 136;
  --buyer-rgb:     77, 200, 255;
  --seller-rgb:    255, 184, 48;

  /* ── SEMANTIC ALIASES (keeps existing CSS working) ── */
  --bg:              var(--void);
  --bg-soft:         var(--deep-space);
  --panel:           rgba(13, 19, 24, 0.9);
  --panel-strong:    rgba(20, 29, 36, 0.96);
  --border:          rgba(0, 255, 136, 0.16);
  --border-strong:   rgba(0, 255, 136, 0.34);
  --text:            var(--body-text);
  --accent:          var(--phosphor);
  --accent-alt:      var(--crt-blue);
  --accent-alt-rgb:  77, 200, 255;
  --accent-warm:     var(--amber);
  --accent-warm-rgb: 255, 184, 48;
  --accent-dim:      rgba(var(--accent-rgb), 0.14);

  /* ── BORDER RADIUS — sharp/hardware, 2px everywhere ── */
  --radius:      2px;
  --radius-xs:   2px;
  --radius-sm:   2px;
  --radius-md:   2px;
  --radius-lg:   2px;
  --radius-pill: 2px;

  /* ── SPACING SCALE ── */
  --space-1:  0.25rem;   /*  4px */
  --space-2:  0.5rem;    /*  8px */
  --space-3:  0.75rem;   /* 12px */
  --space-4:  1rem;      /* 16px */
  --space-5:  1.25rem;   /* 20px */
  --space-6:  1.5rem;    /* 24px */
  --space-8:  2rem;      /* 32px */
  --space-10: 2.5rem;    /* 40px */
  --space-12: 3rem;      /* 48px */
  --space-16: 4rem;      /* 64px */
  --space-20: 5rem;      /* 80px */

  /* ── PAGE LAYOUT ── */
  --page-width: min(1120px, calc(100vw - 2rem));

  /* ── MOTION ── */
  --motion-fast: 200ms ease;
  --motion-slow: 300ms ease;

  /* ── ELEVATION ── */
  --shadow:        0 24px 80px rgba(0, 0, 0, 0.42);
  --shadow-inset:  inset 0 1px 0 rgba(255, 255, 255, 0.03);
  --shadow-accent: 0 0 0 3px rgba(var(--accent-rgb), 0.12);

  /* ── TYPE SCALE ── */
  --fs-display: clamp(36px, 6vw, 56px);
  --fs-h1:      clamp(28px, 4vw, 44px);
  --fs-h2:      24px;
  --fs-h3:      14px;
  --fs-lede:    1.08rem;
  --fs-body:    1rem;
  --fs-small:   0.92rem;
  --fs-mono-xs: 0.72rem;
  --fs-mono-sm: 0.85rem;

  /* Semantic type shorthands — use with font: var(--type-h1) etc. */
  --type-display: 800 var(--fs-display)/0.94 var(--font-display);
  --type-h1:      700 var(--fs-h1)/1.05 var(--font-display);
  --type-h2:      600 var(--fs-h2)/1.1 var(--font-display);
  --type-h3:      600 var(--fs-h3)/1 var(--font-display);
  --type-body:    300 var(--fs-body)/1.65 var(--font-body);
  --type-lede:    300 var(--fs-lede)/1.6 var(--font-body);
  --type-small:   400 var(--fs-small)/1.5 var(--font-body);
  --type-mono:    500 var(--fs-mono-sm)/1.5 var(--font-mono);
  --type-eyebrow: 600 var(--fs-mono-xs)/1 var(--font-mono);
  --type-button:  600 12px/1 var(--font-display);

  /* ── COMPAT ALIASES ── */
  --color-bg:             var(--bg);
  --color-bg-soft:        var(--bg-soft);
  --color-surface:        var(--panel);
  --color-surface-strong: var(--panel-strong);
  --color-border:         var(--border);
  --color-border-strong:  var(--border-strong);
  --color-text:           var(--text);
  --color-text-muted:     var(--muted);
  --color-accent:         var(--accent);
  --color-accent-soft:    var(--accent-dim);
  --color-success:        var(--success);
  --color-warning:        var(--warning);
  --color-danger:         var(--danger);
  --shadow-elevated:      var(--shadow);
}

/* Primary CTA stays phosphor on every page. Per-page overrides apply only to
   secondary/decorative accents (badges, eyebrows) via scoped selectors below. */
body.homepage {
  /* phosphor is the default — no override needed */
}

body.buy-leads {
  /* buyer secondary accents applied via scoped rules below */
}

body.sell-leads {
  /* seller secondary accents applied via scoped rules below */
}

/* Buyer: secondary accent in CRT blue */
.buy-leads .eyebrow { color: var(--crt-blue); }

/* Seller: secondary accent in amber */
.sell-leads .eyebrow { color: var(--amber); }

* {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
  }
  
[hidden] {
  display: none !important;
}

body {
  margin: 0;
  min-height: 100vh;
  color: var(--text);
  color-scheme: dark;
  background: var(--void);
  font-family: var(--font-body);
  font-weight: 300;
  font-size: 16px;
  line-height: 1.6;
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}

/* Scanline overlay — style guide atmosphere.
   Add class="scanlines" to <body> to enable. All public marketing pages
   have this class; omit on admin/auth surfaces where the overlay is unwanted. */
body.scanlines::before {
  content: '';
  position: fixed;
  inset: 0;
  background: repeating-linear-gradient(
    to bottom,
    transparent 0px,
    transparent 2px,
    rgba(0, 0, 0, 0.08) 2px,
    rgba(0, 0, 0, 0.08) 4px
  );
  pointer-events: none;
  z-index: 9999;
}

a {
  color: inherit;
  text-decoration: none;
}

button,
input,
select,
textarea {
  color: inherit;
  font: inherit;
}

:focus-visible {
  outline: none;
  box-shadow: var(--shadow-accent);
}

::selection {
  color: var(--bg);
  background: rgba(var(--accent-rgb), 0.38);
}

.visually-hidden {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  clip-path: inset(50%);
  white-space: nowrap;
  border: 0;
}

/* Grid-line hero background (used on hero/key sections) */
.grid-bg {
  background-image:
    linear-gradient(var(--grid-line) 1px, transparent 1px),
    linear-gradient(90deg, var(--grid-line) 1px, transparent 1px);
  background-size: 32px 32px;
}

/* ── LAYOUT ── */

main,
.footer {
  width: var(--page-width);
  margin: 0 auto;
}

/* Full-viewport-width header with centered content */
.topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1.2rem max(1rem, calc((100vw - var(--page-width)) / 2));
  position: sticky;
  top: 0;
  z-index: 20;
  border-bottom: 1px solid var(--grid-line);
  background: rgba(8, 12, 15, 0.90);
  backdrop-filter: blur(16px);
}

.brand {
  display: inline-flex;
  align-items: center;
  gap: 0.75rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-size: 0.85rem;
  font-weight: 700;
  font-family: var(--font-mono);
}

.brand-mark {
  width: 0.8rem;
  height: 0.8rem;
  border-radius: var(--radius);
  background: var(--phosphor);
  box-shadow: var(--phosphor-glow);
}

.topnav {
  display: flex;
  gap: 1.4rem;
  color: var(--muted);
  font: 500 0.9rem/1 var(--font-mono);
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.topnav a:hover,
.topnav a:focus-visible,
.footer a:hover,
.footer a:focus-visible {
  color: var(--accent);
}

.hero {
  display: grid;
  grid-template-columns: 1.2fr 0.9fr;
  gap: 2rem;
  align-items: center;
  padding: 5.5rem 0 3rem;
}

.badge {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font: 600 0.72rem/1 var(--font-mono);
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.eyebrow,
.badge--pill {
  margin: 0 0 1rem;
  padding: 0.42rem 0.75rem;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  color: var(--accent);
  background: rgba(var(--accent-rgb), 0.08);
}

.badge--inline,
.feature-kicker,
.metric-label,
.step-index {
  margin: 0;
  color: var(--accent);
}

.badge--pill {
  padding-inline: 0.82rem;
}

.badge--inline {
  width: fit-content;
  margin: 0 0 0.7rem;
  padding: 0.28rem 0.55rem;
  border-radius: var(--radius);
  font-size: 0.66rem;
  line-height: 1;
  letter-spacing: 0.1em;
}

h1,
h2,
h3 {
  margin: 0;
  line-height: 1.05;
  font-family: var(--font-display);
  text-wrap: balance;
}

h1 {
  max-width: min(100%, 40rem);
  font-size: clamp(36px, 6vw, 56px);
  font-weight: 800;
  letter-spacing: 0.04em;
  color: var(--white);
}

h2 {
  font-size: 24px;
  font-weight: 600;
  letter-spacing: 0.06em;
  color: var(--bright);
  max-width: 13ch;
}

h3 {
  font-size: 14px;
  font-weight: 600;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--accent);
}

.lede,
.actions-note,
.section p,
.footer,
.feature p,
.step p,
.metric p,
.deploy-card p {
  color: var(--muted);
  line-height: 1.65;
  font-family: var(--font-body);
}

.lede,
.section p,
.footer,
.feature p,
.step p,
.metric p,
.deploy-card p {
  font-size: 1rem;
}

.lede {
  max-width: 52ch;
  margin: 1.4rem 0 0;
  font-size: 1.08rem;
}

.actions-note {
  margin: 0.95rem 0 0;
  max-width: 46ch;
  font-size: 0.95rem;
}

.actions {
  display: flex;
  gap: 1rem;
  flex-wrap: wrap;
  margin-top: 2rem;
}

.button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 3rem;
  padding: 12px 24px;
  border-radius: var(--radius);
  border: 1px solid transparent;
  cursor: pointer;
  font: 600 12px/1 var(--font-display);
  letter-spacing: 0.15em;
  text-transform: uppercase;
  transition: transform var(--motion-fast), border-color var(--motion-fast), background var(--motion-fast), color var(--motion-fast), box-shadow var(--motion-fast);
}

.button:hover,
.button:focus-visible {
  transform: translateY(-1px);
}

/* Primary button is ALWAYS phosphor — never changes per page */
.button-primary {
  color: var(--void);
  background: var(--phosphor);
  border-color: transparent;
  box-shadow: var(--phosphor-glow);
}

.button-primary:hover,
.button-primary:focus-visible {
  background: #33ffaa;
  box-shadow: 0 0 16px rgba(0, 255, 136, 0.7), 0 0 40px rgba(0, 255, 136, 0.3);
}

.button-secondary {
  color: var(--accent);
  background: transparent;
  border-color: var(--phosphor-dim);
}

.button-secondary:hover,
.button-secondary:focus-visible {
  background: rgba(var(--accent-rgb), 0.08);
}

.hero-stats {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.9rem;
  margin: 2rem 0 0;
}

.hero-stat,
.panel-card {
  border: 1px solid var(--border);
  background:
    linear-gradient(180deg, rgba(13, 19, 24, 0.96), rgba(8, 12, 15, 0.92)),
    linear-gradient(135deg, rgba(var(--accent-rgb), 0.06), transparent 38%);
  box-shadow: var(--shadow);
}

.hero-stat {
  border-radius: var(--radius);
  padding: 1rem;
}

.hero-stats dt {
  color: var(--muted);
  font: 600 0.7rem/1 var(--font-mono);
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.hero-stats dd {
  margin: 0.4rem 0 0;
  font-size: 1rem;
}

.hero-panel {
  display: grid;
  gap: 1rem;
}

.panel-card {
  border-radius: var(--radius);
  padding: 1.25rem;
  position: relative;
  overflow: hidden;
}

.panel-card::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(135deg, rgba(var(--accent-rgb), 0.12), transparent 34%, transparent 68%, rgba(var(--accent-alt-rgb), 0.06));
  pointer-events: none;
}

.terminal {
  min-height: 18rem;
}

.terminal-top {
  display: flex;
  gap: 0.35rem;
  margin-bottom: 1rem;
}

.terminal-top span {
  width: 0.65rem;
  height: 0.65rem;
  border-radius: var(--radius);
  background: rgba(255, 255, 255, 0.12);
}

.terminal-body {
  font: 500 0.92rem/1.8 var(--font-mono);
  color: var(--text);
}

.terminal-line {
  margin: 0.4rem 0;
}

.terminal-line span {
  color: var(--accent);
}

.signal-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
}

.metric strong,
.feature h3,
.step h3 {
  display: block;
  margin-top: 0.85rem;
  margin-bottom: 0.65rem;
}

.feature-link {
  display: inline-flex;
  align-items: center;
  margin-top: 1rem;
  color: var(--accent);
  font: 600 0.8rem/1 var(--font-mono);
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.feature-link:hover,
.feature-link:focus-visible {
  color: var(--text);
}

.section {
  padding: 3rem 0;
}

.trust-strip {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
  margin: 0 auto;
}

.trust-item {
  display: grid;
  gap: 0.75rem;
  min-height: 100%;
}

.trust-item p {
  margin: 0;
  color: var(--muted);
  line-height: 1.6;
}

.section-head {
  display: grid;
  gap: 0.8rem;
  margin-bottom: 1.5rem;
}

.section-copy {
  margin: 0;
  max-width: 54ch;
  color: var(--muted);
  line-height: 1.65;
  font-size: 1rem;
  font-family: var(--font-body);
}

.card-grid,
.steps {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
}

.roi-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
}

.feature,
.step,
.roi-card,
.deploy-card {
  min-height: 100%;
}

.feature p,
.step p,
.metric p,
.roi-card p,
.deploy-card p {
  margin: 0;
}

.step-index {
  display: inline-flex;
}

.roi-card {
  display: grid;
  gap: 0.7rem;
}

.roi-card h3 {
  margin-top: 0.7rem;
  margin-bottom: 0;
}

.roi-card p {
  line-height: 1.65;
}

.roi-disclaimer {
  grid-column: 1 / -1;
  display: grid;
  gap: 0.5rem;
  border-color: rgba(0, 255, 136, 0.14);
  background: rgba(10, 15, 23, 0.8);
}

.roi-disclaimer p {
  margin: 0;
  color: var(--muted);
  line-height: 1.65;
}

.roi-disclaimer .metric-label {
  color: var(--warning);
}

.split {
  display: grid;
  grid-template-columns: 0.7fr 1.3fr;
  gap: 1.5rem;
  align-items: start;
}

.trust .trust-card {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
}

.request-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(18rem, 0.85fr);
  gap: 1.1rem;
  align-items: start;
}

#request-access .request-form {
  display: grid;
  gap: 1rem;
  padding: 1.45rem;
  color-scheme: dark;
  background:
    linear-gradient(180deg, rgba(15, 21, 30, 0.98), rgba(9, 13, 20, 0.94)),
    linear-gradient(135deg, rgba(var(--accent-rgb), 0.08), transparent 42%);
  border: 1px solid rgba(var(--accent-rgb), 0.2);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.03),
    0 24px 80px rgba(0, 0, 0, 0.28);
}

.request-route-group {
  display: grid;
  gap: 0.75rem;
  margin: 0;
  padding: 0;
  border: 0;
}

.request-route-group legend {
  padding: 0 0 0.35rem;
  color: rgba(234, 243, 238, 0.88);
  font: 600 0.72rem/1.1 var(--font-mono);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.request-route-options {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.7rem;
}

.request-route-option {
  position: relative;
  cursor: pointer;
}

.request-route-option input {
  position: absolute;
  inset: 0;
  opacity: 0;
  margin: 0;
  pointer-events: none;
}

.request-route-option span {
  display: grid;
  gap: 0.2rem;
  min-height: 4.2rem;
  padding: 0.85rem 0.95rem;
  border: 1px solid rgba(var(--accent-rgb), 0.16);
  border-radius: var(--radius);
  background: rgba(var(--accent-rgb), 0.05);
  transition: border-color 180ms ease, background 180ms ease, box-shadow 180ms ease, transform 180ms ease;
}

.request-route-option strong {
  color: var(--text);
  font: 600 0.95rem/1.2 var(--font-body);
}

.request-route-option small {
  color: var(--muted);
  font: 500 0.8rem/1.3 var(--font-mono);
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.request-route-option:hover span,
.request-route-option input:focus-visible + span {
  border-color: rgba(var(--accent-rgb), 0.28);
  background: rgba(var(--accent-rgb), 0.08);
  transform: translateY(-1px);
}

.request-route-option input:checked + span {
  border-color: var(--border-strong);
  background: linear-gradient(180deg, rgba(var(--accent-rgb), 0.14), rgba(var(--accent-rgb), 0.05));
  box-shadow: 0 0 0 3px rgba(var(--accent-rgb), 0.1);
}

.request-note,
.field-hint {
  margin: 0;
  color: var(--muted);
  line-height: 1.55;
  font-size: 0.92rem;
}

.request-note {
  padding: 0.85rem 1rem;
  border: 1px solid rgba(var(--accent-rgb), 0.16);
  border-radius: var(--radius);
  background: rgba(var(--accent-rgb), 0.06);
}

.field-hint {
  margin-top: -0.35rem;
}

.request-promise {
  margin: 0;
  color: var(--text);
  font: 600 0.98rem/1.4 var(--font-body);
}

.request-trust-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 0.45rem;
}

.request-trust-list li {
  display: flex;
  gap: 0.55rem;
  align-items: flex-start;
  color: var(--muted);
  line-height: 1.45;
}

.request-trust-list li::before {
  content: "";
  width: 0.55rem;
  height: 0.55rem;
  border-radius: var(--radius);
  background: var(--accent);
  box-shadow: 0 0 0 4px var(--accent-dim);
  margin-top: 0.42rem;
  flex: 0 0 auto;
}

.request-aside .request-promise {
  color: var(--warning);
}

.field-row {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.9rem;
}

#request-access .request-form label {
  display: grid;
  gap: 0.5rem;
  color: rgba(234, 243, 238, 0.88);
  font: 600 0.72rem/1.1 var(--font-mono);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

#request-access .request-form input,
#request-access .request-form select,
#request-access .request-form textarea {
  width: 100%;
  min-height: 3.25rem;
  border: 1px solid rgba(var(--accent-rgb), 0.2);
  border-radius: var(--radius);
  background: linear-gradient(180deg, rgba(5, 8, 13, 0.84), rgba(8, 12, 18, 0.72));
  color: var(--text);
  padding: 0.95rem 1rem;
  font: inherit;
  appearance: none;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.03);
}

#request-access .request-form textarea {
  resize: vertical;
  min-height: 8rem;
}

#request-access .request-form input::placeholder,
#request-access .request-form textarea::placeholder {
  color: rgba(158, 176, 165, 0.66);
}

#request-access .request-form input:focus,
#request-access .request-form select:focus,
#request-access .request-form textarea:focus {
  outline: none;
  border-color: var(--border-strong);
  box-shadow: 0 0 0 3px rgba(100, 242, 154, 0.12);
}

.request-verification {
  min-height: 66px;
}

.request-verification iframe {
  max-width: 100%;
}

.full-width {
  grid-column: 1 / -1;
}

#request-access .request-form [disabled] {
  cursor: not-allowed;
  opacity: 0.75;
}

.request-actions {
  display: grid;
  gap: 0.7rem;
  justify-items: start;
}

.request-status {
  margin: 0;
  padding: 0.78rem 0.95rem;
  border: 1px solid rgba(var(--accent-rgb), 0.14);
  border-radius: var(--radius);
  background: rgba(5, 8, 13, 0.45);
  color: var(--muted);
  font-size: 0.95rem;
  line-height: 1.5;
}

.request-status[data-state="pending"] {
  border-color: rgba(var(--accent-rgb), 0.28);
  color: var(--accent);
  background: rgba(var(--accent-rgb), 0.07);
}

.request-status[data-state="success"] {
  border-color: rgba(125, 240, 173, 0.28);
  color: var(--success);
  background: rgba(125, 240, 173, 0.08);
}

.request-status[data-state="error"] {
  border-color: rgba(255, 141, 141, 0.34);
  color: var(--danger);
  background: rgba(255, 141, 141, 0.08);
}

.request-status[data-state="idle"] {
  color: var(--muted);
}

/* Auth panel forms (forgot-password, reset-password) */
.form-field {
  display: grid;
  gap: 0.5rem;
}

.form-field label {
  color: rgba(234, 243, 238, 0.88);
  font: 600 0.72rem/1.1 var(--font-mono);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.form-field input {
  width: 100%;
  min-height: 3.25rem;
  border: 1px solid rgba(var(--accent-rgb), 0.2);
  border-radius: var(--radius);
  background: linear-gradient(180deg, rgba(5, 8, 13, 0.84), rgba(8, 12, 18, 0.72));
  color: var(--text);
  padding: 0.95rem 1rem;
  font: inherit;
  appearance: none;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.03);
}

.form-field input:focus {
  outline: none;
  border-color: var(--border-strong);
  box-shadow: 0 0 0 3px rgba(100, 242, 154, 0.12);
}

.button-row {
  display: flex;
  gap: 0.75rem;
  padding-top: 0.25rem;
}

.panel-card form {
  display: grid;
  gap: 1rem;
}

.panel-card > p {
  margin: 0.75rem 0 0;
  font-size: 0.9rem;
  color: var(--muted);
}

.request-aside {
  display: grid;
  gap: 0.8rem;
  padding: 1.2rem;
  background: linear-gradient(180deg, rgba(14, 20, 31, 0.96), rgba(9, 13, 20, 0.92));
}

.request-brief {
  display: grid;
  gap: 0.7rem;
  padding: 0.95rem;
  border: 1px solid rgba(var(--accent-rgb), 0.14);
  border-radius: var(--radius);
  background: rgba(5, 8, 13, 0.42);
}

.request-brief h3 {
  margin: 0;
}

.request-terms {
  display: grid;
  gap: 0.7rem;
}

.request-term {
  display: grid;
  gap: 0.2rem;
}

.request-term span {
  color: var(--warning);
  font: 600 0.72rem/1.1 var(--font-mono);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.request-term strong {
  color: var(--text);
  font: 500 0.95rem/1.45 var(--font-body);
}

.request-aside .feature-kicker {
  color: var(--warning);
}

.request-list {
  margin: 0;
  padding-left: 1.1rem;
  display: grid;
  gap: 0.55rem;
  color: var(--muted);
  line-height: 1.6;
}

.request-list li::marker {
  color: var(--accent);
}

#request-access .request-form .button-primary {
  color: var(--void);
  border-color: rgba(var(--accent-rgb), 0.24);
  background: linear-gradient(180deg, rgba(var(--accent-rgb), 0.96), rgba(var(--accent-rgb), 0.74));
  box-shadow: 0 12px 32px rgba(var(--accent-rgb), 0.18);
}

#request-access .request-form[data-request-state="pending"] .button-primary {
  opacity: 0.82;
}

#request-access .request-form[data-request-state="success"] .button-primary {
  box-shadow: 0 10px 30px rgba(125, 240, 173, 0.18);
}

#request-access .request-form input:-webkit-autofill,
#request-access .request-form select:-webkit-autofill,
#request-access .request-form textarea:-webkit-autofill,
#request-access .request-form input:-webkit-autofill:hover,
#request-access .request-form select:-webkit-autofill:hover,
#request-access .request-form textarea:-webkit-autofill:hover,
#request-access .request-form input:-webkit-autofill:focus,
#request-access .request-form select:-webkit-autofill:focus,
#request-access .request-form textarea:-webkit-autofill:focus {
  -webkit-text-fill-color: var(--text);
  caret-color: var(--text);
  box-shadow: 0 0 0 1000px rgba(8, 12, 18, 0.96) inset;
  transition: background-color 9999s ease-out 0s, color 9999s ease-out 0s;
}

.trust .trust-card {
  grid-template-columns: minmax(0, 1.2fr) repeat(2, minmax(0, 0.9fr));
  gap: 0.95rem;
}

.trust .trust-card > div {
  display: grid;
  gap: 0.65rem;
  border: 1px solid rgba(var(--accent-rgb), 0.14);
  border-radius: var(--radius);
  padding: 1.15rem;
  background: rgba(10, 15, 23, 0.7);
}

.trust .trust-card > div:first-child {
  border-color: rgba(var(--accent-rgb), 0.28);
  background: linear-gradient(180deg, rgba(var(--accent-rgb), 0.08), rgba(10, 15, 23, 0.82));
}

.trust .trust-card > div:nth-child(2),
.trust .trust-card > div:nth-child(3) {
  background: rgba(8, 13, 19, 0.68);
}

/* ── FOOTER ── */

.footer {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1.4fr);
  gap: 2rem;
  align-items: start;
  padding: 2.5rem 0 3rem;
  border-top: 1px solid var(--grid-line);
  font: 500 0.92rem/1.5 var(--font-mono);
  letter-spacing: 0.04em;
  color: var(--muted);
}

.footer-brand {
  display: grid;
  gap: 0.6rem;
}

.footer-label {
  margin: 0;
  color: var(--accent);
  font: 700 0.72rem/1 var(--font-mono);
  letter-spacing: 0.25em;
  text-transform: uppercase;
}

.footer-tagline {
  margin: 0;
  line-height: 1.7;
  color: var(--muted);
}

.footer-copyright {
  margin: 0;
  color: var(--muted);
  font: 500 0.72rem/1 var(--font-mono);
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.footer-nav {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem 1.5rem;
  align-items: flex-start;
  padding-top: 0.15rem;
}

.footer-nav a {
  color: var(--muted);
}

.footer-nav a:hover,
.footer-nav a:focus-visible {
  color: var(--accent);
}

/* ── REVEAL ANIMATION ── */

[data-reveal] {
  opacity: 0;
  transform: translateY(14px);
  transition: opacity var(--motion-slow), transform var(--motion-slow);
}

[data-reveal].is-visible {
  opacity: 1;
  transform: translateY(0);
}

/* ── GLITCH EFFECT (hero h1 only) ── */

.glitch {
  position: relative;
  display: inline-block;
}

.glitch::before,
.glitch::after {
  content: attr(data-text);
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  font-family: inherit;
  font-size: inherit;
  font-weight: inherit;
  letter-spacing: inherit;
}

.glitch::before {
  color: var(--crt-blue);
  animation: glitch-a 4s infinite steps(1);
  clip-path: polygon(0 0, 100% 0, 100% 35%, 0 35%);
}

.glitch::after {
  color: var(--danger);
  animation: glitch-b 4s infinite steps(1);
  clip-path: polygon(0 65%, 100% 65%, 100% 100%, 0 100%);
}

@keyframes glitch-a {
  0%, 92%, 100% { transform: translate(0, 0); opacity: 0; }
  93% { transform: translate(-3px, 0); opacity: 0.8; clip-path: polygon(0 5%, 100% 5%, 100% 32%, 0 32%); }
  95% { transform: translate(3px, 0); opacity: 0.6; clip-path: polygon(0 10%, 100% 10%, 100% 28%, 0 28%); }
  97% { transform: translate(-2px, 0); opacity: 0.8; clip-path: polygon(0 2%, 100% 2%, 100% 36%, 0 36%); }
}

@keyframes glitch-b {
  0%, 92%, 100% { transform: translate(0, 0); opacity: 0; }
  94% { transform: translate(3px, 0); opacity: 0.7; clip-path: polygon(0 68%, 100% 68%, 100% 95%, 0 95%); }
  96% { transform: translate(-3px, 0); opacity: 0.5; clip-path: polygon(0 72%, 100% 72%, 100% 90%, 0 90%); }
  98% { transform: translate(2px, 0); opacity: 0.7; clip-path: polygon(0 64%, 100% 64%, 100% 97%, 0 97%); }
}

/* ── REDUCED MOTION ── */

@media (prefers-reduced-motion: reduce) {
  html {
    scroll-behavior: auto;
  }

  [data-reveal],
  .glitch::before,
  .glitch::after {
    animation: none !important;
    transition: none !important;
  }

  [data-reveal] {
    opacity: 1;
    transform: none;
  }

  .glitch::before,
  .glitch::after {
    display: none;
  }
}

/* ── RESPONSIVE ── */

@media (max-width: 920px) {
  .hero,
  .split {
    grid-template-columns: 1fr;
  }

  .card-grid,
  .steps,
  .roi-grid,
  .trust-strip,
  .trust .trust-card,
  .signal-grid,
  .request-grid,
  .field-row,
  .request-route-options {
    grid-template-columns: 1fr;
  }

  .request-terms {
    gap: 0.6rem;
  }

  .hero {
    padding-top: 3.5rem;
  }

  h1 {
    font-size: 1.875rem;
    line-height: 0.98;
  }

  .footer {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 640px) {
  .topbar {
    flex-direction: column;
    align-items: flex-start;
    gap: 1rem;
  }

  .topnav {
    gap: 1rem;
    flex-wrap: wrap;
  }

  .hero-stats {
    grid-template-columns: 1fr;
  }

  .actions {
    flex-direction: column;
    align-items: stretch;
  }

  h1 {
    font-size: 1.75rem;
    line-height: 1;
  }

  #request-access .request-form,
  .request-aside {
    padding: 1.2rem;
  }

  .request-actions {
    justify-items: stretch;
  }

  .request-status {
    width: 100%;
  }

  .footer {
    grid-template-columns: 1fr;
  }
}

/* ── HOMEPAGE-SPECIFIC ── */

.homepage .hero {
  grid-template-columns: minmax(0, 1.15fr) minmax(0, 0.95fr);
  gap: 1.8rem;
  padding: 5.2rem 0 3rem;
  align-items: start;
}

.homepage .hero-copy {
  display: grid;
  align-content: start;
  gap: 0.2rem;
}

.homepage .hero-copy h1 {
  font-size: clamp(2.55rem, 5.2vw, 4.6rem);
  line-height: 0.94;
  max-width: 13ch;
}

.homepage .hero .lede {
  max-width: 50ch;
}

.homepage .action-link {
  display: inline-flex;
  width: fit-content;
  margin-top: 0.15rem;
  color: var(--accent);
  font: 600 0.8rem/1 var(--font-mono);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.homepage .action-link:hover,
.homepage .action-link:focus-visible {
  color: var(--text);
}

.homepage .hero-chips,
.homepage .detail-list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.homepage .hero-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
  margin-top: 1.25rem;
}

.homepage .hero-chips li,
.homepage .detail-list li {
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: rgba(var(--accent-rgb), 0.05);
  color: var(--text);
  font: 600 0.72rem/1 var(--font-mono);
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.homepage .hero-chips li {
  padding: 0.7rem 0.95rem;
}

.faq-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.75rem;
}

.faq-item {
  padding: 1rem 1.25rem;
}

.faq-item summary {
  cursor: pointer;
  color: var(--bright);
  font: 500 0.95rem/1.45 var(--font-body);
  list-style: none;
  position: relative;
  padding-right: 1.5rem;
}

.faq-item summary::after {
  content: '+';
  position: absolute;
  right: 0;
  top: 0;
  color: var(--accent);
  font: 600 1rem/1.45 var(--font-mono);
}

.faq-item[open] summary::after {
  content: '−';
}

.faq-item p {
  margin: 0.85rem 0 0;
}

.trust-disclaimer {
  margin-top: 1.25rem;
}

@media (max-width: 920px) {
  .homepage .hero,
  .homepage .faq-grid {
    grid-template-columns: 1fr;
  }

  .homepage .hero {
    padding-top: 3.5rem;
  }
}

@media (max-width: 640px) {
  .homepage .hero-chips,
  .homepage .detail-list {
    gap: 0.5rem;
  }

  .homepage .hero-chips li,
  .homepage .detail-list li {
    width: fit-content;
  }
}

/* Account page — flash prevention and account info card */
body.account .topnav,
body.account main > .hero {
  opacity: 0;
  transition: opacity 0.15s ease;
}

body.account main > .hero {
  padding: 3rem 0 1.75rem;
}

body.account.account-ready .topnav,
body.account.account-ready .account-approved {
  opacity: 1;
}

body.account.account-ready main > .hero {
  display: none;
}

.account-approved {
  opacity: 0;
  padding-top: 1.25rem;
}

.account-info-card {
  max-width: 480px;
  margin: 1.25rem 0;
}

.account-details {
  margin: 0;
  display: grid;
  gap: 0.75rem;
}

.account-detail-row {
  display: grid;
  grid-template-columns: 6rem 1fr;
  gap: 0.5rem;
  align-items: baseline;
  border-bottom: 1px solid rgba(255, 255, 255, 0.06);
  padding-bottom: 0.75rem;
}

.account-detail-row:last-child {
  border-bottom: none;
  padding-bottom: 0;
}

.account-details dt {
  font-family: var(--font-mono);
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--muted);
}

.account-details dd {
  margin: 0;
  font-family: var(--font-body);
  font-size: 0.9rem;
  color: var(--fg);
  word-break: break-all;
}
