/* ============================================================================
   Lapine Ballot — website component kit. Builds on ./tokens.css.
   Source-strength is encoded by FORM + a mono label, never by hue (a11y +
   3-colour discipline). This is the skin advocacy-site-build re-uses.
   ========================================================================== */
@import url("./tokens.css");

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--bg);color:var(--ink);font-family:var(--font-text);font-size:var(--fs-body);line-height:var(--leading-body);-webkit-font-smoothing:antialiased}
img,svg{display:block;max-width:100%}
a{color:var(--link);text-underline-offset:3px;text-decoration-thickness:1.5px}

.container{max-width:var(--maxw);margin:0 auto;padding:0 var(--gutter)}
.container--text{max-width:var(--maxw-text)}

/* ---- type helpers ---- */
.display{font-family:var(--font-display);font-weight:600;letter-spacing:var(--tracking-display);line-height:var(--leading-tight)}
h1,.h1{font-family:var(--font-display);font-weight:600;font-size:var(--fs-h1);letter-spacing:var(--tracking-display);line-height:1.04;margin:0}
h2,.h2{font-family:var(--font-display);font-weight:600;font-size:var(--fs-h2);line-height:1.1;margin:0 0 var(--sp-4)}
h3,.h3{font-family:var(--font-text);font-weight:700;font-size:var(--fs-h3);margin:0 0 var(--sp-2)}
.lede{font-size:var(--fs-lead);line-height:1.55;color:var(--ink-secondary);max-width:var(--maxw-text)}
.eyebrow{font-family:var(--font-mono);font-size:var(--fs-eyebrow);font-weight:500;letter-spacing:var(--tracking-eyebrow);text-transform:uppercase;color:var(--accent)}
.label{font-family:var(--font-mono);font-size:var(--fs-meta);letter-spacing:.1em;text-transform:uppercase;color:var(--ink-meta)}
.mono{font-family:var(--font-mono)}
.meta{font-size:var(--fs-meta);color:var(--ink-meta)}

/* ---- buttons ---- */
.btn{display:inline-flex;align-items:center;gap:var(--sp-2);font-family:var(--font-text);font-weight:700;font-size:.95rem;
  padding:.7rem 1.1rem;border-radius:var(--r-1);border:1.5px solid transparent;cursor:pointer;text-decoration:none;
  transition:background var(--t-fast) var(--ease),border-color var(--t-fast) var(--ease),transform var(--t-fast) var(--ease)}
