/* Shipping Clarity — Design System
   Editorial report-card meets B2B SaaS clarity */

@import url('https://fonts.googleapis.com/css2?family=Geist:wght@300;400;500;600;700&family=Fraunces:ital,opsz,wght@0,9..144,400..900;1,9..144,400..900&family=JetBrains+Mono:wght@400;500;600&display=swap');

:root {
  /* Type */
  --font-sans: "Geist", ui-sans-serif, -apple-system, system-ui, sans-serif;
  --font-serif: "Fraunces", "Times New Roman", serif;
  --font-mono: "JetBrains Mono", ui-monospace, "SF Mono", monospace;

  /* Color — warm paper */
  --paper: oklch(0.985 0.005 80);
  --paper-2: oklch(0.965 0.008 80);
  --paper-3: oklch(0.945 0.010 80);
  --ink: oklch(0.20 0.012 60);
  --ink-soft: oklch(0.45 0.012 60);
  --ink-faint: oklch(0.65 0.010 60);
  --rule: oklch(0.85 0.010 60);
  --rule-soft: oklch(0.92 0.008 60);

  /* Accents */
  --red: oklch(0.52 0.16 250);
  --red-soft: oklch(0.93 0.04 250);
  --green: oklch(0.50 0.12 145);
  --green-soft: oklch(0.94 0.04 145);
  --amber: oklch(0.70 0.13 75);
  --amber-soft: oklch(0.94 0.05 75);

  --maxw: 1240px;
}

* { box-sizing: border-box; }

html, body {
  margin: 0; padding: 0;
  background: var(--paper);
  color: var(--ink);
  font-family: var(--font-sans);
  font-size: 16px;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
}

body { min-height: 100vh; }

a { color: inherit; }

button { font-family: inherit; cursor: pointer; }

img, svg { display: block; }

/* ============== HEADER ============== */
.si-header {
  position: sticky; top: 0; z-index: 50;
  background: color-mix(in srgb, var(--paper) 92%, transparent);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--rule-soft);
}
.si-header-inner {
  max-width: var(--maxw); margin: 0 auto;
  padding: 16px 32px;
  display: flex; align-items: center; gap: 40px;
}
.si-nav { display: flex; gap: 28px; flex: 1; }
.si-nav-link {
  font-size: 14px; color: var(--ink-soft);
  text-decoration: none; padding: 6px 0;
  border-bottom: 1px solid transparent;
  transition: color 150ms, border 150ms;
}
.si-nav-link:hover { color: var(--ink); }
.si-nav-link.active { color: var(--ink); border-bottom-color: var(--red); }

/* ============== BUTTONS ============== */
.btn-primary, .btn-primary-lg {
  background: var(--ink); color: var(--paper);
  border: 1px solid var(--ink);
  padding: 9px 16px; font-size: 14px; font-weight: 500;
  border-radius: 6px;
  transition: background 150ms, transform 80ms;
}
.btn-primary:hover { background: oklch(0.30 0.012 60); }
.btn-primary:active { transform: translateY(1px); }
.btn-primary-lg { padding: 14px 24px; font-size: 15px; border-radius: 8px; }

.btn-ghost, .btn-ghost-lg {
  background: transparent; color: var(--ink);
  border: 1px solid var(--rule);
  padding: 9px 16px; font-size: 14px; font-weight: 500;
  border-radius: 6px;
  transition: background 150ms, border 150ms;
}
.btn-ghost:hover { background: var(--paper-2); border-color: var(--ink); }
.btn-ghost-lg { padding: 14px 24px; font-size: 15px; border-radius: 8px; }

.btn-toggle {
  background: transparent; color: var(--ink);
  border: 1px solid var(--rule);
  padding: 7px 14px; font-size: 13px; font-weight: 500;
  border-radius: 999px; font-family: var(--font-mono);
  transition: all 150ms;
}
.btn-toggle:hover { border-color: var(--ink); }
.btn-toggle.on { background: var(--ink); color: var(--paper); border-color: var(--ink); }

.full-w { width: 100%; }

/* ============== TYPOGRAPHY HELPERS ============== */
.section-eyebrow {
  font-family: var(--font-mono); font-size: 11px; font-weight: 500;
  text-transform: uppercase; letter-spacing: 0.1em;
  color: var(--ink-soft);
  margin-bottom: 16px;
}
.section-title {
  font-family: var(--font-serif); font-weight: 500;
  font-size: clamp(36px, 4vw, 56px);
  line-height: 1.0; letter-spacing: -0.02em;
  margin: 0 0 12px;
  color: var(--ink);
}
.section-title em { font-style: italic; color: var(--red); }

/* ============== HERO (HOMEPAGE) ============== */
.hero {
  position: relative;
  padding: 80px 32px 0;
  background: var(--paper);
  border-bottom: 1px solid var(--rule-soft);
  overflow: hidden;
}
.hero.hero-with-trucks { padding-bottom: 110px; }
@media (max-width: 700px) {
  .hero.hero-with-trucks { padding-bottom: 90px; }
}
.hero-inner { max-width: var(--maxw); margin: 0 auto; position: relative; }
.hero-eyebrow {
  font-family: var(--font-mono); font-size: 12px; font-weight: 500;
  color: var(--ink-soft); display: inline-flex; align-items: center; gap: 10px;
  padding: 8px 14px; border: 1px solid var(--rule);
  border-radius: 999px; background: var(--paper);
  margin-bottom: 32px;
}
.eyebrow-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--red);
  animation: pulse 2s infinite; }
@keyframes pulse { 50% { opacity: 0.4; } }

.hero-title {
  font-family: var(--font-serif); font-weight: 500;
  font-size: clamp(40px, 4.6vw, 72px);
  line-height: 1.05; letter-spacing: -0.02em;
  margin: 0 0 20px; color: var(--ink); text-wrap: pretty;
  max-width: 920px;
}
.hero-title em { font-style: italic; color: var(--red); }
.hero-sub {
  font-size: 19px; color: var(--ink-soft); max-width: 620px;
  line-height: 1.5; margin: 0 0 40px;
}
.hero-search-wrap { position: relative; max-width: 720px; margin-bottom: 24px; }
.hero-search {
  display: flex; align-items: center; gap: 12px;
  background: var(--paper); border: 1.5px solid var(--rule);
  padding: 6px 6px 6px 18px; border-radius: 12px;
  transition: border 150ms, box-shadow 150ms;
}
.hero-search.focused { border-color: var(--ink); box-shadow: 0 0 0 4px color-mix(in srgb, var(--ink) 8%, transparent); }
.hero-search-input {
  flex: 1; border: 0; background: transparent; outline: none;
  font-family: var(--font-sans); font-size: 17px; color: var(--ink);
  padding: 14px 0;
}
.hero-search-input::placeholder { color: var(--ink-faint); }
.hero-search-btn {
  background: var(--ink); color: var(--paper); border: 0;
  padding: 14px 22px; font-size: 14px; font-weight: 500;
  border-radius: 8px; transition: background 150ms;
}
.hero-search-btn:hover { background: oklch(0.30 0.012 60); }

