/* ============================================================
   Care Audit CA — Clinical Dossier
   Aesthetic: icy off-white + ink + single signal crimson
   Type: Newsreader (display serif), Switzer (body grotesque),
         Martian Mono (data, labels, numerals)
   ============================================================ */

@import url("https://fonts.googleapis.com/css2?family=Newsreader:ital,opsz,wght@0,6..72,200..800;1,6..72,200..800&family=Martian+Mono:wght@100..800&display=swap");
@import url("https://api.fontshare.com/v2/css?f[]=switzer@200,300,400,500,600,700,800,900&display=swap");

:root {
  /* paper */
  --paper:        #F4F6F8;
  --paper-warm:   #ECEEF2;
  --paper-tint:   #E9ECEF;
  --paper-deep:   #DDE2E7;

  /* ink */
  --ink:          #0E1116;
  --ink-2:        #1F242C;
  --ink-3:        #2A3038;

  /* grey */
  --g-700:        #3F4651;
  --g-500:        #6B7280;
  --g-400:        #8E96A3;
  --g-300:        #B8BDC6;
  --rule:         #D4D8DD;
  --rule-soft:    #E5E8EC;

  /* signal */
  --alert:        #C8102E;
  --alert-deep:   #8E0A21;
  --alert-soft:   #F5D4D9;
  --alert-paper:  #FBEBEE;

  /* secondary signals */
  --type-b:       #6B5638;
  --type-b-soft:  #EFE7D6;
  --pass:         #1F4A3B;
  --pass-soft:    #DCE8E3;

  /* type */
  --sans:   "Switzer", system-ui, -apple-system, sans-serif;
  --serif:  "Newsreader", "Georgia", serif;
  --mono:   "Martian Mono", ui-monospace, "SF Mono", monospace;

  /* metrics */
  --maxw:   1320px;
  --gutter: 32px;
  --rad:    2px;

  --shadow-sm: 0 1px 0 var(--rule);
  --shadow-card: 0 1px 0 var(--rule), 0 0 0 1px var(--rule);
}

