:root{
  --ink: #0d0c0a;
  --ink-2: #1a1814;
  --ink-3: #2c2820;
  --muted: #57534a;
  --paper: #faf5e6;
  --paper-warm: #f4ecd2;
  --paper-2: #fffdf6;
  --gold: #e5b22d;
  --gold-deep: #b88718;
  --gold-dark: #7a5a0e;
  --gold-soft: #f5d77a;
  --gold-pale: #fbe9a8;
  --green: #1a3a2a;
  --green-deep: #0f2419;
  --rule: rgba(13,12,10,.10);
  --rule-strong: rgba(13,12,10,.22);
  --display: "Anton", "Impact", "Arial Black", sans-serif;
  --sans: "Barlow", -apple-system, BlinkMacSystemFont, system-ui, sans-serif;
  --condensed: "Barlow Condensed", "Barlow", sans-serif;
}

*{box-sizing:border-box}
html, body{margin:0;padding:0}
body{
  font-family:var(--sans);
  color:var(--ink);
  background:var(--paper-2);
  line-height:1.6;
  font-weight:400;
  font-size:16px;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

.container{max-width:1320px;margin:0 auto;padding:0 32px}

.eyebrow{
  font-family:var(--condensed);font-weight:700;
  font-size:13px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--gold-deep);
  display:inline-flex;align-items:center;gap:14px;
}
.eyebrow:before{content:"";width:36px;height:1.5px;background:var(--gold);display:inline-block}
.dark .eyebrow{color:var(--gold-soft)}
.dark .eyebrow:before{background:var(--gold)}
.eyebrow.center{justify-content:center}
.eyebrow.center:before{display:none}

/* ============ Topstrip ============ */
.topstrip{
  background:var(--ink);
  color:var(--paper);
  font-family:var(--condensed);font-weight:600;
  font-size:12px;letter-spacing:.22em;text-transform:uppercase;
  padding:11px 32px;
  display:flex;justify-content:space-between;align-items:center;gap:16px;
}
.topstrip .gold{color:var(--gold-soft)}
.topstrip .diamond{color:var(--gold);margin:0 8px;font-size:9px}

/* ============ Navigation ============ */
.nav{
  position:absolute;top:36px;left:0;right:0;z-index:60;
}
.nav-inner{
  max-width:1320px;margin:0 auto;padding:0 32px;
  display:flex;align-items:center;justify-content:space-between;gap:24px;
  border-bottom:1px solid rgba(245,234,200,.18);
  padding-bottom:18px;padding-top:18px;
}
.nav-logo{
  display:block;height:62px;width:auto;
}
.nav-logo img{height:100%;width:auto;display:block}

.navlinks{display:flex;gap:36px;align-items:center;flex:1;justify-content:center}
.navlinks a{
  font-family:var(--condensed);font-weight:600;font-size:13px;
  letter-spacing:.20em;text-transform:uppercase;
  color:rgba(250,245,230,.86);
  position:relative;padding:6px 0;
  transition:color .2s;
}
.navlinks a:hover{color:var(--gold-soft)}
.navlinks a.active{color:var(--gold-soft)}

.nav-cta{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--condensed);font-weight:700;font-size:12px;
  letter-spacing:.22em;text-transform:uppercase;
  color:var(--ink);background:var(--gold);
  padding:11px 18px;
  border:1.5px solid var(--gold);
  transition:all .2s;
}
.nav-cta:hover{background:transparent;color:var(--gold-soft);border-color:var(--gold-soft)}

.menutoggle{
  display:none;background:transparent;border:1.5px solid rgba(245,234,200,.4);
  color:var(--gold-soft);padding:8px 12px;font-size:18px;cursor:pointer;
}

/* ============ Hero ============ */
.hero{
  position:relative;
  background:var(--ink);
  min-height:760px;
  overflow:hidden;
  display:grid;
  grid-template-columns:1.1fr .9fr;
  padding:0;
}
.hero:before{
  content:"";position:absolute;inset:0;z-index:0;
  background:
    radial-gradient(900px 700px at 100% 20%, rgba(229,178,45,.10), transparent 60%),
    radial-gradient(700px 500px at 0% 90%, rgba(26,58,42,.18), transparent 60%);
  pointer-events:none;
}

.hero-text{
  padding:170px 60px 70px 64px;
  display:flex;flex-direction:column;justify-content:center;
  color:var(--paper);
  position:relative;
  z-index:2;
}

.hero-eyebrow{
  display:flex;align-items:center;gap:16px;
  font-family:var(--condensed);font-weight:700;
  font-size:13px;letter-spacing:.24em;text-transform:uppercase;
  color:var(--gold);
  margin-bottom:30px;
}
.hero-eyebrow:before{content:"";width:48px;height:1.5px;background:var(--gold-deep);display:inline-block}

.hero h1{
  margin:0;
  font-family:var(--display);
  font-weight:400;
  letter-spacing:-.005em;
  line-height:.92;
  color:var(--paper);
  text-transform:uppercase;
}
.hero h1 .first{
  display:block;
  font-size:clamp(80px, 10vw, 154px);
  color:var(--gold);
  letter-spacing:.005em;
}
.hero h1 .last{
  display:block;
  font-size:clamp(86px, 10.4vw, 160px);
  color:var(--paper);
  letter-spacing:.005em;
  margin-top:-12px;
}

