/* ============================================================
   AFTER CALLAIS — design tokens
   Pastel-blue civic dashboard. Independent-analysis voice.
   Maps to deck palette but designed for screen contrast.
   ============================================================ */

:root,
[data-theme='light'] {
  /* Type scale */
  --text-xs: clamp(0.75rem, 0.7rem + 0.25vw, 0.875rem);
  --text-sm: clamp(0.875rem, 0.8rem + 0.35vw, 1rem);
  --text-base: clamp(1rem, 0.95rem + 0.25vw, 1.125rem);
  --text-lg: clamp(1.125rem, 1rem + 0.75vw, 1.5rem);
  --text-xl: clamp(1.5rem, 1.2rem + 1.25vw, 2.25rem);
  --text-2xl: clamp(2rem, 1.2rem + 2.5vw, 3.5rem);
  --text-3xl: clamp(2.5rem, 1rem + 4vw, 5rem);

  /* Spacing */
  --space-1: 0.25rem; --space-2: 0.5rem; --space-3: 0.75rem; --space-4: 1rem;
  --space-5: 1.25rem; --space-6: 1.5rem; --space-8: 2rem; --space-10: 2.5rem;
  --space-12: 3rem; --space-16: 4rem; --space-20: 5rem; --space-24: 6rem;

  /* Surfaces — pale sky blues */
  --color-bg: #F2F6FB;
  --color-surface: #FFFFFF;
  --color-surface-2: #FAFCFE;
  --color-surface-offset: #E6F0FA;
  --color-surface-offset-2: #D6E4F2;
  --color-divider: #C9DEF2;
  --color-border: #B3CCE6;

  /* Text — deep navy hierarchy */
  --color-text: #102A4C;
  --color-text-muted: #5A7591;
  --color-text-faint: #94A8BD;
  --color-text-inverse: #FAFCFE;

  /* Primary accent — true mid-blue */
  --color-primary: #3F77B0;
  --color-primary-hover: #1E4A85;
  --color-primary-active: #0F2F5C;
  --color-primary-highlight: #C9DEF2;

  /* Semantic */
  --color-d: #3F77B0;       /* Democrat blue */
  --color-d-soft: #C9DEF2;
  --color-r: #B85C5C;       /* Muted Republican red — tame, AJC-style */
  --color-r-soft: #ECCCCC;
  --color-risk: #D49B3D;    /* Warning gold */
  --color-risk-soft: #F2E2BF;

  /* Organizing layer colors (chart-only — restrained) */
  --color-priority: #6B4A9C;       /* Plum-violet for priority overlay */
  --color-priority-soft: #DCD0EA;

  /* Radii */
  --radius-sm: 0.375rem; --radius-md: 0.5rem; --radius-lg: 0.75rem;
  --radius-xl: 1rem; --radius-2xl: 1.5rem; --radius-full: 9999px;

  /* Shadows — cool, like the deck */
  --shadow-sm: 0 1px 2px rgba(15, 47, 92, 0.06);
  --shadow-md: 0 4px 14px rgba(15, 47, 92, 0.08);
  --shadow-lg: 0 12px 36px rgba(15, 47, 92, 0.12);

  --transition-interactive: 180ms cubic-bezier(0.16,1,0.3,1);

  /* Fonts */
  --font-display: 'Cabinet Grotesk', 'General Sans', system-ui, sans-serif;
  --font-body: 'General Sans', 'Inter', system-ui, sans-serif;
  --font-mono: ui-monospace, 'SF Mono', Menlo, monospace;

  --content-default: 1200px;
  --content-narrow: 760px;
}

[data-theme='dark'] {
  --color-bg: #0B1A30;
  --color-surface: #102A4C;
  --color-surface-2: #163562;
  --color-surface-offset: #1E4173;
  --color-surface-offset-2: #275088;
  --color-divider: #1E4173;
  --color-border: #2C5694;

  --color-text: #E6F0FA;
  --color-text-muted: #94B0CE;
  --color-text-faint: #5A7591;
  --color-text-inverse: #0F2F5C;

  --color-primary: #8FB7DA;
  --color-primary-hover: #C9DEF2;
  --color-primary-active: #E6F0FA;
  --color-primary-highlight: #1E4A85;

  --color-d: #8FB7DA;
  --color-d-soft: #1E4A85;
  --color-r: #D8908F;
  --color-r-soft: #5A2A2A;
  --color-risk: #E6BD63;
  --color-risk-soft: #6E551B;
  --color-priority: #A98FCC;
  --color-priority-soft: #3D2D5C;

  --shadow-sm: 0 1px 2px rgba(0,0,0,0.25);
  --shadow-md: 0 4px 14px rgba(0,0,0,0.35);
  --shadow-lg: 0 12px 36px rgba(0,0,0,0.5);
}

/* ============================================================
   LAYOUT PRIMITIVES
   ============================================================ */

.container {
  width: 100%;
  max-width: var(--content-default);
  margin-inline: auto;
  padding-inline: var(--space-6);
}

@media (min-width: 768px) {
  .container { padding-inline: var(--space-8); }
}

/* ============================================================
   HEADER
   ============================================================ */

.site-header {
  position: sticky; top: 0; z-index: 50;
  background: color-mix(in oklab, var(--color-bg) 92%, transparent);
  backdrop-filter: saturate(150%) blur(12px);
  -webkit-backdrop-filter: saturate(150%) blur(12px);
  border-bottom: 1px solid var(--color-divider);
}

.header-row {
  display: flex; align-items: center; justify-content: space-between;
  gap: var(--space-6);
  padding-block: var(--space-4);
}

.brand {
  display: flex; align-items: center; gap: var(--space-3);
  text-decoration: none; color: var(--color-text);
}
.brand-mark { color: var(--color-primary); flex: none; }
.brand-text { display: flex; flex-direction: column; line-height: 1.05; }
.brand-title {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: var(--text-lg);
  letter-spacing: -0.01em;
}
.brand-sub {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  margin-top: 2px;
}