.search-dropdown {
  position: absolute; top: calc(100% + 6px); left: 0; right: 0;
  background: var(--paper); border: 1px solid var(--rule);
  border-radius: 10px; padding: 6px;
  box-shadow: 0 12px 40px -8px rgba(0,0,0,0.12);
  z-index: 30;
}
.search-result {
  display: flex; justify-content: space-between; align-items: center;
  width: 100%; padding: 12px 14px; background: transparent; border: 0;
  text-align: left; border-radius: 6px;
  transition: background 100ms;
}
.search-result:hover { background: var(--paper-2); }
.search-result-name { font-size: 15px; }
.search-result-meta { font-family: var(--font-mono); font-size: 12px; color: var(--ink-soft); }

.hero-quick { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; margin-bottom: 64px; }
.hero-quick-label { font-family: var(--font-mono); font-size: 12px; color: var(--ink-soft); text-transform: uppercase; letter-spacing: 0.1em; }
.hero-quick-chip {
  background: transparent; border: 1px solid var(--rule);
  padding: 6px 12px; font-size: 13px; border-radius: 999px;
  transition: all 120ms;
}
.hero-quick-chip:hover { border-color: var(--ink); background: var(--paper-2); }

.hero-stats {
  max-width: var(--maxw); margin: 0 auto;
  display: grid; grid-template-columns: repeat(4, 1fr);
  border-top: 1px solid var(--rule-soft);
  margin-top: 24px;
}
.hero-stat {
  padding: 28px 0; border-right: 1px solid var(--rule-soft);
}
.hero-stat:last-child { border-right: 0; }
.hero-stat-num {
  font-family: var(--font-serif); font-size: 56px; line-height: 1;
  letter-spacing: -0.02em; color: var(--ink);
}
.hero-stat-label { font-family: var(--font-mono); font-size: 11px; color: var(--ink-soft); text-transform: uppercase; letter-spacing: 0.08em; margin-top: 8px; }

/* ============== CATEGORY STRIP ============== */
.cat-strip { padding: 96px 32px; border-bottom: 1px solid var(--rule-soft); }
.cat-strip-inner { max-width: var(--maxw); margin: 0 auto; }
.cat-grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: 0; margin-top: 48px;
  border: 1px solid var(--rule-soft); border-radius: 14px; overflow: hidden; background: var(--paper); }
.cat-card {
  background: var(--paper); border: 0; border-right: 1px solid var(--rule-soft);
  padding: 32px 24px 28px; text-align: left; cursor: pointer;
  transition: background 150ms;
  position: relative; min-height: 200px;
  display: flex; flex-direction: column;
}
.cat-card:last-child { border-right: 0; }
.cat-card:hover { background: var(--paper-2); }
.cat-card.active { background: var(--ink); color: var(--paper); }
.cat-card.active .cat-num, .cat-card.active .cat-desc { color: color-mix(in srgb, var(--paper) 70%, transparent); }
.cat-num { font-family: var(--font-mono); font-size: 11px; color: var(--ink-soft); margin-bottom: auto; letter-spacing: 0.1em; }
.cat-label { font-family: var(--font-serif); font-size: 28px; line-height: 1.05; margin: 36px 0 8px; letter-spacing: -0.02em; }
.cat-desc { font-size: 13px; color: var(--ink-soft); }
.cat-arrow { position: absolute; top: 28px; right: 24px; font-size: 18px; opacity: 0; transition: opacity 150ms; }
.cat-card:hover .cat-arrow, .cat-card.active .cat-arrow { opacity: 1; }

/* ============== MAP SECTION ============== */
.map-section { padding: 96px 32px; background: var(--paper-2); border-bottom: 1px solid var(--rule-soft); }
.map-section-inner { max-width: var(--maxw); margin: 0 auto; }
.map-header { display: flex; justify-content: space-between; align-items: flex-end; margin-bottom: 40px; flex-wrap: wrap; gap: 24px; }
.map-legend { display: flex; gap: 18px; flex-wrap: wrap; }
.legend-item { font-family: var(--font-mono); font-size: 12px; color: var(--ink-soft); display: inline-flex; align-items: center; gap: 6px; }
.legend-dot { width: 10px; height: 10px; border-radius: 50%; }

.map-container { display: grid; grid-template-columns: 1fr 320px; gap: 32px; align-items: stretch; }
.us-map { background: var(--paper); border: 1px solid var(--rule-soft); border-radius: 14px; padding: 24px; min-height: 480px; display: flex; align-items: center; }
.us-map-svg { width: 100%; height: auto; }

.map-side { background: var(--paper); border: 1px solid var(--rule-soft); border-radius: 14px; padding: 24px; }
.map-side-h { font-family: var(--font-mono); font-size: 11px; text-transform: uppercase; letter-spacing: 0.1em; color: var(--ink-soft); margin-bottom: 18px; }

.top-metros { display: flex; flex-direction: column; gap: 4px; }
.top-metro-row {
  display: flex; align-items: center; gap: 14px; padding: 12px 8px;
  background: transparent; border: 0; text-align: left; border-radius: 8px;
  transition: background 120ms; cursor: pointer;
}
.top-metro-row:hover { background: var(--paper-2); }
.top-metro-rank { font-family: var(--font-mono); font-size: 12px; color: var(--ink-faint); }
.top-metro-name { flex: 1; font-size: 15px; }
.top-metro-state { color: var(--ink-soft); }

.city-hover-card { animation: fadeIn 200ms ease-out; }
@keyframes fadeIn { from { opacity: 0; transform: translateY(6px); } to { opacity: 1; transform: none; } }
.city-hover-name { font-family: var(--font-serif); font-size: 36px; line-height: 1; letter-spacing: -0.02em; margin-bottom: 6px; }
.city-hover-state { font-size: 13px; color: var(--ink-soft); margin-bottom: 24px; }
.city-hover-grade-row { display: flex; justify-content: space-between; align-items: flex-end; padding: 16px 0; border-top: 1px solid var(--rule-soft); border-bottom: 1px solid var(--rule-soft); margin-bottom: 16px; }
.city-hover-label { font-family: var(--font-mono); font-size: 11px; text-transform: uppercase; letter-spacing: 0.08em; color: var(--ink-soft); }
.city-hover-val { font-size: 18px; font-weight: 500; }
.city-hover-cta { width: 100%; background: var(--ink); color: var(--paper); border: 0; padding: 12px; border-radius: 8px; font-size: 14px; font-weight: 500; }

/* ============== HOW SECTION ============== */
.how-section { padding: 96px 32px; border-bottom: 1px solid var(--rule-soft); }
.how-inner { max-width: var(--maxw); margin: 0 auto; }
.how-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 0; margin-top: 48px; border-top: 1px solid var(--rule); }
.how-card { padding: 32px 28px 32px 0; border-right: 1px solid var(--rule-soft); }
.how-card:last-child { border-right: 0; padding-right: 0; }
.how-num { font-family: var(--font-mono); font-size: 12px; color: var(--red); letter-spacing: 0.1em; margin-bottom: 24px; }
.how-h { font-family: var(--font-serif); font-size: 26px; line-height: 1.1; letter-spacing: -0.02em; margin-bottom: 12px; }
.how-p { font-size: 14px; color: var(--ink-soft); line-height: 1.55; margin: 0; }