.hero-title{
  margin-top:24px;
  font-family:var(--condensed);font-weight:600;
  font-size:18px;letter-spacing:.16em;text-transform:uppercase;
  line-height:1.45;
  color:var(--paper);
}
.hero-title .gold{color:var(--gold)}

.hero-rule{
  width:90px;height:2px;background:var(--gold);
  margin:26px 0;
}

.hero-lede{
  font-family:var(--sans);font-weight:400;
  font-size:16.5px;line-height:1.65;color:rgba(250,245,230,.85);
  max-width:560px;margin:0;
}
.hero-lede strong{color:var(--paper);font-weight:600}

.hero-pills{
  margin-top:34px;
  display:flex;gap:10px;flex-wrap:wrap;
}
.pill{
  display:inline-flex;align-items:center;
  font-family:var(--condensed);font-weight:700;font-size:13px;
  letter-spacing:.22em;text-transform:uppercase;
  color:var(--gold);background:transparent;
  padding:11px 20px;
  border:1.5px solid var(--gold);
}

.hero-actions{
  margin-top:32px;display:flex;gap:12px;flex-wrap:wrap;
}
.cta{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--condensed);font-weight:700;font-size:13px;
  letter-spacing:.20em;text-transform:uppercase;
  padding:14px 24px;
  border:1.5px solid var(--gold);
  background:var(--gold);color:var(--ink);
  cursor:pointer;transition:all .2s ease;text-decoration:none;
}
.cta:hover{background:transparent;color:var(--gold-soft);border-color:var(--gold-soft)}
.cta.ghost{background:transparent;color:var(--paper);border-color:rgba(250,245,230,.5)}
.cta.ghost:hover{background:var(--paper);color:var(--ink);border-color:var(--paper)}
.cta.dark{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.cta.dark:hover{background:var(--gold);color:var(--ink);border-color:var(--gold)}
.cta.arrow:after{content:"\2192";margin-left:6px;font-weight:700}

/* Hero photo - contextual courtroom portrait */
.hero-photo{
  position:relative;
  min-height:760px;
  overflow:hidden;
  z-index:1;
}
.hero-photo img{
  position:absolute;
  inset:0;
  width:100%;height:100%;
  object-fit:cover;
  object-position:center center;
  filter:contrast(1.04) brightness(0.98) saturate(0.95);
}
.hero-photo:before{
  content:"";position:absolute;inset:0;z-index:2;
  background:
    linear-gradient(90deg, rgba(13,12,10,.7) 0%, rgba(13,12,10,.25) 10%, rgba(13,12,10,0) 22%, rgba(13,12,10,0) 100%);
  pointer-events:none;
}
.hero-photo:after{
  content:"";position:absolute;inset:0;z-index:2;
  background:
    linear-gradient(180deg, rgba(13,12,10,0) 65%, rgba(13,12,10,.45) 92%, rgba(13,12,10,.7) 100%),
    radial-gradient(ellipse at 60% 35%, rgba(229,178,45,.06), transparent 55%);
  pointer-events:none;
}

/* ============ Tagline strip ============ */
.tagline-strip{
  background:var(--gold);color:var(--ink);
  padding:18px 32px;
  font-family:var(--condensed);font-weight:700;font-size:14px;
  letter-spacing:.22em;text-transform:uppercase;
  text-align:center;
}
.tagline-strip .diamond{color:var(--ink);margin:0 18px;font-size:10px;opacity:.7}

/* ============ Sections ============ */
section{padding:120px 0;position:relative}

.section-head-center{
  text-align:center;
  margin-bottom:80px;
}
.section-head-center .eyebrow{
  display:inline-block;
  font-family:var(--condensed);font-weight:700;
  font-size:13px;letter-spacing:.28em;text-transform:uppercase;
  color:var(--gold-deep);
  margin-bottom:18px;
}
.section-head-center .eyebrow:before{display:none}
.section-head-center h2{
  font-family:var(--display);font-weight:400;
  font-size:clamp(46px, 6vw, 84px);
  letter-spacing:.003em;line-height:.95;margin:0;
  color:var(--ink);
  text-transform:uppercase;
}
.section-head-center h2 .gold{color:var(--gold-deep)}
.section-head-center .rule{
  width:80px;height:2px;background:var(--gold);
  margin:28px auto 0;
}
.section-head-center .sublede{
  margin:28px auto 0;
  font-family:var(--sans);font-weight:400;
  font-size:18px;line-height:1.65;color:var(--muted);
  max-width:680px;
}
.dark .section-head-center h2{color:var(--paper)}
.dark .section-head-center h2 .gold{color:var(--gold)}
.dark .section-head-center .sublede{color:rgba(250,245,230,.78)}
.dark .section-head-center .eyebrow{color:var(--gold-soft)}

/* ============ ABOUT ============ */
.about{background:var(--paper-2)}
.about-grid{
  display:grid;grid-template-columns:.85fr 1.15fr;gap:80px;align-items:start;
}
.about-photo{position:relative}
.about-photo img{width:100%;height:auto;display:block}
.about-photo .badge{
  position:absolute;top:24px;left:24px;
  background:var(--ink);color:var(--gold);
  padding:18px 22px;z-index:2;
}
.about-photo .badge .num{
  font-family:var(--display);font-weight:400;font-size:42px;line-height:.9;color:var(--gold);
}
.about-photo .badge .label{
  font-family:var(--condensed);font-weight:600;font-size:10.5px;
  letter-spacing:.22em;text-transform:uppercase;color:var(--paper);
  margin-top:6px;line-height:1.3;
}
.about-body{
  font-family:var(--sans);font-size:16.5px;line-height:1.75;color:var(--ink-2);
}
.about-body .h2{
  font-family:var(--display);font-weight:400;
  font-size:clamp(40px, 5vw, 60px);
  letter-spacing:.003em;line-height:.95;
  color:var(--ink);margin:0 0 14px;
  text-transform:uppercase;
}
.about-body .h2 .gold{color:var(--gold-deep)}
.about-body .subtitle{
  font-family:var(--condensed);font-weight:600;
  font-size:17px;line-height:1.5;color:var(--ink-3);
  letter-spacing:.06em;text-transform:uppercase;
  margin:0 0 28px;
}
.about-body .rule{
  width:70px;height:2px;background:var(--gold);margin:14px 0 28px;
}
.about-body p{margin:0 0 18px}
.about-body p strong{font-weight:700;color:var(--ink)}

.facts-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:18px;
  margin-top:36px;
}
.fact-card{
  border-left:3px solid var(--gold);
  padding:14px 0 14px 18px;
}
.fact-card .l{
  font-family:var(--condensed);font-weight:700;
  font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--gold-deep);
  margin-bottom:5px;
}
.fact-card .v{
  font-family:var(--condensed);font-weight:700;
  font-size:17px;line-height:1.3;color:var(--ink);
  letter-spacing:.01em;
}