.header-nav { display: flex; align-items: center; gap: var(--space-5); }
.header-nav a {
  color: var(--color-text-muted);
  text-decoration: none;
  font-size: var(--text-sm);
  font-weight: 500;
}
.header-nav a:hover { color: var(--color-primary); }

.theme-toggle {
  display: inline-flex; align-items: center; justify-content: center;
  width: 36px; height: 36px;
  border-radius: var(--radius-full);
  border: 1px solid var(--color-border);
  background: var(--color-surface);
  color: var(--color-text-muted);
}
.theme-toggle:hover { color: var(--color-primary); border-color: var(--color-primary); }

@media (max-width: 700px) {
  .header-nav a:not(:last-child):not(.theme-toggle) { display: none; }
  .brand-sub { display: none; }
}

/* ============================================================
   HERO
   ============================================================ */

.hero {
  padding-block: clamp(var(--space-12), 8vw, var(--space-20)) var(--space-12);
  background: linear-gradient(180deg, var(--color-bg) 0%, var(--color-surface) 100%);
  border-bottom: 1px solid var(--color-divider);
}

.hero-grid {
  display: grid;
  grid-template-columns: 1.6fr 1fr;
  gap: var(--space-12);
  align-items: end;
}
@media (max-width: 900px) {
  .hero-grid { grid-template-columns: 1fr; gap: var(--space-8); align-items: stretch; }
}

.eyebrow {
  font-size: var(--text-xs);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--color-text-muted);
  font-weight: 600;
  margin-bottom: var(--space-4);
}

.hero h1 {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: var(--text-2xl);
  letter-spacing: -0.02em;
  line-height: 1.05;
  color: var(--color-text);
  margin-bottom: var(--space-6);
}

.lede {
  font-size: var(--text-lg);
  line-height: 1.5;
  color: var(--color-text);
  max-width: 60ch;
  margin-bottom: var(--space-8);
}
.cite {
  font-style: italic;
  color: var(--color-primary-hover);
}

.hero-stats {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--space-6);
  padding-top: var(--space-6);
  border-top: 1px solid var(--color-divider);
}
.stat { display: flex; flex-direction: column; gap: var(--space-1); }
.stat-num {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: clamp(2rem, 1rem + 3vw, 3rem);
  color: var(--color-primary-active);
  font-variant-numeric: tabular-nums lining-nums;
  line-height: 1;
}
.stat-label {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  letter-spacing: 0.02em;
  line-height: 1.3;
  max-width: 22ch;
}

.hero-aside {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-left: 4px solid var(--color-primary);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  box-shadow: var(--shadow-sm);
  height: fit-content;
}
.hero-aside h3 {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  margin-bottom: var(--space-3);
  color: var(--color-text);
}
.hero-aside p {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  margin-bottom: var(--space-4);
}
.bill-status {
  display: flex; align-items: center; gap: var(--space-3);
  padding-top: var(--space-3);
  border-top: 1px solid var(--color-divider);
}
.status-pill {
  display: inline-flex; align-items: center;
  background: var(--color-surface-offset);
  color: var(--color-primary-hover);
  padding: var(--space-1) var(--space-3);
  border-radius: var(--radius-full);
  font-size: var(--text-xs);
  font-weight: 600;
  letter-spacing: 0.04em;
}
.status-meta { font-size: var(--text-xs); color: var(--color-text-muted); }

/* ============================================================
   SECTION HEAD
   ============================================================ */

.section-head { max-width: 760px; margin-bottom: var(--space-10); }
.section-head h2 {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: var(--text-xl);
  letter-spacing: -0.015em;
  margin-bottom: var(--space-3);
  color: var(--color-text);
}
.section-sub {
  font-size: var(--text-base);
  color: var(--color-text-muted);
  max-width: 65ch;
}

/* ============================================================
   SCENARIOS
   ============================================================ */

.scenarios {
  padding-block: clamp(var(--space-12), 6vw, var(--space-16));
  background: var(--color-surface);
}

.scenario-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: var(--space-4);
  margin-bottom: var(--space-8);
}
@media (max-width: 900px) { .scenario-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px) { .scenario-grid { grid-template-columns: 1fr; } }

.scenario-btn {
  text-align: left;
  background: var(--color-surface-2);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-5);
  display: flex; flex-direction: column; gap: var(--space-2);
  cursor: pointer;
  transition: all var(--transition-interactive);
  position: relative;
}
.scenario-btn:hover { border-color: var(--color-primary); transform: translateY(-2px); box-shadow: var(--shadow-md); }
.scenario-btn[aria-selected="true"] {
  border-color: var(--color-primary);
  background: linear-gradient(180deg, var(--color-surface) 0%, var(--color-surface-offset) 100%);
  box-shadow: 0 0 0 3px var(--color-primary-highlight), var(--shadow-md);
}
.scenario-btn .label-name {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: var(--text-base);
  color: var(--color-text);
}
.scenario-btn .label-sub {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  letter-spacing: 0.04em;
}
.scenario-btn .seat-mini {
  display: flex; align-items: center; gap: var(--space-2);
  margin-top: var(--space-2);
}
.seat-mini-bar {
  display: flex; height: 8px; width: 100%;
  border-radius: var(--radius-full);
  overflow: hidden;
  background: var(--color-divider);
}
.seat-mini-bar > span { display: block; height: 100%; }
.seat-mini-bar .mb-d { background: var(--color-d); }
.seat-mini-bar .mb-r { background: var(--color-r); }
.seat-mini-counts {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
}