/* ============== INSIGHTS ============== */
.insights-section { padding: 96px 32px; background: var(--paper-2); border-bottom: 1px solid var(--rule-soft); }
.insights-inner { max-width: var(--maxw); margin: 0 auto; }
.insights-head { display: flex; justify-content: space-between; align-items: flex-end; margin-bottom: 40px; }
.insights-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; }
.insight-card {
  background: var(--paper); border: 1px solid var(--rule-soft); border-radius: 12px;
  padding: 24px; cursor: pointer; transition: all 150ms;
  display: flex; flex-direction: column; gap: 16px;
}
.insight-card:hover { border-color: var(--ink); transform: translateY(-2px); }
.insight-tag {
  font-family: var(--font-mono); font-size: 10px; text-transform: uppercase; letter-spacing: 0.1em;
  color: var(--red); padding: 4px 8px; border: 1px solid var(--red-soft);
  border-radius: 4px; align-self: flex-start; background: var(--red-soft);
}
.insight-title { font-family: var(--font-serif); font-size: 22px; line-height: 1.15; margin: 0; letter-spacing: -0.01em; }
.insight-meta { font-family: var(--font-mono); font-size: 11px; color: var(--ink-soft); margin-top: auto; display: flex; gap: 6px; align-items: center; }
.dot-sep { opacity: 0.5; }

/* ============== CTA ============== */
.cta-section { padding: 120px 32px; background: var(--ink); color: var(--paper); }
.cta-inner { max-width: 720px; margin: 0 auto; text-align: center; }
.cta-title { font-family: var(--font-serif); font-size: clamp(44px, 5vw, 72px); line-height: 1.0; letter-spacing: -0.02em; margin: 0 0 18px; }
.cta-p { font-size: 18px; color: color-mix(in srgb, var(--paper) 70%, transparent); margin: 0 0 32px; }
.cta-actions { display: flex; gap: 12px; justify-content: center; }
.cta-section .btn-primary-lg { background: var(--paper); color: var(--ink); border-color: var(--paper); }
.cta-section .btn-ghost-lg { color: var(--paper); border-color: color-mix(in srgb, var(--paper) 30%, transparent); }
.cta-section .btn-ghost-lg:hover { background: color-mix(in srgb, var(--paper) 10%, transparent); }

/* ============== FOOTER ============== */
.si-footer { background: var(--paper); border-top: 1px solid var(--rule-soft); padding: 72px 32px 32px; }
.si-footer-inner { max-width: var(--maxw); margin: 0 auto; display: grid; grid-template-columns: 1.4fr 3fr; gap: 64px; }
.si-footer-tag { font-size: 14px; color: var(--ink-soft); max-width: 280px; margin: 16px 0 24px; }
.si-footer-meta { font-family: var(--font-mono); font-size: 11px; color: var(--ink-faint); }
.si-footer-cols { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; }
.si-footer-h { font-family: var(--font-mono); font-size: 11px; text-transform: uppercase; letter-spacing: 0.1em; color: var(--ink); margin-bottom: 16px; }
.si-footer-cols a { display: block; font-size: 13px; color: var(--ink-soft); padding: 5px 0; text-decoration: none; transition: color 120ms; }
.si-footer-cols a:hover { color: var(--ink); }

/* ============== SPONSORED TAG ============== */
.sponsored-tag {
  display: inline-block; font-family: var(--font-mono); font-size: 9px;
  text-transform: uppercase; letter-spacing: 0.1em; color: var(--ink-soft);
  background: var(--paper-3); padding: 2px 6px; border-radius: 3px;
  margin-left: 8px; vertical-align: middle;
}

/* ============== METRIC BAR ============== */
.metric-bar { margin-bottom: 14px; }
.metric-bar-row { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 6px; }
.metric-bar-label { font-size: 13px; color: var(--ink); }
.metric-bar-score { font-family: var(--font-mono); font-size: 13px; font-weight: 500; }
.metric-bar-track { height: 6px; background: var(--rule-soft); border-radius: 3px; overflow: hidden; }
.metric-bar-fill { height: 100%; }

/* ============== REPORT PAGE ============== */
.report-hero { padding: 56px 32px 64px; border-bottom: 1px solid var(--rule-soft); }
.report-hero-inner { max-width: var(--maxw); margin: 0 auto; }
.report-breadcrumb { font-family: var(--font-mono); font-size: 12px; color: var(--ink-soft); display: flex; gap: 8px; margin-bottom: 32px; }
.report-breadcrumb a { color: var(--ink-soft); text-decoration: none; }
.report-breadcrumb a:hover { color: var(--ink); }
.report-breadcrumb .current { color: var(--ink); }
.report-eyebrow { font-family: var(--font-mono); font-size: 12px; color: var(--red); text-transform: uppercase; letter-spacing: 0.1em; margin-bottom: 16px; }
.report-hero-grid { display: grid; grid-template-columns: 1fr 280px; gap: 64px; align-items: center; }
.report-title { font-family: var(--font-serif); font-size: clamp(56px, 7vw, 96px); line-height: 0.95; letter-spacing: -0.02em; margin: 0 0 16px; }
.report-sub { font-family: var(--font-mono); font-size: 13px; color: var(--ink-soft); margin: 0 0 32px; }
.report-tldr { display: flex; gap: 16px; padding: 20px; background: var(--paper-2); border-left: 3px solid var(--red); border-radius: 0 8px 8px 0; max-width: 640px; }
.tldr-label { font-family: var(--font-mono); font-size: 11px; text-transform: uppercase; letter-spacing: 0.1em; color: var(--red); padding-top: 2px; flex-shrink: 0; }
.report-tldr p { margin: 0; font-size: 14px; line-height: 1.55; color: var(--ink); }
.report-overall-card { display: flex; flex-direction: column; align-items: center; gap: 20px; padding: 32px; background: var(--paper-2); border-radius: 14px; border: 1px solid var(--rule-soft); }
.report-overall-label { font-family: var(--font-mono); font-size: 11px; text-transform: uppercase; letter-spacing: 0.1em; color: var(--ink-soft); text-align: center; }
.report-overall-foot { font-family: var(--font-mono); font-size: 12px; color: var(--ink-soft); }

/* ============== CATEGORY TABS ============== */
.cat-tabs { padding: 0 32px; background: var(--paper); border-bottom: 1px solid var(--rule-soft); position: sticky; top: 60px; z-index: 20; }
.cat-tabs-inner { max-width: var(--maxw); margin: 0 auto; display: flex; gap: 0; overflow-x: auto; }
.cat-tab {
  display: flex; align-items: center; gap: 10px;
  padding: 18px 24px; background: transparent; border: 0;
  border-bottom: 2px solid transparent;
  white-space: nowrap; transition: all 150ms;
  font-family: var(--font-sans);
}
.cat-tab-label { font-size: 14px; color: var(--ink-soft); }
.cat-tab:hover .cat-tab-label { color: var(--ink); }
.cat-tab.active { border-bottom-color: var(--red); }
.cat-tab.active .cat-tab-label { color: var(--ink); font-weight: 500; }

