/* ════════════════════════════════════════════════════
   ERIKA UYTERHOEVEN FOR STATE SENATE — v2
   Redesigned from 3 rounds of PWB adversarial review
   Font: Montserrat · Palette: Purple / Red / Green
   ════════════════════════════════════════════════════ */

/* ── TOKENS ── */
:root {
    --purple: #39289a;
    --purple-deep: #2a1e73;
    --purple-light: #5340b5;
    --purple-pale: #e6e3f4;
    --purple-ghost: #f3f2f8;
    --white: #FFFFFF;
    --off-white: #FAFAFA;
    --warm-white: #F8F6F2;
    --ink: #1A1A1A;
    --ink-light: #444;
    --ink-muted: #666;          /* ← was #777, now passes 4.5:1 */
    --ink-faint: #999;          /* ← was #BBB, improved */
    --border: #E5E2EE;
    --red: #E0342D;
    --red-pale: rgba(224,52,45,0.08);
    --green: #1FAA4A;
    --green-pale: rgba(31,170,74,0.08);
    --highlight: #dcf3e8;
    --green-bright: #52c490;

    --font-head: 'Montserrat', sans-serif;
    --font-body: 'Montserrat', sans-serif;
    --font-voice: 'Montserrat', sans-serif;

    --ease: cubic-bezier(0.16,1,0.3,1);
    --ease-out: cubic-bezier(0.0,0.0,0.2,1);

    --max-w: 960px;
    --max-w-narrow: 740px;
    --px: 1.5rem;
    --section-py: 5rem;
}

@media(min-width:900px) {
    :root { --px: 3rem; --section-py: 6.5rem; }
}

/* ── RESET ── */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--font-body);background:var(--white);color:var(--ink);line-height:1.7;overflow-x:hidden;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
img{display:block;max-width:100%}
a{color:inherit}

/* ── FOCUS INDICATORS (WCAG 2.4.7) ── */
:focus-visible {
    outline: 3px solid var(--purple-light);
    outline-offset: 2px;
    border-radius: 2px;
}
button:focus-visible, a:focus-visible, input:focus-visible, select:focus-visible {
    outline: 3px solid var(--purple-light);
    outline-offset: 2px;
}

