/* ==========================================================================
   Prairie Fire Partners — Design Tokens
   Primary brand: Navy #033c68  |  Accent: Ember #c75a2a  |  Display: Prata
   ========================================================================== */

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

:root {
  /* ---------- Brand color anchors ---------- */
  --navy:  #033c68;   /* brand primary, from brand book */
  --ember: #c75a2a;   /* accent, from logo flame */
  --bone:  #f6f1ea;   /* warm alt background */

  /* ---------- Navy scale ---------- */
  --navy-900: #01223c;
  --navy-800: #022d50;
  --navy-700: #033c68;   /* = --navy */
  --navy-600: #0a4f82;
  --navy-500: #2566a0;
  --navy-400: #5f8bba;
  --navy-300: #a2bcd6;
  --navy-200: #d2e0ee;
  --navy-100: #eaf0f7;
  --navy-050: #f5f8fb;

  /* ---------- Ember scale ---------- */
  --ember-700: #8e3a17;
  --ember-600: #a84620;
  --ember-500: #c75a2a;   /* = --ember */
  --ember-400: #db7a4a;
  --ember-300: #e9a17a;
  --ember-200: #f1c3a9;
  --ember-100: #faeadd;

  /* ---------- Neutrals (slightly blue-biased) ---------- */
  --ink:       #0f1720;
  --slate-900: #111923;
  --slate-800: #1f2a36;
  --slate-700: #323e4c;
  --slate-600: #4b5867;
  --slate-500: #6b7686;
  --slate-400: #8993a3;
  --slate-300: #b7bec9;
  --slate-200: #dde1e8;
  --slate-100: #eef1f5;
  --slate-050: #f7f8fb;
  --paper:     #ffffff;

  /* ---------- Semantic ---------- */
  --fg:          var(--ink);
  --fg-muted:    var(--slate-600);
  --fg-subtle:   var(--slate-400);
  --fg-inverse:  var(--paper);
  --fg-brand:    var(--navy-700);
  --fg-accent:   var(--ember-500);

  --bg:          var(--paper);
  --bg-alt:      var(--bone);
  --bg-subtle:   var(--slate-050);
  --bg-inverse:  var(--navy-700);
  --bg-deep:     var(--navy-900);

  --border:          var(--slate-200);
  --border-strong:   var(--navy-300);
  --border-inverse:  rgba(255,255,255,0.16);

  --success: #2f7d57;
  --warning: #c08a1f;
  --danger:  #a83434;
  --info:    var(--navy-500);

  /* ---------- Signature gradients (from the flame logo) ---------- */
  --gradient-brand:     linear-gradient(135deg, #033c68 0%, #15456f 45%, #c75a2a 100%);
  --gradient-brand-soft:linear-gradient(135deg, #033c68 0%, #8e3a17 100%);
  --gradient-protection:linear-gradient(180deg, rgba(1,34,60,0) 0%, rgba(1,34,60,0.0) 40%, rgba(1,34,60,0.85) 100%);
  --gradient-ember:     linear-gradient(135deg, #c75a2a 0%, #8e3a17 100%);

  /* ---------- Spacing (4px base) ---------- */
  --space-1: 4px;
  --space-2: 8px;
  --space-3: 12px;
  --space-4: 16px;
  --space-5: 24px;
  --space-6: 32px;
  --space-7: 48px;
  --space-8: 64px;
  --space-9: 96px;
  --space-10: 128px;

  /* ---------- Layout widths ---------- */
  --width-narrative: 720px;
  --width-standard:  1040px;
  --width-wide:      1280px;

  /* ---------- Radii ---------- */
  --radius-none: 0;
  --radius-sm:   4px;
  --radius-md:   6px;
  --radius-lg:   10px;
  --radius-xl:   16px;
  --radius-full: 9999px;

  /* ---------- Elevation (navy-tinted) ---------- */
  --elev-0: none;
  --elev-1: 0 1px 2px rgba(3, 60, 104, 0.06);
  --elev-2: 0 2px 6px rgba(3, 60, 104, 0.08), 0 1px 2px rgba(3, 60, 104, 0.06);
  --elev-3: 0 8px 24px rgba(3, 60, 104, 0.10), 0 2px 6px rgba(3, 60, 104, 0.06);
  --elev-modal: 0 24px 64px rgba(3, 60, 104, 0.18), 0 8px 24px rgba(3, 60, 104, 0.10);
  --focus-ring: 0 0 0 3px rgba(3, 60, 104, 0.24);

  /* ---------- Motion ---------- */
  --ease:        cubic-bezier(0.2, 0.8, 0.2, 1);
  --ease-in:     cubic-bezier(0.4, 0, 1, 1);
  --duration-xs: 120ms;
  --duration-sm: 160ms;
  --duration-md: 240ms;
  --duration-lg: 400ms;

  /* ---------- Type families ---------- */
  --font-display: 'Prata', 'Cormorant Garamond', Georgia, 'Times New Roman', serif;
  --font-sans:    'Inter', ui-sans-serif, system-ui, -apple-system, 'Helvetica Neue', Arial, sans-serif;
  --font-mono:    'JetBrains Mono', ui-monospace, 'SF Mono', Menlo, Consolas, monospace;

  /* ---------- Type scale ---------- */
  --text-display-xl: 72px;
  --text-display-lg: 56px;
  --text-display-md: 40px;
  --text-h1:         32px;
  --text-h2:         24px;
  --text-h3:         20px;
  --text-body-lg:    18px;
  --text-body:       16px;
  --text-body-sm:    14px;
  --text-caption:    12px;
  --text-eyebrow:    12px;
  --text-mono:       13px;

  --leading-tight:   1.08;
  --leading-snug:    1.2;
  --leading-normal:  1.5;
  --leading-loose:   1.7;

  --tracking-tight:  -0.01em;
  --tracking-normal: 0;
  --tracking-wide:   0.08em;
  --tracking-eyebrow:0.14em;
}

/* ==========================================================================
   Semantic element styles — so authors can use <h1>, <p>, .eyebrow, etc.
   ========================================================================== */

html { -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; }
body {
  font-family: var(--font-sans);
  font-size: var(--text-body);
  line-height: var(--leading-normal);
  color: var(--fg);
  background: var(--bg);
  margin: 0;
}

h1, .h1, h2, .h2, h3, .h3, .display-xl, .display-lg, .display-md {
  font-family: var(--font-display);
  font-weight: 400;     /* Prata has one weight */
  color: var(--fg-brand);
  text-wrap: balance;
  margin: 0 0 var(--space-4);
}

.display-xl { font-size: var(--text-display-xl); line-height: 1.05; letter-spacing: var(--tracking-tight); }
.display-lg { font-size: var(--text-display-lg); line-height: var(--leading-tight); letter-spacing: -0.005em; }
.display-md { font-size: var(--text-display-md); line-height: 1.12; }

h1, .h1 { font-size: var(--text-h1); line-height: var(--leading-snug); }
h2, .h2 { font-size: var(--text-h2); line-height: 1.3; }
h3, .h3 {
  font-family: var(--font-sans);
  font-weight: 600;
  font-size: var(--text-h3);
  line-height: 1.35;
  color: var(--fg);
}

p, .p {
  font-family: var(--font-sans);
  font-size: var(--text-body);
  line-height: var(--leading-normal);
  color: var(--fg);
  margin: 0 0 var(--space-4);
  text-wrap: pretty;
}
.p-lg { font-size: var(--text-body-lg); line-height: 1.55; }
.p-sm { font-size: var(--text-body-sm); }
.muted { color: var(--fg-muted); }
.subtle { color: var(--fg-subtle); }

.eyebrow {
  font-family: var(--font-sans);
  font-size: var(--text-eyebrow);
  font-weight: 600;
  letter-spacing: var(--tracking-eyebrow);
  text-transform: uppercase;
  color: var(--ember-500);
  margin: 0 0 var(--space-3);
}
.eyebrow--navy { color: var(--navy-700); }
.eyebrow--muted { color: var(--slate-500); }

.caption {
  font-size: var(--text-caption);
  line-height: 1.4;
  color: var(--fg-muted);
  letter-spacing: 0.02em;
}

code, .mono {
  font-family: var(--font-mono);
  font-size: var(--text-mono);
  color: var(--slate-800);
}

a {
  color: var(--navy-700);
  text-decoration: none;
  border-bottom: 1px solid transparent;
  transition: border-color var(--duration-sm) var(--ease);
}
a:hover { border-bottom-color: currentColor; }

hr {
  border: 0;
  border-top: 1px solid var(--border);
  margin: var(--space-6) 0;
}

/* ==========================================================================
   Surfaces & utilities
   ========================================================================== */

.surface-paper    { background: var(--paper); color: var(--fg); }
.surface-bone     { background: var(--bone); color: var(--fg); }
.surface-navy     { background: var(--navy-700); color: var(--fg-inverse); }
.surface-deep     { background: var(--navy-900); color: var(--fg-inverse); }
.surface-gradient { background: var(--gradient-brand); color: var(--fg-inverse); }

.surface-navy h1, .surface-navy h2, .surface-navy .display-xl, .surface-navy .display-lg,
.surface-deep h1, .surface-deep h2, .surface-deep .display-xl, .surface-deep .display-lg,
.surface-gradient h1, .surface-gradient h2, .surface-gradient .display-xl, .surface-gradient .display-lg {
  color: var(--fg-inverse);
}
.surface-navy .eyebrow, .surface-deep .eyebrow, .surface-gradient .eyebrow { color: var(--ember-400); }

.card {
  background: var(--paper);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  box-shadow: var(--elev-1);
  padding: var(--space-5);
  transition: box-shadow var(--duration-sm) var(--ease), border-color var(--duration-sm) var(--ease);
}
.card:hover { box-shadow: var(--elev-2); border-color: var(--slate-300); }

/* ==========================================================================
   Buttons
   ========================================================================== */

.btn {
  --btn-bg: var(--navy-700);
  --btn-fg: var(--paper);
  --btn-border: transparent;
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-family: var(--font-sans);
  font-size: var(--text-body-sm);
  font-weight: 600;
  letter-spacing: 0.01em;
  padding: 10px 18px;
  border-radius: var(--radius-sm);
  border: 1px solid var(--btn-border);
  background: var(--btn-bg);
  color: var(--btn-fg);
  cursor: pointer;
  transition: background var(--duration-sm) var(--ease), transform var(--duration-xs) var(--ease);
  text-decoration: none;
}
.btn:hover { background: var(--navy-800); }
.btn:active { transform: translateY(1px); }
.btn:focus-visible { outline: none; box-shadow: var(--focus-ring); }
.btn[disabled] { opacity: 0.4; cursor: not-allowed; pointer-events: none; }

.btn--ghost   { --btn-bg: transparent; --btn-fg: var(--navy-700); --btn-border: var(--slate-300); }
.btn--ghost:hover { background: var(--slate-100); }
.btn--ember   { --btn-bg: var(--ember-500); }
.btn--ember:hover { background: var(--ember-600); }
.btn--link    { --btn-bg: transparent; --btn-fg: var(--navy-700); padding: 4px 0; }
.btn--link:hover { background: transparent; border-bottom: 1px solid currentColor; }

.btn--lg { padding: 14px 24px; font-size: var(--text-body); }
.btn--sm { padding: 6px 12px; font-size: var(--text-caption); }

/* ==========================================================================
   Form fields
   ========================================================================== */

.field {
  display: block;
  width: 100%;
  font-family: var(--font-sans);
  font-size: var(--text-body);
  line-height: 1.4;
  color: var(--fg);
  background: var(--paper);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  padding: 10px 12px;
  transition: border-color var(--duration-sm) var(--ease), box-shadow var(--duration-sm) var(--ease);
}
.field:focus { outline: none; border-color: var(--navy-500); box-shadow: var(--focus-ring); }
.field::placeholder { color: var(--slate-400); }

.label {
  display: block;
  font-size: var(--text-body-sm);
  font-weight: 500;
  color: var(--slate-700);
  margin-bottom: var(--space-2);
}

/* ==========================================================================
   Badges / pills
   ========================================================================== */

.badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: var(--font-sans);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 4px 10px;
  border-radius: var(--radius-full);
  background: var(--navy-100);
  color: var(--navy-700);
  border: 1px solid var(--navy-200);
}
.badge--ember { background: var(--ember-100); color: var(--ember-700); border-color: var(--ember-200); }
.badge--slate { background: var(--slate-100); color: var(--slate-700); border-color: var(--slate-200); }
.badge--solid { background: var(--navy-700); color: var(--paper); border-color: var(--navy-700); }

/* ==========================================================================
   The "signature" section opener: eyebrow + Prata headline
   ========================================================================== */

.section-opener { max-width: var(--width-narrative); }
.section-opener .eyebrow { color: var(--ember-500); }
.section-opener h1, .section-opener .display-lg, .section-opener .display-md {
  margin-top: 8px;
}

/* ==========================================================================
   Divider — single hairline, the defense-finance aesthetic
   ========================================================================== */

.rule { height: 1px; background: var(--border); border: 0; width: 100%; }
.rule--strong { background: var(--navy-300); }
.rule--inverse { background: var(--border-inverse); }