.scenario-detail {
  background: var(--color-surface-offset);
  border: 1px solid var(--color-divider);
  border-radius: var(--radius-xl);
  padding: var(--space-6) var(--space-8);
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-8);
}
@media (max-width: 800px) { .scenario-detail { grid-template-columns: 1fr; } }
.scenario-detail h3 {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  color: var(--color-text);
  margin-bottom: var(--space-3);
}
.scenario-detail p {
  font-size: var(--text-sm);
  color: var(--color-text);
  line-height: 1.6;
  margin-bottom: var(--space-3);
}
.scenario-detail .mini-stats {
  display: flex; gap: var(--space-6);
  padding-top: var(--space-4);
  border-top: 1px solid var(--color-divider);
}
.mini-stat-num { font-family: var(--font-display); font-weight: 600; font-size: var(--text-lg); color: var(--color-primary-active); font-variant-numeric: tabular-nums; }
.mini-stat-label { font-size: var(--text-xs); color: var(--color-text-muted); letter-spacing: 0.04em; text-transform: uppercase; }

/* ============================================================
   MAP
   ============================================================ */

.map-section {
  padding-block: clamp(var(--space-12), 6vw, var(--space-16));
  background: var(--color-bg);
}

.map-controls {
  display: flex; flex-wrap: wrap; gap: var(--space-6);
  align-items: center; justify-content: space-between;
  margin-bottom: var(--space-6);
  padding: var(--space-4) var(--space-5);
  background: var(--color-surface);
  border: 1px solid var(--color-divider);
  border-radius: var(--radius-lg);
}
.layer-group { display: flex; align-items: center; flex-wrap: wrap; gap: var(--space-3); }
.layer-label { font-size: var(--text-xs); font-weight: 600; color: var(--color-text-muted); letter-spacing: 0.08em; text-transform: uppercase; margin-right: var(--space-2); }
.layer-toggle { cursor: pointer; }
.layer-toggle input { position: absolute; opacity: 0; pointer-events: none; }
.layer-pill {
  display: inline-flex; align-items: center; gap: var(--space-2);
  padding: var(--space-2) var(--space-4);
  border-radius: var(--radius-full);
  border: 1px solid var(--color-border);
  background: var(--color-surface-2);
  color: var(--color-text-muted);
  font-size: var(--text-sm);
  font-weight: 500;
  transition: all var(--transition-interactive);
}
.layer-toggle input:checked + .layer-pill {
  background: var(--color-primary-highlight);
  border-color: var(--color-primary);
  color: var(--color-primary-active);
}
.layer-toggle input:focus-visible + .layer-pill {
  outline: 2px solid var(--color-primary);
  outline-offset: 2px;
}
.layer-swatch { width: 12px; height: 12px; border-radius: 3px; }
.swatch-black { background: var(--color-priority); }
.swatch-turnout { background: var(--color-risk); }

.map-legend { display: flex; gap: var(--space-4); align-items: center; flex-wrap: wrap; }
.legend-item { display: inline-flex; align-items: center; gap: var(--space-2); font-size: var(--text-xs); color: var(--color-text-muted); font-weight: 500; }
.legend-dot { width: 12px; height: 12px; border-radius: 3px; }
.dot-d { background: var(--color-d); }
.dot-r { background: var(--color-r); }
.dot-risk { background: var(--color-risk); }

.map-frame {
  display: grid;
  grid-template-columns: 1fr 320px;
  gap: var(--space-6);
}
@media (max-width: 900px) { .map-frame { grid-template-columns: 1fr; } }

.map-wrap {
  background: var(--color-surface);
  border: 1px solid var(--color-divider);
  border-radius: var(--radius-xl);
  padding: var(--space-4);
  position: relative;
  overflow: hidden;
}
#ga-map { width: 100%; height: auto; }

/* District paths */
.district-path {
  fill: var(--color-d-soft);
  stroke: var(--color-surface);
  stroke-width: 1.4;
  cursor: pointer;
  transition: filter 180ms cubic-bezier(0.16,1,0.3,1), opacity 180ms cubic-bezier(0.16,1,0.3,1);
}
.district-path.party-D { fill: var(--color-d-soft); }
.district-path.party-R { fill: var(--color-r-soft); }
.district-path.party-D.solid { fill: var(--color-d); }
.district-path.party-R.solid { fill: var(--color-r); }
.district-path.at-risk { stroke: var(--color-risk); stroke-width: 3; stroke-dasharray: 6 4; }
.district-path:hover { filter: brightness(1.05) saturate(1.1); }
.district-path.dim { opacity: 0.35; }

/* County overlays */
.county-path {
  fill: transparent;
  stroke: rgba(15,47,92,0.08);
  stroke-width: 0.4;
  pointer-events: none;
  transition: fill 180ms cubic-bezier(0.16,1,0.3,1);
}
.county-path.layer-black-on { fill: color-mix(in oklab, var(--color-priority) 0%, transparent); }
.county-path.layer-turnout-on { fill: color-mix(in oklab, var(--color-risk) 0%, transparent); }

/* District labels */
.district-label {
  font-family: var(--font-body);
  font-size: 12px;
  font-weight: 600;
  fill: var(--color-text);
  pointer-events: none;
  text-anchor: middle;
  paint-order: stroke;
  stroke: var(--color-surface);
  stroke-width: 3;
  stroke-linejoin: round;
}

/* Map sidebar */
.map-sidebar { display: flex; flex-direction: column; gap: var(--space-4); }

