/* ==========================================================================
   Ken Davis for State Representative — Missouri 152nd District
   Design tokens + base + components + Newspaper/Heartland variants
   ==========================================================================
   Brand palette (locked by brief):
     navy   #0a2240   accent  #b4262e   cream  #f5e9c8
     ink    #1f2a3a   paper   #ffffff   muted  #5e697a
*/

:root{
  --navy: #0a2240;
  --navy-700: #08182f;
  --navy-300: #2b3c5d;
  --red: #b4262e;
  --red-700: #8e1c23;
  --cream: #f5e9c8;
  --cream-50: #faf3df;
  --cream-200: #ecdfb9;
  --cream-line: #d8c896;
  --ink: #1f2a3a;
  --paper: #ffffff;
  --muted: #5e697a;
  --rule: rgba(10,34,64,.14);
  --rule-strong: rgba(10,34,64,.42);

  /* Heartland mode tint tokens — overridden per body.tint-* below */
  --tint-bg: #f3f5f8;
  --tint-bg-2: #e7ebf1;
  --tint-line: #d7dde6;
  --tint-card: #ffffff;

  --font-display: "Iowan Old Style", "Source Serif Pro", Georgia, "Cambria", "Times New Roman", serif;
  --font-h1: "Saira", "Inter", system-ui, sans-serif;
  --font-h2: "DM Sans", "Inter", system-ui, sans-serif;
  --font-body: "Inter", system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;

  --container: 1200px;
  --container-narrow: 880px;
  --gutter: clamp(20px, 4vw, 56px);

  --r-sm: 6px;
  --r-md: 10px;
  --r-lg: 16px;

  --shadow-1: 0 1px 0 rgba(10,34,64,.08), 0 6px 24px -12px rgba(10,34,64,.25);
  --shadow-2: 0 2px 0 rgba(10,34,64,.06), 0 18px 48px -22px rgba(10,34,64,.4);
}

/* ---------- Reset / base ---------- */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body{
  margin: 0;
  font-family: var(--font-body);
  font-size: 17px;
  line-height: 1.6;
  color: var(--ink);
  background: var(--paper);
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
}
@media (min-width: 768px){ body{ font-size: 18px; } }

img, svg { display: block; max-width: 100%; height: auto; }
a { color: var(--navy); text-decoration: underline; text-underline-offset: 3px; text-decoration-thickness: 1px; }
a:hover { color: var(--red); }
button { font: inherit; cursor: pointer; }
:focus-visible{ outline: 3px solid var(--red); outline-offset: 3px; border-radius: 2px; }

.skip-link{
  position: absolute; left: -9999px; top: 0; padding: 12px 16px;
  background: var(--navy); color: #fff; text-decoration: none; z-index: 1000;
}
.skip-link:focus { left: 12px; top: 12px; }

.container{ width: 100%; max-width: var(--container); margin: 0 auto; padding: 0 var(--gutter); }
.narrow{ max-width: var(--container-narrow); }

/* ---------- Typography ---------- */
h1, h2, h3, h4 { font-family: var(--font-display); color: var(--navy); font-weight: 700; letter-spacing: -0.01em; margin: 0 0 .5em; text-wrap: balance; }
h1 { font-family: var(--font-h1); font-size: clamp(2.25rem, 5.6vw, 4.2rem); line-height: 1.02; letter-spacing: -0.02em; }
h2 { font-family: var(--font-h2); font-size: clamp(1.75rem, 3.4vw, 2.85rem); line-height: 1.08; }
h3 { font-family: var(--font-h2); font-size: 1.125rem; line-height: 1.25; letter-spacing: .04em; text-transform: uppercase; }
p { margin: 0 0 1em; text-wrap: pretty; max-width: 65ch; }
.lede { font-size: 1.125rem; color: var(--ink); }
@media (min-width: 768px){ .lede{ font-size: 1.25rem; line-height: 1.55; } }

.eyebrow{
  font-family: var(--font-body);
  font-size: .8125rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .18em;
  color: var(--red);
  display: inline-flex; align-items: center; gap: 12px;
  margin: 0 0 14px;
}
.eyebrow::before, .eyebrow::after{
  content: ""; width: 24px; height: 1px; background: currentColor; opacity: .6;
}
.eyebrow.left::before{ display:none; }
.eyebrow.right::after{ display:none; }

