/* ============================================================
   WHO POLICES YOU? — localinsights.ai/publicsafety
   Engineered Warmth · Instrument Serif / Barlow / DM Mono
   ============================================================ */

:root {
  /* canvas */
  --paper:        #F5F3EE;
  --paper-deep:   #ECE8DE;
  --surface:      #FFFDF8;
  --surface-2:    #F8F4EB;

  /* ink */
  --ink:          #2D2B28;
  --ink-2:        #4A463F;
  --ink-soft:     #6E675C;
  --ink-faint:    #9A9286;

  /* accents */
  --rust:         #C05621;
  --rust-deep:    #8C3D15;
  --rust-bg:      rgba(192, 86, 33, 0.09);
  --teal:         #2C7A7B;
  --teal-bg:      rgba(44, 122, 123, 0.09);
  --ochre:        #C47D1A;
  --ochre-bg:     rgba(196, 125, 26, 0.10);

  /* dark band (hearing chapter) */
  --room:         #23211D;
  --room-2:       #2E2B26;
  --room-ink:     #EFEAE0;
  --room-soft:    #B5AC9D;

  /* rules + shadow */
  --line:         #DFD8C9;
  --line-strong:  #C9BFA9;
  --shadow:       0 1px 2px rgba(54, 42, 24, .05), 0 16px 44px rgba(54, 42, 24, .10);
  --shadow-sm:    0 1px 2px rgba(54, 42, 24, .06), 0 6px 18px rgba(54, 42, 24, .07);

  /* agency-type categorical (max 7 on screen) */
  --c-municipal:  #2D6F91;
  --c-county:     #2D7A68;   /* sheriff */
  --c-constable:  #C47D1A;
  --c-school:     #B64A32;
  --c-highered:   #7259A4;
  --c-state:      #596573;
  --c-special:    #458398;
  --c-other:      #A39A8B;

  /* type */
  --serif: 'Instrument Serif', Georgia, 'Times New Roman', serif;
  --sans:  'Barlow', -apple-system, BlinkMacSystemFont, sans-serif;
  --cond:  'Barlow Condensed', 'Barlow', sans-serif;
  --mono:  'DM Mono', ui-monospace, SFMono-Regular, monospace;

  --maxw: 1140px;
  --colw: 720px;
  --r: 14px;
  --r-sm: 8px;
}

*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { animation-duration: .001s !important; transition-duration: .001s !important; }
}

body {
  background: var(--paper);
  color: var(--ink);
  font-family: var(--sans);
  font-size: 17px;
  line-height: 1.68;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}

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

a { color: var(--rust-deep); text-decoration-thickness: 1px; text-underline-offset: 3px; }
a:hover { color: var(--rust); }

img, svg, canvas { max-width: 100%; display: block; }

/* ---------- header ---------- */
.site-head {
  position: fixed; top: 0; left: 0; right: 0; z-index: 60;
  display: flex; align-items: center; justify-content: space-between;
  padding: 0 clamp(16px, 4vw, 40px);
  height: 58px;
  background: rgba(245, 243, 238, 0.82);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--line);
}
.brand { display: flex; align-items: baseline; gap: 10px; text-decoration: none; }
.brand .mark { font-family: var(--cond); font-weight: 600; font-size: 15px; letter-spacing: .18em; color: var(--ink); text-transform: uppercase; }
.brand .mark b { color: var(--rust); font-weight: 600; }
.brand .div { color: var(--ink-faint); font-size: 13px; }
.brand .proj { font-family: var(--serif); font-style: italic; font-size: 15px; color: var(--ink-soft); }
.head-nav { display: flex; gap: 22px; align-items: center; }
.head-nav a { font-family: var(--cond); font-size: 13.5px; font-weight: 500; letter-spacing: .14em; text-transform: uppercase; text-decoration: none; color: var(--ink-soft); padding: 4px 0; border-bottom: 2px solid transparent; transition: color .3s ease, border-color .3s ease; }
.head-nav a:hover { color: var(--ink); }
.head-nav a.live { color: var(--rust-deep); border-color: var(--rust); }
.head-cta {
  font-family: var(--cond); font-size: 13.5px; font-weight: 600; letter-spacing: .14em; text-transform: uppercase;
  color: var(--paper); background: var(--ink); border: none; cursor: pointer;
  padding: 9px 16px; border-radius: 999px; text-decoration: none;
  transition: background .3s ease, transform .3s ease;
}
.head-cta:hover { background: var(--rust); color: var(--paper); transform: translateY(-1px); }
@media (max-width: 860px) { .head-nav a { display: none; } .brand .proj, .brand .div { display: none; } }

