/* Cloyd Benjamin Jr. Campaign Site — red/white judicial campaign design */
:root{
  --red:#c4172c;
  --red-dark:#8f0f1f;
  --ink:#121212;
  --white:#ffffff;
  --off:#f7f7f7;
  --muted:#686868;
  --line:#e6e6e6;
  --shadow:0 24px 70px rgba(18,18,18,.14);
  --radius:22px;
  --serif:'Libre Baskerville', Georgia, serif;
  --sans:'Montserrat', system-ui, -apple-system, Segoe UI, sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;color:var(--ink);background:var(--white);font-family:var(--sans);line-height:1.6}
a{color:inherit;text-decoration:none}img{max-width:100%;display:block}.container{width:min(1160px,calc(100% - 32px));margin:auto}
.topline{background:var(--red);color:#fff;font-size:.82rem;letter-spacing:.04em;text-transform:uppercase}.topline .container{display:flex;justify-content:space-between;gap:1rem;padding:.55rem 0}.nav{position:sticky;top:0;z-index:10;background:rgba(255,255,255,.96);backdrop-filter:blur(18px);border-bottom:1px solid var(--line)}.nav-inner{display:flex;align-items:center;justify-content:space-between;padding:1rem 0}.brand{display:grid;gap:.12rem;min-width:210px;max-width:280px}.brand strong{font-family:var(--serif);font-size:clamp(.9rem,1.35vw,1.06rem);letter-spacing:-.01em;white-space:nowrap}.brand span{color:var(--red);font-weight:900;font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;white-space:nowrap}.links{display:flex;align-items:center;gap:.82rem;font-size:.84rem;font-weight:800}.links a{opacity:.82}.links a:hover{opacity:1;color:var(--red)}.menu{display:none;border:0;background:var(--red);color:#fff;border-radius:999px;padding:.6rem .8rem;font-weight:900}.mobile{display:none;padding:0 0 1rem}.mobile a{display:block;padding:.8rem 0;border-top:1px solid var(--line);font-weight:800}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;border-radius:999px;padding:.9rem 1.15rem;font-weight:900;border:2px solid transparent;transition:.2s ease;cursor:pointer}.btn-red{background:var(--red);color:#fff;box-shadow:0 12px 30px rgba(196,23,44,.2)}.btn-red:hover{transform:translateY(-2px);background:var(--red-dark)}.btn-dark{background:var(--ink);color:#fff}.btn-outline{border-color:var(--red);color:var(--red);background:#fff}.btn-small{padding:.65rem .9rem;font-size:.82rem}
.hero{position:relative;overflow:hidden;background:#fff;border-bottom:1px solid var(--line)}.hero:before{display:none}.hero:after{content:'';position:absolute;right:-12vw;top:0;width:46vw;height:100%;background:linear-gradient(135deg,var(--red),var(--red-dark));clip-path:polygon(22% 0,100% 0,100% 100%,0 100%);z-index:0}.hero-grid{position:relative;z-index:1;display:grid;grid-template-columns:1.05fr .95fr;gap:3rem;align-items:center;padding:5rem 0}.eyebrow{display:inline-flex;align-items:center;gap:.6rem;background:#fff;border:2px solid var(--red);border-radius:999px;padding:.45rem .8rem;color:var(--red);font-weight:900;text-transform:uppercase;letter-spacing:.12em;font-size:.73rem}.eyebrow:before{content:'';width:.62rem;height:.62rem;background:var(--red);border-radius:50%}h1,h2,h3{line-height:1.08;margin:0 0 1rem}h1{font-family:var(--serif);font-size:clamp(3rem,7vw,6.6rem);letter-spacing:-.06em}h2{font-family:var(--serif);font-size:clamp(2rem,4vw,3.6rem);letter-spacing:-.04em}h3{font-family:var(--serif);font-size:1.35rem}.hero .lead{font-size:1.18rem;color:#3f3f3f;max-width:680px}.hero-actions{display:flex;flex-wrap:wrap;gap:.8rem;margin:1.7rem 0}.hero-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem;margin-top:2rem}.stat{background:#fff;border:1px solid var(--line);border-left:6px solid var(--red);border-radius:18px;padding:1rem;box-shadow:0 10px 30px rgba(18,18,18,.06)}.stat strong{display:block;color:var(--red);font-size:1.3rem}.stat span{font-size:.8rem;font-weight:900;text-transform:uppercase;color:var(--muted);letter-spacing:.05em}.hero-card{position:relative}.photo-frame{position:relative;background:var(--ink);border-radius:0 42px 0 42px;padding:.8rem;box-shadow:var(--shadow);transform:rotate(.8deg)}.photo-frame img{border-radius:0 34px 0 34px;width:100%;aspect-ratio:4/5;object-fit:cover;object-position:top center}.seal{position:absolute;right:-18px;bottom:24px;background:#fff;color:var(--red);border:8px solid var(--red);border-radius:0 28px 0 28px;width:148px;height:128px;display:grid;place-items:center;text-align:center;font-weight:900;text-transform:uppercase;font-size:.78rem;letter-spacing:.06em;box-shadow:var(--shadow)}
.video-banner{background:#000;line-height:0;border-bottom:5px solid var(--red)}.video-banner-player{width:100%;max-height:90vh;display:block;object-fit:contain}
.section{padding:5rem 0}.section-tight{padding:3rem 0;background:var(--off)}.section-red{background:linear-gradient(135deg,var(--red-dark),var(--red));color:#fff}.section-red .muted,.section-red p{color:#fff}.split{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center}.muted{color:var(--muted)}.kicker{color:var(--red);font-weight:900;text-transform:uppercase;letter-spacing:.14em;font-size:.78rem;margin-bottom:.8rem}.panel{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:1.6rem;box-shadow:0 20px 50px rgba(18,18,18,.08)}.grid{display:grid;gap:1rem}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-2{grid-template-columns:repeat(2,1fr)}.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:1.5rem;box-shadow:0 16px 44px rgba(18,18,18,.07)}.card.redtop{border-top:8px solid var(--red)}.timeline{display:grid;gap:1rem}.timeline-item{display:grid;grid-template-columns:56px 1fr;gap:1rem;align-items:start}.badge{width:56px;height:56px;border-radius:8px;background:var(--red);color:#fff;display:grid;place-items:center;font-weight:900}.checklist{list-style:none;margin:1rem 0 0;padding:0;display:grid;gap:.7rem}.checklist li{display:flex;gap:.7rem;align-items:flex-start}.checklist li:before{content:'✓';background:var(--red);color:#fff;border-radius:50%;width:1.35rem;height:1.35rem;display:inline-grid;place-items:center;flex:0 0 auto;font-weight:900;font-size:.8rem}.quote{font-family:var(--serif);font-size:1.55rem;color:var(--ink);line-height:1.45}.date-card{background:#fff;color:var(--ink);border-radius:22px;padding:1.4rem;border:1px solid rgba(255,255,255,.2)}.date-card strong{display:block;font-size:1.8rem;color:var(--red)}.media-board{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.media-board img{border-radius:0 26px 0 26px;border:1px solid var(--line);box-shadow:0 18px 50px rgba(0,0,0,.12)}
.donation-options{display:grid;gap:.8rem}.donation-tile{display:block;border:2px solid var(--line);border-left:9px solid var(--red);border-radius:18px;padding:1rem;background:#fff;transition:.2s ease}.donation-tile:hover{transform:translateY(-2px);border-color:var(--red);box-shadow:0 14px 34px rgba(18,18,18,.1)}.donation-tile span{display:block;color:var(--muted);font-weight:900;text-transform:uppercase;letter-spacing:.1em;font-size:.75rem}.donation-tile strong{display:block;color:var(--ink);font-size:1.1rem}.amount-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem}.donation-panel{border-top:8px solid var(--red)}
.donate-layout{display:grid;grid-template-columns:1fr 400px;gap:4rem;align-items:start}.donate-sidebar{position:sticky;top:90px}.donate-form-wrap{min-width:0}.form-frame-wrap{border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);margin-top:1.5rem}.form-frame-wrap iframe{display:block;width:100%}.donate-step-header{display:flex;gap:1.1rem;align-items:flex-start;margin-bottom:2rem}.donate-badge{width:3rem;height:3rem;border-radius:50%;background:var(--red);color:#fff;display:grid;place-items:center;font-weight:900;font-size:1.15rem;flex-shrink:0;margin-top:.25rem;box-shadow:0 8px 20px rgba(196,23,44,.25)}.donate-badge-muted{background:var(--ink)}.donate-amounts{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--line)}
.payment-method{margin-top:1.2rem;padding-top:1.2rem;border-top:1px solid var(--line)}.payment-method:first-of-type{margin-top:1rem;padding-top:1rem}.payment-method-label{font-weight:900;font-size:.78rem;text-transform:uppercase;letter-spacing:.1em;color:var(--ink);margin-bottom:.2rem;display:flex;align-items:center;gap:.6rem}.payment-method-soon{opacity:.6}.coming-soon-badge{background:var(--line);color:var(--muted);border-radius:999px;padding:.15rem .6rem;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em}.cashapp-tag{display:inline-block;background:#00D632;color:#fff;font-weight:900;font-size:1.1rem;border-radius:12px;padding:.55rem 1.1rem;letter-spacing:.02em}
@media(max-width:900px){.donate-layout{grid-template-columns:1fr;gap:2.5rem}.donate-sidebar{position:static}}
.footer{background:var(--ink);color:#fff;padding:3rem 0}.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:2rem}.footer a{color:#fff}.footer-tagline{color:rgba(255,255,255,.65);font-style:italic;font-size:.9rem;margin:.25rem 0 .5rem;letter-spacing:.02em}.fineprint{border-top:1px solid rgba(255,255,255,.12);margin-top:2rem;padding-top:1rem;color:#d7d7d7;font-size:.82rem}.page-hero{padding:4rem 0 3rem;background:#fff;border-bottom:1px solid var(--line);position:relative}.page-hero:after{content:'';position:absolute;left:0;bottom:0;width:100%;height:8px;background:linear-gradient(90deg,var(--red) 0 72%,var(--ink) 72% 100%)}.page-hero h1{font-size:clamp(2.6rem,5vw,5rem)}.research-list a{text-decoration:underline;color:var(--red)}
@media(max-width:900px){.links{display:none}.menu{display:inline-flex}.mobile.open{display:block}.topline .container{display:block;text-align:center}.hero:after{opacity:.08;width:100%;right:0;clip-path:none}.hero-grid,.split,.footer-grid{grid-template-columns:1fr}.hero-grid{padding:3rem 0}.hero-stats,.grid-3,.grid-2,.media-board{grid-template-columns:1fr}.seal{right:8px;bottom:8px;width:118px;height:118px}.section{padding:3.5rem 0}.amount-grid{grid-template-columns:1fr}}

/* Campaign photo updates */
.section-soft{background:var(--off)}
.photo-gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-top:1.4rem}
.photo-gallery.compact{grid-template-columns:repeat(2,1fr);margin-top:0}
.photo-gallery img,.photo-card img{width:100%;height:100%;min-height:220px;max-height:420px;object-fit:cover;object-position:center;border-radius:0 26px 0 26px;border:1px solid var(--line);box-shadow:0 18px 50px rgba(0,0,0,.12);background:#fff;image-orientation:from-image}
.photo-card{margin-bottom:1rem}
.photo-card img{aspect-ratio:4/5;max-height:none}
@media(max-width:900px){.photo-gallery,.photo-gallery.compact{grid-template-columns:1fr}.photo-gallery img{max-height:none}}

/* Media gallery */
figure{margin:0;display:grid;gap:.4rem}figure img{border-radius:0 18px 0 18px;width:100%;height:320px;object-fit:cover;border:1px solid var(--line);box-shadow:0 12px 36px rgba(18,18,18,.08)}@media(max-width:900px){figure img{height:260px}}@media(max-width:600px){figure img{height:auto}}

/* 2026 content update sections */
.feature-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-top:1.4rem}
.feature-card,.event-card,.map-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:0 16px 44px rgba(18,18,18,.07)}
.feature-card img{width:100%;height:260px;object-fit:cover;background:#fff}
.feature-card div,.event-card div{padding:1.25rem}
.event-card img{width:100%;height:520px;object-fit:contain;object-position:center top;background:#111}
.map-card img{width:100%;height:auto;background:#fff}
.caption{padding:.9rem 1rem;color:var(--muted);font-size:.82rem;font-weight:700;border-top:1px solid var(--line)}
.event-details{display:grid;gap:.75rem;margin:1.4rem 0}
.event-details div{border-left:6px solid var(--red);background:#fff;border:1px solid var(--line);border-left-width:6px;border-radius:14px;padding:.9rem 1rem;box-shadow:0 10px 28px rgba(18,18,18,.06)}
.event-details span{display:block;color:var(--muted);font-size:.72rem;font-weight:900;text-transform:uppercase;letter-spacing:.1em}
.event-details strong{display:block;color:var(--ink);font-size:1.02rem}
@media(max-width:900px){.feature-grid{grid-template-columns:1fr}.feature-card img,.event-card img{height:auto}}