/* ============== TOOLBAR ============== */
.report-toolbar { padding: 32px 32px 16px; }
.report-toolbar-inner { max-width: var(--maxw); margin: 0 auto; display: flex; justify-content: space-between; align-items: flex-end; gap: 24px; flex-wrap: wrap; }
.toolbar-h { font-family: var(--font-serif); font-size: 32px; letter-spacing: -0.02em; margin: 0 0 4px; }
.toolbar-meta { font-family: var(--font-mono); font-size: 12px; color: var(--ink-soft); }

/* ============== CARRIER TABLE ============== */
.carrier-table-section { padding: 0 32px 96px; }
.carrier-table-inner { max-width: var(--maxw); margin: 0 auto; }
.carrier-table { background: var(--paper); border: 1px solid var(--rule-soft); border-radius: 14px; overflow: hidden; }
.carrier-table-head, .ct-row {
  display: grid;
  grid-template-columns: 48px minmax(220px, 1.6fr) 140px 80px 70px 90px 90px 100px 48px;
  align-items: center;
  padding: 0 20px;
}
.carrier-table-head {
  background: var(--paper-2); border-bottom: 1px solid var(--rule-soft);
  font-family: var(--font-mono); font-size: 11px; text-transform: uppercase;
  letter-spacing: 0.08em; color: var(--ink-soft); padding-top: 14px; padding-bottom: 14px;
}
.ct-col { padding: 0 8px; }
.ct-col.sortable { cursor: pointer; user-select: none; transition: color 120ms; }
.ct-col.sortable:hover { color: var(--ink); }
.ct-row-wrap { border-bottom: 1px solid var(--rule-soft); }
.ct-row-wrap:last-child { border-bottom: 0; }
.ct-row { padding-top: 18px; padding-bottom: 18px; cursor: pointer; transition: background 120ms; }
.ct-row:hover { background: var(--paper-2); }
.ct-row-wrap.expanded .ct-row { background: var(--paper-2); }

.rank-num { font-family: var(--font-mono); font-size: 12px; color: var(--ink-faint); }
.carrier-name-row { display: flex; align-items: center; gap: 12px; }
.carrier-logo-dot {
  width: 36px; height: 36px; border-radius: 8px;
  display: flex; align-items: center; justify-content: center;
  color: white; font-family: var(--font-serif); font-size: 18px; font-weight: 500;
  flex-shrink: 0;
}
.carrier-name { font-size: 15px; font-weight: 500; }
.carrier-sub { font-family: var(--font-mono); font-size: 11px; color: var(--ink-soft); margin-top: 2px; }

.score-cell { display: flex; align-items: center; gap: 10px; }
.score-num { font-family: var(--font-mono); font-size: 16px; font-weight: 500; min-width: 28px; }
.score-bar { flex: 1; height: 4px; background: var(--rule-soft); border-radius: 2px; overflow: hidden; max-width: 80px; }
.score-bar-fill { height: 100%; }

.compare-check {
  width: 22px; height: 22px; border-radius: 6px; border: 1.5px solid var(--rule);
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 13px; color: var(--paper); transition: all 120ms;
}
.compare-check.checked { background: var(--ink); border-color: var(--ink); }
.expand-arrow { font-size: 14px; color: var(--ink-soft); transition: transform 200ms; display: inline-block; }

.ct-detail { padding: 0 20px 32px; background: var(--paper-2); animation: expand 250ms ease-out; }
@keyframes expand { from { opacity: 0; max-height: 0; } to { opacity: 1; max-height: 800px; } }
.ct-detail-grid { display: grid; grid-template-columns: 1.3fr 1fr; gap: 48px; padding-top: 8px; }
.detail-eyebrow { font-family: var(--font-mono); font-size: 11px; text-transform: uppercase; letter-spacing: 0.1em; color: var(--ink-soft); margin-bottom: 12px; }
.detail-verdict-p { font-family: var(--font-serif); font-size: 22px; line-height: 1.3; color: var(--ink); margin: 0 0 24px; font-style: italic; }
.strengths-weak { display: grid; grid-template-columns: 1fr 1fr; gap: 32px; }
.sw-h { font-family: var(--font-mono); font-size: 11px; text-transform: uppercase; letter-spacing: 0.1em; margin-bottom: 12px; }
.sw-h-good { color: var(--green); }
.sw-h-bad { color: var(--red); }
.sw-list { list-style: none; padding: 0; margin: 0; }
.sw-list li { font-size: 14px; color: var(--ink); padding: 6px 0 6px 18px; position: relative; line-height: 1.4; }
.sw-list li::before { content: ""; position: absolute; left: 0; top: 13px; width: 8px; height: 1px; background: var(--ink-soft); }
.sw-list-big li { font-size: 16px; padding: 10px 0 10px 22px; }
.sw-list-big li::before { top: 18px; width: 10px; }
.sw-grid-big { display: grid; grid-template-columns: 1fr 1fr; gap: 48px; }

/* ============== COMPARE DRAWER ============== */
.compare-drawer {
  margin-top: 24px; padding: 32px; background: var(--paper);
  border: 1px solid var(--ink); border-radius: 14px;
  animation: fadeIn 200ms ease-out;
}
.compare-head { display: flex; justify-content: space-between; align-items: center; margin-bottom: 24px; }
.compare-h { font-family: var(--font-serif); font-size: 28px; letter-spacing: -0.02em; }
.compare-close { background: transparent; border: 0; font-size: 24px; color: var(--ink-soft); cursor: pointer; }
.compare-grid { display: grid; grid-template-columns: 1fr auto 1fr; gap: 32px; align-items: center; padding: 24px 0; border-top: 1px solid var(--rule-soft); border-bottom: 1px solid var(--rule-soft); }
.compare-col { display: flex; flex-direction: column; align-items: center; gap: 16px; }
.compare-name { font-family: var(--font-serif); font-size: 28px; }
.compare-vs { font-family: var(--font-mono); font-size: 12px; color: var(--ink-faint); letter-spacing: 0.2em; }
.compare-metrics { padding-top: 24px; }
.compare-metric-row {
  display: grid; grid-template-columns: 50px 1fr 50px 200px;
  gap: 16px; align-items: center; padding: 10px 0;
}
.cmr-val { font-family: var(--font-mono); font-size: 14px; color: var(--ink-soft); transition: color 120ms; }
.cmr-val.win { color: var(--ink); font-weight: 600; }
.cmr-bar-wrap { display: grid; grid-template-columns: 1fr 1fr; height: 6px; background: var(--rule-soft); border-radius: 3px; overflow: hidden; direction: rtl; }
.cmr-bar-wrap > .cmr-bar-a { direction: ltr; justify-self: end; height: 100%; background: var(--red); }
.cmr-bar-wrap > .cmr-bar-b { direction: ltr; justify-self: start; height: 100%; background: var(--ink); }
.cmr-label { font-size: 13px; color: var(--ink); }