/* ---------- shared section scaffolding ---------- */
.beat { position: relative; padding: clamp(72px, 11vw, 140px) clamp(20px, 5vw, 48px); }
.beat-inner { max-width: var(--maxw); margin: 0 auto; }
.copy { max-width: var(--colw); }
.copy p { margin: 0 0 1.35em; color: var(--ink-2); font-size: clamp(17px, 1.9vw, 19px); }
.copy p strong { color: var(--ink); }
.copy p.lede { font-size: clamp(19px, 2.3vw, 23px); line-height: 1.55; color: var(--ink); }

.kicker {
  display: flex; align-items: center; gap: 14px;
  font-family: var(--cond); font-weight: 600; font-size: 14px;
  letter-spacing: .22em; text-transform: uppercase; color: var(--rust-deep);
  margin-bottom: 18px;
}
.kicker::before { content: ""; width: 34px; height: 2px; background: var(--rust); }
.kicker .no { font-family: var(--mono); font-weight: 500; color: var(--ink-faint); letter-spacing: .1em; }

h1, h2, h3 { font-family: var(--serif); font-weight: 400; line-height: 1.06; letter-spacing: -0.01em; }
h2.beat-title { font-size: clamp(34px, 5.2vw, 58px); margin-bottom: 26px; max-width: 820px; }
h3 { font-size: clamp(22px, 2.6vw, 28px); margin-bottom: 12px; }

.ghost-no {
  position: absolute; top: clamp(20px, 4vw, 56px); right: clamp(8px, 3vw, 40px);
  font-family: var(--serif); font-size: clamp(90px, 16vw, 200px);
  color: transparent; -webkit-text-stroke: 1px var(--line-strong);
  line-height: 1; user-select: none; pointer-events: none;
}

/* annotation callout */
.annot {
  font-family: var(--serif); font-style: italic; font-size: 16.5px; line-height: 1.5;
  color: var(--ink-soft);
  border-left: 2px solid var(--rust);
  padding: 2px 0 2px 16px;
  max-width: 460px; margin: 18px 0;
}
.annot .src { display: block; font-family: var(--mono); font-style: normal; font-size: 11.5px; letter-spacing: .04em; color: var(--ink-faint); margin-top: 7px; }

/* source chip under visuals */
.viz-src { font-family: var(--mono); font-size: 11.5px; letter-spacing: .03em; color: var(--ink-faint); margin-top: 14px; }
.viz-src a { color: var(--ink-soft); }

/* reveal-on-scroll (only hides content when JS is running) */
body.js .rv { opacity: 0; transform: translateY(26px); transition: opacity .8s cubic-bezier(.2,.7,.2,1), transform .8s cubic-bezier(.2,.7,.2,1); }
body.js .rv.in { opacity: 1; transform: none; }
body.js .rv.d1 { transition-delay: .12s; } body.js .rv.d2 { transition-delay: .24s; } body.js .rv.d3 { transition-delay: .36s; }

/* ---------- HERO ---------- */
#hero {
  position: relative;
  min-height: 100svh;
  display: grid; align-items: center;
  padding-top: 90px;
  background:
    radial-gradient(1100px 500px at 85% -10%, rgba(196,125,26,.10), transparent 60%),
    radial-gradient(900px 600px at -10% 110%, rgba(44,122,123,.08), transparent 55%),
    var(--paper);
  border-bottom: 1px solid var(--line);
}
.hero-grid { max-width: var(--maxw); margin: 0 auto; display: grid; grid-template-columns: minmax(0, 1.05fr) minmax(0, .95fr); gap: clamp(24px, 5vw, 64px); align-items: center; }
.hero-copy .kicker { color: var(--ink-soft); }
.hero-copy .kicker::before { background: var(--ochre); }
h1.hero-title { font-size: clamp(54px, 9vw, 118px); margin: 6px 0 22px; }
h1.hero-title em { font-style: italic; color: var(--rust); }
.hero-sub { font-size: clamp(18px, 2.2vw, 22px); line-height: 1.55; color: var(--ink-2); max-width: 540px; margin-bottom: 30px; }
.hero-sub b { color: var(--ink); font-weight: 600; }
.hero-actions { display: flex; flex-wrap: wrap; gap: 14px; align-items: center; }
.btn {
  display: inline-flex; align-items: center; gap: 10px;
  font-family: var(--cond); font-size: 15px; font-weight: 600; letter-spacing: .12em; text-transform: uppercase;
  padding: 14px 24px; border-radius: 999px; cursor: pointer; text-decoration: none;
  border: 1.5px solid var(--ink); transition: all .3s ease;
}
.btn.primary { background: var(--ink); color: var(--paper); }
.btn.primary:hover { background: var(--rust); border-color: var(--rust); transform: translateY(-2px); box-shadow: var(--shadow-sm); }
.btn.ghosted { background: transparent; color: var(--ink); }
.btn.ghosted:hover { border-color: var(--rust); color: var(--rust-deep); transform: translateY(-2px); }
.hero-field-wrap { position: relative; }
#heroField { width: 100%; height: auto; }
.hero-field-note { margin: 10px 0 0 4px; }
.scroll-cue {
  position: absolute; left: 50%; bottom: 22px; transform: translateX(-50%);
  font-family: var(--cond); font-size: 12px; letter-spacing: .26em; text-transform: uppercase; color: var(--ink-faint);
  display: flex; flex-direction: column; align-items: center; gap: 8px;
}
.scroll-cue::after { content: ""; width: 1px; height: 34px; background: linear-gradient(var(--ink-faint), transparent); animation: cueDrop 2.2s ease infinite; }
@keyframes cueDrop { 0% { transform: scaleY(0); transform-origin: top; } 55% { transform: scaleY(1); transform-origin: top; } 100% { opacity: 0; } }
@media (max-width: 920px) {
  #hero { min-height: auto; padding-bottom: 90px; }
  .hero-grid { grid-template-columns: 1fr; }
  .hero-field-wrap { order: 2; max-width: 480px; margin: 0 auto; }
}

