/* ═══════════════════════════════════════════════════════════════════════════
   BDB Landing System · brand CSS · pulls from cockpit_v3 design tokens
   Restrained palette · generous whitespace · large type · soft surfaces
   ═══════════════════════════════════════════════════════════════════════════ */

:root {
  /* Restrained palette · BDB brand kept but used sparingly as accent */
  --ink:          #1B1614;
  --ink-soft:     #6E635A;
  --ink-faint:    #B5ADA3;
  --ink-ghost:    #DDD6CC;

  --paper:        #FAFAF8;
  --surface:      #FFFFFF;
  --surface-2:    #F4F2EE;

  --green:        #4F7B3D;
  --green-soft:   #E8F1DE;
  --amber:        #B8632F;
  --amber-soft:   #FBE5D2;
  --red:          #A03D2A;
  --red-soft:     #F5D9D2;
  --accent:       #C97D54;
  --accent-soft:  #F5DCC9;

  /* Type */
  --font-sans: 'Inter', system-ui, -apple-system, sans-serif;
  --font-mono: 'JetBrains Mono', SF Mono, Menlo, monospace;

  /* Spacing */
  --sp-1: 4px; --sp-2: 8px; --sp-3: 12px; --sp-4: 16px;
  --sp-5: 24px; --sp-6: 32px; --sp-7: 48px; --sp-8: 64px; --sp-9: 96px;

  /* Radii */
  --r-sm: 4px; --r-md: 8px; --r-lg: 14px; --r-xl: 20px;

  /* Shadows */
  --shadow-1: 0 1px 2px rgba(27,22,20,0.04), 0 1px 3px rgba(27,22,20,0.06);
  --shadow-2: 0 4px 10px rgba(27,22,20,0.06), 0 2px 4px rgba(27,22,20,0.04);
  --shadow-3: 0 10px 25px rgba(27,22,20,0.08), 0 4px 10px rgba(27,22,20,0.06);
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  font-family: var(--font-sans);
  color: var(--ink);
  background: var(--paper);
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.container { max-width: 1080px; margin: 0 auto; padding: 0 var(--sp-5); }
.container-narrow { max-width: 720px; margin: 0 auto; padding: 0 var(--sp-5); }

/* Header / Footer */
.bdb-header { background: var(--surface); border-bottom: 1px solid var(--ink-ghost); padding: var(--sp-3) 0; }
.bdb-header .container { display: flex; align-items: center; justify-content: space-between; }
.brand { display: flex; align-items: center; gap: 8px; font-weight: 700; font-size: 16px; color: var(--ink); text-decoration: none; letter-spacing: -0.01em; }
.brand-dot { color: var(--accent); font-size: 12px; }
.header-nav { display: flex; gap: var(--sp-5); }
.header-nav a { color: var(--ink-soft); text-decoration: none; font-size: 14px; font-weight: 500; transition: color 0.15s ease; }
.header-nav a:hover { color: var(--accent); }

.bdb-footer { padding: var(--sp-8) 0 var(--sp-6); background: var(--surface-2); border-top: 1px solid var(--ink-ghost); margin-top: var(--sp-9); }
.bdb-footer .container { text-align: center; color: var(--ink-soft); font-size: 13px; }
.bdb-footer .small { font-size: 11px; color: var(--ink-faint); margin-top: var(--sp-2); }

/* Hero */
.hero { padding: var(--sp-9) 0 var(--sp-8); text-align: center; }
.hero .eyebrow { display: inline-block; font-size: 11px; font-weight: 700; letter-spacing: 0.14em; text-transform: uppercase; color: var(--accent); margin-bottom: var(--sp-4); }
.hero h1 { font-size: clamp(34px, 5vw, 56px); font-weight: 800; line-height: 1.04; letter-spacing: -0.03em; max-width: 880px; margin: 0 auto var(--sp-5); }
.hero .lede { font-size: clamp(16px, 1.6vw, 19px); color: var(--ink-soft); max-width: 680px; margin: 0 auto var(--sp-7); line-height: 1.6; }
.hero .promise-list { max-width: 680px; margin: 0 auto var(--sp-7); text-align: left; }
.hero .promise-list li { padding-left: 32px; position: relative; margin-bottom: var(--sp-3); list-style: none; font-size: 16px; line-height: 1.55; color: var(--ink); }
.hero .promise-list li::before { content: '→'; position: absolute; left: 8px; top: 0; color: var(--accent); font-weight: 700; }

/* CTA buttons */
.cta-primary, .cta-secondary {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 14px 28px; border-radius: var(--r-md);
  font-family: var(--font-sans); font-size: 15px; font-weight: 700;
  letter-spacing: 0.01em; text-decoration: none; border: none;
  cursor: pointer; transition: all 0.2s ease;
  box-shadow: var(--shadow-2);
}
.cta-primary { background: var(--accent); color: white; }
.cta-primary:hover { background: #B66A45; transform: translateY(-1px); box-shadow: var(--shadow-3); }
.cta-secondary { background: var(--surface); color: var(--ink); border: 1px solid var(--ink-ghost); }
.cta-secondary:hover { border-color: var(--accent); color: var(--accent); }
.cta-row { display: flex; gap: var(--sp-3); justify-content: center; flex-wrap: wrap; }

/* Section blocks (chapters) */
.section { padding: var(--sp-8) 0; }
.section.alt { background: var(--surface-2); }
.section .eyebrow { font-size: 11px; font-weight: 700; letter-spacing: 0.14em; text-transform: uppercase; color: var(--accent); margin-bottom: var(--sp-2); }
.section h2 { font-size: clamp(26px, 3vw, 36px); font-weight: 800; line-height: 1.1; letter-spacing: -0.02em; margin-bottom: var(--sp-4); }
.section h3 { font-size: 20px; font-weight: 700; margin: var(--sp-6) 0 var(--sp-3); letter-spacing: -0.01em; }
.section p { font-size: 16px; line-height: 1.7; color: var(--ink); margin-bottom: var(--sp-4); max-width: 720px; }
.section ul, .section ol { margin: 0 0 var(--sp-4); padding-left: 24px; }
.section ul li, .section ol li { font-size: 16px; line-height: 1.7; margin-bottom: var(--sp-2); }

/* Cards · for personas, watch-outs, decision rules */
.cards-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: var(--sp-4); margin: var(--sp-5) 0; }
.card { background: var(--surface); border: 1px solid var(--ink-ghost); border-radius: var(--r-lg); padding: var(--sp-5); box-shadow: var(--shadow-1); }
.card.accent { border-left: 4px solid var(--accent); }
.card .card-eyebrow { font-size: 11px; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; color: var(--ink-soft); margin-bottom: var(--sp-2); }
.card h3 { font-size: 18px; font-weight: 700; margin: 0 0 var(--sp-3); }
.card p { font-size: 14.5px; line-height: 1.6; margin-bottom: var(--sp-3); }
.card .card-meta { font-size: 12px; color: var(--ink-soft); margin-top: var(--sp-3); }

/* Truck class cards (1500 / 2500 / 3500) */
.truck-classes { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--sp-4); margin: var(--sp-5) 0; }
@media (max-width: 768px) { .truck-classes { grid-template-columns: 1fr; } }
.truck-class { background: var(--surface); border-radius: var(--r-lg); padding: var(--sp-5); border-top: 4px solid var(--accent); box-shadow: var(--shadow-1); }
.truck-class .class-name { font-size: 32px; font-weight: 800; line-height: 1; letter-spacing: -0.02em; }
.truck-class .class-sub { font-size: 12px; color: var(--ink-soft); text-transform: uppercase; letter-spacing: 0.1em; margin-top: 4px; }
.truck-class h4 { font-size: 13px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.06em; color: var(--ink-soft); margin: var(--sp-4) 0 var(--sp-2); }