/* ============ PLATFORM ============ */
.platform{
  background:var(--ink);color:var(--paper);position:relative;
}
.platform:before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(900px 600px at 100% 0%, rgba(229,178,45,.08), transparent 60%),
    radial-gradient(700px 500px at 0% 100%, rgba(26,58,42,.16), transparent 60%);
  pointer-events:none;
}
.platform .container{position:relative}
.platform-grid{
  display:grid;grid-template-columns:repeat(3, 1fr);gap:1px;
  background:rgba(250,245,230,.12);
  border:1px solid rgba(250,245,230,.12);
}
.platform-card{
  background:var(--ink);
  padding:50px 38px 44px;
  position:relative;
  min-height:280px;
}
.platform-card .num{
  position:absolute;top:30px;right:32px;
  font-family:var(--display);font-weight:400;
  font-size:60px;line-height:1;
  color:rgba(229,178,45,.20);
  letter-spacing:.02em;
}
.platform-card .icon{
  width:44px;height:44px;
  display:flex;align-items:center;justify-content:center;
  font-size:32px;
  margin-bottom:24px;
}
.platform-card h3{
  font-family:var(--condensed);font-weight:700;
  font-size:19px;letter-spacing:.06em;text-transform:uppercase;
  color:var(--gold);
  margin:0 0 14px;line-height:1.25;
}
.platform-card p{
  font-family:var(--sans);font-size:14.5px;line-height:1.65;
  color:rgba(250,245,230,.78);margin:0;
}

/* ============ ENDORSEMENTS ============ */
.endorse{background:var(--paper)}
.endorse-group{margin-top:64px}
.endorse-group:first-of-type{margin-top:0}
.endorse-group-head{
  display:flex;align-items:baseline;justify-content:space-between;gap:24px;
  padding-bottom:16px;margin-bottom:22px;
  border-bottom:2px solid var(--ink);
}
.endorse-group-head h3{
  font-family:var(--display);font-weight:400;
  font-size:clamp(26px, 3vw, 38px);
  letter-spacing:.005em;color:var(--ink);margin:0;
  text-transform:uppercase;
}
.endorse-group-head .count{
  font-family:var(--condensed);font-weight:700;
  font-size:13px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--gold-deep);
}
.endorse-list{
  display:grid;grid-template-columns:repeat(3, minmax(0,1fr));gap:0;
}
.endorse-list .item{
  padding:13px 12px 13px 0;
  border-bottom:1px solid var(--rule);
  font-family:var(--sans);font-weight:500;font-size:15px;
  color:var(--ink-2);
  display:flex;align-items:center;gap:14px;line-height:1.4;
}
.endorse-list .item:before{
  content:"";width:6px;height:6px;background:var(--gold);
  display:inline-block;flex-shrink:0;transform:rotate(45deg);
}
.endorse-note{
  margin-top:60px;padding:28px 32px;
  background:var(--paper-2);
  border-left:4px solid var(--gold);
  font-family:var(--sans);font-size:15px;color:var(--ink-2);line-height:1.65;
}
.endorse-note strong{
  display:block;font-family:var(--condensed);font-weight:700;
  font-size:13px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink);
  margin-bottom:6px;
}