/* ---------- 01 COUNT ---------- */
#count { border-bottom: 1px solid var(--line); }
.count-grid { display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1fr); gap: clamp(28px, 5vw, 72px); align-items: start; margin-top: 14px; }
#nestedViz { width: 100%; height: auto; }
.peer-strip { margin-top: 50px; }
.peer-row { display: grid; grid-template-columns: 130px 1fr 86px; align-items: center; gap: 16px; padding: 13px 0; border-bottom: 1px solid var(--line); }
.peer-row .nm { font-family: var(--cond); font-weight: 600; font-size: 16px; letter-spacing: .06em; text-transform: uppercase; }
.peer-row .bar { height: 16px; border-radius: 3px; background: var(--ink-faint); transform-origin: left; transform: scaleX(0); transition: transform 1.1s cubic-bezier(.2,.7,.2,1) .15s; }
.peer-row.tx .bar { background: var(--rust); }
.peer-row .val { font-family: var(--mono); font-size: 15px; text-align: right; color: var(--ink-2); }
.peer-row .val .ap { color: var(--ink-faint); }
.in .peer-row .bar { transform: scaleX(1); }
@media (max-width: 920px) { .count-grid { grid-template-columns: 1fr; } }

/* ---------- 02 PATHWAYS ---------- */
#pathways { background: var(--surface-2); border-bottom: 1px solid var(--line); }
.units-wrap { margin: 44px 0 10px; }
.unit-row { display: grid; grid-template-columns: 215px 1fr 70px; gap: 14px; align-items: center; padding: 8px 0; }
.unit-row .lab { font-family: var(--cond); font-size: 15px; font-weight: 500; letter-spacing: .04em; color: var(--ink-2); text-align: right; }
.unit-row .dots { display: flex; flex-wrap: wrap; gap: 4px; }
.unit-row .dots i { width: 9px; height: 9px; border-radius: 2px; background: var(--c-other); opacity: 0; transform: scale(.3); transition: opacity .4s ease, transform .4s ease; }
.in .unit-row .dots i { opacity: 1; transform: none; }
.unit-row .ct { font-family: var(--mono); font-size: 14px; color: var(--ink-soft); }
@media (max-width: 720px) { .unit-row { grid-template-columns: 1fr; gap: 6px; } .unit-row .lab { text-align: left; } }

.quote-band {
  margin: clamp(48px, 7vw, 84px) auto; max-width: 880px; text-align: center;
  padding: clamp(28px, 5vw, 52px) clamp(20px, 4vw, 56px);
  border-top: 1px solid var(--line-strong); border-bottom: 1px solid var(--line-strong);
}
.quote-band .q { font-family: var(--serif); font-size: clamp(26px, 4vw, 42px); line-height: 1.22; color: var(--ink); }
.quote-band .q em { color: var(--rust); font-style: italic; }
.quote-band .who { margin-top: 18px; font-family: var(--cond); font-size: 14px; font-weight: 600; letter-spacing: .18em; text-transform: uppercase; color: var(--ink-soft); }