.seat-summary {
  background: var(--color-surface);
  border: 1px solid var(--color-divider);
  border-radius: var(--radius-lg);
  padding: var(--space-5);
}
.seat-summary-title {
  font-size: var(--text-xs); font-weight: 600;
  color: var(--color-text-muted); letter-spacing: 0.08em;
  text-transform: uppercase;
  margin-bottom: var(--space-3);
}
.seat-bar {
  display: flex; height: 36px;
  border-radius: var(--radius-md);
  overflow: hidden;
  background: var(--color-divider);
  margin-bottom: var(--space-3);
}
.seat-bar > span {
  display: flex; align-items: center; justify-content: center;
  font-size: var(--text-sm); font-weight: 600;
  color: var(--color-text-inverse);
  transition: width 380ms cubic-bezier(0.16,1,0.3,1);
}
.bar-d { background: var(--color-d); }
.bar-r { background: var(--color-r); }
.seat-delta-line { font-size: var(--text-xs); color: var(--color-text-muted); }
.seat-delta { font-weight: 600; }
.seat-delta.gain-r { color: var(--color-r); }
.seat-delta.gain-d { color: var(--color-d); }

.info-panel {
  background: var(--color-surface);
  border: 1px solid var(--color-divider);
  border-radius: var(--radius-lg);
  padding: var(--space-5);
  min-height: 180px;
}
.info-empty { font-size: var(--text-sm); color: var(--color-text-muted); }
.info-panel .info-label {
  font-size: var(--text-xs); color: var(--color-text-muted);
  text-transform: uppercase; letter-spacing: 0.08em; font-weight: 600;
}
.info-panel .info-name {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: var(--text-lg);
  color: var(--color-text);
  margin-block: var(--space-1) var(--space-2);
}
.info-panel .info-rep { font-size: var(--text-sm); color: var(--color-text); }
.info-panel .info-row { display: flex; justify-content: space-between; padding-block: var(--space-2); border-bottom: 1px solid var(--color-divider); font-size: var(--text-sm); }
.info-panel .info-row:last-child { border: none; }
.info-panel .info-row strong { color: var(--color-text); font-weight: 600; }
.info-panel .info-row span { color: var(--color-text-muted); }
.info-panel .info-risk-tag {
  display: inline-block;
  margin-top: var(--space-3);
  padding: var(--space-1) var(--space-3);
  border-radius: var(--radius-full);
  background: var(--color-risk-soft);
  color: #6E551B;
  font-size: var(--text-xs);
  font-weight: 600;
  letter-spacing: 0.04em;
}

[data-theme='dark'] .info-panel .info-risk-tag {
  color: var(--color-risk);
}

.map-scenario-name { color: var(--color-primary); font-style: italic; font-family: var(--font-display); }

/* ============================================================
   PRIORITY TABLE
   ============================================================ */

.priorities {
  padding-block: clamp(var(--space-12), 6vw, var(--space-16));
  background: var(--color-surface);
}
.priority-table-wrap {
  background: var(--color-surface-2);
  border: 1px solid var(--color-divider);
  border-radius: var(--radius-xl);
  overflow-x: auto;
}
.priority-table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--text-sm);
  min-width: 720px;
}
.priority-table th {
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-weight: 600;
  color: var(--color-text-muted);
  text-align: left;
  padding: var(--space-4) var(--space-5);
  border-bottom: 1px solid var(--color-divider);
}
.priority-table th.num, .priority-table td.num { text-align: right; font-variant-numeric: tabular-nums; }
.priority-table td {
  padding: var(--space-4) var(--space-5);
  border-bottom: 1px solid var(--color-divider);
  color: var(--color-text);
  vertical-align: middle;
}
.priority-table tr:last-child td { border: none; }
.priority-table tr:hover td { background: var(--color-surface-offset); }
.priority-table .rank {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: var(--text-base);
  color: var(--color-primary);
  width: 50px;
}
.priority-table .county-name { font-weight: 600; }
.priority-bar {
  display: inline-flex; align-items: center; gap: var(--space-2); width: 100%;
  font-variant-numeric: tabular-nums;
}
.priority-bar-track {
  flex: 1;
  height: 8px;
  background: var(--color-divider);
  border-radius: var(--radius-full);
  overflow: hidden;
  max-width: 120px;
}
.priority-bar-fill {
  display: block; height: 100%; background: var(--color-priority);
  border-radius: var(--radius-full);
}
.flag-row { display: flex; flex-wrap: wrap; gap: var(--space-1); }
.flag {
  display: inline-block;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.04em;
  padding: 2px 8px;
  border-radius: var(--radius-full);
  background: var(--color-surface-offset);
  color: var(--color-text-muted);
}
.flag.flag-mb { background: var(--color-priority-soft); color: #4A2D6E; }
.flag.flag-low { background: var(--color-risk-soft); color: #6E551B; }
.flag.flag-anchor { background: var(--color-d-soft); color: var(--color-primary-active); }

[data-theme='dark'] .flag.flag-mb { color: #C9B0E0; }
[data-theme='dark'] .flag.flag-low { color: var(--color-risk); }
[data-theme='dark'] .flag.flag-anchor { color: var(--color-d); }

/* ============================================================
   ACT
   ============================================================ */

.act {
  padding-block: clamp(var(--space-12), 6vw, var(--space-16));
  background: var(--color-bg);
}
.act-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--space-5);
}
@media (max-width: 800px) { .act-grid { grid-template-columns: 1fr; } }
.act-card {
  background: var(--color-surface);
  border: 1px solid var(--color-divider);
  border-top: 4px solid var(--color-primary);
  border-radius: var(--radius-xl);
  padding: var(--space-6);
  display: flex; flex-direction: column; gap: var(--space-3);
  transition: transform var(--transition-interactive), box-shadow var(--transition-interactive);
}
.act-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-md); }
.act-num {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: var(--text-lg);
  color: var(--color-primary);
  letter-spacing: 0.02em;
}
.act-card h3 {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  color: var(--color-text);
}
.act-card p { font-size: var(--text-sm); color: var(--color-text-muted); }
.act-links { display: flex; flex-direction: column; gap: var(--space-1); margin-top: auto; padding-top: var(--space-3); border-top: 1px solid var(--color-divider); }
.act-links li { list-style: none; }
.act-links a {
  font-size: var(--text-sm); color: var(--color-primary); text-decoration: none; font-weight: 500;
  display: inline-flex; align-items: center; gap: var(--space-1);
}
.act-links a::after {
  content: "→"; transition: transform var(--transition-interactive);
}
.act-links a:hover { color: var(--color-primary-hover); }
.act-links a:hover::after { transform: translateX(3px); }

