/* ============================================================
   Monterey Democratic Club — Site Styles
   Modern-progressive civic, adapted from Christopher Rivero
   editorial design system (kept type & rhythm; new palette).
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Inter+Tight:wght@400;500;600;700;800&family=Inter:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500&family=Newsreader:ital,wght@0,400;0,500;0,600;1,400;1,500&display=swap');

:root {
  /* ─── Palette: paper / ink / civic ───────────────────── */
  --paper:       #F4EFE6;
  --paper-2:     #ECE6D9;
  --paper-3:     #E1D9C7;
  --ink:         #0E1B2C;       /* navy-black */
  --ink-2:       #2A3A4E;
  --graphite:    #4A5568;
  --pencil:      #8A8478;
  --rule:        #D4C9B0;
  --rule-strong: #B0A48A;

  /* ─── Civic accents ──────────────────────────────────── */
  --navy:        #1B2A4E;       /* deep democratic blue */
  --cobalt:      #1F5BD6;       /* energetic blue */
  --sky:         #6FA8FF;
  --crimson:     #C8362E;       /* civic red */
  --rose:        #E8635B;
  --gold:        #D8A02C;       /* established / archival */
  --sage:        #3F6B4A;       /* progressive green */
  --plum:        #5B2A55;

  /* ─── Foreground / background tokens ─────────────────── */
  --fg-1: var(--ink);
  --fg-2: var(--graphite);
  --fg-3: var(--pencil);
  --bg-1: var(--paper);
  --bg-2: var(--paper-2);
  --bg-3: var(--paper-3);
  --accent: var(--cobalt);
  --accent-deep: var(--navy);

  /* ─── Type ───────────────────────────────────────────── */
  --font-display: "Inter Tight", -apple-system, BlinkMacSystemFont, sans-serif;
  --font-serif:   "Newsreader", Georgia, "Times New Roman", serif;
  --font-body:    "Inter", -apple-system, BlinkMacSystemFont, sans-serif;
  --font-mono:    "JetBrains Mono", ui-monospace, "SF Mono", Menlo, Consolas, monospace;

  /* ─── Spacing 8px ─────────────────────────────────── */
  --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; --sp-10: 128px;

  --r-1: 2px; --r-2: 4px; --r-3: 8px; --r-4: 12px; --r-pill: 999px;

  --dur-fast: 120ms; --dur-base: 200ms; --dur-slow: 360ms;
  --ease-out: cubic-bezier(0.2, 0.7, 0.2, 1);

  --w-prose: 680px;
  --w-content: 1120px;
  --w-canvas: 1280px;

  --shadow-1: 0 1px 2px rgba(14,27,44,0.06);
  --shadow-2: 0 6px 24px rgba(14,27,44,0.08), 0 1px 2px rgba(14,27,44,0.06);
  --shadow-3: 0 18px 48px rgba(14,27,44,0.14), 0 2px 6px rgba(14,27,44,0.08);
}

* { box-sizing: border-box; }