*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; }
body {
  margin: 0;
  background: var(--paper);
  color: var(--ink);
  font-family: var(--sans);
  font-size: 16px;
  line-height: 1.55;
  font-feature-settings: "ss01", "ss02", "cv11";
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}
img, svg { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
a.in-line { border-bottom: 1px solid var(--ink); }
a.in-line:hover { background: var(--ink); color: var(--paper); }

button { font: inherit; cursor: pointer; }
input, select, textarea { font: inherit; color: inherit; }

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

.vh {
  position: absolute !important; width: 1px; height: 1px; padding: 0;
  margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0;
}
.skip:focus { left: 8px; top: 8px; width: auto; height: auto; clip: auto;
  background: var(--ink); color: var(--paper); padding: 8px 12px; z-index: 200; }

/* --- atmospheric grain & grid layers ----------------------- */
.grain {
  position: fixed; inset: 0; pointer-events: none; z-index: 1;
  background-image:
    radial-gradient(circle at 1px 1px, rgba(14,17,22,0.045) 1px, transparent 0),
    radial-gradient(circle at 4px 6px, rgba(14,17,22,0.025) 1px, transparent 0);
  background-size: 8px 8px, 14px 14px;
  mix-blend-mode: multiply;
  opacity: 0.7;
}
.crosshatch {
  position: absolute; inset: 0; pointer-events: none;
  background-image:
    linear-gradient(90deg, rgba(14,17,22,0.04) 1px, transparent 1px),
    linear-gradient(0deg,  rgba(14,17,22,0.04) 1px, transparent 1px);
  background-size: 80px 80px;
  opacity: 0.6;
}

/* === MASTHEAD ============================================== */
.mast {
  position: sticky; top: 0; z-index: 100;
  background: var(--paper);
  border-bottom: 1px solid var(--ink);
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}
.mast-bar {
  max-width: var(--maxw); margin: 0 auto; padding: 10px var(--gutter);
  display: flex; align-items: center; justify-content: space-between; gap: 24px;
}
.mast-brand {
  display: flex; align-items: baseline; gap: 10px;
  font-weight: 700; color: var(--ink);
}
.mast-brand .dot {
  width: 8px; height: 8px; background: var(--alert); border-radius: 50%;
  display: inline-block; transform: translateY(-1px);
  box-shadow: 0 0 0 3px rgba(200,16,46,0.15);
}
.mast-brand .sub { color: var(--g-500); font-weight: 500; }
.mast-meta { display: flex; gap: 22px; color: var(--g-500); }
.mast-meta b { color: var(--ink); font-weight: 700; }
.mast-nav { display: flex; gap: 22px; }
.mast-nav a { color: var(--g-500); }
.mast-nav a:hover { color: var(--ink); border-bottom: 1px solid var(--ink); }

.mob-toggle {
  display: none; background: none; border: 1px solid var(--ink);
  width: 36px; height: 28px; padding: 6px; flex-direction: column;
  justify-content: space-between; align-items: stretch;
}
.mob-toggle span { display: block; height: 1.5px; background: var(--ink); }

/* === LAYOUT WRAPPERS ======================================= */
.wrap { max-width: var(--maxw); margin: 0 auto; padding: 0 var(--gutter); position: relative; z-index: 2; }
section { position: relative; }
.rule-thick { border-top: 2px solid var(--ink); }
.rule-thin  { border-top: 1px solid var(--rule); }

.eyebrow {
  font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.18em;
  text-transform: uppercase; color: var(--g-500); display: inline-flex;
  align-items: center; gap: 10px;
}
.eyebrow::before {
  content: ""; width: 28px; height: 1px; background: var(--ink); display: inline-block;
}
.eyebrow b { color: var(--ink); font-weight: 700; }

/* === HERO ================================================== */
.hero {
  padding: 80px 0 64px;
  border-bottom: 1px solid var(--ink);
  background: var(--paper);
  overflow: hidden;
}
.hero::before {
  content: "";
  position: absolute; right: -120px; top: -120px;
  width: 480px; height: 480px;
  background:
    radial-gradient(circle at center, rgba(200,16,46,0.07) 0%, rgba(200,16,46,0) 60%),
    repeating-radial-gradient(circle at center, transparent 0 14px, rgba(14,17,22,0.05) 14px 15px);
  border-radius: 50%; pointer-events: none;
}
.hero-grid {
  display: grid; grid-template-columns: 1.45fr 1fr; gap: 56px;
  align-items: end; position: relative; z-index: 2;
}
.hero-eyebrow { margin-bottom: 28px; }
.hero-h {
  font-family: var(--serif);
  font-weight: 300;
  font-size: clamp(44px, 7.2vw, 102px);
  line-height: 0.94;
  letter-spacing: -0.025em;
  color: var(--ink);
  margin: 0 0 28px;
  font-variation-settings: "opsz" 60;
}
.hero-h .line { display: block; }
.hero-h .italic {
  font-style: italic; font-weight: 200;
  font-variation-settings: "opsz" 28;
}
.hero-h .ink-mark {
  background: linear-gradient(180deg, transparent 0 62%, var(--ink) 62% 86%, transparent 86%);
  color: var(--paper);
  padding: 0 0.08em;
}
.hero-h .strike {
  text-decoration: line-through;
  text-decoration-thickness: 3px;
  text-decoration-color: var(--alert);
  color: var(--g-400);
  font-style: italic;
}
.hero-deck {
  font-family: var(--serif);
  font-size: clamp(17px, 1.35vw, 21px);
  line-height: 1.5;
  color: var(--ink-2);
  max-width: 52ch;
  margin: 0 0 32px;
  font-weight: 360;
}
.hero-cta-row {
  display: flex; gap: 14px; align-items: center; flex-wrap: wrap;
}

/* hero-right: editorial stat card */
.stat-card {
  border: 1.5px solid var(--ink);
  background: var(--paper);
  padding: 28px 28px 22px;
  position: relative;
}
.stat-card::before {
  content: "FILE 008 / CARE AUDIT";
  position: absolute; top: -10px; left: 18px;
  background: var(--paper); padding: 0 8px;
  font-family: var(--mono); font-size: 9.5px;
  letter-spacing: 0.18em; color: var(--g-500);
}
.stat-row { display: flex; justify-content: space-between; align-items: baseline; padding: 12px 0;
  border-top: 1px solid var(--rule);
}
.stat-row:first-of-type { border-top: 0; }
.stat-label {
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.15em;
  text-transform: uppercase; color: var(--g-500);
}
.stat-val {
  font-family: var(--mono); font-size: 22px; font-weight: 500; color: var(--ink);
  letter-spacing: -0.01em;
}
.stat-val.big {
  font-family: var(--serif); font-size: 64px; font-weight: 300; line-height: 1;
  letter-spacing: -0.03em;
  font-variation-settings: "opsz" 60;
}
.stat-val.alert { color: var(--alert); }
.stat-card .stamp {
  display: inline-block; margin-top: 18px;
  font-family: var(--mono); font-size: 9.5px; letter-spacing: 0.2em;
  color: var(--alert); border: 1.5px solid var(--alert);
  padding: 5px 8px 4px; transform: rotate(-2deg);
  background: var(--alert-paper);
}

/* === BUTTONS =============================================== */
.btn {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 14px 22px;
  font-family: var(--mono); font-size: 11.5px;
  letter-spacing: 0.18em; text-transform: uppercase;
  font-weight: 600;
  transition: transform 0.15s ease, background 0.15s ease, color 0.15s ease;
}
.btn-ink {
  background: var(--ink); color: var(--paper); border: 1.5px solid var(--ink);
}
.btn-ink:hover { background: transparent; color: var(--ink); }
.btn-ghost {
  background: transparent; color: var(--ink); border: 1.5px solid var(--ink);
}
.btn-ghost:hover { background: var(--ink); color: var(--paper); }
.btn-alert {
  background: var(--alert); color: #fff; border: 1.5px solid var(--alert);
}
.btn-alert:hover { background: var(--alert-deep); }
.btn .arrow { transition: transform 0.2s ease; }
.btn:hover .arrow { transform: translateX(4px); }

/* === ALERT BANNER (WaPo pull quote) ======================== */
.alert-strip {
  background: var(--ink);
  color: var(--paper);
  padding: 28px 0;
  position: relative;
  overflow: hidden;
}
.alert-strip::before {
  content: ""; position: absolute; left: 0; top: 0; bottom: 0; width: 4px;
  background: var(--alert);
}
.alert-grid {
  display: grid; grid-template-columns: auto 1fr auto; gap: 40px; align-items: center;
}
.alert-tag {
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.22em;
  text-transform: uppercase; color: var(--alert);
  padding: 6px 10px; border: 1px solid var(--alert);
}
.alert-quote {
  font-family: var(--serif); font-style: italic; font-weight: 300;
  font-size: clamp(18px, 1.7vw, 26px); line-height: 1.32;
  color: var(--paper); letter-spacing: -0.01em;
  font-variation-settings: "opsz" 36;
}
.alert-quote b { font-weight: 500; font-style: normal; color: #fff; background: var(--alert); padding: 1px 6px; }
.alert-cite {
  font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.12em;
  color: var(--g-300); text-transform: uppercase;
}

/* === SECTION HEADERS ======================================= */
.section-head {
  display: grid; grid-template-columns: 1fr auto; align-items: end;
  gap: 24px; padding: 80px 0 36px;
  border-bottom: 1px solid var(--ink);
}
.section-h {
  font-family: var(--serif); font-weight: 300;
  font-size: clamp(34px, 4.4vw, 60px);
  line-height: 1.02; letter-spacing: -0.02em;
  color: var(--ink); margin: 12px 0 0; max-width: 22ch;
  font-variation-settings: "opsz" 60;
}
.section-h .italic { font-style: italic; font-weight: 200; }
.section-aside {
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.14em;
  text-transform: uppercase; color: var(--g-500); text-align: right;
  max-width: 28ch;
}
.section-aside b { color: var(--ink); display: block; font-size: 13px; margin-bottom: 4px; }

/* === SEARCH / FILTER BAR ================================== */
.filterbar {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr auto;
  gap: 0;
  border: 1.5px solid var(--ink);
  background: var(--paper);
  margin: 36px 0;
}
.filterbar > * {
  padding: 16px 20px;
  border-right: 1px solid var(--ink);
  background: var(--paper);
}
.filterbar > *:last-child { border-right: 0; }
.filter-field { display: flex; flex-direction: column; gap: 4px; }
.filter-label {
  font-family: var(--mono); font-size: 9.5px; letter-spacing: 0.2em;
  text-transform: uppercase; color: var(--g-500);
}
.filter-field select,
.filter-field input {
  border: 0; background: transparent; outline: none;
  font-family: var(--serif); font-size: 18px; font-weight: 400; color: var(--ink);
  padding: 0; width: 100%; appearance: none;
  -webkit-appearance: none;
}
.filter-field select { cursor: pointer; }
.filter-go {
  display: flex; align-items: center; justify-content: center;
  background: var(--ink); color: var(--paper);
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.16em;
  font-weight: 600; text-transform: uppercase; min-width: 140px;
  cursor: pointer; transition: background 0.15s ease;
}
.filter-go:hover { background: var(--alert); }

.filter-summary {
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.1em;
  color: var(--g-500); text-transform: uppercase; margin: -16px 0 28px;
}
.filter-summary b { color: var(--ink); }

/* === AUDIT INDEX CARDS ==================================== */
.audit-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 0;
  border: 1.5px solid var(--ink); border-bottom: 0;
}
.audit-card {
  background: var(--paper);
  border-right: 1px solid var(--ink);
  border-bottom: 1.5px solid var(--ink);
  padding: 28px 28px 24px;
  display: flex; flex-direction: column;
  position: relative; overflow: hidden;
  transition: background 0.18s ease;
}
.audit-card:last-child { border-right: 0; }
.audit-card:hover { background: #fff; }
.audit-card.feature {
  grid-column: span 1; min-height: 360px;
}
.ac-head {
  display: flex; justify-content: space-between; align-items: flex-start; gap: 16px;
  padding-bottom: 16px; border-bottom: 1px solid var(--rule);
  margin-bottom: 16px;
}
.ac-location {
  font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.15em;
  text-transform: uppercase; color: var(--g-500);
}
.ac-location b { color: var(--ink); font-weight: 700; display: block; margin-bottom: 2px; }

.ac-score-tile {
  display: flex; flex-direction: column; align-items: flex-end; gap: 2px;
  min-width: 84px;
}
.ac-score {
  font-family: var(--serif); font-weight: 300;
  font-size: 52px; line-height: 0.9; letter-spacing: -0.03em;
  color: var(--ink); font-variation-settings: "opsz" 60;
}
.ac-score.alert { color: var(--alert); }
.ac-score.warn { color: var(--type-b); }
.ac-score-label {
  font-family: var(--mono); font-size: 8.5px; letter-spacing: 0.18em;
  text-transform: uppercase; color: var(--g-500);
}
.ac-name {
  font-family: var(--serif); font-weight: 400;
  font-size: 26px; line-height: 1.1; letter-spacing: -0.015em;
  color: var(--ink); margin: 0 0 8px;
  font-variation-settings: "opsz" 36;
}
.ac-line {
  display: flex; justify-content: space-between; gap: 12px;
  font-family: var(--mono); font-size: 11px;
  padding: 6px 0; border-top: 1px solid var(--rule-soft);
  color: var(--g-700);
}
.ac-line:first-of-type { border-top: 0; }
.ac-line b { color: var(--ink); font-weight: 600; }
.ac-line .alert { color: var(--alert); font-weight: 700; }
.ac-line .pass { color: var(--pass); font-weight: 700; }
.ac-cta {
  margin-top: auto; padding-top: 16px;
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.18em;
  text-transform: uppercase; color: var(--ink); font-weight: 600;
  display: flex; align-items: center; gap: 8px;
}
.audit-card:hover .ac-cta { color: var(--alert); }

/* score badge stamp on cleaners */
.verified-stamp {
  position: absolute; top: 18px; right: -22px;
  font-family: var(--mono); font-size: 9px; letter-spacing: 0.18em;
  color: var(--pass); border: 1.5px solid var(--pass);
  padding: 4px 26px 3px; transform: rotate(8deg);
  background: var(--pass-soft);
  opacity: 0;
}
.audit-card[data-verified="true"] .verified-stamp { opacity: 1; }
.alert-stamp {
  position: absolute; top: 18px; right: -22px;
  font-family: var(--mono); font-size: 9px; letter-spacing: 0.18em;
  color: var(--alert); border: 1.5px solid var(--alert);
  padding: 4px 26px 3px; transform: rotate(8deg);
  background: var(--alert-paper);
}

/* secondary roster table */
.roster {
  margin-top: -1.5px;
  border: 1.5px solid var(--ink); border-top: 0;
  background: var(--paper);
  font-size: 13px;
}
.roster-row {
  display: grid;
  grid-template-columns: 56px 1fr 1.2fr 0.8fr 0.8fr 0.8fr;
  align-items: center;
  gap: 16px; padding: 14px 24px;
  border-top: 1px solid var(--rule);
  transition: background 0.12s ease;
  cursor: pointer;
}
.roster-row:first-child {
  border-top: 0;
  background: var(--paper-warm);
  font-family: var(--mono); font-size: 10px;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--g-500);
  cursor: default;
}
.roster-row:not(:first-child):hover { background: #fff; }
.roster-row.dim { opacity: 0.35; }
.roster-score {
  font-family: var(--mono); font-size: 16px; font-weight: 700; color: var(--ink);
  text-align: center;
}
.roster-score.alert { color: var(--alert); }
.roster-score.warn  { color: var(--type-b); }
.roster-name { font-family: var(--serif); font-size: 18px; color: var(--ink); font-weight: 400; }
.roster-loc { font-family: var(--mono); font-size: 11px; color: var(--g-500); letter-spacing: 0.04em; }
.roster-price { font-family: var(--mono); font-size: 12px; color: var(--ink); }
.roster-cit { font-family: var(--mono); font-size: 12px; color: var(--g-700); }
.roster-cit b { color: var(--ink); }
.roster-cit.alert b { color: var(--alert); }
.roster-arrow {
  font-family: var(--mono); font-size: 12px; color: var(--g-500);
  text-align: right;
}
.roster-row:not(:first-child):hover .roster-arrow { color: var(--alert); }

/* === METHODOLOGY PREVIEW =================================== */
.method {
  display: grid; grid-template-columns: 1fr 1fr 1fr 1fr; gap: 0;
  border: 1.5px solid var(--ink);
}
.method-cell {
  padding: 28px 24px;
  border-right: 1px solid var(--ink);
  background: var(--paper);
}
.method-cell:last-child { border-right: 0; }
.method-num {
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.18em;
  color: var(--alert); margin-bottom: 14px;
}
.method-h {
  font-family: var(--serif); font-weight: 400;
  font-size: 22px; line-height: 1.15; margin: 0 0 10px;
  letter-spacing: -0.01em;
  font-variation-settings: "opsz" 36;
}
.method-p {
  font-size: 13.5px; line-height: 1.55; color: var(--ink-2); margin: 0;
}
.method-foot {
  margin-top: 14px;
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.15em;
  color: var(--g-500); text-transform: uppercase;
}
.method-foot b { color: var(--ink); }

/* === COMPARE PANEL ========================================= */
.compare {
  background: var(--ink);
  color: var(--paper);
  padding: 64px 0 72px;
  position: relative;
  overflow: hidden;
}
.compare::before {
  content: "";
  position: absolute; left: 0; right: 0; top: 0; bottom: 0;
  background-image:
    linear-gradient(90deg, rgba(255,255,255,0.04) 1px, transparent 1px),
    linear-gradient(0deg,  rgba(255,255,255,0.04) 1px, transparent 1px);
  background-size: 60px 60px;
  pointer-events: none;
}
.compare-inner { position: relative; z-index: 2; }
.compare-head {
  display: grid; grid-template-columns: 1fr auto; align-items: end;
  padding-bottom: 28px; border-bottom: 1px solid rgba(255,255,255,0.18);
}
.compare-head h2 {
  font-family: var(--serif); font-weight: 200;
  font-size: clamp(34px, 4.4vw, 56px); line-height: 1.02;
  margin: 0; color: var(--paper); letter-spacing: -0.02em;
}
.compare-head .italic { font-style: italic; }
.compare-aside {
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.14em;
  text-transform: uppercase; color: var(--g-300);
}
.compare-pickers {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px;
  margin: 28px 0;
}
.compare-picker {
  background: rgba(255,255,255,0.06); border: 1px solid rgba(255,255,255,0.22);
  padding: 12px 14px;
}
.compare-picker .filter-label { color: var(--g-300); }
.compare-picker select {
  width: 100%; background: transparent; border: 0; outline: none;
  font-family: var(--serif); font-size: 19px; color: var(--paper);
  appearance: none; -webkit-appearance: none; padding: 4px 0;
  font-variation-settings: "opsz" 36;
}
.compare-picker option { color: var(--ink); }
.compare-table {
  margin-top: 12px; border-top: 1px solid rgba(255,255,255,0.18);
}
.compare-row {
  display: grid; grid-template-columns: 220px repeat(3, 1fr); gap: 20px;
  padding: 16px 0; border-bottom: 1px solid rgba(255,255,255,0.12);
  align-items: baseline;
}
.compare-row .label {
  font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--g-300);
}
.compare-row .val {
  font-family: var(--mono); font-size: 16px; color: var(--paper); font-weight: 500;
}
.compare-row .val.big {
  font-family: var(--serif); font-size: 36px; font-weight: 300; line-height: 1;
  font-variation-settings: "opsz" 60;
}
.compare-row .val.alert { color: var(--alert); }

/* === MAP =================================================== */
.map-wrap {
  position: relative;
  border: 1.5px solid var(--ink);
  background: var(--paper);
  overflow: hidden;
}
#countyMap {
  height: 520px; width: 100%;
  filter: grayscale(0.6) contrast(1.05);
}
.map-overlay {
  position: absolute; top: 16px; left: 16px;
  background: var(--paper); border: 1.5px solid var(--ink);
  padding: 16px 18px; max-width: 280px; z-index: 5;
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.06em;
  pointer-events: none;
}
.map-overlay h4 {
  margin: 0 0 10px; font-family: var(--serif); font-size: 18px;
  letter-spacing: -0.01em; font-weight: 400;
}
.map-legend { display: flex; flex-direction: column; gap: 6px; }
.map-legend span { display: flex; align-items: center; gap: 8px; }
.map-legend i {
  width: 12px; height: 12px; border-radius: 50%; display: inline-block;
  border: 1.5px solid var(--ink);
}
.legend-clean { background: var(--pass); }
.legend-strong { background: var(--ink); }
.legend-watch { background: var(--type-b); }
.legend-alert { background: var(--alert); }