/* ============================================================
   FOOTER
   ============================================================ */

.site-footer {
  padding-block: var(--space-12);
  background: var(--color-surface);
  border-top: 1px solid var(--color-divider);
}
.footer-grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr;
  gap: var(--space-8);
}
@media (max-width: 800px) { .footer-grid { grid-template-columns: 1fr; gap: var(--space-6); } }
.footer-brand {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: var(--text-base);
  color: var(--color-text);
  margin-bottom: var(--space-2);
}
.footer-note { font-size: var(--text-xs); color: var(--color-text-muted); line-height: 1.6; }
.footer-meta p strong { font-size: var(--text-xs); text-transform: uppercase; letter-spacing: 0.08em; color: var(--color-text); margin-bottom: var(--space-2); display: block; }
.footer-meta ul { padding: 0; }
.footer-meta li { font-size: var(--text-xs); color: var(--color-text-muted); padding-block: 2px; list-style: none; }

/* ============================================================
   SOUTHERN-EXPANSION COMPONENTS (May 2026)
   ============================================================ */

/* Hero — 4-stat grid */
.hero-stats-4 {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}
@media (max-width: 800px) {
  .hero-stats-4 { grid-template-columns: repeat(2, 1fr); }
}
.aside-source {
  font-size: var(--text-xs);
  color: var(--color-text-faint);
  margin-bottom: 0;
  padding-top: var(--space-3);
  border-top: 1px solid var(--color-divider);
  letter-spacing: 0.02em;
}

/* Regional state map */
.state-shape {
  cursor: pointer;
  transition: fill var(--transition-interactive),
              stroke var(--transition-interactive),
              stroke-width var(--transition-interactive);
}
.state-shape:focus-visible {
  outline: 2px solid var(--color-primary);
  outline-offset: 2px;
}
.state-label {
  font-family: var(--font-display);
  font-size: 11px;
  font-weight: 600;
  fill: var(--color-text);
  paint-order: stroke;
  stroke: var(--color-bg);
  stroke-width: 3px;
  pointer-events: none;
  letter-spacing: 0.04em;
}

/* Map legend gradient */
.legend-scale {
  display: inline-flex; align-items: center; gap: var(--space-2);
}
.legend-grad {
  display: inline-block;
  width: 140px; height: 10px;
  border-radius: var(--radius-full);
  border: 1px solid var(--color-divider);
}
.legend-min, .legend-max {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

/* State detail card */
.state-card {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  box-shadow: var(--shadow-sm);
  display: flex; flex-direction: column;
  gap: var(--space-5);
}
.state-card .info-empty {
  color: var(--color-text-muted);
  font-size: var(--text-sm);
  margin: 0;
}
.state-card-head h3 {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: var(--text-lg);
  color: var(--color-text);
  margin-bottom: var(--space-2);
}
.state-card-summary {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  line-height: 1.55;
  margin: 0;
}

/* Metric blocks inside state-card */
.metric-block {
  border-top: 1px solid var(--color-divider);
  padding-top: var(--space-4);
  display: flex; flex-direction: column;
  gap: var(--space-2);
}
.metric-eyebrow {
  font-size: var(--text-xs);
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--color-primary-hover);
  margin: 0 0 var(--space-1);
}
.metric-caption {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  line-height: 1.5;
  margin: 0;
}
.metric-caption strong {
  color: var(--color-text);
  font-weight: 600;
}
.metric-meta {
  border-top: 1px solid var(--color-divider);
  padding-top: var(--space-3);
  font-style: normal;
}

/* Lege grid (Senate / House majority-minority) */
.lege-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-4);
  padding-block: var(--space-2);
}
.lege-label {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  margin: 0 0 var(--space-1);
  letter-spacing: 0.02em;
}
.lege-figure {
  display: flex; align-items: baseline; gap: var(--space-2);
  font-family: var(--font-display);
  font-variant-numeric: tabular-nums lining-nums;
  margin: 0;
}
.figure-now {
  font-size: var(--text-lg);
  font-weight: 600;
  color: var(--color-text);
}
.figure-arrow {
  color: var(--color-text-faint);
  font-size: var(--text-sm);
}
.figure-new {
  font-size: var(--text-lg);
  font-weight: 700;
  color: var(--color-priority);
}