.path-groups { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 18px; margin-top: 40px; }
.path-group { background: var(--surface); border: 1px solid var(--line); border-radius: var(--r); padding: 22px 22px 10px; box-shadow: var(--shadow-sm); }
.path-group > .gname { font-family: var(--cond); font-weight: 600; font-size: 14px; letter-spacing: .16em; text-transform: uppercase; color: var(--ink-soft); padding-bottom: 12px; border-bottom: 1px solid var(--line); display: flex; align-items: center; gap: 9px; }
.path-group > .gname i { width: 10px; height: 10px; border-radius: 50%; flex: none; }
.path-item { padding: 13px 0; border-bottom: 1px solid var(--line); }
.path-item:last-child { border-bottom: none; }
.path-item summary { list-style: none; cursor: pointer; display: block; }
.path-item summary::-webkit-details-marker { display: none; }
.path-item .who { font-family: var(--serif); font-size: 19px; color: var(--ink); display: flex; justify-content: space-between; align-items: baseline; gap: 10px; }
.path-item .who::after { content: "+"; font-family: var(--mono); color: var(--ink-faint); font-size: 15px; transition: transform .3s ease; }
.path-item[open] .who::after { content: "–"; }
.path-item .cite { font-family: var(--mono); font-size: 11.5px; color: var(--ink-faint); letter-spacing: .02em; margin-top: 3px; }
.path-item .plain { font-size: 15.5px; color: var(--ink-2); padding: 9px 0 4px; line-height: 1.6; }

.lowbar {
  margin-top: 44px; display: grid; grid-template-columns: minmax(0, 1.1fr) minmax(0, .9fr); gap: 0;
  border: 1px solid var(--line-strong); border-radius: var(--r); overflow: hidden; background: var(--surface);
  box-shadow: var(--shadow-sm);
}
.lowbar .then { padding: clamp(22px, 3.5vw, 36px); }
.lowbar .now { padding: clamp(22px, 3.5vw, 36px); background: var(--teal-bg); border-left: 1px solid var(--line); }
.lowbar .tag { font-family: var(--cond); font-weight: 600; font-size: 13px; letter-spacing: .2em; text-transform: uppercase; margin-bottom: 10px; }
.lowbar .then .tag { color: var(--rust-deep); }
.lowbar .now .tag { color: var(--teal); }
.lowbar h3 { font-size: clamp(20px, 2.4vw, 26px); }
.lowbar p { font-size: 15.5px; color: var(--ink-2); margin-top: 10px; }
@media (max-width: 820px) { .lowbar { grid-template-columns: 1fr; } .lowbar .now { border-left: none; border-top: 1px solid var(--line); } }

/* ---------- 03 DEPTH (core sample) ---------- */
#depth { border-bottom: 1px solid var(--line); }
.depth-grid { display: grid; grid-template-columns: minmax(0, .92fr) minmax(0, 1.08fr); gap: clamp(28px, 5vw, 70px); align-items: start; }
.depth-sticky { position: sticky; top: 84px; }
@media (max-width: 920px) { .depth-grid { grid-template-columns: 1fr; } .depth-sticky { position: static; } }

.core { background: var(--surface); border: 1px solid var(--line); border-radius: var(--r); box-shadow: var(--shadow); padding: 26px 26px 20px; }
.core-head { display: flex; justify-content: space-between; align-items: baseline; gap: 12px; border-bottom: 1px solid var(--line); padding-bottom: 14px; margin-bottom: 6px; }
.core-head .where { font-family: var(--cond); font-weight: 600; font-size: 14px; letter-spacing: .18em; text-transform: uppercase; color: var(--ink-soft); }
.core-head .n { font-family: var(--mono); font-size: 13px; color: var(--ink-faint); }
.core-count { font-family: var(--serif); font-size: clamp(40px, 5vw, 56px); line-height: 1.05; padding: 12px 0 4px; }
.core-count b { color: var(--rust); font-weight: 400; }
.core-count .sub { display: block; font-size: 16.5px; font-family: var(--sans); color: var(--ink-soft); margin-top: 6px; line-height: 1.5; }
.strata { margin-top: 14px; }
.stratum {
  position: relative; display: grid; grid-template-columns: 44px 1fr; gap: 0; align-items: stretch;
  margin: 7px 0; opacity: 0; transform: translateY(-14px);
  transition: opacity .55s ease, transform .55s cubic-bezier(.2,.7,.2,1);
}
.stratum.in { opacity: 1; transform: none; }
.stratum .tick { font-family: var(--mono); font-size: 10.5px; color: var(--ink-faint); display: flex; flex-direction: column; align-items: center; justify-content: center; border-right: 1px dashed var(--line-strong); margin-right: 12px; }
.stratum .band { border-radius: 7px; padding: 12px 16px; border-left: 5px solid; }
.stratum .band .nm { font-family: var(--cond); font-weight: 600; font-size: 16.5px; letter-spacing: .03em; color: var(--ink); line-height: 1.25; }
.stratum .band .why { font-size: 13.5px; color: var(--ink-2); margin-top: 2px; }
.stratum .band .ty { display: inline-block; font-family: var(--mono); font-size: 10.5px; letter-spacing: .06em; text-transform: uppercase; color: var(--ink-soft); margin-top: 6px; }
.strata-flags { margin-top: 16px; padding-top: 14px; border-top: 1px dashed var(--line-strong); }
.strata-flags .fl-h { font-family: var(--cond); font-size: 12.5px; font-weight: 600; letter-spacing: .18em; text-transform: uppercase; color: var(--ink-faint); margin-bottom: 8px; }
.strata-flags .fl { display: inline-block; font-size: 13px; color: var(--ink-2); background: var(--paper-deep); border: 1px solid var(--line); border-radius: 999px; padding: 4px 12px; margin: 0 6px 6px 0; }
.core-foot { font-family: var(--mono); font-size: 11px; color: var(--ink-faint); margin-top: 14px; line-height: 1.55; }