/* ============== METHODOLOGY ============== */
.report-method { padding: 96px 32px; background: var(--paper-2); border-top: 1px solid var(--rule-soft); }
.report-method-inner { max-width: var(--maxw); margin: 0 auto; display: grid; grid-template-columns: 1.2fr 1fr; gap: 64px; align-items: start; }
.report-method-p { font-size: 16px; color: var(--ink-soft); line-height: 1.6; max-width: 580px; }
.metric-weights { background: var(--paper); padding: 24px; border-radius: 12px; border: 1px solid var(--rule-soft); }
.metric-weights-h { font-family: var(--font-mono); font-size: 11px; text-transform: uppercase; letter-spacing: 0.1em; color: var(--ink-soft); margin-bottom: 18px; }
.metric-weight-row { display: grid; grid-template-columns: 1.4fr 1fr 36px; gap: 12px; align-items: center; padding: 6px 0; }
.mw-label { font-size: 13px; }
.mw-bar { height: 4px; background: var(--rule-soft); border-radius: 2px; overflow: hidden; }
.mw-fill { display: block; height: 100%; background: var(--ink); }
.mw-val { font-family: var(--font-mono); font-size: 12px; color: var(--ink-soft); text-align: right; }

/* ============== CARRIER PROFILE PAGE ============== */
.carrier-hero { padding: 56px 32px 64px; border-bottom: 1px solid var(--rule-soft); background: var(--paper); }
.carrier-hero-inner { max-width: var(--maxw); margin: 0 auto; }
.carrier-hero-grid { display: grid; grid-template-columns: 1fr 240px; gap: 64px; align-items: center; }
.carrier-id-row { display: flex; gap: 24px; align-items: flex-start; margin-bottom: 28px; }
.carrier-logo-big {
  width: 80px; height: 80px; border-radius: 16px;
  display: flex; align-items: center; justify-content: center;
  color: white; font-family: var(--font-serif); font-size: 44px; flex-shrink: 0;
}
.carrier-name-big { font-family: var(--font-serif); font-size: clamp(48px, 6vw, 80px); line-height: 0.95; letter-spacing: -0.02em; margin: 6px 0 8px; }
.carrier-meta { font-family: var(--font-mono); font-size: 12px; color: var(--ink-soft); display: flex; gap: 6px; flex-wrap: wrap; }
.carrier-verdict-big { font-family: var(--font-serif); font-style: italic; font-size: 24px; line-height: 1.3; color: var(--ink); max-width: 640px; margin: 0 0 28px; }
.carrier-action-row { display: flex; gap: 12px; }
.carrier-hero-right { display: flex; flex-direction: column; align-items: center; gap: 16px; }
.carrier-overall-meta { display: flex; gap: 16px; font-family: var(--font-mono); font-size: 12px; color: var(--ink-soft); }

.carrier-body { padding: 80px 32px; }
.carrier-body-inner { max-width: var(--maxw); margin: 0 auto; display: flex; flex-direction: column; gap: 80px; }
.carrier-section {}
.carrier-metrics-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px 48px; margin-top: 32px; }
.city-grades-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px; background: var(--rule-soft); border: 1px solid var(--rule-soft); border-radius: 12px; overflow: hidden; margin-top: 32px; }
.city-grade-cell { background: var(--paper); padding: 24px; display: flex; flex-direction: column; gap: 8px; align-items: flex-start; }
.city-grade-name { font-size: 14px; color: var(--ink-soft); }
.city-grade-score { font-family: var(--font-mono); font-size: 28px; font-weight: 500; }

.claim-banner {
  padding: 40px; background: var(--ink); color: var(--paper); border-radius: 16px;
  display: flex; justify-content: space-between; align-items: center; gap: 32px;
}
.claim-eyebrow { font-family: var(--font-mono); font-size: 11px; text-transform: uppercase; letter-spacing: 0.1em; color: color-mix(in srgb, var(--paper) 60%, transparent); margin-bottom: 8px; }
.claim-h { font-family: var(--font-serif); font-size: 40px; line-height: 1; letter-spacing: -0.02em; margin: 0 0 8px; }
.claim-p { font-size: 15px; color: color-mix(in srgb, var(--paper) 70%, transparent); margin: 0; max-width: 520px; }
.claim-banner .btn-primary-lg { background: var(--paper); color: var(--ink); border-color: var(--paper); flex-shrink: 0; }

/* ============== MEMBERS / PRICING ============== */
.members-hero { padding: 80px 32px 64px; border-bottom: 1px solid var(--rule-soft); background: var(--paper); }
.members-hero-inner { max-width: var(--maxw); margin: 0 auto; }
.members-stat-row { display: grid; grid-template-columns: repeat(3, max-content); gap: 64px; margin-top: 48px; }
.ms-num { font-family: var(--font-serif); font-size: 56px; line-height: 1; letter-spacing: -0.02em; }
.ms-label { font-family: var(--font-mono); font-size: 11px; text-transform: uppercase; letter-spacing: 0.08em; color: var(--ink-soft); margin-top: 8px; }

.pricing-section { padding: 96px 32px; background: var(--paper-2); border-bottom: 1px solid var(--rule-soft); }
.pricing-inner { max-width: var(--maxw); margin: 0 auto; }
.pricing-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; margin-top: 48px; }
.pricing-card {
  background: var(--paper); border: 1px solid var(--rule-soft); border-radius: 16px;
  padding: 32px; cursor: pointer; transition: all 180ms; position: relative;
  display: flex; flex-direction: column;
}
.pricing-card:hover { border-color: var(--ink); }
.pricing-card.selected { border-color: var(--ink); box-shadow: 0 0 0 1px var(--ink); }
.pricing-card.featured { background: var(--ink); color: var(--paper); border-color: var(--ink); }
.pricing-card.featured .pricing-period, .pricing-card.featured .pricing-sub { color: color-mix(in srgb, var(--paper) 70%, transparent); }
.pricing-card.featured .pricing-features li { color: color-mix(in srgb, var(--paper) 85%, transparent); }
.pricing-card.featured .check { color: var(--paper); }
.pricing-card.featured .btn-primary-lg { background: var(--paper); color: var(--ink); border-color: var(--paper); }
.pricing-card.featured .btn-ghost-lg { background: transparent; color: var(--paper); border-color: color-mix(in srgb, var(--paper) 30%, transparent); }
.pricing-badge {
  position: absolute; top: -12px; left: 32px;
  background: var(--red); color: white;
  font-family: var(--font-mono); font-size: 10px; text-transform: uppercase;
  letter-spacing: 0.1em; padding: 6px 12px; border-radius: 999px;
}
.pricing-name { font-family: var(--font-mono); font-size: 12px; text-transform: uppercase; letter-spacing: 0.1em; margin-bottom: 24px; }
.pricing-price { font-family: var(--font-serif); font-size: 56px; line-height: 1; letter-spacing: -0.02em; }
.pricing-period { font-family: var(--font-sans); font-size: 16px; color: var(--ink-soft); margin-left: 6px; }
.pricing-sub { font-size: 14px; color: var(--ink-soft); margin: 8px 0 24px; }
.pricing-features { list-style: none; padding: 0; margin: 0 0 32px; flex: 1; }
.pricing-features li { font-size: 14px; padding: 8px 0 8px 28px; position: relative; line-height: 1.4; }
.check { position: absolute; left: 0; top: 8px; color: var(--green); font-weight: 600; }