/* Impact table — extends .priority-table */
.impact-table tr { transition: background var(--transition-interactive); }
.impact-table .state-cell { font-weight: 600; color: var(--color-text); }
.loss-pill {
  display: inline-flex; align-items: center;
  padding: 2px var(--space-2);
  border-radius: var(--radius-full);
  font-variant-numeric: tabular-nums;
  font-weight: 600;
  font-size: var(--text-xs);
  min-width: 32px;
  justify-content: center;
}
.loss-low {
  background: var(--color-surface-offset);
  color: var(--color-text-muted);
}
.loss-mid {
  background: var(--color-risk-soft);
  color: #6F4F1A;
}
.loss-high {
  background: var(--color-priority-soft);
  color: var(--color-priority);
}
[data-theme='dark'] .loss-mid { color: #E6BD63; }
[data-theme='dark'] .loss-high { color: #C9B6E6; }

/* Georgia deep-dive grid */
.ga-deep-grid {
  display: grid;
  grid-template-columns: 360px 1fr;
  gap: var(--space-8);
  margin-bottom: var(--space-8);
}
@media (max-width: 980px) {
  .ga-deep-grid { grid-template-columns: 1fr; gap: var(--space-6); }
}
.ga-deep-bills {
  display: flex; flex-direction: column;
  gap: var(--space-4);
}
.bill-card {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-left: 4px solid var(--color-priority);
  border-radius: var(--radius-lg);
  padding: var(--space-5);
  box-shadow: var(--shadow-sm);
}
.bill-card h3 {
  font-family: var(--font-display);
  font-size: var(--text-base);
  font-weight: 600;
  color: var(--color-text);
  margin-bottom: var(--space-2);
  line-height: 1.3;
}
.bill-card p {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  line-height: 1.55;
  margin: 0;
}

/* Make the GA scenario-grid fit the second column */
.ga-deep-grid .scenario-grid {
  grid-template-columns: repeat(2, 1fr);
}
@media (max-width: 600px) {
  .ga-deep-grid .scenario-grid { grid-template-columns: 1fr; }
}

/* ============================================================
   STATE-CARD SCENARIO TABS
   ============================================================ */
.scen-tabs {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 6px;
  margin-block: var(--space-2);
}
.scen-tab {
  font-family: var(--font-display);
  background: var(--color-surface);
  border: 1px solid var(--color-divider);
  border-radius: var(--radius-md);
  padding: var(--space-2) var(--space-3);
  text-align: left;
  cursor: pointer;
  display: flex; flex-direction: column; gap: 2px;
  font-size: var(--text-xs);
  transition: all var(--transition-interactive);
  color: var(--color-text);
}
.scen-tab:hover { border-color: var(--color-primary); background: var(--color-surface-2); }
.scen-tab[aria-selected="true"] {
  border-color: var(--color-priority);
  background: var(--color-priority-soft);
  box-shadow: inset 0 0 0 1px var(--color-priority);
}
.scen-tab-name { font-weight: 600; line-height: 1.2; }
.scen-tab-tag {
  font-family: var(--font-body);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--color-text-muted);
}
.scen-tab[aria-selected="true"] .scen-tab-tag { color: var(--color-priority); }
.scen-tab-aggressive[aria-selected="true"] {
  border-color: var(--color-r);
  background: var(--color-r-soft);
  box-shadow: inset 0 0 0 1px var(--color-r);
}
.scen-tab-aggressive[aria-selected="true"] .scen-tab-tag { color: var(--color-r); }
.scen-tab-protective[aria-selected="true"] {
  border-color: var(--color-d);
  background: var(--color-d-soft);
  box-shadow: inset 0 0 0 1px var(--color-d);
}
.scen-tab-protective[aria-selected="true"] .scen-tab-tag { color: var(--color-d); }

.scen-detail {
  background: var(--color-surface-2);
  border: 1px solid var(--color-divider);
  border-radius: var(--radius-md);
  padding: var(--space-3) var(--space-4);
  margin-top: var(--space-2);
  display: flex; flex-direction: column; gap: var(--space-3);
}
.scen-summary {
  font-size: var(--text-sm);
  line-height: 1.55;
  color: var(--color-text);
  margin: 0;
}
.scen-stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-2);
  border-top: 1px solid var(--color-divider);
  padding-top: var(--space-2);
}
.scen-stat { display: flex; flex-direction: column; gap: 2px; }
.scen-stat-eyebrow {
  font-size: 10px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--color-text-muted);
}
.scen-stat-val {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: var(--text-base);
  color: var(--color-text);
  font-variant-numeric: tabular-nums lining-nums;
}
.scen-note {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  font-style: normal;
  border-left: 3px solid var(--color-priority);
  padding-left: var(--space-3);
  margin: 0;
  line-height: 1.5;
}

/* ============================================================
   GA SENATE STRATEGIC OVERLAY
   ============================================================ */