.county-bars { margin-top: 46px; }
.cb-row { display: grid; grid-template-columns: 110px 1fr 56px; gap: 14px; align-items: center; padding: 7px 0; }
.cb-row .nm { font-family: var(--cond); font-size: 15px; font-weight: 500; letter-spacing: .04em; color: var(--ink-2); text-align: right; }
.cb-row .bar { height: 13px; border-radius: 3px; background: var(--ink-faint); transform-origin: left; transform: scaleX(0); transition: transform 1s cubic-bezier(.2,.7,.2,1); }
.cb-row.hl .bar { background: var(--rust); }
.cb-row .val { font-family: var(--mono); font-size: 13.5px; color: var(--ink-soft); }
.in .cb-row .bar { transform: scaleX(1); }

/* ---------- 04 PRICE ---------- */
#price { background: var(--surface-2); border-bottom: 1px solid var(--line); }
.bignum-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(250px, 1fr)); gap: 18px; margin: 40px 0 10px; }
.bignum { background: var(--surface); border: 1px solid var(--line); border-radius: var(--r); padding: 26px 24px 20px; box-shadow: var(--shadow-sm); }
.bignum .v { font-family: var(--serif); font-size: clamp(38px, 4.6vw, 54px); line-height: 1; color: var(--ink); }
.bignum .v small { font-size: .55em; color: var(--ink-soft); }
.bignum.rust .v { color: var(--rust); }
.bignum .l { font-size: 14.5px; color: var(--ink-2); margin-top: 12px; line-height: 1.55; }
.bignum .s { font-family: var(--mono); font-size: 11px; color: var(--ink-faint); margin-top: 12px; }

.oversight { margin: 56px 0 8px; }
.ov-row { display: grid; grid-template-columns: 200px 1fr; gap: 18px; align-items: center; margin: 20px 0; }
.ov-row .lab { font-family: var(--cond); font-size: 15px; font-weight: 600; letter-spacing: .08em; text-transform: uppercase; color: var(--ink-2); text-align: right; }
.ov-row .lab small { display: block; font-family: var(--mono); font-size: 11px; font-weight: 400; letter-spacing: .02em; text-transform: none; color: var(--ink-faint); margin-top: 3px; }
.ov-track { position: relative; }
.ov-bar { height: 30px; border-radius: 5px; transform-origin: left; transform: scaleX(0); transition: transform 1.2s cubic-bezier(.2,.7,.2,1) .1s; }
.ov-row.peer .ov-bar { background: var(--ink-2); }
.ov-row.tx .ov-bar { background: var(--rust); }
.ov-val { position: absolute; top: 50%; transform: translateY(-50%); font-family: var(--mono); font-size: 14px; color: var(--ink); white-space: nowrap; padding-left: 10px; }
.ov-val.inside { left: auto; right: 10px; padding-left: 0; color: var(--paper); }
.in .ov-bar { transform: scaleX(1); }
@media (max-width: 720px) { .ov-row { grid-template-columns: 1fr; gap: 6px; } .ov-row .lab { text-align: left; } }

.case-file {
  margin: 56px 0 0; background: var(--surface); border: 1px solid var(--line-strong); border-radius: var(--r);
  box-shadow: var(--shadow); overflow: hidden;
  display: grid; grid-template-columns: 8px 1fr;
}
.case-file::before { content: ""; background: repeating-linear-gradient(-45deg, var(--rust), var(--rust) 8px, var(--paper) 8px, var(--paper) 14px); }
.case-file .body { padding: clamp(22px, 3.5vw, 36px); }
.case-file .tag { font-family: var(--mono); font-size: 12px; letter-spacing: .16em; text-transform: uppercase; color: var(--rust-deep); margin-bottom: 10px; }
.case-file h3 { font-size: clamp(24px, 3vw, 32px); }
.case-file p { font-size: 15.5px; color: var(--ink-2); margin-top: 12px; max-width: 760px; }

