/* ============================================================
   Bryan Hoss for Red Bank City Judge — shared stylesheet
   ============================================================ */
:root{
  --navy-900:#0f2143;
  --navy-800:#15294f;
  --navy-700:#1c3461;
  --navy:#244a8a;
  --red:#c01f2d;
  --red-dark:#9c1622;
  --cream:#f6f2e9;
  --paper:#fbfaf5;
  --ink:#16223d;
  --gold:#b3893d;
  --muted:#5b6679;
  --line:rgba(15,33,67,.12);
  --font-display:'Anton',Impact,sans-serif;
  --font-serif:'Newsreader',Georgia,serif;
  --font-sans:'Source Sans 3',system-ui,sans-serif;
  --shadow-card:0 1px 2px rgba(15,33,67,.06),0 18px 40px -24px rgba(15,33,67,.45);
  --maxw:1200px;
}
*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;background:#0f2143;}
body{
  font-family:var(--font-sans);
  color:var(--ink);
  background:var(--navy-900);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{display:block;max-width:100%;}
a{color:inherit;text-decoration:none;}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px;}
/* let injected header/footer participate in body layout so position:sticky works */
#site-header{display:contents;}

/* ---------- shared type ---------- */
.eyebrow{
  font-family:var(--font-sans);font-weight:700;font-size:13px;letter-spacing:.22em;
  text-transform:uppercase;color:var(--red);display:inline-flex;align-items:center;gap:12px;
}
.eyebrow.on-dark{color:#e7b9bd;}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--red);display:inline-block;}
.section-title{
  font-family:var(--font-serif);font-weight:500;font-size:clamp(30px,4.4vw,52px);
  line-height:1.05;letter-spacing:-.01em;margin:18px 0 0;
}
.lede{font-size:clamp(17px,1.6vw,20px);color:var(--muted);max-width:60ch;margin-top:18px;}
.section{padding:clamp(72px,9vw,128px) 0;}

/* star rule */
.stars{display:inline-flex;align-items:center;gap:14px;color:var(--red);}
.stars::before,.stars::after{content:"";height:2px;width:64px;background:currentColor;opacity:.55;}
.stars .s{font-size:13px;letter-spacing:.4em;}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  font-family:var(--font-sans);font-weight:700;font-size:15px;letter-spacing:.02em;
  padding:15px 26px;border-radius:3px;border:2px solid transparent;cursor:pointer;
  transition:transform .15s ease,background .2s ease,color .2s ease,box-shadow .2s ease;white-space:nowrap;
}
.btn:active{transform:translateY(1px);}
.btn-red{background:var(--red);color:#fff;box-shadow:0 10px 24px -12px rgba(192,31,45,.9);}
.btn-red:hover{background:var(--red-dark);}
.btn-navy{background:var(--navy);color:#fff;}
.btn-navy:hover{background:var(--navy-700);}
.btn-outline{border-color:rgba(255,255,255,.6);color:#fff;}
.btn-outline:hover{background:rgba(255,255,255,.1);border-color:#fff;}
.btn-outline-dark{border-color:var(--navy);color:var(--navy);}
.btn-outline-dark:hover{background:var(--navy);color:#fff;}
.btn-lg{padding:18px 34px;font-size:16px;}
.btn-white{background:#fff;color:var(--red);}
.btn-white:hover{background:var(--navy-900);color:#fff;}

/* ---------- nav ---------- */
header.nav{
  position:sticky;top:0;z-index:60;background:rgba(15,33,67,0);
  transition:background .3s ease,box-shadow .3s ease,padding .3s ease;padding:18px 0;
}
header.nav.solid{background:rgba(15,33,67,.97);box-shadow:0 10px 30px -20px rgba(0,0,0,.8);padding:12px 0;}
.nav-inner{display:flex;align-items:center;justify-content:space-between;gap:24px;}
.brand{display:flex;align-items:center;gap:13px;color:#fff;}
.brand .mark{
  width:44px;height:44px;border-radius:50%;background:var(--red);border:2px solid #fff;
  display:grid;place-items:center;color:#fff;font-family:var(--font-display);font-size:21px;line-height:1;flex:none;
  box-shadow:0 6px 16px -8px rgba(0,0,0,.6);
}
.brand .bt{line-height:1;}
.brand .bt b{font-family:var(--font-display);font-size:19px;letter-spacing:.04em;display:block;text-transform:uppercase;color:#fff;}
.brand .bt span{font-size:11px;letter-spacing:.26em;text-transform:uppercase;color:#c9d4ea;font-weight:600;}
/* sign-style wordmark (nav + footer) */
.signbrand{display:flex;flex-direction:column;justify-content:center;line-height:.9;color:#fff;padding:4px 0;flex:none;}
.signbrand .keep{font-family:var(--font-display);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--red);transform:rotate(-5deg);transform-origin:left center;width:max-content;margin-bottom:1px;}
.signbrand .nm{font-family:var(--font-display);font-size:22px;letter-spacing:.025em;text-transform:uppercase;color:#fff;white-space:nowrap;}
.signbrand .role{font-size:9px;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:#c9d4ea;margin-top:3px;white-space:nowrap;}
.signbrand.foot{padding:0;}
.signbrand.foot .nm{font-size:27px;}
.signbrand.foot .role{color:#9fb0cf;}
.brand-logo{height:72px;width:auto;display:block;border-radius:3px;box-shadow:0 6px 18px -8px rgba(0,0,0,.55);transition:height .3s ease;flex:none;}
header.nav.solid .brand-logo{height:60px;}
.brand-logo.foot{height:104px;border-radius:5px;box-shadow:0 16px 36px -18px rgba(0,0,0,.7);}
@media(max-width:560px){.brand-logo{height:54px;}}
.nav-links{display:flex;align-items:center;gap:30px;}
.nav-links a{color:#eaf0fb;font-weight:600;font-size:15px;letter-spacing:.01em;position:relative;padding:4px 0;}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-2px;height:2px;width:0;background:var(--red);transition:width .22s ease;}
.nav-links a:hover::after,.nav-links a.active::after{width:100%;}
.nav-links a.active{color:#fff;}
.nav-cta{display:flex;align-items:center;gap:14px;}
/* brand "Home" label under the campaign-sign logo */
.brand{flex-direction:column;gap:5px;}
.brand-home{font-size:10px;letter-spacing:.26em;text-transform:uppercase;color:#c9d4ea;font-weight:700;}
/* social icons in the top nav (right side) */
.nav-socials{display:flex;align-items:center;gap:10px;}
.nav-socials a{width:34px;height:34px;border-radius:50%;border:1px solid rgba(255,255,255,.25);display:grid;place-items:center;color:#fff;transition:.2s;}
.nav-socials a:hover{background:var(--red);border-color:var(--red);}
.nav-socials svg{width:16px;height:16px;}
/* "paid for by" disclaimer shown above contribute boxes */
.paid-for{font-size:13px;letter-spacing:.01em;}
.contribute .paid-for{color:#ffe0e2;font-weight:600;margin:0 auto 16px;}
.modal-paid-for{color:var(--muted);margin:4px 0 14px;}
/* center the footer legal row + everything beneath it */
.foot-legal-row{justify-content:center;}
.foot-bottom{align-items:center;text-align:center;}
.foot-bottom .disc{margin-left:auto;margin-right:auto;}
.foot-legal{justify-content:center;}
.hamburger{display:none;background:none;border:none;cursor:pointer;flex-direction:column;gap:5px;padding:8px;}
.hamburger span{width:26px;height:2.5px;background:#fff;border-radius:2px;transition:.25s;}

/* mobile menu */
.mobile-menu{
  position:fixed;inset:0;z-index:55;background:var(--navy-900);
  display:flex;flex-direction:column;justify-content:center;align-items:center;gap:8px;
  opacity:0;pointer-events:none;transition:opacity .3s ease;
}
.mobile-menu.open{opacity:1;pointer-events:auto;}
.mobile-menu a,.mobile-menu button.linklike{color:#fff;font-family:var(--font-serif);font-size:30px;padding:12px;background:none;border:none;cursor:pointer;}
.mobile-menu .btn{margin-top:18px;font-family:var(--font-sans);font-size:16px;}
.mobile-legal{display:flex;align-items:center;gap:12px;margin-top:28px;padding-top:20px;border-top:1px solid rgba(255,255,255,.18);}
.mobile-legal a{font-family:var(--font-sans);font-size:14px;font-weight:600;color:#c4d0e8;text-decoration:underline;text-underline-offset:3px;letter-spacing:.01em;}
.mobile-legal a:hover{color:#fff;}
.mobile-legal span{color:#7f90b0;font-size:14px;}

/* ---------- hero (home) ---------- */
.hero{position:relative;background:var(--navy-900);color:#fff;overflow:hidden;margin-top:-94px;padding-top:94px;}
.hero::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(120% 90% at 80% 0%,rgba(36,74,138,.55),transparent 60%),radial-gradient(90% 80% at 0% 100%,rgba(192,31,45,.16),transparent 55%);
  pointer-events:none;
}
.hero-grid{position:relative;display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center;min-height:calc(100vh - 94px);padding:48px 0;}
.hero-copy{max-width:620px;}
/* FOP endorsement badge — positioned next to the "N" in BRYAN (transparent logo on navy) */
.hero-fop{position:absolute;top:104px;left:368px;z-index:5;display:flex;flex-direction:column;align-items:center;text-align:center;gap:10px;width:140px;}
.hero-fop img{width:118px;height:auto;}
.endorsed-stamp{font-family:var(--font-display);text-transform:uppercase;color:#d92b34;border:3px solid #d92b34;border-radius:7px;padding:3px 13px 4px;font-size:22px;letter-spacing:.06em;line-height:1;transform:rotate(-7deg);}
.fop-cap{font-size:9px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:#dfe7f5;line-height:1.4;}
.hero .kicker{display:inline-flex;align-items:center;gap:10px;font-weight:700;font-size:13px;letter-spacing:.24em;text-transform:uppercase;color:#e7b9bd;}
.hero .kicker .dot{width:7px;height:7px;border-radius:50%;background:var(--red);}
.hero h1{font-family:var(--font-display);text-transform:uppercase;line-height:.9;letter-spacing:.005em;margin:20px 0 0;}
.hero h1 .keep{display:block;font-size:clamp(20px,2.4vw,30px);color:var(--red);letter-spacing:.18em;transform:rotate(-3deg);transform-origin:left;margin-bottom:6px;}
.hero h1 .name{display:block;font-size:clamp(64px,11vw,140px);color:#fff;text-shadow:0 8px 30px rgba(0,0,0,.35);}
.hero h1 .role{display:block;font-family:var(--font-serif);font-weight:500;text-transform:none;font-size:clamp(22px,3vw,38px);letter-spacing:0;color:#dfe7f5;margin-top:10px;}
.hero .role .red{color:var(--red);font-style:italic;}
.hero p.sub{font-size:clamp(17px,1.7vw,21px);color:#c6d2e8;margin-top:26px;max-width:50ch;}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px;margin-top:34px;}
.hero-meta{display:flex;gap:26px;margin-top:38px;flex-wrap:wrap;}
.hero-meta .m{border-left:2px solid var(--red);padding-left:14px;}
.hero-meta .m b{font-family:var(--font-serif);font-size:26px;display:block;line-height:1;}
.hero-meta .m span{font-size:12.5px;letter-spacing:.12em;text-transform:uppercase;color:#9fb0cf;}
.hero-photo{position:relative;align-self:center;display:flex;align-items:center;justify-content:center;gap:24px;}
.photo-frame{position:relative;width:100%;max-width:430px;}
.photo-frame .block{position:absolute;inset:auto -18px -18px auto;width:78%;height:82%;background:var(--red);border-radius:4px;}
.photo-frame .block.two{inset:-16px auto auto -16px;width:55%;height:42%;background:var(--navy);}
.photo-frame img{position:relative;width:100%;height:min(70vh,620px);border-radius:4px;border:6px solid #fff;box-shadow:0 30px 70px -30px rgba(0,0,0,.8);object-fit:cover;object-position:center 22%;}
.hero-disclaimer{position:relative;text-align:center;font-size:12px;color:#7f90b0;letter-spacing:.04em;padding:18px 16px 24px;}

/* ---------- inner page header band ---------- */
.page-head{position:relative;background:var(--navy-900);color:#fff;overflow:hidden;margin-top:-94px;padding:94px 0 0;}
.page-head::before{content:"";position:absolute;inset:0;background:radial-gradient(110% 90% at 85% 0%,rgba(36,74,138,.5),transparent 60%),radial-gradient(80% 80% at 0% 100%,rgba(192,31,45,.14),transparent 55%);pointer-events:none;}
.page-head .wrap{position:relative;padding:64px 28px 72px;}
.page-head .eyebrow{color:#e7b9bd;}
.page-head h1{font-family:var(--font-serif);font-weight:500;font-size:clamp(38px,6vw,68px);line-height:1.02;letter-spacing:-.01em;margin:18px 0 0;}
.page-head p{color:#c6d2e8;font-size:clamp(17px,1.7vw,20px);margin-top:18px;max-width:60ch;}

/* ---------- endorsements: tighten vertical spacing ---------- */
body[data-page="endorsements"] .page-head .wrap{padding:44px 28px 28px;}
body[data-page="endorsements"] .section.volunteer{padding:24px 0 clamp(72px,9vw,128px);}
/* endorsements: top-align the copy with the top of the form */
body[data-page="endorsements"] .vol-grid{align-items:start;}

/* ---------- home: tighten the "Help keep Bryan on the bench" band ---------- */
body[data-page="home"] .section.volunteer{padding-top:clamp(32px,4vw,56px);}
body[data-page="home"] .vol-grid{align-items:start;}

/* ---------- volunteer: tighten vertical spacing ---------- */
body[data-page="volunteer"] .page-head .wrap{padding:64px 28px 40px;}
body[data-page="volunteer"] .section.volunteer{padding:40px 0 clamp(72px,9vw,128px);}

/* ---------- values strip ---------- */
.values{background:var(--red);color:#fff;}
.values-inner{display:flex;align-items:center;justify-content:center;gap:0;flex-wrap:wrap;padding:22px 0;}
.values .v{display:flex;align-items:center;gap:12px;padding:6px 30px;font-family:var(--font-serif);font-size:clamp(18px,2.1vw,24px);font-style:italic;}
.values .v .star{font-style:normal;opacity:.7;}

/* ---------- about ---------- */
.about{background:var(--cream);}
.about-grid{display:grid;grid-template-columns:.92fr 1.08fr;gap:clamp(36px,5vw,72px);align-items:center;}
.about-photo{position:relative;}
.about-photo img{width:100%;border-radius:4px;box-shadow:var(--shadow-card);}
.about-photo .tag{position:absolute;left:-14px;bottom:24px;background:var(--navy-900);color:#fff;padding:14px 20px;border-radius:3px;border-left:4px solid var(--red);box-shadow:0 18px 40px -20px rgba(0,0,0,.6);}
.about-photo .tag b{font-family:var(--font-serif);font-size:17px;display:block;}
.about-photo .tag span{font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:#a9b8d6;}
.about-body p{margin-top:18px;font-size:17.5px;color:#33405c;}
.about-body p:first-of-type{margin-top:24px;}
.about-body p .lead-in{font-weight:700;color:var(--ink);}
.sig{font-family:var(--font-serif);font-style:italic;font-size:30px;color:var(--navy);margin-top:26px;}
.about-quote{font-family:var(--font-serif);font-style:italic;font-size:clamp(17px,2vw,20px);line-height:1.6;color:var(--navy);border-left:3px solid var(--red);padding:14px 20px;margin:24px 0;background:rgba(36,74,138,.05);border-radius:0 4px 4px 0;}
.about-wide .about-quote{font-size:clamp(16px,1.8vw,19px);}
.about-facts{display:flex;gap:30px;margin-top:30px;flex-wrap:wrap;}
.about-facts .f b{font-family:var(--font-display);font-size:34px;color:var(--red);line-height:1;}
.about-facts .f span{display:block;font-size:13px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-top:6px;}
/* about extra block (full page) */
.about-wide{background:var(--paper);}
.about-wide .wrap{display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,5vw,72px);align-items:center;}
.about-wide.flip .wrap{direction:rtl;}
.about-wide.flip .wrap>*{direction:ltr;}
.about-wide img{width:100%;border-radius:4px;box-shadow:var(--shadow-card);}
.about-wide h2{font-family:var(--font-serif);font-weight:500;font-size:clamp(26px,3.4vw,38px);line-height:1.1;margin-top:16px;}
.about-wide p{margin-top:16px;font-size:17px;color:#33405c;}
.about-wide .pull{font-family:var(--font-serif);font-style:italic;font-weight:500;font-size:clamp(22px,2.7vw,30px);line-height:1.2;color:var(--navy);margin-top:20px;padding-left:18px;border-left:3px solid var(--red);}

/* ---------- priorities ---------- */
.priorities{background:var(--navy-900);color:#fff;}
.pri-head{text-align:center;display:flex;flex-direction:column;align-items:center;}
.pri-head .section-title{color:#fff;}
.pri-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;margin-top:56px;}
.pri-card{background:linear-gradient(180deg,rgba(36,74,138,.32),rgba(21,41,79,.32));border:1px solid rgba(255,255,255,.1);border-radius:6px;padding:30px 26px;transition:transform .25s ease,border-color .25s ease;}
.pri-card:hover{transform:translateY(-6px);border-color:rgba(192,31,45,.6);}
.pri-card .num{font-family:var(--font-display);font-size:18px;color:var(--red);}
.pri-card .ic{width:48px;height:48px;color:var(--red);margin:8px 0 18px;}
.pri-card h3{font-family:var(--font-serif);font-weight:500;font-size:23px;margin-bottom:10px;}
.pri-card p{color:#bcc9e2;font-size:15.5px;}

/* ---------- news ---------- */
.news{background:var(--paper);}
.news-head{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;flex-wrap:wrap;}
.news-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;margin-top:52px;}
.news-card{background:#fff;border:1px solid var(--line);border-radius:6px;overflow:hidden;display:flex;flex-direction:column;box-shadow:var(--shadow-card);transition:transform .25s ease,box-shadow .25s ease;}
.news-card:hover{transform:translateY(-5px);box-shadow:0 28px 56px -28px rgba(15,33,67,.5);}
.news-card .nimg{height:188px;background:var(--navy-700);position:relative;overflow:hidden;}
.news-card .nimg img{width:100%;height:100%;object-fit:cover;}
.news-card .nimg.placeholder{display:grid;place-items:center;background:linear-gradient(135deg,var(--navy),var(--navy-900));}
.news-card .nimg.placeholder svg{width:64px;height:64px;color:rgba(255,255,255,.35);}
.news-body{padding:24px 24px 26px;display:flex;flex-direction:column;flex:1;}
.news-date{font-size:12.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--red);font-weight:700;}
.news-card h3{font-family:var(--font-serif);font-weight:500;font-size:21px;line-height:1.25;margin:10px 0 10px;color:var(--ink);}
.news-card p{color:var(--muted);font-size:15.5px;flex:1;}
/* In the News — press coverage story cards */
.press-list{display:grid;grid-template-columns:repeat(2,1fr);gap:22px;}
.press-card{background:var(--paper);border:1px solid var(--line);border-radius:8px;padding:26px 26px 24px;display:flex;flex-direction:column;box-shadow:var(--shadow-card);text-align:left;}
.press-meta{display:flex;align-items:center;gap:10px;font-size:12px;letter-spacing:.05em;text-transform:uppercase;font-weight:700;}
.press-outlet{color:var(--red);}
.press-dot{color:var(--muted);}
.press-date{color:var(--muted);font-weight:600;}
.press-card h3{font-family:var(--font-serif);font-weight:600;font-size:21px;line-height:1.28;color:var(--ink);margin:9px 0 0;}
.press-card p{color:var(--muted);font-size:15.5px;margin-top:10px;flex:1;}
.press-readmore{display:inline-flex;align-items:center;gap:7px;margin-top:18px;color:var(--red);font-weight:700;font-size:14px;letter-spacing:.02em;align-self:flex-start;transition:gap .15s ease,color .15s ease;}
.press-readmore:hover{gap:11px;color:var(--red-dark);}
@media(max-width:760px){.press-list{grid-template-columns:1fr;}}

/* ---------- volunteer ---------- */
.volunteer{background:var(--navy-900);color:#fff;position:relative;overflow:hidden;}
.volunteer::before{content:"";position:absolute;inset:0;background:radial-gradient(80% 80% at 100% 0,rgba(192,31,45,.18),transparent 60%);pointer-events:none;}
.volunteer .wrap{position:relative;z-index:1;}
.vol-grid{position:relative;display:grid;grid-template-columns:1fr 1.05fr;gap:clamp(40px,6vw,84px);align-items:center;}
.vol-copy .section-title{color:#fff;}
.vol-copy ul{list-style:none;margin-top:28px;display:flex;flex-direction:column;gap:14px;}
.vol-copy ul li{display:flex;gap:14px;align-items:flex-start;font-size:16.5px;color:#cfd9ee;}
.vol-copy ul li svg{width:24px;height:24px;color:var(--red);flex:none;margin-top:1px;}
.form-card{background:var(--paper);color:var(--ink);border-radius:10px;padding:clamp(26px,3vw,40px);box-shadow:0 40px 80px -40px rgba(0,0,0,.7);}
.form-card h3{font-family:var(--font-serif);font-weight:600;font-size:25px;}
.form-card .fsub{color:var(--muted);font-size:15px;margin-top:6px;margin-bottom:22px;}
.field{margin-bottom:16px;}
.field label:not(.check-opt){display:block;font-weight:600;font-size:13.5px;letter-spacing:.02em;margin-bottom:7px;}
.field label .req{color:var(--red);}
.field label .opt{color:var(--muted);font-weight:500;}
.field .fhint{display:block;margin-top:6px;font-size:12.5px;color:var(--muted);}
.field input[type="file"]{padding:10px 12px;font-size:14px;cursor:pointer;background:#fbfaf6;}
.field input[type="file"]::file-selector-button{margin-right:12px;padding:8px 14px;border:none;border-radius:5px;background:var(--navy);color:#fff;font-family:inherit;font-size:13px;font-weight:600;cursor:pointer;}
.field input,.field textarea{width:100%;font-family:var(--font-sans);font-size:16px;color:var(--ink);padding:13px 15px;border:1.5px solid var(--line);border-radius:5px;background:#fff;transition:border-color .2s ease,box-shadow .2s ease;}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--navy);box-shadow:0 0 0 3px rgba(36,74,138,.13);}
.field textarea{resize:vertical;min-height:84px;}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.consent{display:flex;gap:11px;align-items:flex-start;margin:6px 0 20px;}
.consent input{width:19px;height:19px;margin-top:3px;flex:none;accent-color:var(--red);}
.consent label{font-size:13px;color:var(--muted);line-height:1.5;}
.form-card .btn{width:100%;}
.form-note{font-size:12px;color:var(--muted);margin-top:14px;text-align:center;}
.form-error{display:none;background:#fdecec;color:#9c1622;border:1px solid #f3c9cc;border-radius:6px;padding:12px 14px;font-size:14px;margin-bottom:14px;}
.form-error.show{display:block;}
.form-success{display:none;text-align:center;padding:30px 10px;}
.form-success.show{display:block;}
.form-success svg{width:60px;height:60px;color:#1f8a4c;margin:0 auto 16px;}
.form-success h3{font-family:var(--font-serif);font-size:26px;}
.form-success p{color:var(--muted);margin-top:8px;}

/* ---------- contribute band ---------- */
.contribute{background:var(--red);color:#fff;text-align:center;}
.contribute .section-title{color:#fff;}
.contribute p{max-width:54ch;margin:18px auto 0;font-size:18px;color:#ffe2e4;}
.contribute .cta-row{display:flex;justify-content:center;gap:14px;flex-wrap:wrap;margin-top:32px;}

/* ---------- contribute modal (Venmo) ---------- */
.modal-overlay{position:fixed;inset:0;z-index:120;background:rgba(8,18,38,.72);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:24px;opacity:0;pointer-events:none;transition:opacity .25s ease;}
.modal-overlay.open{opacity:1;pointer-events:auto;}
.modal{background:var(--paper);color:var(--ink);width:100%;max-width:440px;border-radius:14px;padding:34px 30px 30px;text-align:center;box-shadow:0 50px 110px -30px rgba(0,0,0,.7);transform:translateY(14px) scale(.98);transition:transform .25s ease;position:relative;}
.modal-overlay.open .modal{transform:none;}
.modal .close{position:absolute;top:14px;right:14px;width:38px;height:38px;border-radius:50%;border:none;background:rgba(15,33,67,.07);color:var(--ink);cursor:pointer;font-size:20px;line-height:1;display:grid;place-items:center;transition:.2s;}
.modal .close:hover{background:rgba(15,33,67,.15);}
.modal .eyebrow{justify-content:center;}
.modal h3{font-family:var(--font-serif);font-weight:600;font-size:27px;margin:14px 0 6px;}
.modal .msub{color:var(--muted);font-size:15px;margin-bottom:22px;}
.venmo-qr{width:230px;height:230px;margin:0 auto;border-radius:12px;border:1px solid var(--line);background:#fff;display:grid;place-items:center;overflow:hidden;box-shadow:var(--shadow-card);}
.venmo-qr img{width:100%;height:100%;object-fit:contain;padding:8px;}
.venmo-qr .ph{color:var(--muted);font-size:13px;padding:20px;line-height:1.4;}
.venmo-user{display:inline-flex;align-items:center;gap:10px;margin:20px auto 0;background:#fff;border:1px solid var(--line);border-radius:999px;padding:10px 16px 10px 18px;font-weight:700;font-size:17px;color:#008CFF;cursor:pointer;transition:.2s;}
.venmo-user:hover{background:#f0f8ff;}
.venmo-user .copy{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);font-weight:700;border-left:1px solid var(--line);padding-left:10px;}
.venmo-user.copied .copy{color:#1f8a4c;}
.modal .venmo-btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;width:100%;margin-top:22px;background:#008CFF;color:#fff;font-family:var(--font-sans);font-weight:700;font-size:16px;padding:16px;border-radius:8px;transition:.2s;}
.modal .venmo-btn:hover{background:#0070cc;}
.modal .disc{font-size:12px;color:var(--muted);margin-top:18px;}

/* ---------- footer ---------- */
footer.site{background:var(--navy-900);color:#c4d0e8;padding:64px 0 30px;}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;}
.foot-brand .brand .mark{width:50px;height:50px;font-size:23px;}
.foot-brand p{margin-top:18px;font-size:14.5px;color:#92a3c4;max-width:34ch;}
.foot-col h4{font-family:var(--font-sans);font-size:13px;letter-spacing:.16em;text-transform:uppercase;color:#fff;margin-bottom:16px;}
.foot-col a,.foot-col p{display:block;color:#b3c1dd;font-size:15px;margin-bottom:10px;background:none;border:none;text-align:left;cursor:pointer;font-family:var(--font-sans);}
.foot-col a:hover{color:#fff;}
.socials{display:flex;gap:12px;margin-top:6px;}
.socials a{width:40px;height:40px;border-radius:50%;border:1px solid rgba(255,255,255,.2);display:grid;place-items:center;color:#fff;transition:.2s;}
.socials a:hover{background:var(--red);border-color:var(--red);}
.socials svg{width:18px;height:18px;}
/* center every part of the footer */
.foot-grid{text-align:center;}
.foot-brand{display:flex;flex-direction:column;align-items:center;}
.foot-brand p{margin-left:auto;margin-right:auto;}
.foot-col h4,.foot-col a,.foot-col p{text-align:center;}
.socials{justify-content:center;}
.foot-legal-row{display:flex;align-items:center;gap:24px;padding:28px 0;margin-top:40px;border-top:2px solid rgba(255,255,255,.25);border-bottom:1px solid rgba(255,255,255,.1);flex-wrap:wrap;}
.foot-legal-row a{color:#ffffff;font-size:16px;font-weight:700;text-decoration:underline;text-underline-offset:4px;letter-spacing:.01em;}
.foot-legal-row a:hover{color:#e7b9bd;}
.foot-legal-row .foot-legal-dot{color:#7f90b0;font-size:16px;}
.foot-bottom{border-top:1px solid rgba(255,255,255,.12);margin-top:48px;padding-top:24px;display:flex;flex-direction:column;gap:10px;font-size:13px;color:#7f90b0;}
.foot-bottom .disc{max-width:60ch;}
.foot-legal{display:flex;align-items:center;gap:14px;flex-wrap:wrap;}
.foot-legal a{color:#c4d0e8;font-size:13px;text-decoration:underline;text-underline-offset:3px;}
.foot-legal a:hover{color:#fff;}
.foot-legal-dot{color:#7f90b0;font-size:13px;}

/* ---------- vote banner ---------- */
.vote-banner{background:var(--red);border-top:4px solid rgba(255,255,255,.25);border-bottom:4px solid rgba(255,255,255,.25);}
.vote-banner-inner{display:flex;align-items:center;justify-content:center;gap:36px;padding:26px 0;flex-wrap:wrap;}
.vote-banner .vote-main,.vote-banner .vote-early{display:flex;flex-direction:column;align-items:center;gap:4px;}
.vote-banner .vote-label{font-size:12px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.8);}
.vote-banner .vote-date{font-family:var(--font-display);font-size:clamp(22px,2.6vw,32px);letter-spacing:.04em;color:#fff;text-transform:uppercase;text-shadow:0 2px 8px rgba(0,0,0,.25);}
.vote-divider{width:2px;height:48px;background:rgba(255,255,255,.35);flex:none;}
.vote-banner .btn{background:#fff;color:var(--red);border-color:#fff;white-space:nowrap;}
.vote-banner .btn:hover{background:var(--navy-900);color:#fff;border-color:var(--navy-900);}

/* ---------- Bryan statement section ---------- */
.statement-section{background:var(--paper);}
.statement-grid{display:grid;grid-template-columns:1fr 1.4fr;gap:clamp(36px,5vw,72px);align-items:start;}
.statement-photos{display:flex;flex-direction:column;gap:18px;position:sticky;top:110px;}
.stmt-photo-bw{position:relative;}
.stmt-photo-bw img{width:100%;border-radius:4px;box-shadow:var(--shadow-card);}
.stmt-photo-label{display:block;font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-top:8px;text-align:center;}
.stmt-photo-color img{width:100%;border-radius:4px;box-shadow:var(--shadow-card);}
.statement-body .section-title{margin-top:12px;}
.statement-quote{margin-top:24px;display:flex;flex-direction:column;gap:14px;}
.statement-quote p{font-size:16.5px;color:#33405c;line-height:1.78;}

/* ---------- volunteer checkboxes ---------- */
.help-options{border:none;padding:0;margin-bottom:16px;}
.help-options legend{font-weight:600;font-size:13.5px;letter-spacing:.02em;margin-bottom:10px;display:block;width:100%;color:var(--ink);}
.check-opt{display:flex;align-items:center;gap:10px;padding:10px 10px;border-radius:5px;cursor:pointer;transition:background .15s;margin-bottom:4px;}
.check-opt:hover{background:rgba(36,74,138,.07);}
.check-opt input[type="checkbox"]{width:18px;height:18px;flex:none;accent-color:var(--red);cursor:pointer;margin:0;flex-shrink:0;}
.check-opt span{font-size:15px;color:var(--ink);line-height:1.4;}
.other-reveal{display:none;padding:2px 10px 8px 38px;}
.other-reveal.show{display:block;}
.other-input{width:100%;padding:8px 12px;border:1px solid #d1d8e8;border-radius:5px;font-size:15px;font-family:var(--font-body);color:var(--ink);background:#f8f9fc;outline:none;box-sizing:border-box;}
.other-input:focus{border-color:var(--navy);}

/* ---------- news section within priorities ---------- */
.news-inner .news-head{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;flex-wrap:wrap;margin-bottom:40px;}

/* reveal */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s cubic-bezier(.2,.7,.2,1),transform .7s cubic-bezier(.2,.7,.2,1);}
.reveal.in{opacity:1;transform:none;}

/* ---------- sticky media: pin photos so long copy doesn't leave big gaps ---------- */
@media(min-width:1001px){
  .about-grid,
  .about-wide .wrap{align-items:start;}
  .about-photo,
  .about-media{position:sticky;top:110px;align-self:start;}
  /* gentle scroll-linked drift on the pinned image (set via site.js) */
  .about-photo img,
  .about-media img{transform:translate3d(0,var(--drift,0px),0);will-change:transform;}
}
@media(prefers-reduced-motion:reduce){
  .about-photo img,
  .about-media img{transform:none !important;}
}

/* ---------- responsive ---------- */
@media(max-width:1000px){
  .pri-grid{grid-template-columns:repeat(2,1fr);}
  .news-grid{grid-template-columns:repeat(2,1fr);}
  .hero-grid{grid-template-columns:1fr;min-height:auto;gap:10px;padding:40px 0 0;}
  .hero-photo{order:-1;max-width:430px;margin:0 auto;gap:14px;}
  .photo-frame img{height:auto;max-height:46vh;}
  .hero-fop{position:static;width:auto;flex-direction:column;align-items:center;gap:8px;margin:12px auto 0;}
  .hero-fop img{width:84px;}
  .endorsed-stamp{font-size:18px;}
  .fop-cap{font-size:10px;max-width:200px;text-align:center;}
  .vol-grid{grid-template-columns:1fr;}
  .about-grid{grid-template-columns:1fr;}
  .about-photo{max-width:480px;}
  .about-wide .wrap{grid-template-columns:1fr;}
  .about-wide.flip .wrap{direction:ltr;}
}
@media(max-width:900px){
  .statement-grid{grid-template-columns:1fr;}
  .statement-photos{flex-direction:row;position:static;}
  .stmt-photo-bw,.stmt-photo-color{flex:1;}
}
@media(max-width:720px){
  .nav-links,.nav-cta .btn,.nav-socials{display:none;}
  .hamburger{display:flex;}
  .vote-banner-inner{gap:18px;padding:20px 0;}
  .vote-banner .btn{width:100%;justify-content:center;}
  .statement-photos{flex-direction:column;}
  .foot-grid{grid-template-columns:1fr;gap:30px;}
  .news-grid{grid-template-columns:1fr;}
  .row2{grid-template-columns:1fr;}
  .values-inner{flex-direction:column;gap:6px;}
  .values .v{padding:4px 0;}
  .values .v:not(:last-child) .star:last-child{display:none;}
  .hero h1 .name{font-size:clamp(52px,15.5vw,84px);}
  .hero-actions{width:100%;}
  .hero-actions .btn{flex:1 1 auto;}
  .hero-meta{gap:16px;}
  .hero-meta .m b{font-size:22px;}
  .section{padding:62px 0;}
  .news-head{flex-direction:column;align-items:flex-start;gap:8px;}
  .about-photo .tag{left:12px;bottom:12px;}
  .section-title{font-size:clamp(27px,7.6vw,40px);}
}
@media(max-width:480px){
  .pri-grid{grid-template-columns:1fr;}
  .wrap{padding:0 20px;}
  .signbrand .nm{font-size:21px;}
  .signbrand .keep{font-size:11px;}
  .signbrand .role{font-size:8.5px;letter-spacing:.13em;}
}
