/* =========================================================================
   COLBY WATSON FOR CONGRESS  —  NC-08
   Design system. Brand-continuous with the campaign ad graphics.
   ========================================================================= */

:root{
  --ink:#0E1A2B;
  --navy:#14294A;
  --navy-2:#1B3560;
  --red:#D8382E;
  --red-hi:#E8483D;
  --gold:#E7B23C;
  --cream:#F4EFE3;
  --paper:#FBF8F1;
  --tint:#EAF0F8;      /* soft blue section bg */
  --line:#dfe4ec;
  --wht:#ffffff;
  --muted:#5c6a7d;

  --maxw:1180px;
  --pad:clamp(20px,5vw,64px);
  --radius:14px;
  --shadow-sm:0 4px 14px rgba(14,26,43,.10);
  --shadow:0 18px 44px rgba(14,26,43,.20);

  --sans:"Public Sans",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  --disp:"Barlow Condensed","Public Sans",sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--sans);
  color:var(--ink);
  background:var(--paper);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}

/* ---------- Type ---------- */
h1,h2,h3,h4,.disp{font-family:var(--disp);font-weight:800;line-height:1.02;letter-spacing:.01em;text-transform:uppercase}
h1{font-size:clamp(2.6rem,6vw,4.6rem)}
h2{font-size:clamp(2rem,4.6vw,3.3rem)}
h3{font-size:clamp(1.4rem,2.6vw,1.9rem)}
p{font-size:clamp(1rem,1.15vw,1.12rem)}
.eyebrow{font-family:var(--disp);font-weight:700;text-transform:uppercase;letter-spacing:.14em;
  font-size:clamp(.74rem,2.2vw,.98rem);color:var(--red)}
.lead{font-size:clamp(1.1rem,1.5vw,1.32rem);line-height:1.55}

/* ---------- Layout ---------- */
.container{max-width:var(--maxw);margin:0 auto;padding-left:var(--pad);padding-right:var(--pad)}
.section{padding:clamp(56px,8vw,110px) 0}
.section--tint{background:var(--tint)}
.section--cream{background:var(--cream)}
.section--navy{background:var(--navy);color:var(--wht)}
.section--ink{background:var(--ink);color:var(--wht)}
.section-head{max-width:760px;margin-bottom:44px}
.section-head.center{margin-left:auto;margin-right:auto;text-align:center}
.section--navy .eyebrow,.section--ink .eyebrow{color:var(--gold)}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:.5em;font-family:var(--disp);font-weight:700;
  text-transform:uppercase;letter-spacing:.05em;font-size:1.05rem;
  padding:.72em 1.5em;border:2px solid transparent;border-radius:10px;transition:.18s;white-space:nowrap}