/* leaflet popup overrides */
.leaflet-popup-content-wrapper {
  border-radius: 0; border: 1.5px solid var(--ink);
  background: var(--paper); box-shadow: 0 4px 0 var(--ink);
}
.leaflet-popup-content { margin: 14px 16px; font-family: var(--sans); }
.leaflet-popup-tip { background: var(--paper); border: 1.5px solid var(--ink); }
.lp-name { font-family: var(--serif); font-size: 17px; line-height: 1.2; color: var(--ink); margin: 0 0 4px; font-weight: 500; }
.lp-loc { font-family: var(--mono); font-size: 10px; letter-spacing: 0.12em; color: var(--g-500); text-transform: uppercase; }
.lp-score { display: flex; align-items: baseline; gap: 6px; margin: 8px 0 6px; }
.lp-score b { font-family: var(--mono); font-size: 18px; color: var(--ink); }
.lp-score b.alert { color: var(--alert); }
.lp-score b.warn { color: var(--type-b); }
.lp-cit { font-family: var(--mono); font-size: 11px; color: var(--g-700); }
.lp-link { display: inline-block; margin-top: 8px; font-family: var(--mono);
  font-size: 10.5px; letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--ink); border-bottom: 1.5px solid var(--ink); padding-bottom: 1px; }