.senate-section {
  padding-block: var(--space-12);
  background: var(--color-surface-2);
  border-top: 1px solid var(--color-divider);
}
.senate-controls {
  display: flex; flex-wrap: wrap; align-items: center;
  gap: var(--space-3);
  margin-block: var(--space-6);
}
.senate-layer-group {
  display: flex; flex-wrap: wrap; gap: var(--space-2);
}
.layer-swatch.swatch-vuln { background: linear-gradient(90deg, #F0F4FA, #B85C5C); }
.layer-swatch.swatch-margin { background: linear-gradient(90deg, #B85C5C, #FFFFFF, #3F77B0); }
.layer-swatch.swatch-aapi { background: linear-gradient(90deg, #FAFCFE, #1F6E5C); }
.layer-swatch.swatch-latino { background: linear-gradient(90deg, #FAFCFE, #C46A1F); }

.senate-frame {
  display: grid;
  grid-template-columns: 1fr 360px;
  gap: var(--space-6);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-5);
  box-shadow: var(--shadow-sm);
}
@media (max-width: 980px) {
  .senate-frame { grid-template-columns: 1fr; }
}
.senate-map-wrap {
  display: flex; flex-direction: column; gap: var(--space-2);
  min-width: 0;
}
#senate-map {
  width: 100%; height: auto;
  background: transparent;
  display: block;
}
.sd-shape {
  cursor: pointer;
  transition: fill var(--transition-interactive),
              stroke var(--transition-interactive),
              stroke-width var(--transition-interactive);
}
.sd-shape:focus-visible {
  outline: 2px solid var(--color-primary);
  outline-offset: 2px;
}

.senate-legend {
  display: flex; align-items: center; gap: var(--space-2);
  flex-wrap: wrap;
  font-size: var(--text-xs);
  color: var(--color-text-muted);
}
.legend-grad-wide {
  width: 220px; height: 10px;
  border-radius: var(--radius-full);
  border: 1px solid var(--color-divider);
  display: inline-block;
}
.legend-caption {
  margin-left: auto;
  font-style: normal;
  letter-spacing: 0.04em;
  color: var(--color-text-muted);
  text-transform: uppercase;
  font-weight: 500;
  font-size: 10px;
}

/* SD detail card */
.sd-card {
  background: var(--color-surface-2);
  border: 1px solid var(--color-divider);
  border-radius: var(--radius-md);
  padding: var(--space-5);
  display: flex; flex-direction: column; gap: var(--space-4);
}
.sd-card .info-empty {
  color: var(--color-text-muted);
  font-size: var(--text-sm);
  margin: 0;
}
.sd-card-head {
  display: flex; flex-direction: column; gap: var(--space-1);
  border-bottom: 1px solid var(--color-divider);
  padding-bottom: var(--space-3);
}
.sd-eyebrow {
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--color-text-muted);
  margin: 0;
}
.sd-card-head h3 {
  font-family: var(--font-display);
  font-size: var(--text-base);
  font-weight: 600;
  color: var(--color-text);
  margin: 0;
}

.vuln-pill {
  display: inline-block;
  align-self: flex-start;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  padding: 2px 8px;
  border-radius: var(--radius-full);
  background: var(--color-surface-offset);
  color: var(--color-text-muted);
}
.vuln-pill.vuln-1 { background: #EDF2F8; color: var(--color-text-muted); }
.vuln-pill.vuln-2 { background: #E1E8F0; color: #3F77B0; }
.vuln-pill.vuln-3 { background: #F2E1C5; color: #6F4F1A; }
.vuln-pill.vuln-4 { background: #F1D5D5; color: #8B3838; }
.vuln-pill.vuln-5 { background: #B85C5C; color: #FFFFFF; }

.sd-metrics {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-3);
}
.sd-metric { display: flex; flex-direction: column; gap: 2px; }
.sd-metric-eyebrow {
  font-size: 10px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--color-text-muted);
}
.sd-metric-val {
  font-family: var(--font-display);
  font-size: var(--text-base);
  font-weight: 600;
  color: var(--color-text);
  font-variant-numeric: tabular-nums lining-nums;
}

.sd-demo {
  display: flex; flex-direction: column; gap: var(--space-2);
  border-top: 1px solid var(--color-divider);
  padding-top: var(--space-3);
}
.sd-demo-eyebrow {
  font-size: 10px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--color-text-muted);
  margin: 0;
}
.sd-demo-bar {
  display: flex;
  height: 14px;
  border-radius: var(--radius-full);
  overflow: hidden;
  border: 1px solid var(--color-divider);
}
.sd-demo-bar > span { display: block; height: 100%; }
.dm-black { background: #3D2A6B; }
.dm-aapi { background: #1F6E5C; }
.dm-latino { background: #C46A1F; }
.dm-other { background: #E6F0FA; }

.sd-demo-list {
  list-style: none; padding: 0; margin: 0;
  display: grid; grid-template-columns: 1fr 1fr 1fr;
  gap: var(--space-1);
  font-size: var(--text-xs);
  color: var(--color-text-muted);
}
.sd-demo-list li {
  display: flex; align-items: center; gap: 6px;
}
.sd-demo-list strong {
  color: var(--color-text);
  font-weight: 600;
  font-variant-numeric: tabular-nums;
}
.sw {
  display: inline-block;
  width: 10px; height: 10px;
  border-radius: 2px;
  flex-shrink: 0;
}
.sw-black { background: #3D2A6B; }
.sw-aapi { background: #1F6E5C; }
.sw-latino { background: #C46A1F; }

.sd-note {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  border-left: 3px solid var(--color-primary);
  padding-left: var(--space-3);
  line-height: 1.5;
  margin: 0;
}

/* Top organizing priorities */
.senate-priority {
  margin-top: var(--space-8);
}
.senate-priority-title {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-weight: 600;
  color: var(--color-text);
  margin-bottom: var(--space-2);
}
.senate-priority-sub { margin-bottom: var(--space-5); }
.senate-priority-list {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: var(--space-4);
}
.priority-card {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: var(--space-4);
  display: flex; flex-direction: column; gap: var(--space-2);
  box-shadow: var(--shadow-sm);
}
.priority-card.vuln-5 { border-left: 4px solid #B85C5C; }
.priority-card.vuln-4 { border-left: 4px solid #C46A1F; }
.priority-card.vuln-3 { border-left: 4px solid var(--color-risk); }
.priority-card.vuln-2 { border-left: 4px solid var(--color-primary); }
.priority-card-head {
  display: flex; align-items: center; justify-content: space-between;
  gap: var(--space-2);
}
.priority-sd {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: var(--text-sm);
  letter-spacing: 0.04em;
  color: var(--color-text);
}
.priority-incumbent {
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--color-text);
  margin: 0;
}
.priority-margin {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  font-variant-numeric: tabular-nums;
  margin: 0;
}
.priority-demo {
  display: flex; align-items: center; gap: 6px;
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  font-variant-numeric: tabular-nums;
}
.priority-demo .sw { margin-right: 2px; }
.priority-note {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  line-height: 1.5;
  margin: 0;
  padding-top: var(--space-2);
  border-top: 1px dashed var(--color-divider);
}

/* ============================================================
   COUNTY OUTLINES — atlas/AJC style hairlines
   ============================================================ */
/* Regional Southern map: thin, low-contrast lines drawn over fills */
.county-outline {
  stroke: rgba(15, 47, 92, 0.18);
  stroke-width: 0.35;
  stroke-linejoin: round;
  pointer-events: none;
  vector-effect: non-scaling-stroke;
}
[data-theme='dark'] .county-outline {
  stroke: rgba(255, 255, 255, 0.18);
}

/* GA Senate map: even lighter so SD borders stay primary */
.county-outline-light {
  stroke: rgba(15, 47, 92, 0.12);
  stroke-width: 0.3;
  stroke-linejoin: round;
  pointer-events: none;
  vector-effect: non-scaling-stroke;
}
[data-theme='dark'] .county-outline-light {
  stroke: rgba(255, 255, 255, 0.14);
}

/* SD borders are styled directly via JS attr to keep them visually above county hairlines */

/* ============================================================
   GA REDRAW (TOP SECTION)
   ============================================================ */

.ga-redraw {
  padding-block: clamp(var(--space-12), 6vw, var(--space-16));
  background: var(--color-surface);
  border-bottom: 1px solid var(--color-divider);
}
.ga-redraw .section-head { max-width: 820px; margin-bottom: var(--space-8); }
.ga-redraw-accent { color: var(--color-primary); }

.ga-redraw-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--space-5);
  margin-bottom: var(--space-10);
}
@media (max-width: 800px) { .ga-redraw-grid { grid-template-columns: 1fr; } }

.ga-redraw-card {
  background: var(--color-surface-2);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  box-shadow: var(--shadow-md);
  transition: transform var(--transition-interactive), box-shadow var(--transition-interactive);
}
.ga-redraw-card:hover { transform: translateY(-2px); box-shadow: var(--shadow-lg, 0 8px 24px rgba(15, 47, 92, 0.10)); }

.ga-redraw-card-primary {
  background: linear-gradient(180deg, var(--color-surface) 0%, var(--color-surface-offset) 100%);
  border-color: var(--color-primary);
  border-width: 2px;
}

.ga-redraw-card-head {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}
.ga-redraw-card-head h3 {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: var(--text-lg);
  line-height: 1.2;
  color: var(--color-text);
  margin: 0;
}

.ga-redraw-pill {
  display: inline-block;
  padding: 4px 10px;
  border-radius: var(--radius-full);
  font-size: var(--text-xs);
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  width: fit-content;
}
.ga-redraw-pill-high { background: var(--color-r-soft); color: #6B2E2E; }
.ga-redraw-pill-med  { background: var(--color-risk-soft); color: #6B4A1A; }
.ga-redraw-pill-low  { background: var(--color-surface-offset-2); color: var(--color-text); }

.ga-redraw-body {
  font-size: var(--text-base);
  line-height: 1.55;
  color: var(--color-text);
  margin: 0;
}

.ga-redraw-meta {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  margin: 0;
  padding-top: var(--space-3);
  border-top: 1px solid var(--color-divider);
}
.ga-redraw-meta > div {
  display: grid;
  grid-template-columns: 12ch 1fr;
  gap: var(--space-3);
  font-size: var(--text-sm);
  line-height: 1.4;
}
.ga-redraw-meta dt {
  color: var(--color-text-muted);
  font-weight: 600;
  letter-spacing: 0.02em;
}
.ga-redraw-meta dd {
  margin: 0;
  color: var(--color-text);
}

/* ----- Rules block ----- */

.ga-redraw-rules {
  background: var(--color-surface-offset);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: clamp(var(--space-6), 3vw, var(--space-10));
}

.ga-redraw-rules-head {
  max-width: 780px;
  margin-bottom: var(--space-8);
}
.ga-redraw-rules-head h3 {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: var(--text-xl);
  line-height: 1.15;
  color: var(--color-text);
  margin: 0 0 var(--space-3) 0;
}
.ga-redraw-rules-sub {
  font-size: var(--text-base);
  color: var(--color-text);
  line-height: 1.55;
  margin: 0;
}

.eyebrow-on-tint {
  color: var(--color-primary-hover);
}

.ga-rules-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--space-4);
}
@media (max-width: 1000px) { .ga-rules-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .ga-rules-grid { grid-template-columns: 1fr; } }

.ga-rule-card {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: var(--space-5);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}
.ga-rule-card h4 {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: var(--text-base);
  line-height: 1.25;
  color: var(--color-text);
  margin: 0;
}
.ga-rule-card p {
  font-size: var(--text-sm);
  line-height: 1.5;
  color: var(--color-text);
  margin: 0;
}
.ga-rule-card-cta {
  background: linear-gradient(180deg, var(--color-surface) 0%, var(--color-primary-highlight) 100%);
  border-color: var(--color-primary);
  border-width: 2px;
}

.ga-rule-tag {
  display: inline-block;
  padding: 3px 8px;
  border-radius: var(--radius-sm, 4px);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  background: var(--color-surface-offset-2);
  color: var(--color-primary-hover);
  width: fit-content;
}

.ga-rule-cite {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  letter-spacing: 0.02em;
  margin-top: auto;
  padding-top: var(--space-2);
  border-top: 1px dashed var(--color-divider);
}

.ga-rule-case {
  font-weight: 600;
  color: var(--color-primary-hover);
}
.ga-rule-emph {
  font-weight: 700;
  color: var(--color-r);
}

/* ---- Hero callout banner pointing to GA Redraw section ---- */

.hero-callout {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: var(--space-5);
  margin-top: var(--space-8);
  padding: var(--space-4) var(--space-5);
  background: linear-gradient(90deg, var(--color-surface-offset) 0%, var(--color-surface-offset-2) 100%);
  border: 1px solid var(--color-primary);
  border-radius: var(--radius-md);
  color: var(--color-text);
  text-decoration: none;
  transition: transform var(--transition-interactive), box-shadow var(--transition-interactive);
}
.hero-callout:hover {
  transform: translateY(-1px);
  box-shadow: var(--shadow-md);
}
.hero-callout-tag {
  display: inline-block;
  padding: 4px 10px;
  border-radius: var(--radius-full);
  background: var(--color-primary);
  color: var(--color-text-inverse);
  font-size: var(--text-xs);
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  white-space: nowrap;
}
.hero-callout-body {
  font-size: var(--text-base);
  line-height: 1.45;
  color: var(--color-text);
}
.hero-callout-cta {
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--color-primary-hover);
  letter-spacing: 0.02em;
  white-space: nowrap;
}
@media (max-width: 720px) {
  .hero-callout {
    grid-template-columns: 1fr;
    gap: var(--space-3);
  }
  .hero-callout-cta { justify-self: start; }
}