.signup-section { padding: 96px 32px; }
.signup-inner { max-width: var(--maxw); margin: 0 auto; display: grid; grid-template-columns: 1fr 480px; gap: 80px; align-items: start; }
.signup-p { font-size: 16px; color: var(--ink-soft); line-height: 1.6; margin: 0 0 24px; max-width: 480px; }
.signup-bullets { list-style: none; padding: 0; margin: 0; }
.signup-bullets li { font-size: 15px; padding: 10px 0 10px 28px; position: relative; }
.signup-form { background: var(--paper-2); border: 1px solid var(--rule-soft); border-radius: 16px; padding: 32px; }
.form-h { font-family: var(--font-serif); font-size: 28px; margin-bottom: 24px; letter-spacing: -0.02em; }
.form-field { margin-bottom: 18px; }
.form-field label { display: block; font-family: var(--font-mono); font-size: 11px; text-transform: uppercase; letter-spacing: 0.08em; color: var(--ink-soft); margin-bottom: 8px; }
.form-field input, .form-field select {
  width: 100%; padding: 12px 14px; font-size: 14px;
  font-family: var(--font-sans); background: var(--paper);
  border: 1px solid var(--rule); border-radius: 8px; color: var(--ink); outline: none;
  transition: border 120ms;
}
.form-field input:focus, .form-field select:focus { border-color: var(--ink); }
.form-pills { display: flex; gap: 8px; flex-wrap: wrap; }
.form-pill { padding: 10px 14px; background: var(--paper); border: 1px solid var(--rule); border-radius: 8px; font-size: 13px; transition: all 120ms; }
.form-pill.active { background: var(--ink); color: var(--paper); border-color: var(--ink); }
.form-fine { font-size: 11px; color: var(--ink-faint); margin: 12px 0 0; line-height: 1.4; }

/* ============== INSIGHTS PAGE ============== */
.insights-hero { padding: 80px 32px 56px; border-bottom: 1px solid var(--rule-soft); }
.insights-hero-inner { max-width: var(--maxw); margin: 0 auto; }
.articles-section { padding: 64px 32px 96px; }
.articles-inner { max-width: var(--maxw); margin: 0 auto; }
.article-feature { padding: 32px 0 48px; border-bottom: 1px solid var(--rule); margin-bottom: 48px; cursor: pointer; }
.article-feature-title { font-family: var(--font-serif); font-size: clamp(40px, 5vw, 64px); line-height: 1.0; letter-spacing: -0.02em; margin: 16px 0 16px; max-width: 900px; }
.article-feature-excerpt { font-size: 18px; color: var(--ink-soft); max-width: 720px; line-height: 1.5; margin: 0 0 16px; }
.articles-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.article-card { padding: 24px; background: var(--paper); border: 1px solid var(--rule-soft); border-radius: 12px; cursor: pointer; transition: all 150ms; display: flex; flex-direction: column; gap: 14px; }
.article-card:hover { border-color: var(--ink); transform: translateY(-2px); }
.article-h { font-family: var(--font-serif); font-size: 22px; line-height: 1.15; margin: 0; letter-spacing: -0.01em; }
.article-p { font-size: 13px; color: var(--ink-soft); line-height: 1.55; margin: 0; }

/* ============== CARRIERS DIRECTORY ============== */
.carriers-hero { padding: 80px 32px 56px; border-bottom: 1px solid var(--rule-soft); }
.carriers-hero-inner { max-width: var(--maxw); margin: 0 auto; }
.carriers-list-section { padding: 32px 32px 96px; }
.carriers-list-inner { max-width: var(--maxw); margin: 0 auto; }
.carriers-list-head { font-family: var(--font-mono); font-size: 12px; color: var(--ink-soft); margin-bottom: 16px; padding: 0 20px; }
.carriers-list { background: var(--paper); border: 1px solid var(--rule-soft); border-radius: 14px; overflow: hidden; }
.carrier-list-row {
  display: grid; grid-template-columns: 40px 36px 1fr 60px 50px 50px 24px;
  gap: 16px; align-items: center; padding: 16px 20px;
  background: transparent; border: 0; border-bottom: 1px solid var(--rule-soft);
  text-align: left; cursor: pointer; transition: background 120ms; width: 100%;
}
.carrier-list-row:last-child { border-bottom: 0; }
.carrier-list-row:hover { background: var(--paper-2); }
.cl-name-main { font-size: 15px; font-weight: 500; }
.cl-name-sub { font-family: var(--font-mono); font-size: 11px; color: var(--ink-soft); margin-top: 2px; }
.cl-score { font-family: var(--font-mono); font-size: 16px; font-weight: 500; text-align: right; }
.cl-arrow { color: var(--ink-soft); }

/* ============== RESPONSIVE ============== */
@media (max-width: 960px) {
  .hero-stats { grid-template-columns: repeat(2, 1fr); }
  .cat-grid, .how-grid, .insights-grid, .articles-grid, .pricing-grid, .city-grades-grid { grid-template-columns: 1fr 1fr; }
  .map-container, .report-hero-grid, .carrier-hero-grid, .signup-inner, .report-method-inner, .si-footer-inner { grid-template-columns: 1fr; gap: 32px; }
  .si-footer-cols { grid-template-columns: repeat(2, 1fr); }
  .ct-detail-grid, .strengths-weak, .sw-grid-big { grid-template-columns: 1fr; gap: 32px; }
  .si-nav { display: none; }
}

/* ============== DRIVER REPORT ============== */
.dr-section { display: flex; flex-direction: column; gap: 40px; }
.dr-header {
  display: grid; grid-template-columns: 1fr auto; gap: 48px; align-items: end;
  padding-bottom: 32px; border-bottom: 1px solid var(--rule-soft);
}
.dr-sub { font-size: 16px; color: var(--ink-soft); line-height: 1.55; max-width: 60ch; margin: 14px 0 0; }
.dr-score-card {
  display: flex; align-items: center; gap: 20px;
  padding: 20px 24px; background: var(--paper-2); border: 1px solid var(--rule-soft); border-radius: 12px;
}
.dr-score-num { font-family: var(--font-serif); font-size: 56px; line-height: 1; letter-spacing: -0.03em; color: var(--ink); }
.dr-score-meta { display: flex; flex-direction: column; gap: 4px; }
.dr-score-tier { font-family: var(--font-mono); font-size: 11px; text-transform: uppercase; letter-spacing: 0.1em; }
.dr-score-trend { font-size: 13px; color: var(--ink-soft); display: flex; align-items: center; gap: 4px; }