/* ── SKIP NAV (WCAG) ── */
.skip-link{position:absolute;top:-100%;left:1rem;background:var(--purple);color:#fff;padding:.75rem 1.5rem;font-weight:700;font-size:.85rem;z-index:9999;border-radius:0 0 6px 6px;transition:top .2s}
.skip-link:focus{top:0}


/* ════════════════════════════════════════════════════
   STICKY BAR
   ════════════════════════════════════════════════════ */
.sticky{position:fixed;bottom:0;left:0;right:0;z-index:200;background:var(--purple-deep);padding:.55rem var(--px);display:flex;align-items:center;justify-content:center;gap:.75rem;transform:translateY(100%);transition:transform .5s var(--ease);backdrop-filter:blur(8px)}
.sticky.show{transform:translateY(0)}
.sticky-text{font-size:.7rem;color:rgba(255,255,255,.6);display:none}
@media(min-width:600px){.sticky-text{display:block}}
.sticky .sb{display:inline-flex;align-items:center;gap:.35rem;padding:.5rem 1.2rem;border-radius:5px;font-family:var(--font-body);font-size:.72rem;font-weight:700;text-decoration:none;text-transform:uppercase;letter-spacing:.07em;cursor:pointer;border:none;transition:all .25s var(--ease)}
.sticky .sb.p{background:var(--red);color:#fff;box-shadow:0 2px 12px rgba(224,52,45,.3)}
.sticky .sb.p:hover{background:#c72a24;transform:translateY(-1px)}
.sticky .sb.g{background:rgba(255,255,255,.08);color:rgba(255,255,255,.85);border:1px solid rgba(255,255,255,.2)}
.sticky .sb.g:hover{border-color:#fff;color:#fff;background:rgba(255,255,255,.12)}


/* ════════════════════════════════════════════════════
   NAVIGATION
   ════════════════════════════════════════════════════ */
nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:1rem var(--px);display:flex;justify-content:space-between;align-items:center;transition:all .4s var(--ease)}
nav.scrolled{background:rgba(255,255,255,.97);backdrop-filter:blur(14px);box-shadow:0 1px 0 var(--border);padding:.55rem var(--px)}
nav.page-nav{background:rgba(255,255,255,.97);backdrop-filter:blur(14px);box-shadow:0 1px 0 var(--border);padding:.55rem var(--px)}
nav.page-nav .nav-logo-img{display:none}
nav.page-nav .nav-logo-dark{display:block}
nav.page-nav .nlinks a{color:var(--ink-muted)}
nav.page-nav .nlinks a:hover{color:var(--purple)}
nav.page-nav .nav-date{color:var(--purple)}

.nav-logo{display:flex;align-items:center;text-decoration:none;transition:all .4s var(--ease)}
.nav-logo-img{height:56px;width:auto;transition:all .4s var(--ease)}
.nav-logo-dark{display:none;height:44px;width:auto;transition:all .4s var(--ease)}
nav.scrolled .nav-logo-img{display:none}
nav.scrolled .nav-logo-dark{display:block;height:32px}
nav.scrolled .nav-date{font-size:.55rem}

.nav-date{position:absolute;left:50%;transform:translateX(-50%);font-family:var(--font-head);font-size:.6rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.5);white-space:nowrap;transition:all .4s var(--ease)}
nav.scrolled .nav-date{color:var(--purple)}
nav.page-nav .nav-date{color:var(--purple)}

.nlinks{display:none;list-style:none;gap:1.1rem;align-items:center}
.nlinks a{font-size:.62rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.65);text-decoration:none;transition:color .3s;position:relative}
.nlinks a:hover{color:#fff}
.nlinks a.active{color:#fff;font-weight:700}
.nlinks a.active::after{content:'';position:absolute;bottom:-.4rem;left:0;right:0;height:2px;background:var(--green-bright);border-radius:1px}
nav.scrolled .nlinks a{color:var(--ink-muted)}
nav.scrolled .nlinks a:hover{color:var(--purple)}
nav.scrolled .nlinks a.active{color:var(--purple)}
nav.scrolled .nlinks a.active::after{background:var(--purple)}
nav.page-nav .nlinks a.active{color:var(--purple)}
nav.page-nav .nlinks a.active::after{background:var(--purple)}

.nlinks .nc{background:var(--red);color:#fff !important;padding:.4rem .9rem;border-radius:5px;box-shadow:0 2px 8px rgba(224,52,45,.2)}
.nlinks .nc:hover{background:#c72a24}
.nlinks .nc::after{display:none}

/* Mobile */
.mobile-toggle{display:flex;flex-direction:column;gap:5px;cursor:pointer;padding:8px;background:none;border:none;z-index:101}
.mobile-toggle span{display:block;width:22px;height:2px;background:rgba(255,255,255,.8);transition:all .3s ease;border-radius:1px}
nav.scrolled .mobile-toggle span,nav.page-nav .mobile-toggle span{background:var(--ink)}
.mobile-menu{display:none;position:fixed;inset:0;z-index:99;background:var(--purple-deep);flex-direction:column;align-items:center;justify-content:center;gap:1.5rem}
.mobile-menu.open{display:flex}
.mobile-menu a{font-family:var(--font-head);font-size:1.15rem;font-weight:700;color:#fff;text-decoration:none;text-transform:uppercase;letter-spacing:.08em;transition:color .2s}
.mobile-menu a:hover{color:var(--green-bright)}
.mobile-menu .nc{background:var(--red);padding:.6rem 1.5rem;border-radius:5px}

@media(min-width:900px){
    .nlinks{display:flex}
    .mobile-toggle{display:none}
}


/* ════════════════════════════════════════════════════
   BUTTONS — now with PRIMARY / SECONDARY hierarchy
   ════════════════════════════════════════════════════ */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.8rem 1.6rem;font-family:var(--font-body);font-size:.85rem;font-weight:700;text-decoration:none;cursor:pointer;border:none;text-transform:uppercase;letter-spacing:.05em;transition:all .3s var(--ease);border-radius:5px;position:relative;overflow:hidden}
.btn svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:2.5}

/* Primary CTA — donate (red, with glow) */
.btn-red{background:var(--red);color:#fff;box-shadow:0 4px 16px rgba(224,52,45,.25)}
.btn-red:hover{background:#c72a24;transform:translateY(-2px);box-shadow:0 6px 24px rgba(224,52,45,.35)}

/* Secondary CTA — volunteer, etc (purple) */
.btn-purple{background:var(--purple);color:#fff}
.btn-purple:hover{background:var(--purple-light);transform:translateY(-2px);box-shadow:0 6px 20px rgba(57,40,154,.2)}

/* Ghost — white on dark backgrounds */
.btn-white{background:rgba(255,255,255,.08);color:#fff;border:2px solid rgba(255,255,255,.3)}
.btn-white:hover{background:rgba(255,255,255,.15);border-color:#fff}
.btn-white-solid{background:#fff;color:var(--purple);border:2px solid #fff;font-weight:800}
.btn-white-solid:hover{background:rgba(255,255,255,.9);transform:translateY(-2px)}

/* Outline */
.btn-outline{background:transparent;color:var(--purple);border:2px solid var(--purple)}
.btn-outline:hover{background:var(--purple);color:#fff}

.btn-big{padding:1rem 2.4rem;font-size:.92rem}
.btn-full{width:100%;justify-content:center}


/* ════════════════════════════════════════════════════
   SECTION SYSTEM — variants to break sameness
   ════════════════════════════════════════════════════ */
section{padding:var(--section-py) var(--px)}
.inner{max-width:var(--max-w-narrow);margin:0 auto}
.wide{max-width:var(--max-w);margin:0 auto}

/* Section tags & titles */
.tag{font-family:var(--font-head);font-size:.58rem;font-weight:800;letter-spacing:.2em;text-transform:uppercase;color:var(--red);margin-bottom:.5rem}
.stitle{font-family:var(--font-head);font-size:clamp(1.6rem,4vw,2.5rem);font-weight:900;text-transform:uppercase;line-height:1.06;margin-bottom:1rem}
.stitle .light{color:var(--ink-muted);font-weight:500;font-family:var(--font-voice);font-style:italic;text-transform:none}
.sdesc{font-family:var(--font-voice);font-size:.95rem;color:var(--ink-muted);max-width:560px;line-height:1.7;margin-bottom:2rem}

/* Large variant — for hero-level section titles */
.stitle-lg{font-size:clamp(2rem,5vw,3.2rem);margin-bottom:1.25rem}

/* Background variants */
.bg-white{background:var(--white)}
.bg-ghost{background:var(--purple-ghost)}
.bg-warm{background:var(--warm-white)}
.bg-purple{background:var(--purple);color:#fff}
.bg-purple .tag{color:var(--green-bright)}
.bg-purple .stitle{color:#fff}
.bg-purple .stitle .light{color:rgba(255,255,255,.35)}
.bg-purple .sdesc{color:rgba(255,255,255,.55)}
.bg-dark{background:var(--ink);color:#fff}
.bg-dark .tag{color:var(--green-bright)}
.bg-dark .stitle{color:#fff}
.bg-dark .stitle .light{color:rgba(255,255,255,.3)}


/* ════════════════════════════════════════════════════
   SCROLL REVEAL — staggered variant
   ════════════════════════════════════════════════════ */
.reveal{opacity:0;transform:translateY(16px);transition:opacity .65s var(--ease-out),transform .65s var(--ease)}
.reveal.visible{opacity:1;transform:translateY(0)}
/* Stagger children inside a .stagger parent */
.stagger .reveal:nth-child(1){transition-delay:0s}
.stagger .reveal:nth-child(2){transition-delay:.07s}
.stagger .reveal:nth-child(3){transition-delay:.14s}
.stagger .reveal:nth-child(4){transition-delay:.21s}
.stagger .reveal:nth-child(5){transition-delay:.28s}
.stagger .reveal:nth-child(6){transition-delay:.35s}
.stagger .reveal:nth-child(7){transition-delay:.42s}
.stagger .reveal:nth-child(8){transition-delay:.49s}
@keyframes fadeIn{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}


/* ════════════════════════════════════════════════════
   HERO — index only, split layout option
   ════════════════════════════════════════════════════ */
.hero{position:relative;min-height:100vh;min-height:100svh;display:flex;align-items:stretch;overflow:hidden;background:var(--purple-deep)}
.hero-img{position:absolute;inset:0;z-index:1}
.hero-img img{width:100%;height:100%;object-fit:cover;object-position:center 20%}
.hero-img::after{content:'';position:absolute;inset:0;background:linear-gradient(to right,rgba(42,30,115,.88) 0%,rgba(42,30,115,.65) 35%,rgba(42,30,115,.25) 65%,rgba(42,30,115,.12) 100%)}
@media(max-width:768px){.hero-img::after{background:linear-gradient(to top,rgba(42,30,115,.92) 0%,rgba(42,30,115,.6) 45%,rgba(42,30,115,.2) 100%)}}

.hero-content{position:relative;z-index:2;padding:7.5rem var(--px) 3.5rem;display:flex;flex-direction:column;justify-content:center;max-width:620px;color:#fff}
@media(min-width:900px){.hero-content{padding:0 var(--px)}}

.hero-tag{display:inline-flex;align-items:center;gap:.5rem;font-size:.58rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.6);margin-bottom:1.5rem;opacity:0;animation:fadeIn .6s ease .2s forwards}
.hero-tag::before{content:'';width:28px;height:2px;background:var(--red)}

.hero-h{font-family:var(--font-head);font-size:clamp(2.6rem,7vw,4.8rem);font-weight:900;line-height:.96;text-transform:uppercase;margin-bottom:1.25rem;opacity:0;animation:fadeIn .6s ease .35s forwards}
.hero-h .accent{color:var(--green-bright)}

.hero-sub{font-family:var(--font-voice);font-size:clamp(1rem,2vw,1.2rem);font-weight:400;color:rgba(255,255,255,.8);line-height:1.65;max-width:500px;margin-bottom:2rem;opacity:0;animation:fadeIn .6s ease .5s forwards}
.hero-sub strong{color:#fff;font-weight:600}

.hero-btns{display:flex;flex-wrap:wrap;gap:.65rem;opacity:0;animation:fadeIn .6s ease .65s forwards}


/* ════════════════════════════════════════════════════
   STATS BAR
   ════════════════════════════════════════════════════ */
.stats-bar{background:var(--white);border-bottom:1px solid var(--border)}
.stats-inner{display:flex;flex-wrap:wrap;max-width:var(--max-w);margin:0 auto}
.stat-item{flex:1;min-width:140px;padding:1.25rem 1rem;border-right:1px solid var(--border);text-align:center}
.stat-item:last-child{border-right:none}
.stat-val{font-family:var(--font-head);font-size:1.65rem;font-weight:900;color:var(--purple);line-height:1}
.stat-val span{color:var(--red);font-size:.85rem;font-weight:700}
.stat-label{font-size:.6rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-muted);margin-top:.25rem}
@media(max-width:600px){.stat-item{min-width:50%;border-bottom:1px solid var(--border)}}


/* ════════════════════════════════════════════════════
   WINS — card grid with hover
   ════════════════════════════════════════════════════ */
.wins-grid{display:grid;grid-template-columns:1fr;gap:1rem;margin-top:1.75rem}
@media(min-width:650px){.wins-grid{grid-template-columns:1fr 1fr}}

.win-card{background:var(--white);border:1px solid var(--border);border-radius:10px;padding:1.4rem;transition:all .35s var(--ease);position:relative;overflow:hidden}
.win-card:hover{transform:translateY(-3px);box-shadow:0 10px 28px rgba(49,37,132,.08);border-color:var(--purple-pale)}
.win-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--green);transform:scaleX(0);transform-origin:left;transition:transform .5s var(--ease)}
.win-card:hover::before{transform:scaleX(1)}

.win-check{display:flex;align-items:center;gap:.45rem;margin-bottom:.6rem}
.win-check-icon{width:20px;height:20px;background:var(--green);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:.6rem;font-weight:700;flex-shrink:0}
.win-check-label{font-size:.55rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--green)}
.win-name{font-family:var(--font-head);font-size:1.05rem;font-weight:800;color:var(--ink);margin-bottom:.25rem;line-height:1.2}
.win-desc{font-size:.82rem;color:var(--ink-muted);line-height:1.6}


/* ════════════════════════════════════════════════════
   FIGHTS — vertical timeline treatment (breaks sameness)
   ════════════════════════════════════════════════════ */
.fights-list{margin-top:2rem;position:relative;padding-left:2rem}
.fights-list::before{content:'';position:absolute;top:0;bottom:0;left:6px;width:2px;background:var(--border)}
.fight-row{position:relative;padding:0 0 2rem 0}
.fight-row:last-child{padding-bottom:0}
.fight-row::before{content:'';position:absolute;top:.35rem;left:-2rem;width:14px;height:14px;border-radius:50%;border:3px solid;background:var(--white);z-index:1}
.fight-row.active::before{border-color:var(--red)}
.fight-row.next::before{border-color:var(--purple)}
.fight-badge{display:inline-block;font-family:var(--font-head);font-size:.48rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;padding:.2rem .55rem;border:2px solid;border-radius:3px;margin-bottom:.35rem}
.fight-badge.active{color:var(--red);border-color:var(--red)}
.fight-badge.next{color:var(--purple);border-color:var(--purple)}
.fight-name{font-family:var(--font-head);font-size:.95rem;font-weight:800;line-height:1.2;margin-bottom:.2rem}
.fight-desc{font-size:.82rem;color:var(--ink-muted);line-height:1.6}

@media(min-width:700px){
    .fights-list{padding-left:2.5rem}
    .fight-row::before{left:-2.5rem}
}


/* ════════════════════════════════════════════════════
   PHOTO BREAK — parallax-ready
   ════════════════════════════════════════════════════ */
.photo-break{padding:0;position:relative;height:clamp(280px,40vw,450px);overflow:hidden}
.photo-break img{width:100%;height:120%;object-fit:cover;transform:translateY(-10%);transition:transform .1s linear}
.photo-break .caption{position:absolute;bottom:0;left:0;right:0;padding:1rem var(--px);background:linear-gradient(transparent,rgba(42,30,115,.85));font-size:.72rem;color:rgba(255,255,255,.8);font-weight:500}

/* Full-width interrupt moment — stat/quote overlay on photo */
.photo-statement{position:relative;height:clamp(300px,45vw,500px);overflow:hidden;display:flex;align-items:center;justify-content:center;text-align:center}
.photo-statement img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.photo-statement::after{content:'';position:absolute;inset:0;background:rgba(42,30,115,.8)}
.photo-statement-content{position:relative;z-index:2;max-width:640px;padding:2rem var(--px)}
.photo-statement-text{font-family:var(--font-voice);font-size:clamp(1.2rem,3vw,1.8rem);font-weight:600;color:#fff;line-height:1.45;font-style:italic}
.photo-statement-cite{font-family:var(--font-head);font-size:.6rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--green-bright);margin-top:.75rem}


/* ════════════════════════════════════════════════════
   WATCH HER FIGHT — video section
   ════════════════════════════════════════════════════ */
.wf-intro{font-family:var(--font-voice);font-size:1rem;color:var(--ink-muted);max-width:540px;margin-bottom:2rem;line-height:1.7}
.wf-grid{display:grid;grid-template-columns:1fr;gap:1.25rem}
@media(min-width:550px){.wf-grid{grid-template-columns:1fr 1fr}}
@media(min-width:850px){.wf-grid{grid-template-columns:1fr 1fr 1fr}}
.wf-card{position:relative;border-radius:12px;overflow:hidden;background:var(--ink);aspect-ratio:9/16;max-height:500px}
.wf-card iframe{width:100%;height:100%;border:none}
.wf-follow{margin-top:2rem;display:flex;flex-wrap:wrap;align-items:center;gap:1rem}
.wf-follow-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.65rem 1.35rem;background:var(--purple);color:#fff;border-radius:6px;font-family:var(--font-body);font-size:.8rem;font-weight:700;text-decoration:none;transition:all .25s var(--ease)}
.wf-follow-btn:hover{background:var(--purple-light);transform:translateY(-1px)}
.wf-follow-btn svg{width:18px;height:18px;fill:#fff}
.wf-follow-note{font-size:.78rem;color:var(--ink-muted)}


/* ════════════════════════════════════════════════════
   EXHIBIT / THE PROOF — the design star, enhanced
   ════════════════════════════════════════════════════ */
.exhibit-doc{background:var(--white);border:1px solid var(--border);border-radius:0;max-width:680px;margin:1.5rem auto 0;position:relative;box-shadow:0 8px 40px rgba(42,30,115,.06)}
.exhibit-doc::before{content:'THE PROOF';position:absolute;top:-.65rem;left:1.25rem;font-family:var(--font-head);font-size:.52rem;font-weight:800;letter-spacing:.16em;color:var(--purple);background:var(--warm-white);padding:.12rem .55rem;border:1.5px solid var(--purple)}
.exhibit-hd{padding:1.75rem 1.5rem 1rem;border-bottom:1px solid var(--border)}
.exhibit-hd-sub{font-size:.5rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-muted);margin-bottom:.3rem}
.exhibit-hd-title{font-family:var(--font-voice);font-size:1.15rem;font-weight:700}
.exhibit-bd{padding:1.5rem}
.exhibit-bd p{font-family:var(--font-voice);font-size:.95rem;color:var(--ink-light);line-height:1.9;margin-bottom:.85rem}
.exhibit-bd strong{color:var(--ink);font-weight:700}
.exhibit-bd .hl{background:var(--highlight);padding:.05em .2em;font-weight:700;color:var(--ink)}
.exhibit-bd .ul{background:linear-gradient(180deg,transparent 58%,var(--highlight) 58%);padding:0 .1em}
.exhibit-cl{padding:1.25rem 1.5rem 1.75rem;border-top:1px solid var(--border);font-family:var(--font-voice);font-size:1rem;font-weight:600;color:var(--ink);line-height:1.75}
.exhibit-sig{margin-top:.6rem;font-style:italic;font-weight:400;color:var(--ink-muted);font-size:.9rem}
@media(min-width:900px){.exhibit-hd{padding:2rem 2rem 1rem}.exhibit-bd{padding:1.5rem 2rem}.exhibit-cl{padding:1.5rem 2rem 2rem}}


/* ════════════════════════════════════════════════════
   PLAN — numbered agenda, bolder numbers
   ════════════════════════════════════════════════════ */
.plan-list{margin-top:2.5rem;display:grid;gap:2.25rem}
.plan-item{display:grid;grid-template-columns:auto 1fr;gap:1.25rem;align-items:start}
.plan-num{font-family:var(--font-head);font-size:2.5rem;font-weight:900;color:var(--green-bright);line-height:.85;opacity:.4}
.plan-item h4{font-family:var(--font-head);font-size:.92rem;font-weight:800;text-transform:uppercase;margin-bottom:.3rem;line-height:1.2}
.plan-item p{font-size:.88rem;color:rgba(255,255,255,.55);line-height:1.7}


/* ════════════════════════════════════════════════════
   JOIN / CTA
   ════════════════════════════════════════════════════ */
.join{text-align:center;padding-bottom:5rem}
.join-h{font-family:var(--font-voice);font-size:clamp(1.3rem,3vw,1.9rem);font-weight:700;color:var(--ink);max-width:580px;margin:0 auto .5rem;line-height:1.35}
.bg-purple .join-h{color:#fff}
.join-sub{font-family:var(--font-voice);font-style:italic;font-size:1rem;color:var(--ink-muted);max-width:480px;margin:0 auto 2rem}
.bg-purple .join-sub{color:rgba(255,255,255,.5)}
.join-btns{display:flex;flex-wrap:wrap;justify-content:center;gap:.65rem;margin-bottom:2.5rem}

.join-email{max-width:420px;margin:0 auto;background:var(--purple-ghost);border:1px solid var(--border);padding:1.5rem;border-radius:10px;text-align:left}
.join-email-t{font-family:var(--font-head);font-size:.75rem;font-weight:800;text-transform:uppercase;margin-bottom:.15rem}
.join-email-d{font-size:.78rem;color:var(--ink-muted);margin-bottom:.85rem}
.erow{display:flex;gap:.4rem}
.einput{flex:1;padding:.6rem .85rem;background:var(--white);border:1px solid var(--border);border-radius:5px;font-family:var(--font-body);font-size:.85rem;color:var(--ink);outline:none;transition:border .2s}
.einput:focus{border-color:var(--purple)}
.einput::placeholder{color:var(--ink-faint)}
.ego{padding:.6rem 1rem;background:var(--purple);border:none;border-radius:5px;color:#fff;font-family:var(--font-body);font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;cursor:pointer;white-space:nowrap;transition:all .25s var(--ease)}
.ego:hover{background:var(--purple-light)}


/* ════════════════════════════════════════════════════
   FOOTER — expanded, 3-column
   ════════════════════════════════════════════════════ */
footer{border-top:1px solid var(--border);padding:3rem var(--px) 5.5rem;background:var(--off-white)}
.footer-grid{display:grid;grid-template-columns:1fr;gap:2rem;max-width:var(--max-w);margin:0 auto}
@media(min-width:700px){.footer-grid{grid-template-columns:1.2fr 1fr 1fr;gap:1.5rem}}

.footer-brand .footer-logo{width:110px;height:auto;margin-bottom:.6rem}
.footer-brand p{font-size:.75rem;color:var(--ink-muted);line-height:1.6;max-width:260px}

.footer-col-title{font-family:var(--font-head);font-size:.55rem;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:var(--ink);margin-bottom:.6rem}
.footer-links{display:flex;flex-direction:column;gap:.35rem}
.footer-links a{font-size:.75rem;color:var(--ink-muted);text-decoration:none;transition:color .2s}
.footer-links a:hover{color:var(--purple)}

.footer-bottom{max-width:var(--max-w);margin:2rem auto 0;padding-top:1.25rem;border-top:1px solid var(--border);text-align:center}
.flegal{font-size:.55rem;color:var(--ink-faint);line-height:1.65}


/* ════════════════════════════════════════════════════
   PAGE HEROES — inner pages, improved
   ════════════════════════════════════════════════════ */
.page-hero{background:var(--purple);padding:7rem var(--px) 3rem;position:relative;overflow:hidden}
.page-hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 20% 50%,rgba(83,64,181,.3) 0%,transparent 60%)}
.page-hero .inner{position:relative;z-index:2}
.page-hero .tag{color:rgba(255,255,255,.4)}
.page-hero-title{font-family:var(--font-head);font-size:clamp(2rem,5vw,3rem);font-weight:900;text-transform:uppercase;line-height:1.04;color:#fff;margin-bottom:.65rem}
.page-hero-title .accent{color:var(--green-bright)}
.page-hero-sub{font-family:var(--font-voice);font-size:clamp(.95rem,1.8vw,1.12rem);color:rgba(255,255,255,.65);max-width:520px;line-height:1.65}
@media(min-width:900px){.page-hero{padding:8rem var(--px) 3.5rem}}

/* Compact hero for simpler pages */
.page-hero.compact{padding:6.5rem var(--px) 2.5rem}
@media(min-width:900px){.page-hero.compact{padding:7rem var(--px) 2.75rem}}


/* ════════════════════════════════════════════════════
   MEET ERIKA PAGE
   ════════════════════════════════════════════════════ */
.bio-grid{display:grid;grid-template-columns:1fr;gap:3rem;max-width:900px;margin:0 auto}
@media(min-width:768px){.bio-grid{grid-template-columns:1fr 1.4fr;gap:2.5rem}}
.bio-photo img{width:100%;border-radius:10px;box-shadow:0 16px 48px rgba(42,30,115,.1)}
.bio-photo-caption{font-size:.68rem;color:var(--ink-muted);margin-top:.5rem;font-style:italic}
.bio-text h3{font-family:var(--font-head);font-size:1rem;font-weight:800;text-transform:uppercase;color:var(--purple);margin-bottom:.45rem;margin-top:1.5rem}
.bio-text h3:first-child{margin-top:0}
.bio-text p{font-size:.9rem;color:var(--ink-light);line-height:1.8;margin-bottom:.7rem}
.bio-quote{background:var(--purple-ghost);border-left:4px solid var(--purple);padding:1.5rem;margin:2rem 0;border-radius:0 10px 10px 0}
.bio-quote p{font-family:var(--font-voice);font-size:1.02rem;font-weight:500;color:var(--ink);line-height:1.7;font-style:italic}
.bio-quote cite{display:block;font-size:.78rem;color:var(--ink-muted);margin-top:.5rem;font-style:normal;font-weight:600}

.record-grid{display:grid;grid-template-columns:1fr;gap:1rem;max-width:var(--max-w-narrow);margin:1.5rem auto 0}
@media(min-width:600px){.record-grid{grid-template-columns:1fr 1fr}}
.record-card{background:var(--white);border:1px solid var(--border);border-radius:10px;padding:1.25rem;transition:all .35s var(--ease)}
.record-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(42,30,115,.06)}
.record-card-icon{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.9rem;margin-bottom:.55rem}
.record-card-icon.won{background:var(--green-pale);color:var(--green)}
.record-card-icon.filed{background:var(--purple-pale);color:var(--purple)}
.record-card h4{font-family:var(--font-head);font-size:.82rem;font-weight:800;text-transform:uppercase;margin-bottom:.2rem;line-height:1.2}
.record-card p{font-size:.8rem;color:var(--ink-muted);line-height:1.6}


/* ════════════════════════════════════════════════════
   ISSUES PAGE — tiered visual hierarchy
   ════════════════════════════════════════════════════ */
.issues-grid{max-width:var(--max-w);margin:0 auto;display:grid;grid-template-columns:1fr;gap:1.25rem}
@media(min-width:700px){.issues-grid{grid-template-columns:1fr 1fr}}
@media(min-width:1000px){.issues-grid{grid-template-columns:1fr 1fr 1fr}}

/* All issue cards — unified style with purple left bar */
.issue-card{background:var(--white);border:1px solid var(--border);border-radius:12px;padding:1.75rem;cursor:pointer;transition:all .35s var(--ease);position:relative;overflow:hidden;display:flex;flex-direction:column}
.issue-card:hover{transform:translateY(-3px);box-shadow:0 12px 32px rgba(42,30,115,.08);border-color:var(--purple)}
.issue-card::before{content:'';position:absolute;top:0;left:0;width:4px;height:100%;background:var(--purple)}
.issue-summary{font-size:.88rem;color:var(--ink-muted);line-height:1.6;margin-top:.25rem;flex:1}

.issue-icon{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;margin-bottom:.6rem;background:var(--purple-pale);color:var(--purple)}
.issue-icon svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:2}
.issue-card.featured .issue-icon{width:42px;height:42px;background:var(--purple);color:#fff}
.issue-card.featured .issue-icon svg{width:20px;height:20px;stroke:#fff}

.issue-card h3{font-family:var(--font-head);font-size:.88rem;font-weight:800;text-transform:uppercase;line-height:1.2;margin-bottom:.3rem;color:var(--ink)}
.issue-card.featured h3{font-size:.95rem}
.issue-card p{font-size:.8rem;color:var(--ink-muted);line-height:1.6}

.issue-points{margin-top:.7rem;display:none}
.issue-card.open .issue-points{display:block}
.issue-points li{font-size:.78rem;color:var(--ink-light);line-height:1.65;padding:.2rem 0 .2rem 1rem;position:relative;list-style:none}
.issue-points li::before{content:'→';position:absolute;left:0;color:var(--purple);font-weight:700;font-size:.7rem}
.issue-toggle{font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--purple);margin-top:.5rem;display:inline-block}
.issue-card.open .issue-toggle{color:var(--ink-muted)}
.issue-detail-link{display:block;margin-top:auto;padding-top:1rem;color:var(--red);font-weight:700;font-size:.88rem;text-decoration:none}
.issue-detail-link:hover{text-decoration:underline}


/* ════════════════════════════════════════════════════
   VOTE PAGE
   ════════════════════════════════════════════════════ */
.vote-intro-text{font-family:var(--font-voice);font-size:1rem;color:var(--ink-light);max-width:640px;margin:0 auto;text-align:center;line-height:1.7}
.vote-intro-text strong{color:var(--ink);font-weight:700}

.vote-grid{display:grid;grid-template-columns:1fr;gap:1.25rem;max-width:var(--max-w);margin:1.5rem auto 0}
@media(min-width:700px){.vote-grid{grid-template-columns:1fr 1fr 1fr}}
.vote-card{background:var(--white);border:1px solid var(--border);border-radius:12px;padding:2rem 1.5rem;text-align:center;transition:all .35s var(--ease);position:relative;overflow:hidden}
.vote-card:hover{transform:translateY(-4px);box-shadow:0 14px 36px rgba(42,30,115,.08);border-color:var(--purple)}
.vote-card::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:var(--purple)}
.vote-card-num{font-family:var(--font-head);font-size:2.5rem;font-weight:900;color:var(--purple);line-height:1;margin-bottom:.5rem;opacity:.3}
.vote-card-title{font-family:var(--font-head);font-size:.95rem;font-weight:800;text-transform:uppercase;margin-bottom:.7rem;line-height:1.2}
.vote-card-body{font-size:.82rem;color:var(--ink-muted);line-height:1.65;text-align:left}
.vote-card-body ul{list-style:none;margin:.6rem 0}
.vote-card-body li{padding:.25rem 0 .25rem 1.1rem;position:relative}
.vote-card-body li::before{content:'';position:absolute;left:0;top:.6rem;width:6px;height:6px;border-radius:50%;background:var(--purple)}
.vote-card-body a{color:var(--purple);font-weight:600;text-decoration:none}
.vote-card-body a:hover{text-decoration:underline}
.vote-card .btn{margin-top:1.25rem;width:100%;justify-content:center;font-size:.82rem;padding:.85rem 1.2rem;letter-spacing:.06em}

.city-links{display:flex;flex-wrap:wrap;justify-content:center;gap:.55rem;max-width:560px;margin:1rem auto 0}
.city-chip{display:inline-flex;align-items:center;gap:.35rem;padding:.5rem 1.1rem;background:var(--purple-ghost);border:1px solid var(--border);border-radius:50px;font-size:.76rem;font-weight:600;color:var(--purple);text-decoration:none;transition:all .25s var(--ease)}
.city-chip:hover{background:var(--purple);color:#fff;border-color:var(--purple)}
.city-chip svg{width:13px;height:13px}


/* ════════════════════════════════════════════════════
   VOLUNTEER PAGE
   ════════════════════════════════════════════════════ */
.vol-intro-text{font-family:var(--font-voice);font-size:1rem;color:var(--ink-light);max-width:640px;margin:0 auto;text-align:center;line-height:1.7}

.vol-form{max-width:540px;margin:0 auto;background:var(--purple-ghost);border:1px solid var(--border);border-radius:12px;padding:2rem}
.vol-form h3{font-family:var(--font-head);font-size:.82rem;font-weight:800;text-transform:uppercase;letter-spacing:.08em;color:var(--purple);margin-bottom:1rem}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:.55rem;margin-bottom:.55rem}
.form-row.full{grid-template-columns:1fr}
.form-field{display:flex;flex-direction:column;gap:.2rem}
.form-field label{font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-muted)}
.form-field input,.form-field select{padding:.65rem .85rem;background:var(--white);border:1px solid var(--border);border-radius:5px;font-family:var(--font-body);font-size:.85rem;color:var(--ink);outline:none;transition:border .25s var(--ease)}
.form-field input:focus,.form-field select:focus{border-color:var(--purple)}

.events-list{max-width:700px;margin:1.5rem auto 0;display:grid;gap:.85rem}
.event-card{background:var(--white);border:1px solid var(--border);border-radius:10px;padding:1.15rem 1.35rem;display:grid;grid-template-columns:auto 1fr auto;gap:1rem;align-items:center;transition:all .35s var(--ease)}
.event-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(42,30,115,.06)}
.event-date{text-align:center;min-width:52px}
.event-date-month{font-family:var(--font-head);font-size:.52rem;font-weight:800;text-transform:uppercase;letter-spacing:.1em;color:var(--red)}
.event-date-day{font-family:var(--font-head);font-size:1.75rem;font-weight:900;color:var(--purple);line-height:1}
.event-date-dow{font-size:.52rem;font-weight:600;color:var(--ink-muted);text-transform:uppercase;letter-spacing:.05em}
.event-info h4{font-family:var(--font-head);font-size:.85rem;font-weight:700;line-height:1.25;margin-bottom:.15rem}
.event-info p{font-size:.76rem;color:var(--ink-muted);line-height:1.5}
.event-info .event-time{font-size:.68rem;font-weight:600;color:var(--purple);margin-bottom:.1rem}
.event-join a{display:inline-flex;padding:.4rem .9rem;background:var(--purple);color:#fff;border-radius:5px;font-size:.68rem;font-weight:700;text-decoration:none;text-transform:uppercase;letter-spacing:.05em;transition:all .25s var(--ease)}
.event-join a:hover{background:var(--purple-light)}
@media(max-width:600px){.event-card{grid-template-columns:1fr;text-align:center}.event-join{justify-self:center}}


/* ════════════════════════════════════════════════════
   NEWSLETTERS PAGE
   ════════════════════════════════════════════════════ */
.nl-grid{max-width:700px;margin:0 auto;display:grid;gap:0}
.nl-item{display:grid;grid-template-columns:auto 1fr;gap:1rem;align-items:center;padding:1rem 0;border-bottom:1px solid var(--border);transition:all .2s}
.nl-item:first-child{border-top:1px solid var(--border)}
.nl-item:hover{background:var(--purple-ghost);margin:0 -.75rem;padding-left:.75rem;padding-right:.75rem;border-radius:8px}
.nl-date{font-family:var(--font-head);font-size:.58rem;font-weight:700;color:var(--ink-muted);letter-spacing:.04em;white-space:nowrap;min-width:88px}
.nl-title{font-family:var(--font-voice);font-size:.9rem;font-weight:600;color:var(--ink);line-height:1.35}
.nl-title a{color:inherit;text-decoration:none;transition:color .2s}
.nl-title a:hover{color:var(--purple)}
.nl-more{text-align:center;padding-top:2rem}
.nl-more a{font-size:.75rem;font-weight:700;color:var(--purple);text-decoration:none;text-transform:uppercase;letter-spacing:.08em}
.nl-more a:hover{text-decoration:underline}


/* ════════════════════════════════════════════════════
   ENDORSEMENTS PAGE
   ════════════════════════════════════════════════════ */

/* Endorsement counters */
.endorse-counters{display:flex;gap:1.5rem;flex-wrap:wrap}
.endorse-counter{text-align:center}
.endorse-counter-val{font-family:var(--font-head);font-size:clamp(2.5rem,6vw,3.8rem);font-weight:900;color:#fff;line-height:1}
.endorse-counter-val span{color:var(--green-bright)}
.endorse-counter-label{font-family:var(--font-head);font-size:.52rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.35);margin-top:.2rem}

/* Pullquote strip */
.pullquote-strip{background:var(--white);border-bottom:1px solid var(--border);padding:2.75rem var(--px);position:relative}
.pullquote-strip::before{content:'';position:absolute;top:0;left:0;width:4px;height:100%;background:var(--purple)}
.pullquote-inner{max-width:860px;margin:0 auto;display:grid;grid-template-columns:1fr;gap:1.25rem;align-items:center}
@media(min-width:650px){.pullquote-inner{grid-template-columns:auto 1fr;gap:2rem}}
.pullquote-photo{width:76px;height:76px;border-radius:50%;overflow:hidden;border:3px solid var(--purple-pale);flex-shrink:0}
.pullquote-photo img{width:100%;height:100%;object-fit:cover}
.pullquote-text{font-family:var(--font-voice);font-size:clamp(.92rem,1.5vw,1.1rem);font-weight:500;color:var(--ink);line-height:1.7;font-style:italic;position:relative;padding-left:1.25rem}
.pullquote-text::before{content:'\201C';font-family:var(--font-head);font-size:3.5rem;font-weight:900;color:var(--purple);line-height:1;position:absolute;top:-.35rem;left:-.1rem;opacity:.12}
.pullquote-cite{font-family:var(--font-head);font-size:.62rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--purple);margin-top:.2rem;padding-left:1.25rem}
.pullquote-cite span{color:var(--ink-muted);font-weight:600;letter-spacing:.04em;text-transform:none}

/* Union cards */
.union-grid{display:grid;grid-template-columns:1fr;gap:1rem;max-width:800px;margin:2rem auto 0}
@media(min-width:550px){.union-grid{grid-template-columns:1fr 1fr}}
.union-card{background:var(--white);border:1px solid var(--border);border-radius:12px;padding:1.75rem 1.5rem;display:flex;align-items:center;gap:1.25rem;transition:all .35s var(--ease);position:relative;overflow:hidden}
.union-card:hover{transform:translateY(-3px);box-shadow:0 14px 36px rgba(42,30,115,.08);border-color:var(--purple)}
.union-card::after{content:'';position:absolute;bottom:0;left:0;right:0;height:3px;background:var(--red);transform:scaleX(0);transform-origin:left;transition:transform .5s var(--ease)}
.union-card:hover::after{transform:scaleX(1)}
.union-logo-wrap{width:76px;height:76px;flex-shrink:0;display:flex;align-items:center;justify-content:center}
.union-logo-wrap img{max-width:100%;max-height:100%;object-fit:contain}
.union-name{font-family:var(--font-head);font-size:.82rem;font-weight:800;text-transform:uppercase;letter-spacing:.03em;color:var(--ink);line-height:1.2;margin-bottom:.15rem}
.union-desc{font-size:.75rem;color:var(--ink-muted);line-height:1.5}

/* Official cards */
.officials-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;max-width:560px;margin:2rem auto 0}
@media(min-width:700px){.officials-row{grid-template-columns:1fr 1fr 1fr;max-width:800px}}
.official-card{text-align:center;padding:1.65rem 1rem;background:var(--purple-ghost);border-radius:12px;border:1px solid transparent;transition:all .35s var(--ease)}
.official-card:hover{border-color:var(--purple);transform:translateY(-3px);box-shadow:0 12px 28px rgba(42,30,115,.08)}
.official-photo{width:84px;height:84px;border-radius:50%;margin:0 auto .7rem;overflow:hidden;border:3px solid var(--purple-pale);transition:border-color .3s}
.official-card:hover .official-photo{border-color:var(--purple)}
.official-photo img{width:100%;height:100%;object-fit:cover}
.official-name{font-family:var(--font-head);font-size:.7rem;font-weight:800;text-transform:uppercase;letter-spacing:.04em;color:var(--purple);line-height:1.25;margin-bottom:.12rem}
.official-title{font-size:.65rem;font-weight:500;color:var(--ink-muted);line-height:1.4}

/* Growing CTA strip */
.growing{background:var(--purple);padding:3.25rem var(--px);text-align:center}
.growing-inner{max-width:520px;margin:0 auto}
.growing-tag{font-family:var(--font-head);font-size:.52rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--green-bright);margin-bottom:.5rem}
.growing-h{font-family:var(--font-head);font-size:clamp(1.2rem,3vw,1.7rem);font-weight:900;text-transform:uppercase;color:#fff;line-height:1.1;margin-bottom:.4rem}
.growing-sub{font-family:var(--font-voice);font-size:.88rem;color:rgba(255,255,255,.5);line-height:1.6;margin-bottom:1.4rem}


/* ════════════════════════════════════════════════════
   UTILITY
   ════════════════════════════════════════════════════ */
.text-center{text-align:center}
.mt-0{margin-top:0}
.mb-0{margin-bottom:0}


/* ════════════════════════════════════════════════════
   v3 ADDITIONS — HOMEPAGE REDESIGN
   ════════════════════════════════════════════════════ */

/* Screen reader only */
.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* Bigger logo — shrinks on scroll via nav.scrolled rules */
.nav-logo-img{height:56px !important}
.nav-logo-dark{height:44px !important}
@media(max-width:700px){.nav-date{display:none}}
@media(min-width:900px){
    .nav-logo-img{height:64px !important}
    .nav-logo-dark{height:48px !important}
}
/* Bigger nav link text */
.nlinks a{font-size:.72rem !important;letter-spacing:.08em !important}


/* ════════════════════════════════════════════════════
   SIGNUP BANNER — Michelle Wu style, big email form
   ════════════════════════════════════════════════════ */
.signup-banner{background:var(--purple);padding:2.5rem var(--px)}
.signup-banner-inner{max-width:640px;margin:0 auto;text-align:center}
.signup-banner-title{font-family:var(--font-head);font-size:clamp(1rem,2.5vw,1.35rem);font-weight:800;color:#fff;margin-bottom:1rem;text-transform:uppercase;letter-spacing:.03em}
.signup-banner-row{display:flex;gap:.5rem;max-width:500px;margin:0 auto}
@media(max-width:500px){.signup-banner-row{flex-direction:column}}
.signup-banner-input{flex:1;padding:.85rem 1.1rem;background:rgba(255,255,255,.12);border:2px solid rgba(255,255,255,.3);border-radius:6px;color:#fff;font-family:var(--font-body);font-size:.95rem;font-weight:500;outline:none;transition:all .25s}
.signup-banner-input::placeholder{color:rgba(255,255,255,.5)}
.signup-banner-input:focus{border-color:#52c490;background:rgba(255,255,255,.18)}
.signup-banner-btn{padding:.85rem 2rem;background:var(--red);color:#fff;border:none;border-radius:6px;font-family:var(--font-body);font-size:.9rem;font-weight:800;text-transform:uppercase;letter-spacing:.06em;cursor:pointer;transition:all .25s;box-shadow:0 3px 14px rgba(224,52,45,.3);white-space:nowrap}
.signup-banner-btn:hover{background:#c72a24;transform:translateY(-1px)}
.signup-banner-disclaimer{font-size:.58rem;color:rgba(255,255,255,.3);line-height:1.6;max-width:500px;margin:1rem auto 0}


/* ════════════════════════════════════════════════════
   RECORD LIST — single column with imagery (AOC style)
   ════════════════════════════════════════════════════ */
.record-list{display:grid;gap:1.5rem;margin-top:2rem}

.record-item{position:relative;border-radius:12px;overflow:hidden;background:var(--white);border:1px solid var(--border);transition:all .35s var(--ease)}
.record-item:hover{transform:translateY(-3px);box-shadow:0 12px 36px rgba(42,30,115,.1)}

.record-item-img{position:relative;height:200px;overflow:hidden;background:var(--purple-deep)}
.record-item-img img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.record-item:hover .record-item-img img{transform:scale(1.04)}
.record-item-img.no-img{display:none}
.record-item-img.no-img + .record-item-content{padding-top:1.5rem}
.record-item-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(42,30,115,.7) 0%,rgba(42,30,115,.1) 60%,transparent 100%)}

.record-item-content{padding:1.5rem 1.75rem 1.75rem}
.record-item-badge{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;background:var(--green);color:#fff;font-size:.88rem;font-weight:900;margin-bottom:.5rem}
.record-item-role{font-family:var(--font-head);font-size:.62rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--purple);margin-bottom:.35rem}
.record-item-title{font-family:var(--font-head);font-size:clamp(1.1rem,2.5vw,1.5rem);font-weight:900;text-transform:uppercase;line-height:1.15;color:var(--ink);margin-bottom:.4rem}
.record-item-desc{font-size:.92rem;color:var(--ink-muted);line-height:1.7}
.record-item-partners{font-size:.78rem;color:var(--purple);font-weight:600;margin-top:.5rem;font-style:italic}

@media(min-width:700px){
    .record-item{display:grid;grid-template-columns:280px 1fr}
    .record-item-img{height:100%;min-height:200px}
    .record-item-content{display:flex;flex-direction:column;justify-content:center;padding:2rem 2.25rem}
}


/* ════════════════════════════════════════════════════
   ENDORSEMENT LOGO STRIP
   ════════════════════════════════════════════════════ */
.endorse-strip{background:var(--white);border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:2.5rem var(--px)}
.endorse-strip-items{display:grid;grid-template-columns:1fr;gap:2rem;max-width:var(--max-w);margin:0 auto}
@media(min-width:700px){.endorse-strip-items{grid-template-columns:1fr 1fr 1fr}}

.endorse-strip-item{display:flex;flex-direction:column;align-items:center;text-align:center;gap:.75rem}
.endorse-strip-logo{height:60px;width:auto;max-width:140px;object-fit:contain;filter:grayscale(30%);transition:filter .3s}
.endorse-strip-item:hover .endorse-strip-logo{filter:grayscale(0)}
.endorse-strip-label{font-family:var(--font-voice);font-size:.78rem;font-weight:600;color:var(--ink-muted);line-height:1.4;font-style:italic}
@media(hover:none){.endorse-strip-logo{filter:grayscale(0) !important}}


/* ════════════════════════════════════════════════════
   INSTAGRAM VIDEO SLIDER — inline iframe embeds
   ════════════════════════════════════════════════════ */
.ig-slider-wrap{position:relative;margin-top:1.5rem}
.ig-slider{display:flex;gap:1rem;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;padding:1rem .5rem 1.5rem;scrollbar-width:none}
.ig-slider::-webkit-scrollbar{display:none}

.ig-frame{flex:0 0 auto;width:320px;scroll-snap-align:start;border-radius:12px;overflow:hidden;background:var(--white);box-shadow:0 6px 24px rgba(42,30,115,.1);border:1px solid var(--border)}
.ig-frame iframe{width:100%;height:570px;border:none;display:block}

@media(max-width:500px){
    .ig-frame{width:280px}
    .ig-frame iframe{height:500px}
}

.ig-slider-arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:5;width:44px;height:44px;border-radius:50%;background:var(--purple);color:#fff;border:none;font-size:1.5rem;font-weight:700;cursor:pointer;box-shadow:0 4px 16px rgba(42,30,115,.2);transition:all .25s;display:none}
.ig-slider-arrow:hover{background:var(--purple-light);transform:translateY(-50%) scale(1.05)}
.ig-prev{left:-.75rem}
.ig-next{right:-.75rem}
@media(min-width:700px){.ig-slider-arrow{display:flex;align-items:center;justify-content:center}}


/* ════════════════════════════════════════════════════
   PLATFORM LIST — icons instead of numbers
   ════════════════════════════════════════════════════ */
.platform-list{margin-top:2.5rem;display:grid;gap:2.25rem}
.platform-item{display:grid;grid-template-columns:auto 1fr;gap:1.25rem;align-items:start}
.platform-icon{width:48px;height:48px;border-radius:12px;background:rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.platform-icon svg{width:24px;height:24px;stroke:#52c490;stroke-width:2;fill:none}
.platform-item h4{font-family:var(--font-head);font-size:1rem;font-weight:800;text-transform:uppercase;margin-bottom:.35rem;line-height:1.2;color:#fff}
.platform-item p{font-size:.9rem;color:rgba(255,255,255,.78);line-height:1.7}


/* ════════════════════════════════════════════════════
   NEWSLETTER CARDS — photo-based grid
   ════════════════════════════════════════════════════ */
.nl-cards-grid{display:grid;grid-template-columns:1fr;gap:1.25rem;max-width:900px;margin:0 auto}
@media(min-width:600px){.nl-cards-grid{grid-template-columns:1fr 1fr}}
@media(min-width:900px){.nl-cards-grid{grid-template-columns:1fr 1fr 1fr}}

.nl-card{display:flex;flex-direction:column;background:var(--white);border:1px solid var(--border);border-radius:12px;overflow:hidden;text-decoration:none;color:inherit;transition:all .35s var(--ease)}
.nl-card:hover{transform:translateY(-4px);box-shadow:0 14px 40px rgba(42,30,115,.1);border-color:var(--purple)}

.nl-card-img{height:180px;overflow:hidden;background:var(--purple-ghost)}
.nl-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease)}
.nl-card:hover .nl-card-img img{transform:scale(1.06)}

.nl-card-placeholder{height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--purple-ghost) 0%,var(--purple-pale) 100%)}
.nl-card-placeholder svg{width:48px;height:48px;stroke:var(--purple);opacity:.3}

.nl-card-body{padding:1.25rem;flex:1;display:flex;flex-direction:column}
.nl-card-date{font-family:var(--font-head);font-size:.56rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-muted);margin-bottom:.35rem}
.nl-card-title{font-family:var(--font-head);font-size:.88rem;font-weight:800;line-height:1.3;color:var(--ink);margin-bottom:.35rem}
.nl-card-summary{font-size:.78rem;color:var(--ink-muted);line-height:1.55}
.nl-card-link{display:inline-block;margin-top:auto;padding-top:.75rem;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--purple)}


/* ════════════════════════════════════════════════════
   FOOTER CONTACT — bigger phone/email
   ════════════════════════════════════════════════════ */
.footer-contact{max-width:var(--max-w);margin:1.75rem auto 0;padding:1.25rem 0;border-top:1px solid var(--border);display:flex;flex-wrap:wrap;justify-content:center;gap:1.5rem;text-align:center}
.footer-contact-item{font-size:.88rem;color:var(--ink)}
.footer-contact-item strong{font-weight:700}
.footer-contact-item a{color:var(--purple);text-decoration:none;font-weight:700}
.footer-contact-item a:hover{text-decoration:underline}


/* ════════════════════════════════════════════════════
   BOTTOM CONTACT — index page
   ════════════════════════════════════════════════════ */
.bottom-contact{margin-top:2rem;text-align:center}
.bottom-contact-line{font-size:1.05rem;color:var(--ink);margin-bottom:.4rem;font-weight:500}
.bottom-contact-line strong{font-weight:700}
.bottom-contact-line a{color:var(--purple);text-decoration:none;font-weight:700;font-size:1.1rem}
.bottom-contact-line a:hover{text-decoration:underline}

/* ── PYRIG UI FIXES ── */

/* Record items without images — purple accent bar, no grid */
.record-no-img{border-left:5px solid var(--purple)}
.record-no-img:hover{border-left-color:var(--green)}
@media(min-width:700px){
    .record-no-img{display:block}
}
.record-no-img .record-item-content{padding:1.75rem 2rem}

/* Exhibit CTA */
.exhibit-cta{text-align:center;margin-top:1.5rem}

/* Detail page hero image */
.detail-body img{width:100%;border-radius:10px;margin-bottom:2rem;height:auto}

/* Detail page components */
.detail-body h2{font-family:var(--font-head);font-size:clamp(1.3rem,3vw,1.7rem);font-weight:800;color:var(--purple);margin:2.5rem 0 1rem;line-height:1.25}
.detail-body h3{font-family:var(--font-head);font-size:1.1rem;font-weight:700;color:var(--ink);margin:1.5rem 0 .75rem}
.detail-body p{line-height:1.75;margin-bottom:1rem;color:var(--ink)}
.detail-body ol,.detail-body ul{margin:1rem 0 1.5rem 1.25rem;line-height:1.75}
.detail-body li{margin-bottom:.4rem}

/* Stat comparison block */
.detail-vs{display:grid;grid-template-columns:1fr 1fr;gap:0;margin:2rem 0;border-radius:12px;overflow:hidden;box-shadow:0 8px 32px rgba(42,30,115,.1)}
.detail-vs-you,.detail-vs-them{padding:2rem 1.5rem;text-align:center}
.detail-vs-you{background:var(--green);color:#fff}
.detail-vs-them{background:var(--purple-deep);color:#fff}
.detail-vs-num{font-family:var(--font-head);font-size:clamp(2.5rem,6vw,3.5rem);font-weight:900;line-height:1}
.detail-vs-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.08em;margin-top:.5rem;opacity:.85}
@media(max-width:500px){.detail-vs{grid-template-columns:1fr}.detail-vs-you,.detail-vs-them{padding:1.5rem 1rem}}

/* Dark callout box */
.detail-callout{background:var(--ink);color:#fff;border-radius:10px;padding:2rem 2rem 1.5rem;margin:1.5rem 0 2rem}
.detail-callout h3{color:var(--green);margin-top:0}
.detail-callout ol,.detail-callout ul{color:rgba(255,255,255,.85)}
.detail-callout p{color:rgba(255,255,255,.9)}
.detail-callout strong{color:#fff}

/* Highlighted section (emotional/personal) */
.detail-highlight{background:var(--purple-ghost);border-left:4px solid var(--purple);border-radius:0 10px 10px 0;padding:2rem 2rem 1.5rem;margin:2rem 0}
.detail-highlight p{color:var(--ink)}

/* Big single stat callout */
.detail-bigstat{text-align:center;padding:2.5rem 1rem;margin:2rem 0}
.detail-bigstat-num{font-family:var(--font-head);font-size:clamp(3rem,8vw,5rem);font-weight:900;color:var(--purple);line-height:1}
.detail-bigstat-vs{font-size:1rem;color:var(--ink-muted);margin:.25rem 0}
.detail-bigstat-num2{font-family:var(--font-head);font-size:clamp(3rem,8vw,5rem);font-weight:900;color:var(--red);line-height:1}
.detail-bigstat-label{font-size:.85rem;color:var(--ink-muted);margin-top:.75rem;max-width:400px;margin-left:auto;margin-right:auto}

/* Amendment list */
.detail-amendment{background:var(--white);border:1px solid var(--border);border-radius:8px;padding:1rem 1.25rem;margin-bottom:.75rem}
.detail-amendment strong{color:var(--purple)}
.detail-amendment span{color:var(--ink-muted);font-size:.9rem}

/* CTA block at bottom of detail */
.detail-cta{text-align:center;padding:2.5rem 0 1rem;border-top:1px solid var(--border);margin-top:3rem}
.detail-cta p{font-size:1.05rem;font-weight:600;color:var(--ink);margin-bottom:1.25rem}

/* ════════════════════════════════════════════════════
   VOTE REMINDER BANNER
   ════════════════════════════════════════════════════ */
/* Vote reminder removed — date now in nav */

/* ════════════════════════════════════════════════════
   RECORD CARD — ROLE & COMMUNITY PARTNERS
   ════════════════════════════════════════════════════ */
.record-card-role{font-family:var(--font-head);font-size:.62rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--purple);margin-top:.35rem}
.record-card-partners{font-size:.78rem;color:var(--purple);font-weight:600;margin-top:.5rem;font-style:italic}

/* ════════════════════════════════════════════════════
   SOCIAL LINKS (reusable include)
   ════════════════════════════════════════════════════ */
.social-links{display:flex;gap:1rem;justify-content:center;align-items:center;flex-wrap:wrap;margin:1rem 0}
.social-link{display:inline-flex;align-items:center;gap:.4rem;color:var(--ink-muted);font-size:.78rem;font-weight:700;text-decoration:none;text-transform:uppercase;letter-spacing:.06em;transition:color .3s}
.social-link:hover{color:var(--purple)}
.social-link svg{width:18px;height:18px}

/* ════════════════════════════════════════════════════
   ENDORSEMENT QUOTES (union & official cards)
   ════════════════════════════════════════════════════ */
.union-quote{font-size:.82rem;color:var(--ink-muted);line-height:1.6;margin-top:.5rem;font-style:italic;border-left:3px solid var(--purple-pale);padding-left:.75rem}
.union-quote strong{color:var(--ink);font-style:normal}
.official-quote{font-size:.78rem;color:var(--ink-muted);line-height:1.5;margin-top:.5rem;font-style:italic}
.official-quote strong{color:var(--ink);font-style:normal}

/* ════════════════════════════════════════════════════
   AI DETAIL PAGE — SCORING RUBRIC TABLE
   ════════════════════════════════════════════════════ */
.rubric-table{width:100%;border-collapse:collapse;margin:1.5rem 0 2rem;font-size:.85rem;border-radius:10px;overflow:hidden;box-shadow:0 4px 20px rgba(42,30,115,.08)}
.rubric-table th{background:var(--purple-deep);color:#fff;text-align:left;padding:.75rem 1rem;font-weight:700;font-size:.72rem;text-transform:uppercase;letter-spacing:.08em}
.rubric-table td{padding:.65rem 1rem;border-bottom:1px solid var(--border)}
.rubric-table tr:last-child td{border-bottom:none}
.rubric-table .rubric-cat{font-weight:700;color:var(--ink)}
.rubric-table .rubric-wt{font-weight:800;color:var(--purple);text-align:center;font-size:.95rem}
.rubric-table .rubric-missing{background:rgba(224,52,45,.06)}
.rubric-table .rubric-missing .rubric-cat{color:var(--red)}
.rubric-table .rubric-missing .rubric-wt{color:var(--red)}

/* Source links at bottom of detail pages */
.detail-sources{margin-top:2.5rem;padding-top:1.5rem;border-top:1px solid var(--border)}
.detail-sources h4{font-size:.72rem;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-muted);margin-bottom:.75rem}
.detail-sources ol{margin:0;padding-left:1.25rem}
.detail-sources li{font-size:.75rem;color:var(--ink-muted);line-height:1.6;margin-bottom:.35rem}
.detail-sources a{color:var(--purple);text-decoration:none;word-break:break-all}
.detail-sources a:hover{text-decoration:underline}

/* Experience section */
.experience-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem;align-items:center;max-width:900px;margin:0 auto}
@media(max-width:700px){.experience-grid{grid-template-columns:1fr}}

/* Newsletter web content — constrains email HTML to readable width */
.newsletter-web-content{max-width:600px;margin:0 auto;overflow:hidden}
.newsletter-web-content table{max-width:100%!important}
.newsletter-web-content img{max-width:100%;height:auto}
.newsletter-web-content td{word-wrap:break-word}

/* Mobile touch target and layout fixes */
@media(max-width:700px){.sticky .sb{padding:.65rem 1.2rem;font-size:.75rem}}
.mobile-toggle{padding:12px}
@media(max-width:500px){
    .form-row{grid-template-columns:1fr}
    .rubric-table td,.rubric-table th{padding:.5rem .6rem;font-size:.78rem}
}
@media(max-width:450px){.officials-row{grid-template-columns:1fr}}