/* === MONITOR / WAITLIST =================================== */
.monitor {
  display: grid; grid-template-columns: 1fr 1fr; gap: 64px;
  padding: 80px 0; border-top: 2px solid var(--ink);
  align-items: center;
}
.monitor-h {
  font-family: var(--serif); font-weight: 200;
  font-size: clamp(36px, 4.8vw, 64px); line-height: 1.02;
  letter-spacing: -0.02em; margin: 12px 0 18px;
  font-variation-settings: "opsz" 60;
}
.monitor-h .italic { font-style: italic; }
.monitor-h em { color: var(--alert); font-style: italic; font-weight: 300; }
.monitor p { font-family: var(--serif); font-size: 18px; line-height: 1.5; color: var(--ink-2); margin: 0 0 16px; max-width: 50ch; }
.monitor-form { background: var(--paper); border: 1.5px solid var(--ink); padding: 24px; }
.form-row { display: flex; flex-direction: column; gap: 6px; margin-bottom: 18px; }
.form-row label {
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.18em;
  text-transform: uppercase; color: var(--g-500);
}
.form-row input,
.form-row select {
  background: transparent; border: 0; border-bottom: 1.5px solid var(--ink);
  padding: 8px 0 10px;
  font-family: var(--serif); font-size: 18px; color: var(--ink);
  outline: none; width: 100%;
  font-variation-settings: "opsz" 36;
}
.form-row input:focus,
.form-row select:focus { border-bottom-color: var(--alert); }
.form-disclaim {
  font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.1em;
  color: var(--g-500); line-height: 1.5; margin: 6px 0 14px;
}
.form-result {
  background: var(--pass-soft); border: 1px solid var(--pass);
  padding: 12px 14px; font-family: var(--mono); font-size: 12px;
  color: var(--pass); display: none;
}
.form-result.show { display: block; }