.cant-count {
  margin-top: 56px; max-width: 820px;
  border: 1.5px dashed var(--line-strong); border-radius: var(--r);
  padding: clamp(22px, 3.5vw, 34px);
  background: transparent;
}
.cant-count .tag { font-family: var(--cond); font-size: 13px; font-weight: 600; letter-spacing: .2em; text-transform: uppercase; color: var(--teal); margin-bottom: 10px; }
.cant-count h3 { font-size: clamp(21px, 2.6vw, 27px); }
.cant-count p { font-size: 15.5px; color: var(--ink-2); margin-top: 10px; }

/* ---------- 05 THE CASE ---------- */
#case { border-bottom: 1px solid var(--line); }
.benefit-list { margin-top: 36px; max-width: 860px; }
.benefit { display: grid; grid-template-columns: 64px 1fr; gap: 18px; padding: 30px 0; border-bottom: 1px solid var(--line); }
.benefit:last-child { border-bottom: none; }
.benefit .idx { font-family: var(--serif); font-size: 34px; color: var(--line-strong); line-height: 1; padding-top: 4px; }
.benefit h3 { font-size: clamp(21px, 2.6vw, 26px); margin-bottom: 8px; }
.benefit p { font-size: 16px; color: var(--ink-2); }
.benefit .bq { font-family: var(--serif); font-style: italic; font-size: 18px; color: var(--ink); border-left: 2px solid var(--teal); padding-left: 14px; margin-top: 14px; }
.benefit .bq .by { display: block; font-family: var(--mono); font-style: normal; font-size: 11.5px; color: var(--ink-faint); margin-top: 6px; }
.benefit .srcs { font-family: var(--mono); font-size: 11px; color: var(--ink-faint); margin-top: 10px; }
@media (max-width: 640px) { .benefit { grid-template-columns: 1fr; gap: 6px; } .benefit .idx { font-size: 24px; } }

/* ---------- 06 HEARING (dark band) ---------- */
#hearing { background: var(--room); color: var(--room-ink); border-bottom: 1px solid #000; }
#hearing .kicker { color: var(--ochre); }
#hearing .kicker::before { background: var(--ochre); }
#hearing .ghost-no { -webkit-text-stroke-color: #403B33; }
#hearing h2.beat-title, #hearing h3 { color: var(--room-ink); }
#hearing .copy p { color: var(--room-soft); }
#hearing .copy p strong, #hearing .copy p b { color: var(--room-ink); }
#hearing a { color: var(--ochre); }
.charge-doc {
  max-width: 780px; margin: 40px 0; padding: clamp(24px, 4vw, 40px);
  background: var(--room-2); border: 1px solid #454037; border-radius: var(--r-sm);
  position: relative;
}
.charge-doc::before { content: "INTERIM CHARGE"; position: absolute; top: -11px; left: 24px; background: var(--ochre); color: var(--room); font-family: var(--cond); font-weight: 600; font-size: 12px; letter-spacing: .2em; padding: 3px 12px; border-radius: 3px; }
.charge-doc p { font-family: var(--serif); font-size: clamp(18px, 2.2vw, 22px); line-height: 1.5; color: var(--room-ink); }
.charge-doc .meta { font-family: var(--mono); font-size: 11.5px; color: var(--room-soft); margin-top: 16px; }