/* ============ BACKGROUND CARDS ============ */
.background-section{background:var(--paper-2)}
.bg-grid{
  display:grid;grid-template-columns:repeat(4, 1fr);gap:32px;
  margin-top:24px;
}
.bg-card{text-align:center;padding:8px 0}
.bg-card .icon{font-size:42px;margin-bottom:18px;display:block}
.bg-card h3{
  font-family:var(--condensed);font-weight:700;
  font-size:19px;letter-spacing:.04em;line-height:1.25;
  color:var(--ink);margin:0 0 12px;
  text-transform:uppercase;
  min-height:50px;
}
.bg-card .rule{
  width:50px;height:2px;background:var(--gold);
  margin:0 auto 16px;
}
.bg-card p{
  font-family:var(--sans);font-size:14px;line-height:1.65;color:var(--muted);margin:0;
}

/* ============ QUOTE STRIP ============ */
.quote-strip{
  background:var(--gold);color:var(--ink);
  padding:90px 32px;
}
.quote-inner{
  max-width:920px;margin:0 auto;
  text-align:center;position:relative;
}
.quote-inner:before{
  content:"\201C";
  font-family:var(--display);font-weight:400;
  font-size:120px;line-height:.7;color:rgba(13,12,10,.18);
  display:block;margin-bottom:12px;
}
.quote-inner blockquote{
  margin:0;
  font-family:var(--sans);font-style:normal;font-weight:500;
  font-size:clamp(20px, 2.4vw, 28px);
  line-height:1.55;color:var(--ink);
  letter-spacing:-.005em;
}
.quote-inner blockquote strong{
  display:block;margin-top:14px;
  font-family:var(--display);font-weight:400;
  font-size:clamp(22px, 2.8vw, 36px);
  letter-spacing:.01em;text-transform:uppercase;line-height:1.05;
}
.quote-inner cite{
  display:block;margin-top:26px;
  font-family:var(--condensed);font-weight:700;font-size:13px;
  letter-spacing:.24em;text-transform:uppercase;
  color:var(--ink);font-style:normal;
}
.quote-inner cite .gold{color:var(--gold-dark)}

/* ============ TAKE ACTION ============ */
.action{background:var(--paper-2)}
.action-cards{
  display:grid;grid-template-columns:repeat(2, 1fr);gap:32px;
  margin-top:24px;
}
.action-card{
  background:var(--paper-2);
  border-top:3px solid var(--gold);
  padding:36px 30px;position:relative;
  box-shadow: 0 1px 0 rgba(13,12,10,.04), 0 12px 36px -16px rgba(13,12,10,.12);
}
.action-card .icon{font-size:38px;margin-bottom:18px;display:block}
.action-card h3{
  font-family:var(--display);font-weight:400;
  font-size:34px;letter-spacing:.005em;line-height:1;
  color:var(--ink);margin:0 0 6px;
  text-transform:uppercase;
}
.action-card .l{
  font-family:var(--condensed);font-weight:700;
  font-size:12px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--gold-deep);margin-bottom:14px;
}
.action-card .rule{width:48px;height:2px;background:var(--gold);margin:0 0 18px}
.action-card p{
  font-family:var(--sans);font-size:14.5px;line-height:1.65;color:var(--ink-3);
  margin:0 0 22px;
}

/* ============ DONATE ============ */
.donate-amounts{
  display:grid;grid-template-columns:repeat(4, 1fr);gap:8px;
  margin-bottom:14px;
}
.donate-amount{
  padding:16px 6px;text-align:center;
  border:1.5px solid var(--rule-strong);background:var(--paper-2);
  cursor:pointer;transition:all .15s;
}
.donate-amount:hover{border-color:var(--gold);background:var(--paper)}
.donate-amount.active{border-color:var(--gold);background:var(--gold);color:var(--ink)}
.donate-amount .amount{
  font-family:var(--display);font-weight:400;font-size:26px;display:block;
  line-height:1;color:var(--ink);letter-spacing:.005em;
}
.donate-amount .tier{
  font-family:var(--condensed);font-weight:700;
  font-size:10px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--gold-deep);margin-top:6px;display:block;
}
.donate-amount.active .tier{color:var(--ink-2)}
.donate-other{
  display:flex;align-items:center;gap:10px;
  padding:14px 16px;
  border:1.5px solid var(--rule-strong);background:var(--paper-2);
  margin-bottom:14px;
}
.donate-other .label{
  font-family:var(--condensed);font-weight:700;font-size:11px;
  letter-spacing:.18em;text-transform:uppercase;color:var(--ink);flex-shrink:0;
}
.donate-other input{
  flex:1;border:none;background:transparent;
  font-family:var(--display);font-weight:400;font-size:22px;
  color:var(--ink);padding:0;
}
.donate-other input:focus{outline:none}
.donate-other:focus-within{border-color:var(--gold);background:var(--paper)}
.donate-offline{
  margin-top:18px;padding:22px 24px;
  background:var(--paper);border:1.5px dashed var(--gold-deep);
  text-align:center;
}
.donate-offline .heading{
  font-family:var(--condensed);font-weight:700;
  font-size:12px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--gold-deep);margin-bottom:8px;
}
.donate-offline .body{
  font-family:var(--sans);font-size:13.5px;line-height:1.6;color:var(--ink-2);
}
.donate-offline .address{
  font-family:var(--condensed);font-weight:700;font-size:14.5px;color:var(--ink);
  margin-top:8px;line-height:1.45;letter-spacing:.02em;
}
.donate-offline .email{
  margin-top:10px;font-family:var(--sans);font-size:12.5px;color:var(--muted);
}
.donate-offline .email a{color:var(--gold-deep);font-weight:600;border-bottom:1px solid var(--gold)}