html, body {
  margin: 0; padding: 0;
  background: var(--bg-1);
  color: var(--fg-1);
  font-family: var(--font-body);
  font-size: 16px;
  line-height: 1.6;
  font-variant-numeric: tabular-nums oldstyle-nums;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

img, svg { display: block; max-width: 100%; }
button { font: inherit; color: inherit; cursor: pointer; }
input, textarea, select { font: inherit; color: inherit; }

/* ─── Typography ───────────────────────────────────────── */
.h-display {
  font-family: var(--font-serif);
  font-weight: 500;
  line-height: 1.0;
  letter-spacing: -0.025em;
  text-wrap: balance;
}
.h1 {
  font-family: var(--font-serif);
  font-size: clamp(48px, 7.5vw, 96px);
  font-weight: 500;
  line-height: 0.98;
  letter-spacing: -0.025em;
  color: var(--fg-1);
  margin: 0;
  text-wrap: balance;
}
.h1 em { font-style: italic; font-weight: 500; color: var(--cobalt); }

.h2 {
  font-family: var(--font-serif);
  font-size: clamp(32px, 4.5vw, 56px);
  font-weight: 500;
  line-height: 1.04;
  letter-spacing: -0.02em;
  margin: 0;
  text-wrap: balance;
}

.h3 {
  font-family: var(--font-display);
  font-size: clamp(20px, 2vw, 26px);
  font-weight: 600;
  line-height: 1.25;
  letter-spacing: -0.01em;
  margin: 0;
}

.h4 {
  font-family: var(--font-display);
  font-size: 18px;
  font-weight: 600;
  line-height: 1.3;
  margin: 0;
}

.body { font-size: 17px; line-height: 1.65; color: var(--fg-1); margin: 0; text-wrap: pretty; }
.body-sm { font-size: 15px; line-height: 1.55; color: var(--fg-2); margin: 0; }
.body-xs { font-size: 13px; line-height: 1.5; color: var(--fg-2); margin: 0; }

.eyebrow, .label {
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 500;
  line-height: 1;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--fg-2);
}

.index-num {
  font-family: var(--font-mono);
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.08em;
  color: var(--fg-3);
}

::selection { background: var(--cobalt); color: var(--paper); }

a {
  color: inherit;
  text-decoration: none;
  border-bottom: 1px solid currentColor;
  transition: color var(--dur-base) var(--ease-out), border-color var(--dur-base) var(--ease-out);
}
a:hover { color: var(--cobalt); border-color: var(--cobalt); }
a.unstyled, a.btn { border-bottom: 0; }

/* ─── Layout ───────────────────────────────────────────── */
.container { width: 100%; max-width: var(--w-content); margin: 0 auto; padding: 0 24px; }
.container-canvas { width: 100%; max-width: var(--w-canvas); margin: 0 auto; padding: 0 24px; }
.container-prose { width: 100%; max-width: var(--w-prose); margin: 0 auto; padding: 0 24px; }

.section { padding: clamp(56px, 9vw, 128px) 0; position: relative; }
.section + .section { border-top: 1px solid var(--rule); }
.section-bleed { background: var(--bg-2); }
.section-dark { background: var(--ink); color: var(--paper); }
.section-dark .body, .section-dark .body-sm { color: rgba(244,239,230,0.85); }
.section-dark .eyebrow { color: rgba(244,239,230,0.6); }
.section-dark a:hover { color: var(--sky); border-color: var(--sky); }

.section-head {
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
  margin-bottom: 56px;
  align-items: end;
}
@media (min-width: 720px) {
  .section-head { grid-template-columns: 1.4fr 1fr; gap: 48px; }
}
.section-head .lead { color: var(--fg-2); font-size: 17px; max-width: 48ch; }

.eyebrow-row {
  display: flex; align-items: center; gap: 12px;
  margin-bottom: 16px;
}
.eyebrow-row .dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--crimson);
}