/* === PLEDGE STRIP ========================================== */
.pledge {
  background: var(--paper-warm);
  border-top: 1px solid var(--ink); border-bottom: 1px solid var(--ink);
  padding: 56px 0;
  text-align: center;
}
.pledge-h {
  font-family: var(--serif); font-weight: 200;
  font-size: clamp(28px, 3.4vw, 44px); line-height: 1.18;
  letter-spacing: -0.015em; max-width: 28ch; margin: 0 auto 14px;
  font-variation-settings: "opsz" 36;
}
.pledge-h em { color: var(--alert); font-style: italic; }
.pledge-sub {
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.18em;
  text-transform: uppercase; color: var(--g-500);
}
.pledge-sub b { color: var(--ink); }

/* === FOOTER ================================================ */
footer {
  background: var(--ink); color: var(--paper); padding: 64px 0 32px;
  font-family: var(--sans);
}
.foot-grid {
  display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 48px;
  padding-bottom: 48px; border-bottom: 1px solid rgba(255,255,255,0.15);
}
.foot-brand { font-family: var(--serif); font-weight: 200; font-size: 36px;
  line-height: 1.05; letter-spacing: -0.02em; margin: 0 0 12px;
  font-variation-settings: "opsz" 60;
}
.foot-brand em { font-style: italic; color: var(--alert); }
.foot-tag {
  font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.18em;
  text-transform: uppercase; color: var(--g-300); margin-bottom: 18px;
}
.foot-col h4 {
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.2em;
  text-transform: uppercase; color: var(--g-300); font-weight: 600;
  margin: 0 0 16px;
}
.foot-col ul { list-style: none; padding: 0; margin: 0; }
.foot-col li { margin: 8px 0; font-size: 13px; color: var(--paper); }
.foot-col li a { color: var(--paper); border-bottom: 1px solid rgba(255,255,255,0.2); }
.foot-col li a:hover { border-bottom-color: var(--alert); color: var(--alert); }
.foot-col p { font-size: 12px; color: var(--g-300); line-height: 1.6; margin: 0; }
.foot-bottom {
  padding-top: 28px; display: flex; justify-content: space-between;
  align-items: center; flex-wrap: wrap; gap: 14px;
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.14em;
  color: var(--g-300); text-transform: uppercase;
}
.foot-bottom b { color: var(--paper); }