/* Donate tier display (informational, not interactive) */
.donate-tiers .donate-amount{cursor:default}
.donate-tiers .donate-amount:hover{border-color:var(--rule-strong);background:var(--paper-2)}

/* Suggested giving — clean text presentation, not button-like */
.suggested-giving{
  margin:18px 0 18px;
  padding:18px 20px;
  background:var(--paper);
  border-left:3px solid var(--gold);
}
.suggested-label{
  font-family:var(--condensed);font-weight:700;
  font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--gold-deep);margin-bottom:12px;
}
.suggested-list{
  display:flex;flex-wrap:wrap;gap:6px 22px;
  margin-bottom:10px;
}
.suggested-list .level{
  font-family:var(--sans);font-size:14.5px;
  color:var(--ink-2);line-height:1.5;
}
.suggested-list .level strong{
  font-family:var(--display);font-weight:400;
  font-size:18px;color:var(--ink);
  letter-spacing:.005em;margin-right:6px;
}
.suggested-note{
  font-family:var(--sans);font-style:italic;font-size:13px;
  color:var(--muted);line-height:1.55;
}

.donate-paypal-note{
  font-family:var(--sans);font-style:italic;font-size:13px;
  color:var(--muted);text-align:center;
  margin:0 0 14px;padding:0;
}

/* Donate CTA - styled as a prominent link button */
.donate-cta{
  display:flex;align-items:center;justify-content:center;gap:10px;
  text-decoration:none;
  background:var(--gold);color:var(--ink);
  font-size:14px;letter-spacing:.18em;
  padding:18px 24px;
  transition:all .2s;
}
.donate-cta:hover{background:var(--ink);color:var(--gold)}
.donate-cta:after{content:"\2192";margin-left:6px}

/* QR code section */
.donate-qr{
  display:grid;grid-template-columns:1fr auto;gap:24px;align-items:center;
  margin-top:20px;padding:24px;
  background:var(--paper);
  border-left:3px solid var(--ink);
}
.donate-qr-text{font-family:var(--sans)}
.donate-qr-text .qr-heading{
  font-family:var(--condensed);font-weight:700;
  font-size:14px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--ink);margin-bottom:8px;
}
.donate-qr-text .qr-sub{
  font-size:13px;line-height:1.55;color:var(--ink-2);
}
.donate-qr-img{
  width:140px;height:140px;
  background:#fff;padding:8px;
  flex-shrink:0;
}
.donate-qr-img img{width:100%;height:100%;display:block}

/* ============ FORM FIELDS ============ */
.field{margin-bottom:14px}
.field.full{grid-column:1/-1}
.field label{
  display:block;font-family:var(--condensed);font-weight:700;font-size:11px;
  letter-spacing:.18em;text-transform:uppercase;color:var(--ink-2);
  margin-bottom:6px;
}
.field label .req{color:var(--gold-deep);margin-left:4px}
.field input, .field select, .field textarea{
  width:100%;
  font-family:var(--sans);font-size:14.5px;color:var(--ink);
  padding:11px 13px;background:var(--paper);
  border:1.5px solid var(--rule-strong);border-radius:0;font-weight:400;
  transition:border-color .15s, box-shadow .15s;
}
.field input:focus, .field select:focus, .field textarea:focus{
  outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(229,178,45,.15);
}
.field textarea{min-height:90px;resize:vertical}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.checkrow{
  display:flex;align-items:flex-start;gap:10px;
  padding:12px 14px;background:var(--paper);
  border-left:3px solid var(--gold);
  font-family:var(--sans);font-size:12.5px;color:var(--ink-2);line-height:1.55;
  margin:6px 0 14px;
}
.checkrow input[type=checkbox]{margin-top:2px;accent-color:var(--gold-deep);width:14px;height:14px;flex-shrink:0}
.affidavit-text{
  margin-top:8px;padding:18px 20px;background:var(--paper);border-left:3px solid var(--gold);
  font-family:var(--sans);font-size:13.5px;line-height:1.6;color:var(--ink-2);
}
.affidavit-text strong{font-weight:700;color:var(--ink)}

.action-submit{
  width:100%;margin-top:10px;
  font-family:var(--condensed);font-weight:700;font-size:13px;
  letter-spacing:.22em;text-transform:uppercase;
  padding:14px 24px;border:none;cursor:pointer;
  background:var(--ink);color:var(--gold);
  transition:all .2s;
}
.action-submit:hover{background:var(--gold);color:var(--ink)}
.action-submit:after{content:"\2192";margin-left:8px}
.action-fineprint{
  font-family:var(--sans);font-size:11.5px;color:var(--muted);
  line-height:1.55;margin-top:12px;text-align:center;
}