.dr-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px; background: var(--rule-soft); border: 1px solid var(--rule-soft); border-radius: 12px; overflow: hidden; }
.dr-stat { background: var(--paper); padding: 24px; display: flex; flex-direction: column; gap: 8px; }
.dr-stat-l { font-family: var(--font-mono); font-size: 11px; color: var(--ink-soft); text-transform: uppercase; letter-spacing: 0.08em; }
.dr-stat-num { font-family: var(--font-serif); font-size: 28px; letter-spacing: -0.02em; color: var(--ink); line-height: 1.1; }
.dr-mix { display: flex; flex-direction: column; gap: 8px; margin-top: 4px; }
.dr-mix-bar { height: 8px; background: color-mix(in srgb, var(--ink) 12%, transparent); border-radius: 4px; overflow: hidden; }
.dr-mix-emp { display: block; height: 100%; background: var(--ink); border-radius: 4px; }
.dr-mix-legend { display: flex; gap: 14px; font-size: 11px; color: var(--ink-soft); flex-wrap: wrap; }
.dot { display: inline-block; width: 8px; height: 8px; border-radius: 2px; margin-right: 6px; vertical-align: middle; }
.dot-emp { background: var(--ink); }
.dot-con { background: color-mix(in srgb, var(--ink) 25%, transparent); }
.dot-pos { background: oklch(0.65 0.13 145); }
.dot-neu { background: color-mix(in srgb, var(--ink) 30%, transparent); }
.dot-neg { background: var(--red); }

.dr-row { display: grid; grid-template-columns: 1.2fr 1fr; gap: 24px; }
.dr-card { background: var(--paper); border: 1px solid var(--rule-soft); border-radius: 12px; padding: 24px; display: flex; flex-direction: column; gap: 16px; }
.dr-card-l { font-family: var(--font-mono); font-size: 11px; text-transform: uppercase; letter-spacing: 0.08em; color: var(--ink-soft); }
.dr-card-foot { font-size: 12px; color: var(--ink-soft); margin-top: auto; padding-top: 12px; border-top: 1px dashed var(--rule-soft); }
.dr-sent-bar { display: flex; height: 14px; border-radius: 7px; overflow: hidden; background: var(--paper-2); }
.dr-sent-bar .seg { display: block; height: 100%; }
.dr-sent-bar .seg-pos { background: oklch(0.65 0.13 145); }
.dr-sent-bar .seg-neu { background: color-mix(in srgb, var(--ink) 30%, transparent); }
.dr-sent-bar .seg-neg { background: var(--red); }
.dr-sent-legend { display: flex; gap: 18px; font-size: 12px; color: var(--ink-soft); flex-wrap: wrap; }
.dr-safety-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.dr-safety-num { font-family: var(--font-serif); font-size: 28px; letter-spacing: -0.02em; color: var(--ink); line-height: 1; margin-bottom: 6px; }
.dr-safety-l { font-size: 11px; color: var(--ink-soft); line-height: 1.35; }

.dr-sw { display: grid; grid-template-columns: 1fr 1fr; gap: 48px; }

.dr-quotes { padding-top: 16px; border-top: 1px solid var(--rule-soft); }
.dr-quote-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; margin-top: 20px; }
.dr-quote { margin: 0; padding: 24px; background: var(--paper-2); border-left: 3px solid var(--red); border-radius: 0 8px 8px 0; }
.dr-quote blockquote { font-family: var(--font-serif); font-size: 20px; line-height: 1.4; letter-spacing: -0.01em; color: var(--ink); margin: 0 0 12px; font-style: italic; }
.dr-quote figcaption { font-family: var(--font-mono); font-size: 11px; text-transform: uppercase; letter-spacing: 0.08em; color: var(--ink-soft); }
.dr-quote-note { font-size: 12px; color: var(--ink-faint); font-style: italic; margin-top: 16px; }

@media (max-width: 960px) {
  .dr-header { grid-template-columns: 1fr; gap: 24px; }
  .dr-grid { grid-template-columns: 1fr 1fr; }
  .dr-row, .dr-quote-grid, .dr-sw { grid-template-columns: 1fr; gap: 16px; }
  .dr-safety-grid { grid-template-columns: 1fr; gap: 12px; }
}

/* ===========================================================================
   HERO TRUCKS — animated SVG semis rolling across the bottom of the hero
   =========================================================================== */
.hero-with-trucks { position: relative; overflow: hidden; }

.hero-trucks {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 110px;
  z-index: 0;
  overflow: hidden;
  pointer-events: none; /* container ignored, but each truck button captures clicks */
}

.hero-road {
  position: absolute;
  bottom: 22px;
  left: 0;
  right: 0;
  height: 2px;
  background: repeating-linear-gradient(
    to right,
    var(--ink-soft) 0,
    var(--ink-soft) 28px,
    transparent 28px,
    transparent 52px
  );
  opacity: 0.55;
}

.hero-truck {
  position: absolute;
  bottom: 26px;
  width: 200px;
  height: 70px;
  color: var(--ink);
  opacity: 0.85;
  will-change: transform;
  pointer-events: auto;
  cursor: pointer;
  background: transparent;
  border: 0;
  padding: 0;
  display: block;
  transition: transform .12s, filter .12s;
}
.hero-truck:hover { filter: drop-shadow(0 4px 8px rgba(0,0,0,.18)); }
.hero-truck:active { transform: translateY(1px) scale(0.98); }
.hero-truck:focus { outline: none; }
.hero-truck:focus-visible { outline: 2px dashed var(--red); outline-offset: 4px; border-radius: 4px; }

@keyframes truck-drive {
  from { transform: translateX(-240px); }
  to   { transform: translateX(calc(100vw + 60px)); }
}

.hero-truck.truck-1 {
  animation: truck-drive 32s linear infinite;
  animation-delay: 0s;
  opacity: 0.95;
}

.hero-truck.truck-2 {
  animation: truck-drive 44s linear infinite;
  animation-delay: 7s;
  opacity: 0.75;
  bottom: 30px;
  width: 175px;
  height: 60px;
  color: var(--red);
}

.hero-truck.truck-3 {
  animation: truck-drive 56s linear infinite;
  animation-delay: 18s;
  opacity: 0.65;
  width: 180px;
}

.hero-with-trucks .hero-inner,
.hero-with-trucks .hero-stats { position: relative; z-index: 1; }

/* Mobile: smaller trucks, less of them visible at once */
@media (max-width: 700px) {
  .hero-trucks { height: 80px; }
  .hero-truck { width: 130px; height: 45px; bottom: 18px; }
  .hero-truck.truck-2 { bottom: 22px; width: 110px; height: 40px; }
  .hero-truck.truck-3 { width: 120px; }
  .hero-road { bottom: 16px; }
}

@media (prefers-reduced-motion: reduce) {
  .hero-truck { animation: none; }
  .hero-truck.truck-1 { left: 6%;  transform: none; }
  .hero-truck.truck-2 { left: 38%; transform: none; }
  .hero-truck.truck-3 { left: 70%; transform: none; }
}

/* ===========================================================================
   PERSPECTIVES — "What you don't see" four-Report section
   =========================================================================== */
.perspectives-section {
  background: var(--paper-2);
  border-top: 1px solid var(--rule);
  border-bottom: 1px solid var(--rule);
  padding: 80px 24px;
}
.perspectives-inner { max-width: 1240px; margin: 0 auto; }
.perspectives-sub {
  max-width: 720px;
  font-size: 17px;
  line-height: 1.55;
  color: var(--ink-soft);
  margin: 12px 0 36px;
}
.perspectives-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 22px;
}
@media (max-width: 900px) {
  .perspectives-grid { grid-template-columns: 1fr; }
  .perspectives-section { padding: 56px 20px; }
}