/* === FACILITY DETAIL ====================================== */
.fdetail-hero {
  padding: 60px 0 48px; border-bottom: 1px solid var(--ink); position: relative;
}
.fdetail-back {
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--g-500);
  margin-bottom: 28px; display: inline-flex; gap: 8px; align-items: center;
}
.fdetail-back:hover { color: var(--ink); }
.fdetail-grid {
  display: grid; grid-template-columns: 1.4fr 1fr; gap: 56px; align-items: end;
}
.fdetail-name {
  font-family: var(--serif); font-weight: 300;
  font-size: clamp(40px, 6vw, 88px); line-height: 0.96;
  letter-spacing: -0.025em; margin: 16px 0 16px;
  font-variation-settings: "opsz" 60;
}
.fdetail-loc {
  font-family: var(--mono); font-size: 12px; letter-spacing: 0.18em;
  text-transform: uppercase; color: var(--g-500);
}
.fdetail-loc b { color: var(--ink); }
.fdetail-scorebox {
  border: 2px solid var(--ink); background: var(--paper);
  padding: 28px 28px 24px; position: relative;
}
.fdetail-scorebox::before {
  content: "CARE AUDIT SCORE"; position: absolute; top: -10px; left: 18px;
  background: var(--paper); padding: 0 8px;
  font-family: var(--mono); font-size: 9.5px;
  letter-spacing: 0.2em; color: var(--g-500);
}
.fd-big {
  font-family: var(--serif); font-weight: 300;
  font-size: 110px; line-height: 0.9; letter-spacing: -0.04em;
  font-variation-settings: "opsz" 60;
}
.fd-big.alert { color: var(--alert); }
.fd-big.warn { color: var(--type-b); }
.fd-bar {
  height: 6px; background: var(--paper-deep); margin: 18px 0 10px; position: relative;
}
.fd-bar i {
  position: absolute; top: 0; left: 0; bottom: 0;
  background: var(--ink); display: block;
}
.fd-bar.warn i { background: var(--type-b); }
.fd-bar.alert i { background: var(--alert); }
.fd-bar-marks {
  display: flex; justify-content: space-between;
  font-family: var(--mono); font-size: 9px; letter-spacing: 0.15em;
  color: var(--g-500);
}
.fd-band {
  font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.18em;
  text-transform: uppercase; padding: 4px 8px;
  display: inline-block; margin-top: 10px;
}
.fd-band.clean { background: var(--pass); color: var(--paper); }
.fd-band.strong { background: var(--ink); color: var(--paper); }
.fd-band.watch { background: var(--type-b); color: var(--paper); }
.fd-band.alert { background: var(--alert); color: #fff; }

/* facility detail KPI strip */
.fd-kpis {
  display: grid; grid-template-columns: repeat(5, 1fr); gap: 0;
  border: 1.5px solid var(--ink); margin: 48px 0;
}
.fd-kpi { padding: 24px; border-right: 1px solid var(--ink); }
.fd-kpi:last-child { border-right: 0; }
.fd-kpi-label {
  font-family: var(--mono); font-size: 9.5px; letter-spacing: 0.18em;
  text-transform: uppercase; color: var(--g-500); margin-bottom: 8px;
}
.fd-kpi-val {
  font-family: var(--mono); font-size: 24px; color: var(--ink); font-weight: 600;
  letter-spacing: -0.01em;
}
.fd-kpi-val.alert { color: var(--alert); }
.fd-kpi-sub {
  font-family: var(--mono); font-size: 10px; color: var(--g-500);
  letter-spacing: 0.08em; margin-top: 2px;
}

/* citation timeline */
.tl-wrap { padding: 12px 0 60px; }
.tl-head { padding-bottom: 28px; border-bottom: 2px solid var(--ink); }
.tl-h {
  font-family: var(--serif); font-weight: 300;
  font-size: clamp(30px, 4vw, 52px); margin: 12px 0 8px;
  line-height: 1.02; letter-spacing: -0.02em;
  font-variation-settings: "opsz" 60;
}
.tl {
  display: flex; flex-direction: column;
  border-left: 2px solid var(--ink);
  margin: 36px 0 0 36px;
  padding-left: 36px; position: relative;
}
.tl-item {
  position: relative; padding: 28px 0 28px;
  border-bottom: 1px solid var(--rule);
  opacity: 0; transform: translateX(-12px);
  animation: tlIn 0.6s ease forwards;
}
@keyframes tlIn {
  to { opacity: 1; transform: translateX(0); }
}
.tl-item::before {
  content: ""; position: absolute; left: -45px; top: 36px;
  width: 18px; height: 18px; background: var(--paper);
  border: 2px solid var(--ink); border-radius: 50%;
}
.tl-item[data-type="TYPE A"]::before { background: var(--alert); border-color: var(--alert); box-shadow: 0 0 0 4px var(--alert-paper); }
.tl-item[data-type="TYPE B"]::before { background: var(--type-b); border-color: var(--type-b); }
.tl-item[data-type="INSPECTION"]::before { background: var(--paper); }
.tl-item[data-type="COMPLAINT"]::before { background: var(--paper-warm); }
.tl-row {
  display: grid; grid-template-columns: 180px 1fr; gap: 32px; align-items: start;
}
.tl-date {
  font-family: var(--mono); font-size: 12px; font-weight: 600; color: var(--ink);
  letter-spacing: 0.08em;
}
.tl-date small {
  display: block; font-weight: 400; color: var(--g-500); font-size: 10px;
  letter-spacing: 0.18em; text-transform: uppercase; margin-top: 4px;
}
.tl-content h4 {
  font-family: var(--serif); font-weight: 400;
  font-size: 22px; line-height: 1.2; margin: 0 0 6px;
  letter-spacing: -0.01em; font-variation-settings: "opsz" 36;
}
.tl-content h4 .badge {
  display: inline-block; vertical-align: middle;
  margin-left: 10px;
  font-family: var(--mono); font-size: 9.5px; letter-spacing: 0.2em;
  padding: 3px 7px 2px; border: 1.5px solid var(--ink);
  text-transform: uppercase; font-weight: 600;
}
.tl-content h4 .badge.alert { color: var(--alert); border-color: var(--alert); background: var(--alert-paper); }
.tl-content h4 .badge.warn  { color: var(--type-b); border-color: var(--type-b); background: var(--type-b-soft); }
.tl-content h4 .badge.pass  { color: var(--pass); border-color: var(--pass); background: var(--pass-soft); }
.tl-code {
  font-family: var(--mono); font-size: 11px; color: var(--g-500); letter-spacing: 0.04em;
  margin-bottom: 10px;
}
.tl-summary {
  font-family: var(--serif); font-size: 17px; line-height: 1.5; color: var(--ink-2);
  margin: 0 0 10px;
}
.tl-outcome {
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.12em;
  text-transform: uppercase; color: var(--g-700);
}
.tl-outcome b { color: var(--ink); }
.tl-outcome .pen { color: var(--alert); }

/* what-this-means box */
.wtm {
  background: var(--paper-warm); border: 1.5px solid var(--ink);
  padding: 28px 32px; margin: 48px 0;
  display: grid; grid-template-columns: 180px 1fr; gap: 32px;
}
.wtm-label {
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.2em;
  text-transform: uppercase; color: var(--alert); font-weight: 700;
}
.wtm-label b { color: var(--ink); display: block; margin-top: 4px; font-size: 14px; }
.wtm p { margin: 0 0 12px; font-family: var(--serif); font-size: 17px; line-height: 1.5; color: var(--ink); }
.wtm p:last-child { margin: 0; }

/* === RESPONSIVE =========================================== */
@media (max-width: 1024px) {
  .hero-grid { grid-template-columns: 1fr; gap: 36px; align-items: start; }
  .audit-grid { grid-template-columns: 1fr 1fr; }
  .audit-card:nth-child(2) { border-right: 0; }
  .method { grid-template-columns: 1fr 1fr; }
  .method-cell:nth-child(2) { border-right: 0; }
  .method-cell:nth-child(1), .method-cell:nth-child(2) { border-bottom: 1px solid var(--ink); }
  .compare-pickers { grid-template-columns: 1fr; }
  .compare-row { grid-template-columns: 1fr; gap: 6px; }
  .foot-grid { grid-template-columns: 1fr 1fr; gap: 32px; }
  .monitor { grid-template-columns: 1fr; gap: 32px; }
  .fd-kpis { grid-template-columns: 1fr 1fr; }
  .fd-kpi:nth-child(2) { border-right: 0; }
  .fdetail-grid { grid-template-columns: 1fr; gap: 32px; }
}

@media (max-width: 720px) {
  :root { --gutter: 18px; }
  .mast-meta { display: none; }
  .mast-nav { display: none; }
  .mob-toggle { display: flex; }
  .mast-nav.open {
    display: flex; position: absolute; top: 100%; left: 0; right: 0;
    background: var(--paper); border-bottom: 1px solid var(--ink);
    flex-direction: column; padding: 16px var(--gutter); gap: 12px; z-index: 99;
  }
  .hero { padding: 48px 0 36px; }
  .hero-h { font-size: clamp(40px, 12vw, 72px); }
  .filterbar { grid-template-columns: 1fr; }
  .filterbar > * { border-right: 0; border-bottom: 1px solid var(--ink); }
  .filterbar > *:last-child { border-bottom: 0; }
  .audit-grid { grid-template-columns: 1fr; }
  .audit-card { border-right: 0; }
  .method { grid-template-columns: 1fr; }
  .method-cell { border-right: 0; border-bottom: 1px solid var(--ink); }
  .method-cell:last-child { border-bottom: 0; }
  .section-head { grid-template-columns: 1fr; gap: 12px; }
  .section-aside { text-align: left; }
  .roster-row { grid-template-columns: 48px 1fr; gap: 8px; padding: 12px 18px; }
  .roster-row > .roster-loc,
  .roster-row > .roster-price,
  .roster-row > .roster-cit,
  .roster-row > .roster-arrow { display: none; }
  .roster-row:first-child > * { display: none; }
  .roster-row:first-child { display: none; }
  .alert-grid { grid-template-columns: 1fr; gap: 14px; }
  .foot-grid { grid-template-columns: 1fr; }
  .wtm { grid-template-columns: 1fr; gap: 16px; }
  .fd-kpis { grid-template-columns: 1fr 1fr; }
  .fd-kpi:nth-child(odd) { border-right: 1px solid var(--ink); }
  .fd-kpi:nth-child(even) { border-right: 0; }
  .fd-kpi:nth-child(-n+4) { border-bottom: 1px solid var(--ink); }
  .fd-big { font-size: 90px; }
  .tl-row { grid-template-columns: 1fr; gap: 8px; }
  .tl { margin-left: 18px; padding-left: 24px; }
  .tl-item::before { left: -33px; }
}

/* === ENTER ANIMATIONS ===================================== */
.reveal { opacity: 0; transform: translateY(14px); transition: opacity 0.8s ease, transform 0.8s ease; }
.reveal.in { opacity: 1; transform: translateY(0); }
.reveal-d1 { transition-delay: 0.08s; }
.reveal-d2 { transition-delay: 0.16s; }
.reveal-d3 { transition-delay: 0.24s; }
.reveal-d4 { transition-delay: 0.32s; }

@media (prefers-reduced-motion: reduce) {
  .reveal, .tl-item { opacity: 1; transform: none; animation: none; transition: none; }
}