/* ─── Buttons ──────────────────────────────────────────── */
.btn {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 12px 18px;
  font-family: var(--font-display);
  font-size: 15px;
  font-weight: 600;
  letter-spacing: -0.005em;
  border: 1px solid var(--ink);
  border-radius: var(--r-pill);
  background: var(--ink);
  color: var(--paper);
  text-decoration: none;
  transition: transform var(--dur-base) var(--ease-out), background var(--dur-base) var(--ease-out), color var(--dur-base) var(--ease-out), border-color var(--dur-base) var(--ease-out);
}
.btn:hover { background: var(--cobalt); border-color: var(--cobalt); color: var(--paper); }
.btn:active { transform: translateY(1px); }
.btn-ghost {
  background: transparent;
  color: var(--ink);
}
.btn-ghost:hover { background: var(--ink); color: var(--paper); }
.btn-accent {
  background: var(--cobalt);
  border-color: var(--cobalt);
}
.btn-accent:hover { background: var(--navy); border-color: var(--navy); }
.btn-crimson {
  background: var(--crimson);
  border-color: var(--crimson);
}
.btn-crimson:hover { background: #a02922; border-color: #a02922; }
.btn-sm { padding: 8px 14px; font-size: 13px; }

.btn .arrow { transition: transform var(--dur-base) var(--ease-out); }
.btn:hover .arrow { transform: translateX(3px); }

/* ─── Form controls ────────────────────────────────────── */
.field { display: grid; gap: 6px; }
.field label {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--fg-2);
}
.input, .textarea, .select {
  width: 100%;
  padding: 12px 14px;
  background: var(--paper);
  border: 1px solid var(--rule-strong);
  border-radius: var(--r-2);
  font-size: 15px;
  font-family: var(--font-body);
  color: var(--fg-1);
  transition: border-color var(--dur-base) var(--ease-out), box-shadow var(--dur-base) var(--ease-out);
}
.input:focus, .textarea:focus, .select:focus {
  outline: 0;
  border-color: var(--cobalt);
  box-shadow: 0 0 0 3px rgba(31,91,214,0.18);
}
.textarea { min-height: 110px; resize: vertical; }
.field-error { color: var(--crimson); font-size: 12px; font-family: var(--font-mono); letter-spacing: 0.06em; }
.field.invalid .input,
.field.invalid .textarea,
.field.invalid .select { border-color: var(--crimson); }

.checkbox-row { display: flex; align-items: center; gap: 10px; font-size: 14px; color: var(--fg-2); }
.checkbox-row input { accent-color: var(--cobalt); width: 16px; height: 16px; }

/* ─── Generic card ─────────────────────────────────────── */
.card {
  background: var(--paper);
  border: 1px solid var(--rule);
  border-radius: var(--r-3);
  padding: 24px;
  transition: border-color var(--dur-base) var(--ease-out), transform var(--dur-base) var(--ease-out);
}
.card:hover { border-color: var(--ink); }

/* ─── Tag / Pill ───────────────────────────────────────── */
.tag {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 4px 10px;
  background: var(--bg-3);
  border-radius: var(--r-pill);
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.08em;
  color: var(--fg-2);
}
.tag.solid {
  background: var(--ink);
  color: var(--paper);
}
.tag.cobalt { background: rgba(31,91,214,0.12); color: var(--cobalt); }
.tag.crimson { background: rgba(200,54,46,0.12); color: var(--crimson); }
.tag.gold { background: rgba(216,160,44,0.18); color: #8a6311; }
.tag.sage { background: rgba(63,107,74,0.14); color: var(--sage); }

/* ─── Misc ─────────────────────────────────────────────── */
.divider { height: 1px; background: var(--rule); border: 0; }
.muted { color: var(--fg-3); }
.serif-italic { font-family: var(--font-serif); font-style: italic; font-weight: 500; }

/* Banner stripe — civic flag bar */
.flag-stripe {
  display: flex;
  height: 6px;
  width: 100%;
}
.flag-stripe span { flex: 1; }
.flag-stripe .a { background: var(--navy); }
.flag-stripe .b { background: var(--paper); }
.flag-stripe .c { background: var(--crimson); }

/* ─── Animations ───────────────────────────────────────── */
@keyframes rise {
  from { opacity: 0; transform: translateY(12px); }
  to   { opacity: 1; transform: translateY(0); }
}
.rise { animation: rise 600ms var(--ease-out) both; }
@keyframes fadein {
  from { opacity: 0; }
  to   { opacity: 1; }
}
.fadein { animation: fadein 800ms var(--ease-out) both; }

/* Reveal on scroll */
.reveal { opacity: 1; transform: translateY(0); transition: opacity 700ms var(--ease-out), transform 700ms var(--ease-out); }
.reveal.in { opacity: 1; transform: translateY(0); }

/* Print + reduced motion */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: 0.01ms !important; transition-duration: 0.01ms !important; }
}