.p-card {
  background: var(--paper);
  border: 1px solid var(--rule);
  border-radius: 8px;
  padding: 28px 28px 24px;
  position: relative;
  display: flex;
  flex-direction: column;
  border-top-width: 4px;
}
.p-card-blue   { border-top-color: oklch(0.55 0.16 250); }
.p-card-green  { border-top-color: oklch(0.50 0.14 145); }
.p-card-amber  { border-top-color: oklch(0.65 0.14 70); }
.p-card-red    { border-top-color: oklch(0.55 0.18 25); }

.p-card-tag {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-soft);
  margin-bottom: 14px;
}
.p-card-body p {
  font-family: var(--font-serif);
  font-size: 18px;
  line-height: 1.5;
  color: var(--ink);
  margin: 0 0 14px;
  letter-spacing: -0.005em;
}
.p-card-body p:first-child::before {
  content: '"';
  font-family: var(--font-serif);
  font-size: 36px;
  color: var(--ink-faint);
  line-height: 0;
  margin-right: 4px;
  vertical-align: -8px;
}
.p-card-body em {
  font-style: italic;
  color: var(--red);
}
.p-card-pitch {
  margin-top: 6px;
  padding-top: 16px;
  border-top: 1px solid var(--rule-soft);
  font-size: 14px;
  line-height: 1.5;
  color: var(--ink);
}
.p-card-pitch strong { color: var(--red); font-weight: 600; }

.p-card-cta { margin-top: 18px; }
.p-card-btn {
  background: transparent;
  border: 1px solid var(--ink);
  color: var(--ink);
  font-size: 13px;
  font-weight: 500;
  padding: 9px 16px;
  border-radius: 4px;
  cursor: pointer;
  font-family: inherit;
  transition: background .15s, color .15s;
}
.p-card-btn:hover { background: var(--ink); color: var(--paper); }

.p-card-form { display: flex; gap: 8px; }
.p-card-form input {
  flex: 1;
  border: 1px solid var(--rule);
  border-radius: 4px;
  padding: 9px 12px;
  font-size: 13px;
  font-family: inherit;
  background: var(--paper);
}
.p-card-form input:focus { outline: 2px solid var(--red); outline-offset: -1px; }
.p-card-form .btn-primary {
  padding: 9px 14px;
  font-size: 13px;
}
.p-card-thanks {
  font-size: 13px;
  color: oklch(0.55 0.14 145);
  background: oklch(0.96 0.04 145);
  padding: 9px 12px;
  border-radius: 4px;
}
.p-card-meta {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--ink-faint);
  margin-top: 10px;
}

/* ===========================================================================
   PULSE — daily intelligence subscription signup (homepage)
   =========================================================================== */
.pulse-section {
  background: var(--paper-2);
  border-top: 1px solid var(--rule);
  border-bottom: 1px solid var(--rule);
  padding: 80px 24px;
}
.pulse-inner { max-width: 1240px; margin: 0 auto; }
.pulse-grid {
  display: grid;
  grid-template-columns: 1.3fr 1fr;
  gap: 56px;
  align-items: start;
}
@media (max-width: 900px) {
  .pulse-grid { grid-template-columns: 1fr; gap: 32px; }
  .pulse-section { padding: 56px 20px; }
}

.pulse-sub {
  font-size: 17px;
  line-height: 1.55;
  color: var(--ink-soft);
  max-width: 580px;
  margin: 14px 0 24px;
}
.pulse-bullets {
  list-style: none;
  padding: 0;
  margin: 0;
}
.pulse-bullets li {
  font-size: 15px;
  padding: 10px 0;
  border-bottom: 1px solid var(--rule-soft);
  color: var(--ink);
  position: relative;
  padding-left: 24px;
}
.pulse-bullets li:last-child { border-bottom: none; }
.pulse-bullets li::before {
  content: "→";
  position: absolute;
  left: 0;
  color: var(--red);
  font-weight: 600;
}

.pulse-card {
  background: var(--paper);
  border: 1px solid var(--rule);
  border-top: 4px solid var(--red);
  border-radius: 8px;
  padding: 32px 28px;
  position: sticky;
  top: 24px;
}
.pulse-card-tag {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-soft);
  margin-bottom: 18px;
}
.pulse-form { display: flex; flex-direction: column; }
.pulse-label {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ink-soft);
  margin: 8px 0 6px;
}
.pulse-label:first-of-type { margin-top: 0; }
.pulse-select, .pulse-email {
  border: 1px solid var(--rule);
  border-radius: 6px;
  padding: 11px 13px;
  font-size: 15px;
  font-family: inherit;
  background: var(--paper);
  width: 100%;
  box-sizing: border-box;
}
.pulse-select:focus, .pulse-email:focus {
  outline: 2px solid var(--red);
  outline-offset: -1px;
  border-color: transparent;
}
.pulse-submit {
  margin-top: 18px;
  padding: 13px 18px;
  font-size: 15px;
  font-weight: 500;
  width: 100%;
}
.pulse-fineprint {
  font-size: 12px;
  color: var(--ink-faint);
  text-align: center;
  margin: 12px 0 0;
}
.pulse-card-thanks-h {
  font-family: var(--font-serif);
  font-size: 22px;
  margin-bottom: 8px;
  color: oklch(0.50 0.14 145);
}
.pulse-card-thanks p { color: var(--ink-soft); margin: 0; }

/* ===========================================================================
   CITY TILE GRID — replaces the old stylized US map
   =========================================================================== */
.city-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 16px;
  margin-top: 28px;
}
.city-tile {
  text-align: left;
  background: var(--paper);
  border: 1px solid var(--rule);
  border-radius: 8px;
  padding: 22px 22px 18px;
  cursor: pointer;
  transition: border-color .12s, transform .12s, box-shadow .12s;
  display: flex;
  flex-direction: column;
  gap: 14px;
  min-height: 170px;
}
.city-tile:hover {
  border-color: var(--ink);
  transform: translateY(-2px);
  box-shadow: 0 8px 20px -10px rgba(0,0,0,0.08);
}
.city-tile-top { display: flex; align-items: baseline; justify-content: space-between; gap: 12px; }
.city-tile-name {
  font-family: var(--font-serif);
  font-size: 24px;
  letter-spacing: -0.015em;
  color: var(--ink);
}
.city-tile-state {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-soft);
}
.city-tile-mid { flex: 1; display: flex; flex-direction: column; gap: 4px; }
.city-tile-leader { font-size: 14px; color: var(--ink); }
.city-tile-leader-l {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--ink-soft);
  margin-right: 4px;
}
.city-tile-pop { font-size: 12px; color: var(--ink-soft); }
.city-tile-bottom {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-top: 12px;
  border-top: 1px solid var(--rule-soft);
}
.city-tile-arrow {
  font-size: 18px;
  color: var(--ink-soft);
  transition: transform .12s;
}
.city-tile:hover .city-tile-arrow { transform: translateX(4px); color: var(--ink); }

/* Hide the legacy map container if it accidentally renders */
.us-map { display: none; }