/* ---------- Buttons ---------- */
.btn{
  display: inline-flex; align-items: center; justify-content: center; gap: 10px;
  padding: 14px 22px; min-height: 48px;
  font-family: var(--font-body); font-weight: 600; font-size: 1rem; letter-spacing: .01em;
  text-decoration: none;
  border: 2px solid transparent; border-radius: 2px;
  transition: transform .08s ease, background .15s ease, color .15s ease, border-color .15s ease, box-shadow .15s ease;
}
.btn:hover{ transform: translateY(-1px); }
.btn:active{ transform: translateY(0); }
.btn--red{ background: var(--red); color: #fff; border-color: var(--red); }
.btn--red:hover{ background: var(--red-700); border-color: var(--red-700); color:#fff; }
.btn--navy-outline{ background: transparent; color: var(--navy); border-color: var(--navy); }
.btn--navy-outline:hover{ background: var(--navy); color: #fff; }
.btn--navy{ background: var(--navy); color:#fff; border-color: var(--navy); }
.btn--navy:hover{ background: var(--navy-700); color:#fff; }
.btn--cream-outline{ background: transparent; color: #fff; border-color: rgba(255,255,255,.6); }
.btn--cream-outline:hover{ background: #fff; color: var(--navy); border-color:#fff; }
.btn--full{ width: 100%; }
.btn--lg{ padding: 16px 28px; font-size: 1.0625rem; min-height: 54px; }
.btn--ghost{ background: transparent; color: var(--navy); border-color: var(--rule-strong); }
.btn--ghost:hover{ background: var(--cream); }

/* ---------- Top Nav ---------- */
.nav{
  position: sticky; top: 0; z-index: 50;
  background: var(--paper);
  border-bottom: 1px solid var(--rule);
  backdrop-filter: saturate(140%) blur(6px);
}
.nav__inner{
  display: flex; align-items: center; justify-content: space-between;
  gap: 16px;
  height: 68px;
}
.brand{
  display: flex; align-items: center; gap: 12px;
  text-decoration: none; color: var(--navy);
}
.brand__mark{
  width: 40px; height: 40px; border-radius: 2px;
  background: var(--navy); color: var(--cream);
  display: grid; place-items: center;
  font-family: var(--font-display); font-weight: 700; font-size: 1.05rem;
  letter-spacing: .02em;
  position: relative;
  box-shadow: inset 0 0 0 2px var(--navy), inset 0 0 0 3px var(--cream), inset 0 0 0 4px var(--navy);
}
.brand__name{ font-family: var(--font-display); font-weight: 700; font-size: 1.0625rem; line-height: 1.15; color: var(--navy); }
.brand__sub{ display:block; font-family: var(--font-body); font-size: .6875rem; letter-spacing: .18em; text-transform: uppercase; color: var(--muted); font-weight: 600; }

.nav__links{
  display: none;
  align-items: center; gap: 28px;
}
.nav__links a{
  color: var(--ink); text-decoration: none; font-weight: 500; font-size: .95rem;
  padding: 8px 0; position: relative;
}
.nav__links a:hover{ color: var(--red); }
.nav__links a::after{
  content:""; position: absolute; left:0; right:100%; bottom: 2px; height: 2px;
  background: var(--red); transition: right .2s ease;
}
.nav__links a:hover::after{ right: 0; }

.nav__cta{ display: flex; align-items: center; gap: 10px; }
.nav__cta .btn{ padding: 10px 18px; min-height: 40px; font-size: .9375rem; }

.nav__toggle{
  display: inline-flex; align-items: center; gap: 8px;
  background: transparent; border: 1px solid var(--rule-strong); color: var(--navy);
  height: 40px; padding: 0 12px; border-radius: 2px;
}
.nav__toggle svg{ width: 18px; height: 18px; }

@media (min-width: 1024px){
  .nav__links{ display: flex; }
  .nav__toggle{ display: none; }
}

.nav__mobile{
  display: none;
  border-top: 1px solid var(--rule);
  padding: 14px var(--gutter) 22px;
  background: var(--paper);
}
.nav__mobile.is-open{ display: block; }
.nav__mobile ul{ list-style: none; margin: 0; padding: 0; display: grid; gap: 4px; }
.nav__mobile a{
  display: block; padding: 12px 4px; text-decoration: none; color: var(--ink);
  border-bottom: 1px solid var(--rule);
  font-weight: 500;
}
.nav__mobile a:hover{ color: var(--red); }
.nav__mobile .btn{ margin-top: 14px; }

/* ---------- Sections ---------- */
section{ padding: clamp(56px, 8vw, 110px) 0; position: relative; }
section + section{ border-top: 1px solid var(--rule); }
.section-head{ max-width: 760px; margin-bottom: clamp(32px, 4vw, 56px); }
.section-head .eyebrow.left{ padding: 0; }
.section-head p{ color: var(--muted); font-size: 1.0625rem; max-width: 60ch; }

/* ---------- HERO: shared shell ---------- */
.hero{ padding: 0; border-top: none; }
.hero-news, .hero-heart{ display: none; }
body.mode-newspaper .hero-news{ display: block; }
body.mode-heartland .hero-heart{ display: block; }

/* ---------- HERO: NEWSPAPER variant ---------- */
.hero-news{
  background: var(--paper);
  color: var(--ink);
  border-bottom: 1px solid var(--rule);
}
.masthead{
  background: var(--navy);
  color: var(--cream);
  font-family: var(--font-display);
  font-size: .8125rem;
  letter-spacing: .22em;
  text-transform: uppercase;
}
.masthead__inner{
  display: flex; justify-content: space-between; align-items: center;
  height: 38px;
  gap: 12px;
}
.masthead__inner > span{ white-space: nowrap; }
.masthead__inner > span:nth-child(2){ display: none; }
.masthead__inner > span:nth-child(4){ display: none; }
@media (min-width: 720px){
  .masthead__inner > span:nth-child(2), .masthead__inner > span:nth-child(4){ display: inline; opacity: .7; }
}

.broadside{
  padding: 28px 0 22px;
  text-align: center;
  border-bottom: 4px double var(--navy);
}
.broadside__title{
  font-family: var(--font-display);
  font-weight: 700;
  font-size: clamp(1.75rem, 4.2vw, 2.5rem);
  letter-spacing: -.01em;
  color: var(--navy);
  margin: 0;
  font-variant: small-caps;
}
.broadside__meta{
  display: flex; justify-content: center; align-items: center; gap: 14px;
  margin-top: 8px;
  font-family: var(--font-body); font-size: .75rem; letter-spacing: .18em; text-transform: uppercase;
  color: var(--muted);
}
.broadside__meta::before, .broadside__meta::after{
  content: ""; flex: 1; height: 1px; background: var(--rule-strong);
  max-width: 140px;
}

.hero-news__grid{
  display: grid;
  grid-template-columns: 1fr;
  gap: 32px;
  padding: clamp(36px, 6vw, 64px) 0 clamp(40px, 6vw, 72px);
  align-items: start;
}
@media (min-width: 900px){
  .hero-news__grid{ grid-template-columns: minmax(320px, 1.35fr) minmax(280px, 1fr); gap: 56px; }
}
.hero-news__lead .eyebrow{ margin-bottom: 18px; }
.hero-news__headline{
  font-size: clamp(2.5rem, 6.2vw, 4.5rem);
  line-height: .98;
  margin: 0 0 22px;
  letter-spacing: -.025em;
}
.hero-news__lede{
  font-size: clamp(1.0625rem, 1.5vw, 1.25rem);
  line-height: 1.5;
  color: var(--ink);
  max-width: 36ch;
}
.hero-news__lede::first-letter{
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 3.6em;
  float: left;
  line-height: .85;
  padding: 6px 10px 0 0;
  color: var(--navy);
}
.hero-news__rules{
  display: grid; grid-template-columns: 1fr auto 1fr; gap: 16px; align-items: center;
  margin: 22px 0 14px;
  font-family: var(--font-body); font-size: .75rem; letter-spacing: .22em; text-transform: uppercase; color: var(--muted);
}
.hero-news__rules::before, .hero-news__rules::after{ content:""; height: 1px; background: var(--rule-strong); }
.hero-news__ctas{ display: flex; flex-wrap: wrap; gap: 12px; margin-top: 24px; }

.hero-news__portrait{
  position: relative;
  border: 1px solid var(--rule-strong);
  background: var(--cream-50);
  aspect-ratio: 4 / 5;
  display: grid; place-items: end stretch;
  overflow: hidden;
}
.hero-news__portrait .silhouette{ width: 100%; height: 100%; }
.hero-news__caption{
  position: absolute; left: 0; right: 0; bottom: 0;
  background: var(--navy);
  color: var(--cream);
  padding: 12px 16px;
  font-family: var(--font-body); font-size: .75rem; letter-spacing: .14em; text-transform: uppercase;
  display: flex; justify-content: space-between; gap: 10px;
}
.hero-news__caption strong{ color: #fff; letter-spacing: .12em; }
.hero-news__stamp{
  position: absolute; top: 14px; right: 14px;
  border: 2px solid var(--red);
  color: var(--red);
  font-family: var(--font-display);
  text-transform: uppercase; letter-spacing: .14em;
  font-size: .7rem;
  padding: 8px 12px;
  transform: rotate(-6deg);
  background: rgba(255,255,255,.85);
  font-weight: 700;
}

/* Bylines / column rules under hero (newspaper) */
.subribbon{
  background: var(--cream);
  border-top: 1px solid var(--cream-line);
  border-bottom: 1px solid var(--cream-line);
  font-family: var(--font-display);
  font-size: .95rem;
  color: var(--navy);
}
.subribbon__row{
  display: grid; grid-template-columns: 1fr; gap: 6px 24px;
  padding: 18px 0;
}
@media (min-width: 768px){
  .subribbon__row{ grid-template-columns: repeat(4, 1fr); }
}
.subribbon__item{ display: flex; align-items: center; gap: 10px; }
.subribbon__item .dot{ width: 8px; height: 8px; background: var(--red); border-radius: 50%; flex: none; }

body.mode-heartland .subribbon{ display: none; }

/* ---------- HERO: HEARTLAND variant ---------- */

/* Heartland tint variants (gray / navy / red) */
body.mode-heartland.tint-gray{
  --tint-bg: #f1f4f8;
  --tint-bg-2: #e6ebf2;
  --tint-line: #d4dbe4;
  --tint-card: #ffffff;
}
body.mode-heartland.tint-navy{
  --tint-bg: #eaeff6;
  --tint-bg-2: #d9e2ee;
  --tint-line: #b9c6d8;
  --tint-card: #ffffff;
}
body.mode-heartland.tint-red{
  --tint-bg: #f7ecec;
  --tint-bg-2: #f1dcdd;
  --tint-line: #e5cfd0;
  --tint-card: #ffffff;
}

.hero-heart{
  background:
    radial-gradient(1100px 480px at 80% -10%, rgba(180,38,46,.04), transparent 60%),
    linear-gradient(180deg, var(--tint-bg) 0%, var(--tint-bg-2) 100%);
  color: var(--ink);
  position: relative;
  overflow: hidden;
}
.hero-heart::before{
  /* subtle paper texture */
  content:"";
  position: absolute; inset: 0;
  background-image:
    repeating-linear-gradient(0deg, rgba(31,42,58,.025) 0 1px, transparent 1px 4px),
    repeating-linear-gradient(90deg, rgba(31,42,58,.018) 0 1px, transparent 1px 4px);
  pointer-events: none;
  mix-blend-mode: multiply;
  opacity: .8;
}
.hero-heart__inner{
  display: grid; grid-template-columns: 1fr; gap: 36px;
  padding: clamp(44px, 7vw, 88px) 0 clamp(24px, 3vw, 40px);
  position: relative;
  align-items: center;
}
@media (min-width: 900px){
  .hero-heart__inner{ grid-template-columns: 1.15fr 1fr; gap: 56px; }
}
.hero-heart__seal{
  display: inline-flex; align-items: center; gap: 12px;
  background: var(--red); color: #fff;
  font-family: var(--font-display); font-weight: 700;
  font-size: .8125rem; letter-spacing: .2em; text-transform: uppercase;
  padding: 8px 14px;
  border-radius: 2px;
  position: relative;
  margin-bottom: 24px;
}
.hero-heart__seal::after{
  content:""; position: absolute; right: -6px; top: 50%;
  width: 6px; height: 6px; background: var(--red);
  transform: translate(0,-50%) rotate(45deg);
}
.hero-heart__star{
  width: 14px; height: 14px; fill: #fff;
}
.hero-heart__headline{
  font-family: var(--font-h1);
  font-size: clamp(2.5rem, 6vw, 4.4rem);
  line-height: 1.02;
  margin: 0 0 22px;
  letter-spacing: -.018em;
}
.hero-heart__headline em{
  font-style: italic; color: var(--red); font-weight: 700;
}
.hero-heart__lede{
  font-size: clamp(1.0625rem, 1.5vw, 1.2rem);
  line-height: 1.55;
  color: var(--ink);
  max-width: 44ch;
}
.hero-heart__ctas{ display: flex; flex-wrap: wrap; gap: 12px; margin-top: 28px; }
.hero-heart__meta{
  display: flex; flex-wrap: wrap; gap: 18px 28px;
  margin-top: 36px;
  padding-top: 22px;
  border-top: 1px solid var(--tint-line);
  font-family: var(--font-body); font-size: .8125rem; letter-spacing: .14em; text-transform: uppercase;
  color: var(--muted);
}
.hero-heart__meta strong{ color: var(--navy); display: block; font-family: var(--font-display); font-size: 1.05rem; letter-spacing: -.01em; text-transform: none; margin-top: 2px; font-weight: 700; }

.hero-heart__portrait{
  position: relative;
  width: 100%;
  max-width: 560px;
  margin: 0 auto;
  align-self: end;
  margin-bottom: clamp(-40px, -3vw, -24px);
  /* No frame — photo sits directly on the section background */
}
.hero-heart__portrait img{
  width: 100%; height: auto;
  display: block;
  filter: drop-shadow(0 18px 28px rgba(10,34,64,.16));
}

.hero-heart__landscape{
  margin-top: clamp(64px, 8vw, 110px);
  position: relative;
}
.hero-heart__landscape svg{ width: 100%; display: block; }

body.mode-newspaper .hero-heart__landscape{ display: none; }

/* ---------- Section: Ken's Story ---------- */
.story{
  background: var(--paper);
}
.story__grid{
  display: grid; grid-template-columns: 1fr; gap: 40px; align-items: start;
}
@media (min-width: 900px){
  .story__grid{ grid-template-columns: 1fr 360px; gap: 64px; }
}
.story__body p{ font-size: 1.0625rem; line-height: 1.7; }
.story h2{ font-size: clamp(1.5rem, 2.6vw, 2.1rem); line-height: 1.15; }
.story .section-head{ margin-bottom: clamp(28px, 3vw, 40px); }
.story__aside{
  background: var(--cream-50);
  border: 1px solid var(--cream-line);
  padding: 28px;
  position: relative;
}
.story__aside h4{
  font-family: var(--font-display);
  font-size: 1.0625rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--navy);
  margin: 0 0 14px;
}
.story__aside dl{ margin: 0; display: grid; grid-template-columns: 1fr; gap: 14px; }
.story__aside dt{ font-family: var(--font-body); font-size: .75rem; letter-spacing: .14em; text-transform: uppercase; color: var(--muted); margin-bottom: 2px; }
.story__aside dd{ margin: 0; font-family: var(--font-display); font-size: 1.0625rem; color: var(--navy); }

body.mode-heartland .story__aside{
  background: transparent;
  border: 0;
  border-top: 1px solid var(--tint-line);
  padding: 22px 0 0;
}
body.mode-heartland .story__aside h4{ color: var(--muted); font-size: .75rem; letter-spacing: .18em; }
body.mode-heartland .story__aside dd{ font-size: .9375rem; font-family: var(--font-body); color: var(--ink); }

/* ---------- Section: Issues ---------- */
.issues{ background: var(--cream-50); }
body.mode-newspaper .issues{ background: var(--paper); }
body.mode-heartland .issues{ background: var(--tint-bg); }
.issues__grid{
  display: grid; grid-template-columns: 1fr; gap: 18px;
}
@media (min-width: 640px){ .issues__grid{ grid-template-columns: 1fr 1fr; } }
@media (min-width: 1024px){ .issues__grid{ grid-template-columns: repeat(3, 1fr); gap: 22px; } }

.issue{
  background: var(--paper);
  border: 1px solid var(--cream-line);
  padding: 28px 26px;
  position: relative;
  display: flex; flex-direction: column;
  transition: transform .15s ease, box-shadow .2s ease, border-color .15s ease;
}
.issue:hover{ transform: translateY(-2px); box-shadow: var(--shadow-2); border-color: var(--navy-300); }
.issue__icon{
  width: 44px; height: 44px;
  display: grid; place-items: center;
  color: var(--navy);
  background: var(--cream);
  border-radius: 2px;
  margin-bottom: 18px;
}
.issue__icon svg{ width: 26px; height: 26px; }
.issue h3{ color: var(--navy); margin-bottom: 10px; font-size: .9375rem; letter-spacing: .14em; }
.issue p{ font-size: 1rem; line-height: 1.55; color: var(--ink); margin: 0; }
.issue__num{
  position: absolute; top: 16px; right: 18px;
  font-family: var(--font-display); font-size: .9rem;
  color: var(--muted); letter-spacing: .1em;
}

body.mode-newspaper .issue{
  border-width: 1px;
  border-top: 3px solid var(--navy);
}
body.mode-newspaper .issue__icon{ background: transparent; border: 1px solid var(--navy); border-radius: 0; }

body.mode-heartland .issue{
  border-radius: 6px;
  border-color: var(--tint-line);
  background: var(--tint-card);
}
body.mode-heartland .issue__icon{ border-radius: 50%; background: var(--tint-bg); }

/* ---------- Section: Record / pull quote ---------- */
.record{ background: var(--paper); }
.record__lead{ max-width: 65ch; }
.record__lead p{ font-size: 1.0625rem; line-height: 1.7; }

.record__stats{
  display: grid; grid-template-columns: 1fr; gap: 14px;
  margin: 28px 0 36px;
}
@media (min-width: 640px){ .record__stats{ grid-template-columns: repeat(3, 1fr); } }
.stat{
  padding: 20px 22px;
  border-left: 3px solid var(--red);
  background: var(--cream-50);
}
.stat strong{
  display: block;
  font-family: var(--font-display);
  font-size: 2rem;
  line-height: 1;
  color: var(--navy);
  margin-bottom: 6px;
}
.stat span{
  font-size: .9375rem;
  color: var(--ink);
}

body.mode-newspaper .stat{ background: transparent; border-left: none; border-top: 2px solid var(--navy); padding-left: 0; }

.pullquote{
  margin: 0;
  padding: 44px 36px 36px;
  background: var(--cream);
  border: 1px solid var(--cream-line);
  position: relative;
}
.pullquote::before{
  content: "\201C";
  position: absolute;
  top: -18px; left: 24px;
  font-family: var(--font-display);
  font-size: 7rem;
  line-height: 1;
  color: var(--navy);
  font-weight: 700;
}
.pullquote blockquote{
  margin: 0;
  font-family: var(--font-display);
  font-size: clamp(1.25rem, 2vw, 1.6rem);
  line-height: 1.4;
  color: var(--navy);
  font-style: italic;
}
.pullquote cite{
  display: block;
  margin-top: 22px;
  font-style: normal;
  font-family: var(--font-body);
  font-size: .75rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--muted);
}
.pullquote cite strong{ color: var(--navy); font-weight: 700; margin-right: 8px; letter-spacing: .12em; }

body.mode-newspaper .pullquote{
  border: none;
  border-top: 4px double var(--navy);
  border-bottom: 4px double var(--navy);
  background: transparent;
  padding: 36px 0;
}
body.mode-newspaper .pullquote::before{ left: 0; top: -10px; }

/* ---------- Section: District ---------- */
.district{ background: var(--navy); color: var(--cream); overflow: hidden; }
.district h2{ color: #fff; }
.district .eyebrow{ color: #f5e9c8; }
.district .eyebrow::before, .district .eyebrow::after{ background: rgba(245,233,200,.45); }
.district p{ color: rgba(255,255,255,.86); }
.district__grid{
  display: grid; grid-template-columns: 1fr; gap: 36px; align-items: center;
}
@media (min-width: 900px){ .district__grid{ grid-template-columns: 1.1fr 1fr; gap: 56px; } }

.district__chips{
  display: flex; flex-wrap: wrap; gap: 8px;
  margin-top: 26px;
}
.chip{
  display: inline-flex; align-items: center; gap: 8px;
  padding: 8px 14px;
  border: 1px solid rgba(245,233,200,.35);
  font-family: var(--font-body); font-size: .8125rem; letter-spacing: .12em; text-transform: uppercase;
  color: #fff;
  border-radius: 2px;
}
.chip .dot{ width: 6px; height: 6px; background: var(--red); border-radius: 50%; }

.district__art{
  border: 1px solid rgba(245,233,200,.25);
  background: #fff;
  padding: 10px;
}
.district__art svg{ width: 100%; height: auto; }
.district__art img{ width: 100%; height: auto; display: block; }
.district__art figcaption{
  margin: 0;
  padding: 12px 12px 4px;
  font-family: var(--font-body); font-size: .75rem; letter-spacing: .18em; text-transform: uppercase;
  color: var(--navy);
  display: flex; justify-content: space-between; gap: 12px;
}

/* ---------- Section: Upcoming Events ---------- */
.events{ background: var(--cream-50); }
body.mode-newspaper .events{ background: var(--paper); }
body.mode-heartland .events{ background: var(--tint-bg); }
.events__list{ display: grid; grid-template-columns: 1fr; gap: 14px; max-width: 820px; }
.event-card{
  display: grid; grid-template-columns: auto 1fr; gap: 22px; align-items: start;
  background: var(--paper);
  border: 1px solid var(--rule);
  border-left: 3px solid var(--red);
  padding: 22px 24px;
}
body.mode-heartland .event-card{ background: var(--cream-50); }
.event-card__date{ text-align: center; min-width: 60px; padding-top: 2px; }
.event-card__date .mo{
  display: block; font-family: var(--font-body);
  font-size: .72rem; letter-spacing: .16em; text-transform: uppercase;
  color: var(--red); margin-bottom: 4px;
}
.event-card__date .day{
  display: block; font-family: var(--font-display);
  font-size: 2.1rem; font-weight: 700; color: var(--navy); line-height: 1;
}
.event-card__body h3{ font-family: var(--font-display); font-size: 1.2rem; color: var(--navy); margin: 0 0 8px; }
.event-card__meta{
  display: flex; flex-wrap: wrap; gap: 4px 18px;
  color: var(--muted); font-size: .8125rem; letter-spacing: .06em; text-transform: uppercase;
  margin-bottom: 10px;
}
.event-card__body p{ margin: 0; font-size: 1rem; color: var(--ink); line-height: 1.55; max-width: 58ch; }
.events__note{ margin: 24px 0 0; color: var(--muted); font-size: .9375rem; max-width: 60ch; }
.events__note a{ color: var(--red); font-weight: 600; }

/* ---------- Section: Donate ---------- */
.donate{ background: var(--paper); }
body.mode-heartland .donate{ background: var(--tint-bg); }
.donate__grid{ display: block; max-width: 720px; }
.donate__grid > div{ width: 100%; }

.amounts{
  display: grid; grid-template-columns: repeat(2, 1fr); gap: 10px;
  margin: 18px 0 16px;
}
@media (min-width: 520px){ .amounts{ grid-template-columns: repeat(5, 1fr); } }
.amount{
  display: inline-flex; align-items: center; justify-content: center; gap: 6px;
  padding: 16px 10px; min-height: 56px;
  background: var(--paper); color: var(--navy);
  border: 2px solid var(--navy);
  font-family: var(--font-display); font-weight: 700; font-size: 1.15rem;
  text-decoration: none;
  border-radius: 2px;
  transition: background .15s ease, color .15s ease;
}
.amount:hover, .amount.is-active{ background: var(--navy); color: #fff; }
.amount.is-other{ font-family: var(--font-body); font-size: .9375rem; letter-spacing: .08em; text-transform: uppercase; font-weight: 600; }

.donate__action{ display: flex; flex-wrap: wrap; gap: 12px; margin-top: 18px; align-items: center; }
.donate__assure{ color: var(--muted); font-size: .9375rem; margin: 16px 0 0; }
.donate__assure strong{ color: var(--navy); }

.qr-card{
  background: var(--cream-50);
  border: 1px solid var(--cream-line);
  padding: 24px;
  display: grid; grid-template-columns: 96px 1fr; gap: 18px; align-items: center;
}
.qr-card .qr{ width: 96px; height: 96px; background: #fff; border: 1px solid var(--rule-strong); }
.qr-card h4{
  font-family: var(--font-display); font-size: 1.0625rem; margin: 0 0 4px; color: var(--navy);
  letter-spacing: .04em; text-transform: uppercase;
}
.qr-card p{ margin: 0; font-size: .9375rem; color: var(--muted); }

.actblue{
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--font-body); font-size: .8125rem; letter-spacing: .14em; text-transform: uppercase; color: var(--muted);
}
.actblue::before{
  content: ""; width: 18px; height: 18px; background: #338bdc; border-radius: 50%;
  box-shadow: inset 0 0 0 3px #fff, inset 0 0 0 5px #338bdc;
}

/* ---------- Section: Volunteer ---------- */
.volunteer{ background: var(--cream-50); }
body.mode-newspaper .volunteer{ background: var(--paper); border-top: 4px double var(--navy); border-bottom: 4px double var(--navy); }
body.mode-heartland .volunteer{ background: var(--tint-bg); }
body.mode-heartland .form{ background: var(--tint-card); border-color: var(--tint-line); }
body.mode-heartland .check{ background: var(--tint-bg); border-color: var(--tint-line); }

.volunteer__grid{
  display: grid; grid-template-columns: 1fr; gap: 40px; align-items: start;
}
@media (min-width: 900px){ .volunteer__grid{ grid-template-columns: 1fr 1.2fr; gap: 56px; } }

.form{
  background: var(--paper);
  border: 1px solid var(--cream-line);
  padding: clamp(24px, 3vw, 36px);
}
body.mode-newspaper .form{ border-top: 3px solid var(--navy); }
.form-row{ display: grid; grid-template-columns: 1fr; gap: 14px; margin-bottom: 14px; }
@media (min-width: 640px){ .form-row.cols-2{ grid-template-columns: 1fr 1fr; } }
.field{ display: flex; flex-direction: column; gap: 6px; }
.field label{
  font-family: var(--font-body);
  font-size: .8125rem; letter-spacing: .12em; text-transform: uppercase;
  color: var(--navy); font-weight: 600;
}
.field input, .field textarea, .field select{
  font: inherit;
  padding: 12px 14px; min-height: 46px;
  background: var(--paper);
  border: 1px solid var(--rule-strong);
  border-radius: 2px;
  color: var(--ink);
}
.field input:focus, .field textarea:focus, .field select:focus{
  outline: 3px solid rgba(180,38,46,.25);
  border-color: var(--red);
}
.field textarea{ min-height: 110px; resize: vertical; }
.field .help{ font-size: .8125rem; color: var(--muted); }

.checks{ display: grid; grid-template-columns: 1fr; gap: 8px; }
@media (min-width: 520px){ .checks{ grid-template-columns: 1fr 1fr; } }
.check{
  display: flex; align-items: flex-start; gap: 10px;
  padding: 12px 14px;
  border: 1px solid var(--rule);
  background: var(--cream-50);
  cursor: pointer;
  font-size: .95rem;
}
.check input{ margin-top: 3px; accent-color: var(--red); }
.check:hover{ border-color: var(--navy-300); }
.check input:checked + span{ font-weight: 600; color: var(--navy); }

.volunteer__pitch h2{ margin-bottom: 14px; }
.volunteer__pitch ul{
  list-style: none; padding: 0; margin: 22px 0 0;
  display: grid; gap: 10px;
}
.volunteer__pitch li{
  display: grid; grid-template-columns: 28px 1fr; gap: 12px; align-items: start;
  font-size: 1rem;
}
.volunteer__pitch li svg{ width: 22px; height: 22px; color: var(--red); margin-top: 2px; }

/* ---------- Section: Closing CTA (Follow on Facebook) ---------- */
.cta{ background: var(--cream-50); }
body.mode-newspaper .cta{ background: var(--paper); }
body.mode-heartland .cta{ background: var(--tint-bg); }
.cta__panel{
  background: var(--navy);
  color: var(--cream);
  text-align: center;
  max-width: 920px; margin: 0 auto;
  padding: clamp(40px, 6vw, 76px) clamp(24px, 5vw, 64px);
  border-top: 4px solid var(--red);
  position: relative;
}
.cta__icon{
  display: inline-grid; place-items: center;
  width: 58px; height: 58px; border-radius: 50%;
  background: rgba(245,233,200,.12); color: var(--cream);
  margin-bottom: 20px;
}
.cta__panel .eyebrow{ color: var(--cream); margin-bottom: 12px; }
.cta__panel .eyebrow::before, .cta__panel .eyebrow::after{ background: rgba(245,233,200,.5); opacity: 1; }
.cta__panel h2{
  font-family: var(--font-display); color: #fff;
  font-size: clamp(1.9rem, 4.2vw, 2.9rem); line-height: 1.08; margin: 0;
}
.cta__lede{
  color: rgba(255,255,255,.85);
  font-size: 1.125rem; line-height: 1.6;
  max-width: 52ch; margin: 18px auto 0;
}
.cta__actions{ display: flex; flex-wrap: wrap; gap: 14px; justify-content: center; margin-top: 32px; }
.cta__contact{
  color: rgba(245,233,200,.7);
  font-size: .875rem; letter-spacing: .02em;
  margin: 30px 0 0;
}
.cta__contact a{ color: var(--cream); text-decoration: none; }
.cta__contact a:hover{ text-decoration: underline; }

/* Full-bleed variant — navy stretches edge to edge, no surrounding band */
.cta--full{ background: transparent; padding: 0; border-top: 0; }
.cta--full > .container{ max-width: none; padding: 0; width: 100%; }
.cta--full .cta__panel{ max-width: none; margin: 0; }

/* ---------- Footer ---------- */
.footer{
  background: var(--navy);
  color: rgba(255,255,255,.78);
  padding: 56px 0 40px;
  border-top: none;
}
.footer .disclosure{
  background: rgba(255,255,255,.04);
  border-left: 3px solid var(--red);
  padding: 16px 20px;
  font-family: var(--font-display);
  color: #fff;
  font-size: 1rem;
  margin: 0 0 26px;
  max-width: 720px;
}
.footer__cols{
  display: grid; grid-template-columns: 1fr; gap: 32px;
  margin-bottom: 32px;
}
@media (min-width: 768px){ .footer__cols{ grid-template-columns: 1.4fr 1fr 1fr; gap: 48px; } }
.footer h4{
  font-family: var(--font-body); font-size: .75rem; letter-spacing: .18em; text-transform: uppercase;
  color: var(--cream); margin: 0 0 14px; font-weight: 700;
}
.footer ul{ list-style: none; padding: 0; margin: 0; display: grid; gap: 8px; }
.footer__contact li{ color: rgba(255,255,255,.78); line-height: 1.55; font-size: .95rem; }
.footer__contact a{ word-break: break-word; }
.footer a{ color: rgba(255,255,255,.85); text-decoration: none; }
.footer a:hover{ color: var(--cream); }
.footer__brand .brand__mark{ background: var(--cream); color: var(--navy); box-shadow: inset 0 0 0 2px var(--cream), inset 0 0 0 3px var(--navy), inset 0 0 0 4px var(--cream); }
.footer__brand .brand__name{ color: #fff; }
.footer__brand .brand__sub{ color: rgba(245,233,200,.7); }
.footer__bottom{
  border-top: 1px solid rgba(255,255,255,.12);
  padding-top: 22px;
  display: flex; flex-wrap: wrap; justify-content: space-between; gap: 14px;
  font-size: .8125rem; color: rgba(255,255,255,.6);
}
.footer__bottom a{ color: rgba(255,255,255,.85); }

/* ---------- Tweaks panel (vanilla) ---------- */
#tweaks-root{ display: none; }
#tweaks-root.is-open{ display: block; }
.tweaks{
  position: fixed; right: 18px; bottom: 18px;
  z-index: 200;
  width: 300px;
  background: var(--paper);
  border: 1px solid var(--rule-strong);
  box-shadow: var(--shadow-2);
  font-family: var(--font-body);
  border-radius: 6px;
  overflow: hidden;
}
.tweaks__head{
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 16px;
  background: var(--navy); color: #fff;
  font-size: .9rem; letter-spacing: .14em; text-transform: uppercase; font-weight: 600;
}
.tweaks__head button{
  background: transparent; border: 0; color: #fff; font-size: 1rem; padding: 4px 8px; cursor: pointer;
}
.tweaks__body{ padding: 16px; }
.tweaks__label{ font-size: .75rem; letter-spacing: .14em; text-transform: uppercase; color: var(--muted); margin: 4px 0 10px; }
.tweaks__seg{ display: grid; grid-template-columns: 1fr 1fr; gap: 6px; border: 1px solid var(--rule-strong); border-radius: 4px; padding: 4px; }
.tweaks__seg--3{ grid-template-columns: 1fr 1fr 1fr; }
.tweaks__seg button{
  font: inherit;
  padding: 10px 8px;
  border: 0;
  background: transparent;
  color: var(--ink);
  border-radius: 3px;
  font-size: .875rem;
  font-weight: 600;
  cursor: pointer;
}
.tweaks__seg button.is-active{ background: var(--navy); color: #fff; }
.tweaks__note{ font-size: .75rem; color: var(--muted); margin-top: 12px; line-height: 1.5; }

/* ---------- Misc ---------- */
.visually-hidden{ position: absolute; width:1px; height:1px; overflow: hidden; clip: rect(0 0 0 0); white-space: nowrap; }