/* ============ GET IN TOUCH ============ */
.contact{
  background:var(--ink);color:var(--paper);position:relative;
}
.contact:before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(700px 500px at 100% 0%, rgba(229,178,45,.10), transparent 60%),
    radial-gradient(500px 400px at 0% 100%, rgba(26,58,42,.16), transparent 60%);
  pointer-events:none;
}
.contact .container{position:relative}
.contact-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:80px;align-items:start;margin-top:20px}
.contact-info{font-family:var(--sans);font-size:16px;line-height:1.7;color:rgba(250,245,230,.86)}
.contact-info .lets-talk{
  font-family:var(--display);font-weight:400;
  font-size:54px;letter-spacing:.005em;color:var(--paper);
  margin:0 0 14px;line-height:.95;text-transform:uppercase;
}
.contact-info .lets-talk .gold{color:var(--gold)}
.contact-info .intro{
  font-family:var(--sans);font-size:16px;line-height:1.65;color:rgba(250,245,230,.78);
  margin:0 0 36px;
}
.contact-info .block{display:flex;align-items:flex-start;gap:16px;padding:14px 0;border-bottom:1px solid rgba(250,245,230,.12)}
.contact-info .block:last-child{border-bottom:none}
.contact-info .block .iconwrap{
  width:36px;height:36px;background:rgba(229,178,45,.14);
  display:flex;align-items:center;justify-content:center;
  font-size:18px;flex-shrink:0;
}
.contact-info .block .l{
  font-family:var(--condensed);font-weight:700;font-size:11px;
  letter-spacing:.22em;text-transform:uppercase;color:var(--gold-soft);
  margin-bottom:3px;
}
.contact-info .block .v{font-family:var(--sans);font-size:15px;color:var(--paper);line-height:1.4}
.contact-info .block a{color:var(--gold);transition:color .2s}
.contact-info .block a:hover{color:var(--gold-soft)}

.contact-form{
  background:var(--paper-2);color:var(--ink);
  padding:44px 40px;border-top:3px solid var(--gold);
}
.contact-form h3{
  font-family:var(--display);font-weight:400;font-size:34px;
  margin:0 0 4px;color:var(--ink);
  text-transform:uppercase;letter-spacing:.005em;
}
.contact-form .sub{
  font-family:var(--sans);font-size:13px;color:var(--muted);
  margin:0 0 24px;
}

/* ============ FOOTER ============ */
footer{
  background:var(--ink);color:rgba(250,245,230,.65);
  padding:42px 32px 28px;
  border-top:1px solid rgba(250,245,230,.12);
  font-family:var(--sans);
}
.foot-inner{
  max-width:1320px;margin:0 auto;
  display:flex;justify-content:space-between;align-items:center;gap:24px;
  flex-wrap:wrap;
  padding-bottom:24px;border-bottom:1px solid rgba(250,245,230,.12);
}
.foot-logo{height:80px;width:auto;display:block}
.foot-logo img{height:100%;width:auto;display:block}
.foot-pills{display:flex;gap:10px;flex-wrap:wrap}
.foot-pills .pill{
  font-size:11px;padding:8px 16px;color:var(--gold-soft);
  border-color:rgba(229,178,45,.4);
}

.foot-bottom{
  max-width:1320px;margin:0 auto;padding-top:24px;
  display:flex;justify-content:space-between;gap:24px;align-items:flex-start;
  font-family:var(--sans);font-size:11.5px;line-height:1.6;color:rgba(250,245,230,.5);
  flex-wrap:wrap;
}
.foot-bottom .disclaim{max-width:780px}
.foot-bottom .disclaim b{
  display:block;font-family:var(--condensed);font-weight:700;
  font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--gold-soft);margin-bottom:6px;
}

/* ============ Responsive ============ */
@media (max-width: 1100px){
  .hero{grid-template-columns:1fr;min-height:auto}
  .hero-text{padding:160px 32px 40px}
  .hero-photo{min-height:520px}
  .hero-photo img{position:absolute;inset:0;width:100%;height:100%;max-height:none}
  .about-grid{grid-template-columns:1fr;gap:48px}
  .about-photo{max-width:500px;margin:0 auto}
  .platform-grid{grid-template-columns:1fr 1fr}
  .endorse-list{grid-template-columns:1fr 1fr}
  .bg-grid{grid-template-columns:1fr 1fr;gap:40px}
  .action-cards{grid-template-columns:1fr;gap:24px;max-width:560px;margin:24px auto 0}
  .donate-amounts{grid-template-columns:repeat(2, 1fr)}
  .donate-qr{grid-template-columns:1fr;text-align:center;gap:18px}
  .donate-qr-img{margin:0 auto}
  .contact-grid{grid-template-columns:1fr;gap:48px}
  .navlinks{display:none}
  .menutoggle{display:block}
  .nav-cta{display:none}
  .navlinks.open{
    display:flex;flex-direction:column;align-items:flex-start;gap:18px;
    position:absolute;top:100%;left:0;right:0;
    background:var(--ink);padding:24px 32px;z-index:60;
    border-top:1px solid rgba(250,245,230,.18);
  }
  .nav-inner{flex-wrap:wrap;gap:14px;justify-content:space-between}
  .nav-logo{height:52px}
  .section-head{grid-template-columns:1fr;gap:20px}
}
@media (max-width: 640px){
  section{padding:80px 0}
  .container{padding:0 20px}
  .topstrip{font-size:10px;padding:9px 16px;letter-spacing:.16em;flex-wrap:wrap;gap:6px}
  .topstrip .hide-sm{display:none}
  .nav{top:32px}
  .nav-logo{height:44px}
  .hero-text{padding:140px 22px 40px}
  .hero h1 .first{font-size:74px}
  .hero h1 .last{font-size:80px;margin-top:-8px}
  .hero-title{font-size:15px}
  .tagline-strip{font-size:12px;padding:14px 16px;letter-spacing:.16em}
  .tagline-strip .diamond{margin:0 8px}
  .platform-grid{grid-template-columns:1fr}
  .endorse-list{grid-template-columns:1fr}
  .bg-grid{grid-template-columns:1fr;gap:40px}
  .form-row{grid-template-columns:1fr}
  .foot-inner{flex-direction:column;align-items:flex-start;gap:20px}
  .foot-logo{height:60px}
}

