/*
Theme Name: Brandon Harvey Premium Campaign
Theme URI: https://midwesthorizonsmarketing.com
Author: Amanda Pearce, Midwest Horizons Marketing, LLC
Author URI: https://midwesthorizonsmarketing.com
Description: Premium campaign WordPress theme for Brandon Harvey Missouri District 2.
Version: 7.0
License: GPLv2 or later
Text Domain: brandon-harvey-premium-campaign
*/
:root{--navy:#06162f;--navy2:#0d2448;--red:#c91523;--red2:#e8303f;--gold:#f5c542;--cream:#f8f3e7;--ink:#14213d;--muted:#d8deea}
*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;font-family:system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;background:var(--cream);color:var(--ink);overflow-x:hidden}a{color:inherit}
.site-header{position:sticky;top:0;z-index:99;background:rgba(6,22,47,.95);color:#fff;box-shadow:0 18px 40px rgba(0,0,0,.22);backdrop-filter:blur(14px)}
.nav-wrap{max-width:1240px;margin:auto;padding:16px 22px;display:flex;align-items:center;justify-content:space-between;gap:20px}
.brand{text-decoration:none;font-weight:950;letter-spacing:.06em;font-size:20px;line-height:1}.brand span{display:block;font-size:10px;color:var(--gold);letter-spacing:.18em;margin-top:5px}
.nav-links{display:flex;gap:18px;flex-wrap:wrap;align-items:center}.nav-links a{color:#fff;text-decoration:none;font-weight:800;font-size:14px;opacity:.9;transition:.25s}.nav-links a:hover{opacity:1;color:var(--gold);transform:translateY(-1px)}.nav-cta{background:linear-gradient(135deg,var(--red),var(--red2));color:#fff!important;padding:11px 20px;border-radius:999px;box-shadow:0 10px 25px rgba(201,21,35,.35)}
.hero{position:relative;min-height:88vh;display:grid;place-items:center;text-align:left;color:#fff;background:linear-gradient(90deg,rgba(6,22,47,.92),rgba(6,22,47,.62),rgba(6,22,47,.24)),url('https://harveyformissouri.com/wp-content/uploads/2026/05/Untitled-design-2026-05-18T170640.746.png');background-size:cover;background-position:center right;padding:130px 22px 125px;overflow:hidden}
.hero:before{content:"";position:absolute;inset:-40%;background:conic-gradient(from 180deg,transparent,rgba(245,197,66,.16),transparent,rgba(232,48,63,.13),transparent);animation:spin 18s linear infinite;opacity:.72}.hero:after{content:"";position:absolute;inset:0;background:linear-gradient(115deg,transparent,rgba(255,255,255,.08),transparent);transform:translateX(-100%);animation:shine 6s ease-in-out infinite}
.hero-inner{position:relative;z-index:2;max-width:1240px;width:100%}.hero-copy{max-width:760px}.eyebrow{display:inline-flex;color:var(--gold);text-transform:uppercase;letter-spacing:.2em;font-weight:950;font-size:13px;border:1px solid rgba(245,197,66,.45);border-radius:999px;padding:10px 16px;background:rgba(255,255,255,.08)}.hero h1{font-size:clamp(48px,8vw,96px);line-height:.9;margin:22px 0 18px;letter-spacing:-.07em;text-shadow:0 18px 50px rgba(0,0,0,.35)}.hero p{font-size:clamp(19px,2.1vw,28px);color:var(--muted);max-width:760px;margin:0}
.hero-tagline{
  display:inline-block;
  margin:16px 0 0;
  color:#fff;
  font-size:clamp(22px,3vw,36px);
  font-weight:950;
  letter-spacing:-.035em;
  text-shadow:0 12px 35px rgba(0,0,0,.35);
}

.button-row{display:flex;gap:14px;margin-top:34px;flex-wrap:wrap}.btn{display:inline-block;text-decoration:none;padding:16px 26px;border-radius:999px;font-weight:950;transition:.25s}.btn:hover{transform:translateY(-3px) scale(1.02)}.btn-primary{background:linear-gradient(135deg,var(--red),var(--red2));color:#fff;box-shadow:0 16px 35px rgba(201,21,35,.35)}.btn-secondary{background:#fff;color:var(--navy);box-shadow:0 16px 35px rgba(255,255,255,.16)}
.hero-badges{display:flex;gap:14px;flex-wrap:wrap;margin-top:34px}.badge{padding:13px 19px;border-radius:999px;background:rgba(255,255,255,.13);border:1px solid rgba(255,255,255,.2);backdrop-filter:blur(10px);font-weight:900;animation:float 3s ease-in-out infinite}.badge:nth-child(2){animation-delay:.6s}.badge:nth-child(3){animation-delay:1.2s}
.motion-banner{position:relative;z-index:4;overflow:hidden;background:linear-gradient(90deg,var(--red),#7d1018,var(--red));color:#fff;box-shadow:0 14px 30px rgba(201,21,35,.24)}.motion-track{display:flex;width:max-content;animation:marquee 25s linear infinite}.motion-track span{white-space:nowrap;padding:14px 34px;font-weight:950;letter-spacing:.08em;text-transform:uppercase}.motion-track b{color:var(--gold)}
.stat-strip{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));max-width:1120px;margin:-28px auto 0;position:relative;z-index:6;padding:0 22px 8px;gap:16px}.stat{background:rgba(255,255,255,.96);border:1px solid rgba(6,22,47,.1);border-radius:20px;padding:24px 22px;box-shadow:0 20px 60px rgba(6,22,47,.18);text-align:center;backdrop-filter:blur(10px)}.stat strong{display:block;color:var(--red);font-size:28px}.stat span{font-size:13px;font-weight:900;text-transform:uppercase;letter-spacing:.08em}
.section{max-width:1240px;margin:auto;padding:86px 22px}.section.dark{max-width:none;background:radial-gradient(circle at 80% 10%,rgba(245,197,66,.13),transparent 28%),linear-gradient(135deg,var(--navy),#081224);color:#fff}.section.dark .inner{max-width:1240px;margin:auto}.section-title{font-size:clamp(36px,5.2vw,66px);letter-spacing:-.055em;line-height:1;margin:0 0 18px}.lead{font-size:20px;line-height:1.68;max-width:920px;color:#42526b}.dark .lead{color:#d8deea}
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:22px;margin-top:34px}.card{position:relative;background:#fff;border-radius:24px;padding:32px;box-shadow:0 22px 55px rgba(6,22,47,.13);border:1px solid rgba(6,22,47,.08);overflow:hidden;transition:.28s}.card:before{content:"";position:absolute;top:0;left:0;right:0;height:5px;background:linear-gradient(90deg,var(--red),var(--gold),#143c78)}.card:hover{transform:translateY(-8px);box-shadow:0 35px 75px rgba(6,22,47,.2)}.card h3{font-size:25px;margin:0 0 10px}.card p{line-height:1.65;color:#526078}.dark .card{background:#102b52;color:#fff;border-color:rgba(255,255,255,.08)}.dark .card p{color:#d8deea}
.about-grid{display:grid;grid-template-columns:minmax(0,1.1fr) minmax(300px,.9fr);gap:36px;align-items:center}.about-photo{width:100%;border-radius:30px;box-shadow:0 30px 80px rgba(6,22,47,.25);border:10px solid #fff}.check-list{display:grid;gap:14px;padding:0;list-style:none}.check-list li{background:#fff;border-radius:18px;padding:18px 20px;box-shadow:0 14px 35px rgba(6,22,47,.08);border-left:6px solid var(--red);font-weight:800}
.page-hero{position:relative;overflow:hidden;background:radial-gradient(circle at top left,rgba(245,197,66,.22),transparent 30%),linear-gradient(135deg,var(--navy),var(--navy2));color:#fff;padding:98px 22px;text-align:center}.page-hero h1{font-size:clamp(44px,7vw,80px);margin:0 0 12px;letter-spacing:-.055em}.page-hero p{max-width:820px;margin:auto;font-size:20px;color:#d8deea}.page-content{max-width:1060px;margin:auto;padding:68px 22px;font-size:18px;line-height:1.75}.custom-html-box{border:2px dashed rgba(6,22,47,.24);background:#fff;border-radius:24px;padding:30px;margin:28px 0;box-shadow:0 16px 45px rgba(6,22,47,.08)}
.site-footer{background:#040b17;color:#aab4c8;padding:48px 22px 26px}.footer-inner{max-width:1240px;margin:auto;display:grid;grid-template-columns:1fr auto;gap:28px;align-items:center}.footer-inner strong{color:#fff}.footer-badge{width:132px;max-width:38vw;filter:drop-shadow(0 18px 30px rgba(0,0,0,.35))}.footer-paid{color:#fff;font-weight:900;text-transform:uppercase;letter-spacing:.04em;margin-top:14px}.footer-credit{max-width:1240px;margin:28px auto 0;border-top:1px solid rgba(255,255,255,.12);padding-top:18px;font-size:13px;text-align:center}.footer-credit a{color:var(--gold);font-weight:900;text-decoration:none}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}@keyframes spin{from{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes shine{0%,45%{transform:translateX(-120%)}70%,100%{transform:translateX(120%)}}@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
@media(max-width:820px){.nav-wrap{align-items:flex-start;flex-direction:column}.nav-links{gap:12px}.hero{text-align:center;background-position:center}.hero p{margin:auto}.button-row,.hero-badges{justify-content:center}.stat-strip{margin-top:0;padding-top:22px}.about-grid{grid-template-columns:1fr}.footer-inner{grid-template-columns:1fr;text-align:center;justify-items:center}}



/* ===== Mobile polish update ===== */
.mobile-menu-toggle{
  display:none;
  background:rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.22);
  color:#fff;
  border-radius:12px;
  padding:10px 13px;
  font-weight:900;
  letter-spacing:.05em;
}

@media(max-width:820px){
  body{
    background:#f8f3e7;
  }

  .site-header{
    position:sticky;
  }

  .nav-wrap{
    flex-direction:row;
    align-items:center;
    padding:12px 16px;
  }

  .brand{
    font-size:16px;
    max-width:190px;
  }

  .brand span{
    font-size:8px;
    letter-spacing:.14em;
  }

  .mobile-menu-toggle{
    display:block;
    margin-left:auto;
  }

  .nav-links{
    display:none;
    width:100%;
    flex-direction:column;
    align-items:stretch;
    gap:0;
    padding:12px 0 4px;
  }

  body.mobile-menu-open .nav-links{
    display:flex;
  }

  .nav-links a{
    display:block;
    width:100%;
    padding:13px 14px;
    border-top:1px solid rgba(255,255,255,.12);
    font-size:15px;
  }

  .nav-cta{
    text-align:center;
    margin-top:10px;
  }

  .hero{
    min-height:auto;
    text-align:center;
    place-items:end center;
    background:
      linear-gradient(180deg,rgba(6,22,47,.42) 0%,rgba(6,22,47,.72) 52%,rgba(6,22,47,.98) 100%),
      url('https://harveyformissouri.com/wp-content/uploads/2026/05/Untitled-design-2026-05-18T170640.746.png');
    background-size:cover;
    background-position:center top;
    padding:315px 18px 54px;
  }

  .hero:before,
  .hero:after{
    opacity:.35;
  }

  .hero-copy{
    max-width:100%;
  }

  .eyebrow{
    font-size:10px;
    letter-spacing:.12em;
    padding:8px 12px;
    justify-content:center;
  }

  .hero h1{
    font-size:46px;
    line-height:.94;
    margin:16px 0 8px;
    letter-spacing:-.045em;
  }

  .hero-tagline{
    font-size:24px;
    line-height:1.05;
    margin:8px 0 12px;
  }

  .hero p{
    font-size:16px;
    line-height:1.48;
    max-width:340px;
    margin:auto;
  }

  .button-row{
    justify-content:center !important;
    gap:10px;
    margin-top:22px;
  }

  .btn{
    width:100%;
    max-width:315px;
    text-align:center;
    padding:14px 18px;
  }

  .hero-badges{
    justify-content:center;
    gap:8px;
    margin-top:18px;
  }

  .badge{
    font-size:12px;
    padding:10px 12px;
    animation:none;
  }

  .motion-banner{
    margin:0;
  }

  .motion-track{
    animation-duration:18s;
  }

  .motion-track span{
    padding:11px 20px;
    font-size:12px;
    letter-spacing:.05em;
  }

  .stat-strip{
    grid-template-columns:1fr;
    margin:0;
    padding:18px 16px 0;
    gap:10px;
  }

  .stat{
    padding:17px 14px;
    border-radius:16px;
  }

  .stat strong{
    font-size:24px;
  }

  .stat span{
    font-size:11px;
  }

  .section{
    padding:52px 18px;
  }

  .section-title{
    font-size:36px;
    line-height:.98;
    letter-spacing:-.04em;
  }

  .lead{
    font-size:17px;
    line-height:1.55;
  }

  .cards{
    grid-template-columns:1fr;
    gap:14px;
    margin-top:24px;
  }

  .card{
    padding:24px;
    border-radius:20px;
  }

  .card:hover{
    transform:none;
  }

  .page-hero{
    padding:64px 18px;
  }

  .page-hero h1{
    font-size:42px;
  }

  .page-hero p{
    font-size:16px;
    line-height:1.5;
  }

  .page-content{
    padding:46px 18px;
    font-size:16px;
  }

  .about-grid{
    grid-template-columns:1fr;
    gap:24px;
  }

  .about-photo{
    border-radius:20px;
    border-width:6px;
  }

  .custom-html-box{
    padding:22px;
    border-radius:18px;
  }

  .footer-inner{
    grid-template-columns:1fr;
    text-align:center;
    justify-items:center;
  }

  .footer-badge{
    width:112px;
  }

  .footer-paid{
    font-size:12px;
    line-height:1.5;
  }
}

@media(max-width:420px){
  .hero{
    padding-top:285px;
  }

  .hero h1{
    font-size:40px;
  }

  .hero-tagline{
    font-size:21px;
  }

  .brand{
    font-size:15px;
  }

  .section-title{
    font-size:32px;
  }
}

/* ===== Donation CTA prominence update ===== */
.nav-cta{font-size:15px;text-transform:uppercase;letter-spacing:.04em;box-shadow:0 14px 32px rgba(201,21,35,.48),0 0 0 2px rgba(245,197,66,.22) inset}
.btn-donate{position:relative;text-transform:uppercase;letter-spacing:.04em;box-shadow:0 18px 42px rgba(201,21,35,.42),0 0 0 2px rgba(245,197,66,.20) inset}
.btn-donate:after{content:"";position:absolute;inset:-4px;border-radius:999px;border:1px solid rgba(245,197,66,.45);opacity:.9;pointer-events:none}
.donate-band{max-width:1180px;margin:0 auto 18px;padding:26px 28px;border-radius:28px;background:linear-gradient(135deg,var(--navy),#0c2d59);color:#fff;display:flex;align-items:center;justify-content:space-between;gap:22px;box-shadow:0 28px 70px rgba(6,22,47,.20);border:1px solid rgba(245,197,66,.28)}
.donate-band span{display:block;color:var(--gold);font-weight:950;text-transform:uppercase;letter-spacing:.08em;font-size:13px;margin-bottom:7px}
.donate-band strong{display:block;font-size:clamp(22px,3vw,34px);line-height:1.08;letter-spacing:-.035em}
.donate-box{text-align:center;border-color:rgba(201,21,35,.32);background:linear-gradient(180deg,#fff,#fff8ee)}
.donate-box h3{font-size:30px;margin:0 0 8px;color:var(--navy)}
@media(max-width:820px){.donate-band{margin:0 18px 10px;padding:24px 20px;flex-direction:column;text-align:center}.donate-band .btn{width:100%;max-width:315px}.nav-cta{margin-top:12px;font-size:16px}.btn-donate:after{inset:-3px}}