.btn:focus-visible{outline:3px solid var(--gold);outline-offset:2px}
.btn-donate{background:var(--red);color:#fff}
.btn-donate:hover{background:var(--red-hi);transform:translateY(-2px)}
.btn-primary{background:var(--navy);color:#fff}
.btn-primary:hover{background:var(--navy-2);transform:translateY(-2px)}
.btn-gold{background:var(--gold);color:var(--ink)}
.btn-gold:hover{filter:brightness(1.05);transform:translateY(-2px)}
.btn-ghost{background:transparent;color:currentColor;border-color:currentColor}
.btn-ghost:hover{background:currentColor}
.btn-ghost:hover span{color:var(--navy)}
.btn-lg{font-size:1.2rem;padding:.85em 1.9em}
.btn .arrow{transition:.18s}
.btn:hover .arrow{transform:translateX(3px)}

/* ---------- Header / Nav ---------- */
.site-header{position:fixed;top:0;left:0;right:0;z-index:100;transition:.28s;padding:14px 0}
.site-header.scrolled{background:var(--navy);box-shadow:0 6px 24px rgba(0,0,0,.22);padding:8px 0}
.nav{display:flex;align-items:center;justify-content:space-between;gap:20px}
.brand{display:flex;align-items:center;gap:12px;color:#fff}
.brand .mark{font-family:var(--disp);font-weight:800;line-height:.86;text-transform:uppercase;letter-spacing:.02em}
.brand .mark b{display:block;font-size:1.5rem;color:#fff;white-space:nowrap}
.brand .mark .r{color:var(--red-hi)}
.brand .mark small{display:block;font-size:.62rem;letter-spacing:.28em;font-weight:700;color:var(--gold);white-space:nowrap}
.site-header.scrolled .brand .mark .r{color:var(--gold)}
.nav-links{display:flex;align-items:center;gap:26px;list-style:none}
.nav-links a{font-family:var(--disp);font-weight:600;text-transform:uppercase;letter-spacing:.06em;
  font-size:1.02rem;color:#fff;padding:6px 2px;position:relative}
.nav-links a::after{content:"";position:absolute;left:0;right:100%;bottom:0;height:2px;background:var(--gold);transition:.2s}
.nav-links a:hover::after,.nav-links a[aria-current="page"]::after{right:0}
.nav-right{display:flex;align-items:center;gap:16px}
.socials{display:flex;gap:10px}
.socials a{width:32px;height:32px;border-radius:50%;display:grid;place-items:center;
  background:rgba(255,255,255,.14);color:#fff;transition:.18s}
.socials a:hover{background:var(--red)}
.socials svg{width:15px;height:15px;fill:currentColor}
.nav-toggle{display:none;background:none;border:0;width:44px;height:44px;flex-direction:column;
  justify-content:center;gap:5px}
.nav-toggle span{display:block;height:3px;width:26px;background:#fff;border-radius:2px;transition:.25s}

/* ---------- Hero ---------- */
.hero{position:relative;min-height:92vh;display:flex;align-items:center;background:var(--ink);overflow:hidden}
.hero__img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:70% 30%}
.hero__scrim{position:absolute;inset:0;
  background:linear-gradient(100deg,rgba(10,20,35,.94) 0%,rgba(11,22,40,.86) 34%,rgba(12,24,44,.34) 64%,rgba(12,24,44,.05) 100%)}
.hero .container{position:relative;z-index:2;width:100%;padding-top:120px;padding-bottom:60px}
.hero__inner{max-width:620px;color:#fff}
.hero h1{margin:.18em 0 .3em}
.hero h1 .line2{color:var(--gold);display:block}
.hero__sub{font-size:clamp(1.05rem,1.5vw,1.28rem);color:#e7edf6;max-width:33em;margin-bottom:26px}

/* signup card */
.signup{background:var(--cream);color:var(--ink);border-radius:16px;padding:22px;box-shadow:var(--shadow);
  border-top:6px solid var(--red)}
.signup h3{font-size:1.35rem;color:var(--navy);margin-bottom:12px}
.signup .grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.signup input{width:100%;padding:12px 14px;border:1.5px solid var(--line);border-radius:9px;font-size:1rem;
  font-family:var(--sans);background:#fff}
.signup input:focus{outline:none;border-color:var(--navy);box-shadow:0 0 0 3px rgba(20,41,74,.15)}
.signup .full{grid-column:1/-1}
.signup button{width:100%}
.consent{font-size:.72rem;color:var(--muted);margin-top:10px;line-height:1.4}
.form-msg{display:none;margin-top:12px;padding:12px 14px;border-radius:9px;background:#e7f5ec;color:#1c6b3f;font-weight:600}
.form-msg.show{display:block}

/* trust bar */
.trustbar{background:var(--ink);color:#fff;padding:16px 0}
.trustbar .container{display:flex;flex-wrap:wrap;gap:14px 40px;justify-content:center;align-items:center;
  font-family:var(--disp);text-transform:uppercase;letter-spacing:.08em;font-weight:600;font-size:1.05rem}
.trustbar b{color:var(--gold)}
.trustbar .dot{color:var(--red-hi)}

/* ---------- Split / bio ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,5vw,72px);align-items:center}
.split--rev .split__media{order:2}
.polaroid{background:#fff;padding:14px 14px 14px;border-radius:4px;box-shadow:var(--shadow);
  transform:rotate(-2.2deg);transition:.3s}
.polaroid:hover{transform:rotate(0)}
.polaroid img{border-radius:2px;aspect-ratio:4/3;object-fit:cover;width:100%}
.polaroid--r{transform:rotate(2deg)}
.stack{position:relative}

/* ---------- Donate strip ---------- */
.donate-strip{background:var(--red);color:#fff;text-align:center}
.donate-strip h2{color:#fff}
.amounts{display:grid;grid-template-columns:repeat(6,1fr);gap:12px;margin-top:28px}
.amt{background:var(--navy);color:#fff;font-family:var(--disp);font-weight:800;font-size:1.7rem;
  padding:.7em 0;border-radius:11px;border:2px solid transparent;transition:.16s;display:block;text-align:center}
.amt:hover{background:var(--ink);transform:translateY(-3px)}
.amt.other{background:transparent;border-color:#fff}
.amt.other:hover{background:#fff;color:var(--red)}
.donate-note{font-size:.82rem;color:rgba(255,255,255,.85);margin-top:16px}

/* ---------- Issue cards ---------- */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.card{background:#fff;border-radius:var(--radius);padding:28px;box-shadow:var(--shadow-sm);
  border-bottom:4px solid var(--gold);transition:.2s;display:flex;flex-direction:column;gap:10px}
.card:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.card .ico{width:52px;height:52px;border-radius:12px;background:var(--tint);display:grid;place-items:center;color:var(--navy)}
.card .ico svg{width:28px;height:28px;fill:none;stroke:currentColor;stroke-width:2.1;stroke-linecap:round;stroke-linejoin:round}
.card h3{font-size:1.32rem;color:var(--navy)}
.card p{font-size:1rem;color:#425064}
.card--navy{background:var(--navy);color:#fff;border-bottom-color:var(--red)}
.card--navy h3{color:#fff}.card--navy p{color:#d4ddea}.card--navy .ico{background:rgba(255,255,255,.12);color:var(--gold)}

/* ---------- Accordion (issues page) ---------- */
.acc{border-top:1px solid rgba(255,255,255,.16)}
.acc__item{border-bottom:1px solid rgba(255,255,255,.16)}
.acc__btn{width:100%;background:none;border:0;color:#fff;text-align:left;padding:26px 54px 26px 0;
  position:relative;font-family:var(--disp);font-weight:800;text-transform:uppercase;
  font-size:clamp(1.4rem,2.4vw,2rem);letter-spacing:.01em;line-height:1.05}
.acc__btn .sign{position:absolute;right:0;top:50%;transform:translateY(-50%);width:38px;height:38px;
  border:2px solid var(--gold);border-radius:50%;display:grid;place-items:center;color:var(--gold);transition:.2s}
.acc__btn .sign::before,.acc__btn .sign::after{content:"";position:absolute;background:var(--gold);border-radius:2px}
.acc__btn .sign::before{width:16px;height:2.5px}
.acc__btn .sign::after{width:2.5px;height:16px;transition:.2s}
.acc__item[open] .sign::after{transform:rotate(90deg);opacity:0}
.acc__panel{overflow:hidden;max-height:0;transition:max-height .35s ease}
.acc__inner{padding:0 54px 30px 0;display:grid;grid-template-columns:1.2fr 1fr;gap:34px;align-items:start}
.acc__inner .body{color:#dbe4f0;font-size:1.08rem}
.acc__inner ul{list-style:none;margin-top:12px;display:grid;gap:9px}
.acc__inner li{padding-left:26px;position:relative;color:#eef2f8}
.acc__inner li::before{content:"";position:absolute;left:0;top:.55em;width:11px;height:11px;background:var(--red-hi);
  border-radius:3px;transform:rotate(45deg)}

/* ---------- Quote ---------- */
.quote{position:relative;text-align:center;color:#fff}
.quote__mark{font-family:var(--disp);font-size:6rem;color:var(--gold);line-height:.6;opacity:.9}
.quote blockquote{font-family:var(--disp);font-weight:700;text-transform:none;
  font-size:clamp(1.6rem,3.4vw,2.7rem);line-height:1.15;max-width:16em;margin:0 auto .5em}
.quote cite{font-style:normal;font-family:var(--disp);text-transform:uppercase;letter-spacing:.12em;
  color:var(--gold);font-weight:600;font-size:1rem}

/* ---------- Get involved ---------- */
.involve-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.involve{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.14);border-radius:var(--radius);
  padding:30px;text-align:center;transition:.2s}
.involve:hover{background:rgba(255,255,255,.1);transform:translateY(-4px)}
.involve .ico{width:56px;height:56px;margin:0 auto 14px;border-radius:14px;background:var(--gold);color:var(--ink);
  display:grid;place-items:center}
.involve .ico svg{width:30px;height:30px;fill:none;stroke:currentColor;stroke-width:2.1;stroke-linecap:round;stroke-linejoin:round}
.involve h3{color:#fff;margin-bottom:6px}
.involve p{color:#cdd8e6;font-size:.98rem;margin-bottom:16px}

/* page hero (interior) */
.page-hero{position:relative;background:var(--navy);color:#fff;padding:150px 0 70px;overflow:hidden}
.page-hero::after{content:none}
.page-hero .eyebrow{color:var(--gold)}
.page-hero p{max-width:40em;color:#dbe4f0;margin-top:14px}

/* prose (about page) */
.prose{max-width:70ch}
.prose p{margin-bottom:1.1em}
.chapter{margin-bottom:clamp(40px,6vw,72px)}
.chapter .eyebrow{color:var(--red)}
.section--navy .chapter .eyebrow{color:var(--gold)}
.creds{list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:10px 24px;margin-top:18px}
.creds li{padding-left:26px;position:relative}
.creds li::before{content:"";position:absolute;left:0;top:.5em;width:11px;height:11px;background:var(--red);
  border-radius:3px;transform:rotate(45deg)}

/* ---------- Footer ---------- */
.footer{background:var(--ink);color:#c6d1e0;padding:64px 0 28px}
.footer__top{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;padding-bottom:40px;
  border-bottom:1px solid rgba(255,255,255,.12)}
.footer h4{font-family:var(--disp);color:#fff;text-transform:uppercase;letter-spacing:.08em;font-size:1.1rem;margin-bottom:14px}
.footer a:hover{color:var(--gold)}
.footer ul{list-style:none;display:grid;gap:9px}
.footer .brand .mark b{font-size:1.7rem}
.footer .socials{margin-top:16px}
.footer__bottom{padding-top:24px;text-align:center;font-size:.82rem;color:#8595ab;display:grid;gap:10px}
.paidfor{display:inline-block;border:1px solid rgba(255,255,255,.25);border-radius:8px;padding:8px 18px;
  font-family:var(--disp);letter-spacing:.06em;text-transform:uppercase;color:#c6d1e0;margin:0 auto}
.disclaimer{max-width:60ch;margin:0 auto;font-style:italic;color:#7788a0}

/* reveal on scroll */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .6s ease,transform .6s ease}
.reveal.in{opacity:1;transform:none}

/* ---------- Responsive ---------- */
@media(max-width:960px){
  .split{grid-template-columns:1fr}
  .split--rev .split__media{order:0}
  .cards,.involve-grid{grid-template-columns:1fr 1fr}
  .amounts{grid-template-columns:repeat(3,1fr)}
  .acc__inner{grid-template-columns:1fr}
  .footer__top{grid-template-columns:1fr 1fr}
  .creds{grid-template-columns:1fr}
}
@media(max-width:720px){
  .nav-links,.nav-right .socials{display:none}
  .nav-toggle{display:flex}
  .nav{gap:7px}
  .site-header{padding:11px 0 8px}                          /* header bottom padding */
  .site-header .container{padding-right:9px}                /* cut the empty space to the right of the hamburger */
  .brand .mark b{font-size:1.8rem;line-height:.9}           /* bigger name — WATSON's width now matches the tagline */
  .brand .mark .r{display:block}                            /* stack COLBY / WATSON so the logo stays narrow */
  .brand .mark small{font-size:.52rem;letter-spacing:.13em;margin-top:1px}
  .site-header .nav-right{gap:6px}
  .site-header .nav-right .btn{padding:.42em .52em;font-size:1.17rem}   /* Volunteer + Donate bigger (tighter padding so the hamburger still fits) */
  .nav.open .nav-links{display:flex;position:absolute;top:100%;left:0;right:0;flex-direction:column;
    background:var(--navy);padding:8px var(--pad) 20px;gap:0;box-shadow:0 20px 30px rgba(0,0,0,.3)}
  .nav.open .nav-links a{padding:20px 4px;font-size:1.7rem;text-align:center;border-bottom:1px solid rgba(255,255,255,.08)}
  .nav.open .nav-links a:last-child{border-bottom:0}
  .nav.open .nav-links a::after{display:none}
  .hero{min-height:auto}
  .hero .container{padding-top:120px}
  .signup .grid{grid-template-columns:1fr}
  .cards,.involve-grid{grid-template-columns:1fr}
  .amounts{grid-template-columns:1fr 1fr}
  .footer__top{grid-template-columns:1fr}
  .nav.open{position:relative}
}
@media(prefers-reduced-motion:reduce){*{transition:none!important;animation:none!important}.reveal{opacity:1;transform:none}}

/* =========================================================================
   v2 additions — strategist round 1 (contrast, abundance, conversion, field)
   ========================================================================= */

/* value prop under signup */
.signup .valprop{font-size:.92rem;color:#4a566a;margin:-4px 0 12px;line-height:1.4}
.signup legend{padding:0}

/* THE CHOICE — contrast band */
.choice{background:var(--ink);color:#fff}
.choice__grid{display:grid;grid-template-columns:1fr 1fr;gap:0;border-radius:16px;overflow:hidden;box-shadow:var(--shadow);margin-top:34px}
.choice__col{padding:clamp(24px,3vw,40px)}
.choice__col--him{background:#2a1416;border-right:1px solid rgba(255,255,255,.08)}
.choice__col--colby{background:var(--navy)}
.choice__col h3{font-size:clamp(1.5rem,2.6vw,2rem);margin-bottom:6px}
.choice__col .who{font-family:var(--disp);text-transform:uppercase;letter-spacing:.1em;font-size:.95rem;font-weight:700;margin-bottom:14px}
.choice__col--him .who{color:#ff7a6e}
.choice__col--colby .who{color:var(--gold)}
.choice__list{list-style:none;display:grid;gap:12px}
.choice__list li{padding-left:34px;position:relative;color:#e7edf6;font-size:1.05rem;line-height:1.4}
.choice__list li::before{position:absolute;left:0;top:-1px;width:24px;height:24px;border-radius:50%;display:grid;place-items:center;font-weight:800;font-size:.9rem}
.choice__col--him .choice__list li::before{content:"\2715";background:rgba(255,90,80,.18);color:#ff7a6e}
.choice__col--colby .choice__list li::before{content:"\2713";background:rgba(231,178,60,.18);color:var(--gold)}
.choice__src{font-size:.8rem;color:#8595ab;margin-top:18px;text-align:center}
@media(max-width:760px){.choice__grid{grid-template-columns:1fr}.choice__col--him{border-right:0;border-bottom:1px solid rgba(255,255,255,.08)}}

/* feature issue cards (bigger, for cost + housing) */
.features{display:grid;grid-template-columns:1fr 1fr;gap:22px;margin-bottom:22px}
.feature{position:relative;border-radius:var(--radius);overflow:hidden;min-height:340px;display:flex;flex-direction:column;
  justify-content:flex-end;padding:32px;color:#fff;box-shadow:var(--shadow-sm)}
.feature img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.feature::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,20,35,.15) 0%,rgba(10,20,35,.55) 45%,rgba(10,20,35,.94) 100%);z-index:1}
.feature > *{position:relative;z-index:2}
.feature .tag{font-family:var(--disp);text-transform:uppercase;letter-spacing:.1em;font-weight:700;font-size:.9rem;color:var(--gold)}
.feature h3{font-size:clamp(1.6rem,2.6vw,2.1rem);margin:6px 0 8px;color:#fff}
.feature p{color:#e7edf6;font-size:1.02rem;max-width:34em}
@media(max-width:760px){.features{grid-template-columns:1fr}.feature{min-height:300px}}

/* donate: recurring + impact */
.recurring-ask{background:rgba(255,255,255,.12);border:2px solid #fff;border-radius:12px;padding:16px 20px;margin:0 auto 22px;max-width:560px;
  display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}
.recurring-ask .txt{text-align:left}
.recurring-ask .txt b{font-family:var(--disp);font-size:1.25rem;text-transform:uppercase;letter-spacing:.03em;display:block}
.recurring-ask .txt small{color:rgba(255,255,255,.85)}
.amt .impact{display:block;font-family:var(--sans);font-weight:500;text-transform:none;letter-spacing:0;font-size:.7rem;color:rgba(255,255,255,.8);margin-top:4px;line-height:1.2}
.amt{padding:.7em .4em}

/* footer email capture */
.foot-signup{background:var(--navy);border-radius:var(--radius);padding:22px 24px;margin-bottom:36px;
  display:grid;grid-template-columns:1fr auto;gap:14px;align-items:center}
.foot-signup h4{margin:0 0 2px;color:#fff}
.foot-signup p{margin:0;color:#c6d1e0;font-size:.92rem}
.foot-signup form{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}
.foot-signup input{padding:12px 14px;border:0;border-radius:9px;font-size:1rem;min-width:150px}
@media(max-width:760px){.foot-signup{grid-template-columns:1fr}.foot-signup form{justify-content:stretch}.foot-signup input{flex:1}}

/* share buttons */
.share{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;margin-top:16px}
.share button{background:rgba(255,255,255,.12);color:#fff;border:1px solid rgba(255,255,255,.25);border-radius:9px;
  padding:.55em 1em;font-family:var(--disp);text-transform:uppercase;letter-spacing:.05em;font-weight:600;font-size:.95rem;transition:.16s}
.share button:hover{background:var(--gold);color:var(--ink);border-color:var(--gold)}

/* post-signup success next-step */
.signup.done .grid,.signup.done fieldset,.signup.done>button,.signup.done .consent,.signup.done .valprop{display:none}
.next-step{display:none}
.signup.done .next-step{display:block}
.next-step h3{color:var(--navy)}
.next-step .btn{width:100%;margin-top:10px}

/* sticky mobile CTA */
.mobile-cta{position:fixed;left:0;right:0;bottom:0;z-index:90;display:none;gap:10px;padding:10px 14px;
  background:var(--ink);box-shadow:0 -6px 20px rgba(0,0,0,.3)}
.mobile-cta a{flex:1;text-align:center;justify-content:center}
/* mobile sticky CTA removed for now — Volunteer + Donate already live in the header */

/* register / vote-plan */
.vote-tools{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.vote-tool{background:#fff;border-radius:var(--radius);padding:26px;box-shadow:var(--shadow-sm);border-top:4px solid var(--red)}
.vote-tool h3{color:var(--navy);font-size:1.25rem;margin-bottom:6px}
.vote-tool p{font-size:.98rem;color:#425064;margin-bottom:14px}
.section--navy .vote-tool{background:rgba(255,255,255,.06);border-top-color:var(--gold)}
.section--navy .vote-tool h3{color:#fff}.section--navy .vote-tool p{color:#cdd8e6}
@media(max-width:860px){.vote-tools{grid-template-columns:1fr}}

/* county chips */
.counties{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-top:22px}
.counties span{font-family:var(--disp);text-transform:uppercase;letter-spacing:.06em;font-weight:600;
  background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);color:#fff;padding:8px 16px;border-radius:999px;font-size:1rem}

/* footer signup next-step (close the dead-end) + relational share emphasis */
.foot-next{display:none;grid-column:1/-1}
.foot-next p{color:#fff;margin:0 0 10px}
.foot-signup.done > div:first-child,.foot-signup.done > form{display:none}
.foot-signup.done .foot-next{display:block}
.share button[data-net="sms"]{background:var(--gold);color:var(--ink);border-color:var(--gold);order:-1}

/* =========================================================================
   v3 — client revisions (cutout hero, signup band, static issues, fixes)
   ========================================================================= */

/* cutout hero */
.hero--cutout{min-height:auto;background:radial-gradient(120% 130% at 12% -10%,#1B3560 0%,#14294A 46%,#0E1A2B 100%)}
.hero--cutout .hero__bgmap{position:absolute;right:-40px;bottom:-30px;width:520px;opacity:.06;z-index:0}
.hero--cutout .container{position:relative;z-index:2;padding-top:132px;padding-bottom:0}
.hero__grid{display:grid;grid-template-columns:1.15fr .85fr;gap:24px;align-items:end}
.hero--cutout .hero__inner{padding-bottom:64px;max-width:none}
.hero__figure{align-self:end}
.hero__figure img{max-height:74vh;width:auto;margin:0 auto;display:block;filter:drop-shadow(0 22px 44px rgba(0,0,0,.45))}
@media(max-width:820px){
  .hero__grid{grid-template-columns:1fr}
  .hero--cutout .hero__inner{padding-bottom:24px}
  .hero__figure img{max-height:52vh}
}

/* signup band (moved out of hero) */
.signup-band__grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(24px,4vw,54px);align-items:center}
.signup-band h2{color:var(--navy)}
@media(max-width:820px){.signup-band__grid{grid-template-columns:1fr}.signup-band__grid>div:first-child{text-align:center}}

/* header + mobile Volunteer button legibility */
.site-header .btn-ghost{color:#fff;border-color:rgba(255,255,255,.85)}
.site-header .btn-ghost:hover{background:#fff}
.site-header .btn-ghost:hover span{color:var(--navy)}
.mobile-cta .btn-ghost{color:#fff;border-color:rgba(255,255,255,.85)}

/* feature cards: bias image toward faces, tighten */
.feature img{object-position:50% 28%}
.feature p{font-size:1.05rem;max-width:30em}
.polaroid img{object-position:50% 28%}

/* static issues layout (no dropdowns) */
.iss-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}
@media(max-width:760px){.iss-grid{grid-template-columns:1fr}}
.iss{padding:28px;border-radius:var(--radius)}
.section--navy .iss,.section--ink .iss{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.13)}
.section--cream .iss{background:#fff;box-shadow:var(--shadow-sm);border-bottom:4px solid var(--gold)}
.iss h3{font-size:1.35rem;margin-bottom:12px}
.section--navy .iss h3,.section--ink .iss h3{color:#fff}
.section--cream .iss h3{color:var(--navy)}
.iss ul{list-style:none;display:grid;gap:9px}
.iss li{padding-left:26px;position:relative;font-size:1.04rem;line-height:1.4}
.iss li::before{content:"";position:absolute;left:0;top:.5em;width:10px;height:10px;background:var(--red-hi);border-radius:2px;transform:rotate(45deg)}
.section--cream .iss li{color:#33465e}
.section--cream .iss li::before{background:var(--red)}
.section--navy .iss li,.section--ink .iss li{color:#e7edf6}

/* capture mode (for automated full-page screenshots only) */
html.cap .hero{min-height:auto}
html.cap .reveal{opacity:1!important;transform:none!important}
html.cap .mobile-cta{display:none!important}

/* v4 fixes */
.signup input[type="checkbox"]{width:auto;flex:none;margin:0}   /* fix: checkboxes were stretching to 100% */
.page-hero + .section{padding-top:clamp(30px,4vw,48px)}          /* kill dead space under interior page headers */
.hl-affordable .red{color:var(--red)}

/* v5 — homepage hero video: wide panel whose faded left edge overlaps the text at ANY width (no empty gap) */
.hero--brick{min-height:clamp(580px,84vh,940px)}
.hero--brick .hero__img{
  left:auto; right:0; top:84px; bottom:0;
  width:56vw; height:calc(100% - 84px);   /* pure vw, NO cap → left edge at 44vw always reaches the text column */
  object-fit:cover; object-position:56% 20%;
  -webkit-mask-image:linear-gradient(to right, transparent 0, rgba(0,0,0,.45) 14%, #000 42%),
                     linear-gradient(to top, transparent 0, #000 12%);
          mask-image:linear-gradient(to right, transparent 0, rgba(0,0,0,.45) 14%, #000 42%),
                     linear-gradient(to top, transparent 0, #000 12%);
  -webkit-mask-composite:source-in; mask-composite:intersect;
}
.hero--brick .hero__scrim{
  background:linear-gradient(100deg,
    rgba(10,20,35,.96) 0%,
    rgba(11,22,40,.9) 40%,
    rgba(12,24,44,.55) 58%,
    rgba(12,24,44,.12) 78%,
    rgba(12,24,44,0) 100%);
}
@media(max-width:860px){
  /* mobile: stack the video ABOVE the text on a solid dark bg — clear video, fully legible copy, no overlap with the nav */
  .site-header{background:var(--ink)}   /* solid bar so the video can never bleed up behind the nav */
  .hero--brick{display:flex;flex-direction:column;align-items:stretch;min-height:0;background:var(--ink);padding-top:76px}
  .hero--brick .hero__img{position:relative;inset:auto;width:100%;height:49vh;max-height:460px;
    object-fit:cover;object-position:50% 16%;opacity:1;
    -webkit-mask-image:linear-gradient(180deg,#000 84%,transparent);mask-image:linear-gradient(180deg,#000 84%,transparent)}
  .hero--brick .hero__scrim{display:none}
  .hero--brick .container{position:relative;z-index:2;padding-top:18px;padding-bottom:36px}
  .hero--brick h1{font-size:clamp(1.7rem,7.4vw,2.3rem)}
  .hero--brick h1 br{display:none}          /* headline collapses to 2 lines: "We used to build things." / "Let's build them again." */
  .hero--brick .sub-lede{display:none}       /* drop the groceries/Wall St lede on mobile; keep the 2 punch lines */
  .hero--brick .hero__inner{text-align:center}          /* center the hero text + buttons on mobile */
  .hero--brick .hero__inner > div{justify-content:center}
  .hero--brick .eyebrow{display:none}                    /* hide the eyebrow on mobile */
  .hero--brick .hero__sub{margin-bottom:18px}            /* tighten the gap above the buttons (was 26px) */
  .hero--brick .btn-lg{padding:.58em 1.9em}              /* shorter Chip In / Meet Colby (same width, ~5px less top & bottom) */
}
@media(max-width:640px){
  .trustbar{padding:11px 0}
  .trustbar .container{font-size:.86rem;letter-spacing:.06em}
  .trustbar .container > *:not(:first-child){display:none}   /* mobile: show only "Born & raised in Union County" */
}