.js .reveal{opacity:0;transform:translateY(24px);transition:opacity .8s ease, transform .8s ease}
.js .reveal.in{opacity:1;transform:none}
/* ============================================== */
/* MULTI-PAGE ADDITIONS                            */
/* ============================================== */

/* ============ Page hero (subpages) ============ */
.page-hero{
  background:var(--ink);
  color:var(--paper);
  padding:160px 0 80px;
  position:relative;
  overflow:hidden;
}
.page-hero:before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(900px 600px at 100% 0%, rgba(229,178,45,.10), transparent 60%),
    radial-gradient(700px 500px at 0% 100%, rgba(26,58,42,.16), transparent 60%);
  pointer-events:none;
}
.page-hero .container{position:relative;z-index:1}
.page-hero .breadcrumb{
  font-family:var(--condensed);font-weight:700;
  font-size:12px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--gold-soft);margin-bottom:18px;
}
.page-hero .breadcrumb a{
  color:rgba(245,215,122,.65);
  border-bottom:1px solid rgba(245,215,122,.3);
  padding-bottom:1px;transition:color .15s;
}
.page-hero .breadcrumb a:hover{color:var(--gold)}
.page-hero .breadcrumb .sep{margin:0 10px;color:rgba(245,215,122,.4)}
.page-hero h1{
  font-family:var(--display);font-weight:400;
  font-size:clamp(48px, 7vw, 96px);
  line-height:.95;letter-spacing:.005em;
  margin:0;color:var(--paper);
  text-transform:uppercase;
}
.page-hero h1 .gold{color:var(--gold)}
.page-hero .rule{
  width:80px;height:2px;background:var(--gold);
  margin:24px 0 0;
}
.page-hero .intro{
  font-family:var(--sans);font-size:18px;line-height:1.65;
  color:rgba(250,245,230,.78);
  max-width:680px;margin:28px 0 0;
}

/* ============ Donate strip (every page bottom) ============ */
.donate-strip{
  background:var(--ink);color:var(--paper);
  padding:60px 32px;
  border-top:1px solid rgba(250,245,230,.12);
  position:relative;
  overflow:hidden;
}
.donate-strip:before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(900px 500px at 100% 50%, rgba(229,178,45,.12), transparent 60%);
  pointer-events:none;
}
.donate-strip-inner{
  max-width:1320px;margin:0 auto;
  display:grid;grid-template-columns:1.4fr 1fr;gap:48px;align-items:center;
  position:relative;
}
.donate-strip h2{
  font-family:var(--display);font-weight:400;
  font-size:clamp(28px, 3.5vw, 44px);
  line-height:1;letter-spacing:.005em;
  margin:0 0 10px;color:var(--paper);
  text-transform:uppercase;
}
.donate-strip h2 .gold{color:var(--gold)}
.donate-strip p{
  font-family:var(--sans);font-size:15px;line-height:1.55;
  color:rgba(250,245,230,.78);margin:0;max-width:560px;
}
.donate-strip .cta-group{
  display:flex;gap:12px;justify-content:flex-end;flex-wrap:wrap;
}
.donate-strip .cta{
  background:var(--gold);color:var(--ink);
  border-color:var(--gold);
}
.donate-strip .cta:hover{background:transparent;color:var(--gold-soft);border-color:var(--gold-soft)}
.donate-strip .cta.ghost{
  background:transparent;color:var(--paper);border-color:rgba(250,245,230,.4);
}
.donate-strip .cta.ghost:hover{background:var(--paper);color:var(--ink);border-color:var(--paper)}