/* Callout boxes */
.callout { background: var(--accent-soft); border-left: 3px solid var(--accent); padding: var(--sp-4) var(--sp-5); border-radius: var(--r-md); margin: var(--sp-4) 0; font-size: 15px; line-height: 1.6; }
.callout.green { background: var(--green-soft); border-left-color: var(--green); }
.callout.amber { background: var(--amber-soft); border-left-color: var(--amber); }
.callout.red { background: var(--red-soft); border-left-color: var(--red); }

/* Form */
.kit-form { background: var(--surface); border: 1px solid var(--ink-ghost); border-radius: var(--r-lg); padding: var(--sp-6); box-shadow: var(--shadow-2); max-width: 480px; margin: 0 auto; }
.kit-form h3 { font-size: 22px; font-weight: 800; margin-bottom: var(--sp-2); letter-spacing: -0.01em; }
.kit-form p.intro { font-size: 14px; color: var(--ink-soft); margin-bottom: var(--sp-5); }
.kit-form .form-field { margin-bottom: var(--sp-4); }
.kit-form label { display: block; font-size: 13px; font-weight: 600; color: var(--ink); margin-bottom: 6px; letter-spacing: 0.01em; }
.kit-form input, .kit-form select, .kit-form textarea {
  width: 100%; padding: 12px 14px; font-family: var(--font-sans); font-size: 15px;
  border: 1px solid var(--ink-ghost); border-radius: var(--r-sm); background: var(--surface);
  color: var(--ink); transition: border-color 0.15s ease;
}
.kit-form input:focus, .kit-form select:focus, .kit-form textarea:focus {
  outline: none; border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-soft);
}
.kit-form .consent-row { display: flex; align-items: flex-start; gap: 8px; margin: var(--sp-4) 0; font-size: 13px; color: var(--ink-soft); line-height: 1.5; }
.kit-form .consent-row input { width: auto; margin-top: 2px; }
.kit-form button { width: 100%; }
.kit-form .form-error { display: none; background: var(--red-soft); color: var(--red); padding: 12px 16px; border-radius: var(--r-sm); font-size: 14px; margin-bottom: var(--sp-3); }
.kit-form .form-error.show { display: block; }

/* Live brain-data badge */
.live-stat { display: inline-flex; align-items: baseline; gap: 6px; padding: 2px 10px; background: var(--green-soft); color: var(--green); border-radius: 999px; font-size: 13px; font-weight: 600; font-family: var(--font-mono); }
.live-stat::before { content: '●'; color: var(--green); font-size: 8px; }