.exchange-list { max-width: 780px; margin-top: 46px; }
.exchange { padding: 22px 0; border-bottom: 1px solid #3B3630; display: grid; grid-template-columns: 190px 1fr; gap: 20px; }
.exchange:last-child { border-bottom: none; }
.exchange .who { font-family: var(--cond); font-weight: 600; font-size: 14.5px; letter-spacing: .1em; text-transform: uppercase; color: var(--ochre); text-align: right; line-height: 1.4; }
.exchange .who small { display: block; font-family: var(--sans); font-weight: 400; font-size: 12px; letter-spacing: .02em; text-transform: none; color: var(--room-soft); margin-top: 3px; }
.exchange .txt { font-family: var(--serif); font-size: clamp(17px, 2vw, 20px); line-height: 1.5; color: var(--room-ink); }
.exchange .txt .via { display: block; font-family: var(--mono); font-size: 10.5px; color: var(--room-soft); margin-top: 8px; letter-spacing: .03em; }
@media (max-width: 680px) { .exchange { grid-template-columns: 1fr; gap: 6px; } .exchange .who { text-align: left; } }

.timeline { margin-top: 64px; display: grid; grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)); gap: 0; border-top: 1px solid #454037; }
.tl-item { padding: 22px 18px 6px 0; border-left: 1px solid #454037; padding-left: 18px; position: relative; }
.tl-item::before { content: ""; position: absolute; left: -4.5px; top: -4.5px; width: 8px; height: 8px; border-radius: 50%; background: var(--room-soft); }
.tl-item.now::before { background: var(--ochre); box-shadow: 0 0 0 5px rgba(196,125,26,.22); }
.tl-item .yr { font-family: var(--mono); font-size: 13px; color: var(--ochre); letter-spacing: .06em; }
.tl-item .ev { font-size: 13.5px; color: var(--room-soft); line-height: 1.55; margin-top: 8px; }
.tl-item.now .ev { color: var(--room-ink); }

/* ---------- 07 YOURS ---------- */
#yours { background: var(--paper); }
.finder { max-width: 880px; margin: 36px 0 0; background: var(--surface); border: 1px solid var(--line); border-radius: var(--r); box-shadow: var(--shadow); padding: clamp(22px, 4vw, 40px); }
.finder-tabs { display: flex; gap: 8px; margin-bottom: 22px; flex-wrap: wrap; }
.finder-tab {
  font-family: var(--cond); font-size: 14px; font-weight: 600; letter-spacing: .12em; text-transform: uppercase;
  border: 1.5px solid var(--line-strong); background: transparent; color: var(--ink-soft);
  border-radius: 999px; padding: 9px 18px; cursor: pointer; transition: all .25s ease;
}
.finder-tab.on { background: var(--ink); border-color: var(--ink); color: var(--paper); }
.finder-row { display: flex; gap: 12px; flex-wrap: wrap; }
.finder input[type="text"] {
  flex: 1; min-width: 220px;
  font-family: var(--mono); font-size: 18px; color: var(--ink);
  background: var(--paper); border: 1.5px solid var(--line-strong); border-radius: var(--r-sm);
  padding: 14px 18px; outline: none; transition: border-color .25s ease, box-shadow .25s ease;
}
.finder input[type="text"]:focus { border-color: var(--rust); box-shadow: 0 0 0 4px var(--rust-bg); }
.finder input::placeholder { color: var(--ink-faint); }
.finder .go {
  font-family: var(--cond); font-size: 15px; font-weight: 600; letter-spacing: .14em; text-transform: uppercase;
  background: var(--rust); color: #fff; border: none; border-radius: var(--r-sm);
  padding: 14px 28px; cursor: pointer; transition: background .25s ease, transform .25s ease;
}
.finder .go:hover { background: var(--rust-deep); transform: translateY(-1px); }
.finder-hint { font-size: 13.5px; color: var(--ink-soft); margin-top: 12px; }
.finder-err { font-size: 14.5px; color: var(--rust-deep); margin-top: 12px; display: none; }

.result-wrap { display: none; margin-top: 34px; }
.result-wrap.show { display: grid; grid-template-columns: minmax(0, 1.05fr) minmax(0, .95fr); gap: clamp(22px, 4vw, 48px); align-items: start; }
@media (max-width: 920px) { .result-wrap.show { grid-template-columns: 1fr; } }

.share-rail { position: sticky; top: 84px; }
.share-rail .sh-h { font-family: var(--cond); font-weight: 600; font-size: 14px; letter-spacing: .18em; text-transform: uppercase; color: var(--ink-soft); margin-bottom: 14px; }
.share-prev { background: var(--surface); border: 1px solid var(--line); border-radius: var(--r); box-shadow: var(--shadow); padding: 14px; }
.share-prev canvas { width: 100%; height: auto; border-radius: 6px; }
.share-fmt { display: flex; gap: 8px; margin: 14px 0; flex-wrap: wrap; }
.share-fmt button {
  font-family: var(--mono); font-size: 12px; letter-spacing: .04em;
  border: 1.5px solid var(--line-strong); background: transparent; color: var(--ink-soft);
  border-radius: 999px; padding: 7px 14px; cursor: pointer; transition: all .25s ease;
}
.share-fmt button.on { background: var(--ink); border-color: var(--ink); color: var(--paper); }
.share-dl { display: flex; gap: 10px; flex-wrap: wrap; }
@media (max-width: 920px) { .share-rail { position: static; } }

.cta-block {
  margin-top: clamp(56px, 8vw, 90px); max-width: 880px;
  background: var(--ink); color: var(--paper); border-radius: var(--r);
  padding: clamp(28px, 5vw, 52px); box-shadow: var(--shadow);
}
.cta-block .tag { font-family: var(--cond); font-size: 13px; font-weight: 600; letter-spacing: .22em; text-transform: uppercase; color: var(--ochre); margin-bottom: 12px; }
.cta-block h3 { font-size: clamp(26px, 3.6vw, 38px); color: var(--paper); }
.cta-block p { font-size: 16px; color: rgba(245,243,238,.78); margin-top: 12px; max-width: 640px; }
.cta-actions { display: flex; gap: 12px; flex-wrap: wrap; margin-top: 26px; }
.cta-actions .btn { border-color: rgba(245,243,238,.4); color: var(--paper); }
.cta-actions .btn.primary { background: var(--rust); border-color: var(--rust); }
.cta-actions .btn.primary:hover { background: var(--ochre); border-color: var(--ochre); }
.cta-actions .btn.ghosted:hover { border-color: var(--ochre); color: var(--ochre); }

/* ---------- METHOD ---------- */
#method { background: var(--surface-2); border-top: 1px solid var(--line); }
#method .copy p { font-size: 15.5px; }
.src-table { margin-top: 30px; border-top: 1px solid var(--line-strong); max-width: 880px; }
.src-row { display: grid; grid-template-columns: minmax(0, 1fr) auto; gap: 16px; padding: 12px 0; border-bottom: 1px solid var(--line); align-items: baseline; }
.src-row .sl { font-size: 14.5px; color: var(--ink-2); }
.src-row .sl b { color: var(--ink); font-weight: 600; }
.src-row .sl small { display: block; font-family: var(--mono); font-size: 11px; color: var(--ink-faint); margin-top: 2px; }
.src-row a { font-family: var(--cond); font-size: 13px; font-weight: 600; letter-spacing: .1em; text-transform: uppercase; white-space: nowrap; }
.caveats { margin-top: 36px; max-width: 880px; }
.caveats li { font-size: 14.5px; color: var(--ink-2); margin: 8px 0 8px 18px; }

/* ---------- footer ---------- */
.site-foot { background: var(--ink); color: rgba(245,243,238,.75); padding: 44px clamp(20px, 5vw, 48px); }
.foot-inner { max-width: var(--maxw); margin: 0 auto; display: flex; justify-content: space-between; gap: 24px; flex-wrap: wrap; align-items: center; }
.foot-mark { font-family: var(--cond); font-weight: 600; letter-spacing: .2em; text-transform: uppercase; color: var(--paper); font-size: 15px; }
.foot-mark b { color: var(--rust); }
.foot-meta { font-family: var(--mono); font-size: 11.5px; line-height: 1.7; }
.foot-meta a { color: rgba(245,243,238,.85); }

/* skip link */
.skip { position: absolute; left: -9999px; top: 0; background: var(--ink); color: var(--paper); padding: 10px 16px; z-index: 99; }
.skip:focus { left: 12px; top: 12px; }

/* ---------- Beehiiv newsletter popup ---------- */
.newsletter-overlay[hidden] { display: none; }
.newsletter-overlay {
  position: fixed;
  inset: 0;
  z-index: 220;
  display: grid;
  place-items: center;
  padding: 24px;
}
.newsletter-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(35, 33, 29, 0.58);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
}
.newsletter-card {
  position: relative;
  width: min(100%, 460px);
  background: var(--surface);
  border: 1px solid var(--line-strong);
  border-radius: 18px;
  box-shadow: 0 24px 70px rgba(45, 43, 40, 0.24);
  padding: 34px 30px 28px;
  text-align: center;
}
.newsletter-close {
  position: absolute;
  top: 12px;
  right: 14px;
  border: 0;
  background: transparent;
  color: var(--ink-faint);
  font-size: 26px;
  line-height: 1;
  cursor: pointer;
}
.newsletter-label {
  font-family: var(--cond);
  font-weight: 600;
  font-size: 12px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--rust-deep);
  margin-bottom: 10px;
}
.newsletter-card h2 {
  font-size: clamp(27px, 5vw, 38px);
  margin-bottom: 12px;
}
.newsletter-card p {
  color: var(--ink-2);
  margin-bottom: 20px;
}
.newsletter-form {
  display: flex;
  gap: 10px;
  align-items: stretch;
}
.newsletter-form input[type="email"] {
  flex: 1;
  min-width: 0;
  border: 1px solid var(--line-strong);
  border-radius: 999px;
  padding: 12px 15px;
  font: 500 15px var(--sans);
  background: var(--paper);
  color: var(--ink);
}
.newsletter-form button {
  border: 0;
  border-radius: 999px;
  padding: 0 18px;
  background: var(--rust);
  color: var(--paper);
  font: 600 14px var(--cond);
  letter-spacing: .1em;
  text-transform: uppercase;
  cursor: pointer;
}
.newsletter-note {
  margin: 12px 0 0 !important;
  font-size: 12px;
  color: var(--ink-faint) !important;
}
@media (max-width: 560px) {
  .newsletter-form { flex-direction: column; }
  .newsletter-form button { padding: 13px 18px; }
}