/* ============ Home page teaser sections ============ */
.home-teaser{
  background:var(--paper-2);
  padding:100px 0;
}
.home-teaser.dark{background:var(--ink);color:var(--paper)}
.home-teaser-grid{
  display:grid;grid-template-columns:.85fr 1.15fr;gap:64px;align-items:center;
}
.home-teaser-grid.reverse{grid-template-columns:1.15fr .85fr}
.home-teaser-photo img{
  width:100%;height:auto;display:block;
}
.home-teaser-body .eyebrow{margin-bottom:16px}
.home-teaser-body h2{
  font-family:var(--display);font-weight:400;
  font-size:clamp(40px, 5vw, 68px);
  letter-spacing:.003em;line-height:.95;
  color:var(--ink);margin:0 0 20px;
  text-transform:uppercase;
}
.home-teaser.dark .home-teaser-body h2{color:var(--paper)}
.home-teaser-body h2 .gold{color:var(--gold-deep)}
.home-teaser.dark .home-teaser-body h2 .gold{color:var(--gold)}
.home-teaser-body p{
  font-family:var(--sans);font-size:16.5px;line-height:1.7;
  color:var(--ink-2);margin:0 0 16px;
}
.home-teaser.dark .home-teaser-body p{color:rgba(250,245,230,.85)}
.home-teaser-body .rule{
  width:60px;height:2px;background:var(--gold);
  margin:12px 0 24px;
}
.home-teaser-body .more-link{
  display:inline-flex;align-items:center;gap:10px;
  margin-top:22px;
  font-family:var(--condensed);font-weight:700;
  font-size:13px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--gold-deep);
  padding-bottom:8px;
  border-bottom:2px solid var(--gold);
  transition:gap .2s;
}
.home-teaser.dark .home-teaser-body .more-link{color:var(--gold)}
.home-teaser-body .more-link:hover{gap:18px}
.home-teaser-body .more-link:after{content:"\2192"}

/* Home record snapshot - mini cards */
.home-record-snapshot{
  display:grid;grid-template-columns:repeat(3, 1fr);gap:1px;
  background:rgba(250,245,230,.12);
  border:1px solid rgba(250,245,230,.12);
  margin-top:48px;
}
.home-record-snapshot .platform-card{min-height:220px}

/* Home coalition snapshot */
.coalition-snapshot{
  display:grid;grid-template-columns:repeat(4, 1fr);gap:24px;
  margin-top:48px;
}
.coalition-stat{
  text-align:center;
  padding:24px 16px;
  background:var(--paper);
  border-top:3px solid var(--gold);
}
.coalition-stat .num{
  font-family:var(--display);font-weight:400;
  font-size:64px;line-height:.9;
  color:var(--ink);letter-spacing:.005em;
}
.coalition-stat .label{
  font-family:var(--condensed);font-weight:700;
  font-size:12px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--ink-2);margin-top:8px;line-height:1.3;
}

/* Home action quick links */
.home-action-cluster{
  display:grid;grid-template-columns:repeat(4, 1fr);gap:20px;
  margin-top:40px;
}
.action-link-card{
  display:block;
  background:var(--paper-2);
  border-top:3px solid var(--gold);
  padding:32px 26px;
  text-align:left;
  transition:transform .2s, box-shadow .2s;
  box-shadow: 0 1px 0 rgba(13,12,10,.04), 0 12px 36px -16px rgba(13,12,10,.12);
}
.action-link-card:hover{
  transform:translateY(-4px);
  box-shadow: 0 1px 0 rgba(13,12,10,.04), 0 20px 50px -20px rgba(13,12,10,.18);
}
.action-link-card .icon{font-size:32px;margin-bottom:14px;display:block}
.action-link-card h3{
  font-family:var(--display);font-weight:400;
  font-size:28px;line-height:1;color:var(--ink);
  margin:0 0 8px;text-transform:uppercase;letter-spacing:.005em;
}
.action-link-card p{
  font-family:var(--sans);font-size:13.5px;line-height:1.55;
  color:var(--muted);margin:0 0 14px;
}
.action-link-card .arrow{
  font-family:var(--condensed);font-weight:700;
  font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--gold-deep);
}
.action-link-card .arrow:after{content:" \2192"}

/* ============ Active nav state ============ */
.navlinks a.active{color:var(--gold-soft);position:relative}
.navlinks a.active:after{
  content:"";position:absolute;bottom:-2px;left:0;right:0;
  height:2px;background:var(--gold);
}

/* ============ Responsive multi-page ============ */
@media (max-width: 1100px){
  .donate-strip-inner{grid-template-columns:1fr;gap:24px;text-align:center}
  .donate-strip .cta-group{justify-content:center}
  .donate-strip p{margin:0 auto}
  .home-teaser-grid, .home-teaser-grid.reverse{grid-template-columns:1fr;gap:40px}
  .home-record-snapshot{grid-template-columns:1fr 1fr}
  .coalition-snapshot{grid-template-columns:1fr 1fr}
  .home-action-cluster{grid-template-columns:1fr 1fr;gap:16px}
  .page-hero{padding:140px 0 60px}
}
@media (max-width: 640px){
  .donate-strip{padding:48px 20px}
  .home-record-snapshot{grid-template-columns:1fr}
  .coalition-snapshot{grid-template-columns:1fr 1fr;gap:14px}
  .coalition-stat .num{font-size:48px}
  .home-action-cluster{grid-template-columns:1fr;gap:14px}
  .page-hero{padding:120px 0 50px}
}