.btn:active{transform:translateY(1px)}
.btn--accent{background:var(--accent-500);color:#1a1206}
.btn--accent:hover{background:var(--accent-bright)}
.btn--ghost{border-color:var(--hairline-strong);color:var(--ink)}
.btn--ghost:hover{border-color:var(--accent);color:var(--accent)}
.btn:focus-visible{outline:2px solid var(--accent-bright);outline-offset:2px}

/* Email signup input border + focus state — kept in CSS (was inline onfocus/onblur
   handlers) so script-src can stay hash-locked with no 'unsafe-inline'. */
#mce-EMAIL{border:1.5px solid var(--hairline-strong)}
#mce-EMAIL:focus{border-color:var(--accent)}

/* ---- section scaffold ---- */
.section{padding:var(--sp-12) 0;border-top:1px solid var(--hairline)}
.section--flush{border-top:0}
.section__head{margin-bottom:var(--sp-6)}

/* ---- site header ---- */
.site-header{position:sticky;top:0;z-index:var(--z-sticky);background:color-mix(in srgb,var(--bg) 88%,transparent);
  backdrop-filter:blur(8px);border-bottom:1px solid var(--hairline)}
.site-header__in{display:flex;align-items:center;justify-content:space-between;gap:var(--sp-5);padding:var(--sp-3) var(--gutter);max-width:var(--maxw);margin:0 auto}
.brand{display:flex;align-items:center;gap:var(--sp-3);text-decoration:none;color:var(--ink)}
.brand__seal{width:56px;height:56px;flex:none;border-radius:50%;filter:drop-shadow(0 1px 3px rgba(0,0,0,.55))}
.brand b{font-family:var(--font-display);font-weight:600;font-size:1.05rem;letter-spacing:-.01em}
.brand small{display:block;font-family:var(--font-mono);font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;color:var(--accent)}
.site-nav{display:flex;gap:var(--sp-5);align-items:center}
.site-nav a{font-size:.9rem;color:var(--ink-secondary);text-decoration:none}
.site-nav a:hover{color:var(--accent)}
.site-nav a.btn--accent{color:#1a1206}            /* keep accent button text dark + readable */
.site-nav a.btn--accent:hover{color:#1a1206}
/* keep the primary CTA reachable on mobile; only the section jump-links collapse */
@media(max-width:720px){.site-nav a:not(.btn--accent){display:none}}

/* ---- movement section: copy + seal badge ---- */
.movement__grid{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:var(--sp-8);align-items:start}
.movement__copy .lede{max-width:64ch}
.movement__badge{margin:0;justify-self:end}
.movement__badge img{display:block;width:220px;height:220px;border-radius:50%;
  filter:drop-shadow(0 4px 18px rgba(0,0,0,.5))}
@media(max-width:820px){
  .movement__grid{grid-template-columns:1fr;gap:var(--sp-5);justify-items:start}
  .movement__badge{order:-1;justify-self:center;margin:0 auto}
  .movement__badge img{width:112px;height:112px}
}

/* ---- eyebrow status chip (the fact boundary, sparingly) ---- */
.status{display:inline-flex;align-items:center;gap:var(--sp-2);font-family:var(--font-mono);font-size:var(--fs-eyebrow);
  letter-spacing:.12em;text-transform:uppercase;color:var(--accent);border:1px solid var(--line-accent);
  padding:.35rem .6rem;border-radius:var(--r-1)}
.status .d{width:7px;height:7px;border-radius:50%;background:var(--accent)}

/* =====================================================================
   SOURCE CHIPS — uniform; each links to its source (opens in a new tab)
   ===================================================================== */
.chips{display:flex;flex-wrap:wrap;gap:var(--sp-2)}
.chip{display:inline-flex;align-items:center;gap:.4rem;font-family:var(--font-mono);font-size:.8rem;
  letter-spacing:.06em;text-transform:uppercase;padding:.25rem .55rem;border-radius:var(--r-1);
  background:var(--ink-50);color:#0b1422;border:1px solid transparent;white-space:nowrap;
  text-decoration:none;transition:background var(--t-fast),color var(--t-fast)}
.chip::before{content:"";width:6px;height:6px;border-radius:1px;background:#0b1422;flex:none}
a.chip:hover,a.chip:focus-visible{background:var(--accent);color:#0b1422;outline:none}

/* ---- the three provisions ---- */
.provisions{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--sp-5)}
@media(max-width:760px){.provisions{grid-template-columns:1fr}}
.prov{background:var(--surface);border:1px solid var(--hairline);border-top:3px solid var(--brand-on-dark);
  border-radius:var(--r-1);padding:var(--sp-5)}
.prov--light{border-top-color:var(--accent-500)}
.prov h3{font-family:var(--font-display);font-weight:600;font-size:1.4rem}
.prov p{margin:var(--sp-2) 0 0;color:var(--ink-secondary);font-size:.96rem}

/* ---- big numbers strip ---- */
.numbers{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--sp-5)}
@media(max-width:860px){.numbers{grid-template-columns:repeat(2,1fr)}}
@media(max-width:460px){.numbers{grid-template-columns:1fr}}
.num{border-left:2px solid var(--hairline-strong);padding-left:var(--sp-4)}
.num--accent{border-left-color:var(--accent)}
.num b{display:block;font-family:var(--font-display);font-weight:600;font-size:var(--fs-num);line-height:1;
  font-variant-numeric:tabular-nums;letter-spacing:-.02em}
.num--accent b{color:var(--accent)}
.num span{display:block;margin-top:var(--sp-2);font-size:.85rem;color:var(--ink-secondary)}
.num .src{margin-top:var(--sp-3)}
.numbers--pair{grid-template-columns:repeat(2,1fr);margin-top:var(--sp-6)}
@media(max-width:460px){.numbers--pair{grid-template-columns:1fr}}

/* ---- mini-hero: the 55 dBA cap leads the record ---- */
.numbers-lead{display:grid;grid-template-columns:minmax(180px,.8fr) 2fr;gap:var(--sp-8);align-items:start;
  background:var(--surface);border:1px solid var(--hairline);border-left:3px solid var(--accent);
  border-radius:var(--r-1);padding:var(--sp-7)}
@media(max-width:780px){.numbers-lead{grid-template-columns:1fr;gap:var(--sp-7)}}
.numbers-lead__stat b{display:block;font-family:var(--font-display);font-weight:600;
  font-size:clamp(3.2rem,7vw,5.2rem);line-height:.9;letter-spacing:-.02em;color:var(--ink);
  font-variant-numeric:tabular-nums}
.numbers-lead__stat b .u{font-size:1.4rem;letter-spacing:0}
.numbers-lead__stat span{display:block;margin-top:var(--sp-3);color:var(--ink-secondary);font-size:.95rem}
.numbers-lead__stat .src{margin-top:var(--sp-4)}

/* ---- 55 dBA decibel scale (lives inside the .numbers-lead mini-hero) ---- */
.dbscale{margin:0;min-width:0}
.dbscale__head{font-family:var(--font-display);font-weight:600;font-size:1.2rem;margin:0}
.dbscale__track{position:relative;height:8px;border-radius:999px;background:var(--hairline-strong);
  margin:calc(var(--sp-10) + var(--sp-2)) 0 var(--sp-5)}
.dbscale__fill{position:absolute;left:0;top:0;height:100%;width:25.2%;border-radius:999px;background:var(--positive)}
.dbmark{position:absolute;top:50%}
.dbmark::before{content:"";position:absolute;left:0;top:50%;transform:translate(-50%,-50%);
  width:2px;height:16px;background:var(--ink-500);border-radius:1px}
.dbmark__val{position:absolute;left:0;bottom:14px;transform:translateX(-50%);white-space:nowrap;
  font-family:var(--font-display);font-weight:600;font-size:1.05rem;color:var(--ink);line-height:1}
.dbmark__val small{font-size:.7rem;font-weight:500;color:var(--ink-secondary)}
/* scale labels live in a readable legend under the track (>=14px mono),
   not as cramped under-mark text — keeps the numbers on the scale, names below */
.dbscale__key{display:flex;flex-wrap:wrap;gap:var(--sp-2) var(--sp-5);list-style:none;margin:0 0 var(--sp-6);
  padding:0;font-family:var(--font-mono);font-size:.875rem;letter-spacing:.01em;color:var(--ink-secondary);line-height:1.4}
.dbscale__key li{display:flex;align-items:baseline;gap:.4rem}
.dbscale__key b{color:var(--ink);font-weight:600;font-variant-numeric:tabular-nums}
.dbscale__key--cap b{color:var(--accent)}
.dbmark--cap::before{height:24px;width:3px;background:var(--accent)}
.dbmark--cap .dbmark__val{font-size:1.4rem;color:var(--accent)}
.dbmark--loud::before{background:var(--ink-300);height:20px}
.dbmark--loud .dbmark__val{color:var(--ink)}
/* keep the edge numbers from clipping the container: anchor them inward */
.dbmark--first .dbmark__val{left:0;transform:none;text-align:left}
.dbmark--loud .dbmark__val{left:auto;right:0;transform:none;text-align:right}
.dbscale__legend{margin:0;color:var(--ink-secondary);font-size:.92rem;max-width:74ch}
.dbscale__legend strong{color:var(--ink)}
@media(max-width:560px){
  .dbmark__val{font-size:.9rem} .dbmark--cap .dbmark__val{font-size:1.1rem}
}

/* ---- ranked claim cards (Tier-A arguments) ---- */
.claims{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--sp-5)}
@media(max-width:760px){.claims{grid-template-columns:1fr}}
.claim{background:var(--surface);border:1px solid var(--hairline);border-radius:var(--r-1);padding:var(--sp-5);display:flex;flex-direction:column;gap:var(--sp-3)}
.claim__n{font-family:var(--font-mono);font-size:.8rem;color:var(--ink-meta);letter-spacing:.1em}
.claim h3{font-family:var(--font-display);font-weight:600;font-size:1.25rem}
.claim p{margin:0;color:var(--ink-secondary);font-size:.96rem}

/* ---- CTA band ---- */
.cta{background:linear-gradient(180deg,var(--surface-sunk),var(--bg-deep));border:1px solid var(--hairline);
  border-radius:var(--r-1);padding:var(--sp-10) var(--sp-8);text-align:center}
.cta h2{margin-bottom:var(--sp-3)}
.cta .row{display:flex;gap:var(--sp-3);justify-content:center;flex-wrap:wrap;margin-top:var(--sp-5)}

/* ---- footer ---- */
.site-footer{border-top:1px solid var(--hairline);padding:var(--sp-8) 0;color:var(--ink-meta);font-size:.85rem}
.site-footer a{color:var(--ink-secondary)}

/* =====================================================================
   "HOLD THE LINE" centerpiece (Concept A) — visitor-controlled contrast
   ===================================================================== */
.hero{padding:var(--sp-8) 0 var(--sp-12)}
/* full-width ballot-measure banner above the hero */
.hero__banner{display:flex;align-items:center;justify-content:center;gap:var(--sp-3);width:100%;
  margin:0 0 var(--sp-8);padding:var(--sp-4) var(--sp-5);font-family:var(--font-mono);
  font-size:clamp(1rem,2.4vw,1.6rem);font-weight:500;letter-spacing:.16em;text-transform:uppercase;
  text-align:center;color:var(--accent);background:color-mix(in srgb,var(--accent) 8%,transparent);
  border:1px solid var(--line-accent);border-radius:var(--r-1)}
.hero__banner .d{width:.5em;height:.5em;border-radius:50%;background:var(--accent);flex:none}
.hero__grid{display:grid;grid-template-columns:1.1fr .9fr;gap:var(--sp-8);align-items:center}
@media(max-width:880px){.hero__grid{grid-template-columns:1fr}}
.hero h1{margin:var(--sp-4) 0}
.hero .lede{margin-bottom:var(--sp-5)}
.hero .row{display:flex;gap:var(--sp-3);flex-wrap:wrap}

/* ---- hero centerpiece: "one night, two rules" (shielded vs unshielded) ---- */
.lightfig{margin:0}
.compare{position:relative;border-radius:var(--r-1);overflow:hidden;border:1px solid var(--hairline);
  aspect-ratio:4/3;background:var(--ground-900)}
.compare svg{display:block;width:100%;height:100%}
.compare .glare{animation:glarePulse 3.4s ease-in-out infinite}
.compare .plabel{position:absolute;top:10px;font-family:var(--font-mono);font-size:.6rem;letter-spacing:.08em;
  text-transform:uppercase;color:var(--ink-300);background:rgba(6,11,20,.5);padding:3px 7px;border-radius:var(--r-1)}
.compare .plabel--l{left:10px} .compare .plabel--r{right:10px}
.compare .cap{position:absolute;bottom:10px;font-family:var(--font-mono);font-size:.62rem;letter-spacing:.03em;
  color:var(--ink-50);background:rgba(6,11,20,.6);padding:3px 7px;border-radius:var(--r-1);max-width:44%}
.compare .cap--l{left:10px} .compare .cap--r{right:10px;text-align:right}

/* ---- ordinance page ---- */
.ord-body{max-width:var(--maxw-text)}
.ord-body h2{font-family:var(--font-text);font-weight:700;font-size:var(--fs-h3);margin:var(--sp-8) 0 var(--sp-2);color:var(--ink)}
.ord-body p{margin:var(--sp-3) 0;color:var(--ink-secondary)}
.ord-body ol{margin:var(--sp-3) 0;padding-left:var(--sp-6);color:var(--ink-secondary)}
.ord-body ol li{margin-bottom:var(--sp-2)}
.ord-body ol ol{list-style-type:lower-alpha;margin-top:var(--sp-2)}
.ord-notice{background:var(--surface);border:1px solid var(--hairline);border-left:3px solid var(--accent);border-radius:var(--r-1);padding:var(--sp-4) var(--sp-5);margin:var(--sp-6) 0}
.ord-notice p{margin:0;color:var(--ink-secondary);font-size:.92rem}
.ord-notice strong{color:var(--ink)}

/* "Where other communities stand" review page: full-width body + rendered-markdown tables */
.review-body{max-width:none}
.review-body h2{font-family:var(--font-text);font-weight:700;font-size:var(--fs-h3);margin:var(--sp-8) 0 var(--sp-2);color:var(--ink)}
.review-body h3{font-family:var(--font-text);font-weight:700;margin:var(--sp-6) 0 var(--sp-2);color:var(--ink)}
.review-body blockquote{border-left:3px solid var(--accent);background:var(--surface);padding:var(--sp-3) var(--sp-4);margin:var(--sp-4) 0;border-radius:var(--r-1);color:var(--ink-secondary)}
.review-body ul{margin:var(--sp-3) 0;padding-left:var(--sp-6);color:var(--ink-secondary)}
.review-body ul li{margin-bottom:var(--sp-2)}
.review-body code{font-family:var(--font-mono);font-size:.85em}
.review-body table{width:100%;border-collapse:collapse;margin:var(--sp-3) 0 var(--sp-6);font-size:.78rem;display:block;overflow-x:auto}
.review-body thead th{background:var(--surface);color:var(--ink);text-align:left;font-family:var(--font-mono);font-weight:600;font-size:.7rem;text-transform:uppercase;letter-spacing:.04em;white-space:nowrap}
.review-body th,.review-body td{border:1px solid var(--hairline);padding:var(--sp-2) var(--sp-3);vertical-align:top;color:var(--ink-secondary)}
.review-body td a{color:var(--accent)}

@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
}

@keyframes tw{from{opacity:.4}to{opacity:1}}
@keyframes glarePulse{0%,100%{opacity:.8}50%{opacity:1}}
