:root{
  --cream:#fbf6ed;
  --warm:#f4eadb;
  --paper:#fffdf8;
  --navy:#082b67;
  --navy-2:#123d7a;
  --red:#c9122d;
  --blue:#0b57bd;
  --green:#08743e;
  --gold:#d99513;
  --text:#273044;
  --muted:#6c7280;
  --shadow:0 18px 45px rgba(8,43,103,.14);
  --radius:28px;
  --serif: Georgia, 'Times New Roman', serif;
  --sans: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--cream);color:var(--text);font-family:var(--sans);line-height:1.6}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.container{width:min(1140px,92vw);margin-inline:auto}
.narrow{width:min(820px,90vw);margin-inline:auto}
.skip-link{position:absolute;left:-999px;top:auto;background:var(--navy);color:#fff;padding:.75rem 1rem;z-index:999}
.skip-link:focus{left:1rem;top:1rem}
.site-header{position:sticky;top:0;background:rgba(255,253,248,.92);backdrop-filter:blur(12px);z-index:20;border-bottom:1px solid rgba(8,43,103,.08)}
.nav-wrap{display:flex;align-items:center;justify-content:space-between;padding:.65rem 0}
.brand img{width:112px;height:auto}
.desktop-nav{display:flex;align-items:center;gap:1.35rem;font-size:.94rem;font-weight:700;color:var(--navy)}
.desktop-nav a{padding:.35rem 0;border-bottom:2px solid transparent}
.desktop-nav a:hover{border-color:var(--gold)}
.nav-donate{background:var(--gold);color:#fff;padding:.75rem 1.1rem!important;border-radius:999px;border:0!important;box-shadow:0 8px 18px rgba(217,149,19,.22)}
.menu-button{display:none;border:1px solid rgba(8,43,103,.18);background:#fff;color:var(--navy);border-radius:999px;padding:.6rem .9rem;font-weight:800}
.hero{display:grid;grid-template-columns:minmax(0,1.05fr) minmax(360px,.85fr);min-height:760px;background:linear-gradient(135deg,#fffdf8 0%,#f7ecdc 100%);position:relative;overflow:hidden}
.hero::after{content:"";position:absolute;right:-10vw;bottom:-7vw;width:64vw;height:22vw;background:linear-gradient(90deg,var(--red),var(--blue),var(--green));opacity:.12;border-radius:50%;transform:rotate(-7deg)}
.hero-image{background-image:linear-gradient(90deg,rgba(251,246,237,.0) 70%,rgba(251,246,237,.78)),url('assets/chantel-hero-flag.jpg');background-size:cover;background-position:center top;min-height:680px}
.hero-content{position:relative;z-index:1;align-self:center;padding:5rem clamp(1.5rem,5vw,5.5rem) 5rem 3rem}
.hero-logo{width:150px;margin-bottom:1rem}
.eyebrow{text-transform:uppercase;letter-spacing:.12em;color:var(--gold);font-size:.8rem;font-weight:900;margin:0 0 .75rem}
h1,h2,h3{color:var(--navy);line-height:1.05;margin:0 0 1rem}
h1{font-family:var(--serif);font-size:clamp(2.7rem,5vw,5.5rem);letter-spacing:-.04em}
h1 span{color:var(--navy)}
h2{font-family:var(--serif);font-size:clamp(2rem,3.4vw,3.45rem);letter-spacing:-.03em}
h3{font-size:1.18rem;font-weight:900}
p{font-size:1.05rem;margin:0 0 1rem}.subhead{font-weight:900;color:var(--navy);font-size:1.1rem}
.button-row{display:flex;flex-wrap:wrap;gap:.8rem;margin:1.6rem 0}
.button{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;padding:.85rem 1.25rem;font-weight:900;text-transform:uppercase;letter-spacing:.03em;font-size:.88rem;border:2px solid transparent;cursor:pointer}
.button.primary{background:var(--navy);color:#fff}.button.gold{background:var(--gold);color:#fff}.button.secondary{background:#fff;color:var(--navy);border-color:rgba(8,43,103,.18)}.button.large{padding:1rem 1.55rem;margin-top:1rem}
.election-banner{display:grid;gap:.2rem;background:#fff;border-left:6px solid var(--gold);box-shadow:var(--shadow);border-radius:18px;padding:1rem 1.15rem;color:var(--navy);max-width:500px}
.election-banner span{font-weight:700;color:var(--text)}
.credibility-strip{background:var(--paper);padding:2rem 0;border-block:1px solid rgba(8,43,103,.08)}
.three-col{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem}.three-col article{background:#fff;border-radius:22px;padding:1.35rem;box-shadow:0 12px 24px rgba(8,43,103,.08)}
.icon{font-size:1.5rem;margin-bottom:.4rem}.icon.red{color:var(--red)}.icon.blue{color:var(--blue)}.icon.green{color:var(--green)}
.section{padding:5.5rem 0;position:relative}.why{background:var(--cream);text-align:center}.split{display:grid;grid-template-columns:.9fr 1.1fr;gap:4rem;align-items:center}.split.reverse{grid-template-columns:1fr .95fr}
.portrait-card{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);background:#fff}.portrait-card img{width:100%;aspect-ratio:4/5;object-fit:cover;object-position:center top}
.text-link{font-weight:900;color:var(--navy);border-bottom:2px solid var(--gold)}
.priorities{background:var(--paper)}.center{text-align:center}.intro{color:var(--muted);max-width:740px;margin-inline:auto;margin-bottom:2rem}
.card-grid{display:grid;gap:1.15rem}.card-grid.five{grid-template-columns:repeat(5,1fr)}
.priority-card{background:#fff;border-radius:24px;padding:1.35rem;box-shadow:0 14px 30px rgba(8,43,103,.08);border-top:7px solid var(--gold);min-height:245px}.priority-card p{font-size:.97rem}.card-icon{font-size:1.25rem;color:var(--gold);display:inline-block;margin-bottom:.5rem}
.red-line{border-color:var(--red)}.blue-line{border-color:var(--blue)}.gold-line{border-color:var(--gold)}.green-line{border-color:var(--green)}.navy-line{border-color:var(--navy)}
.gallery{background:var(--cream)}.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}.photo-placeholder{min-height:220px;border-radius:24px;background:linear-gradient(135deg,#fff,#f1e3cf);border:1px dashed rgba(8,43,103,.24);display:grid;place-items:center;color:var(--navy);font-weight:900}
.endorsements-events{background:var(--paper)}.two-cards{display:grid;grid-template-columns:1fr 1fr;gap:1.4rem}.info-panel{background:#fff;border-radius:var(--radius);padding:2rem;box-shadow:var(--shadow)}.clean-list{margin:0;padding-left:1.2rem;color:var(--text);font-weight:700}
.volunteer-section{background:linear-gradient(135deg,var(--cream),#fff)}.mini-buttons{display:flex;flex-wrap:wrap;gap:.55rem;margin-top:1.2rem}.mini-buttons span{background:#fff;border:1px solid rgba(8,43,103,.12);border-radius:999px;padding:.55rem .8rem;font-weight:800;color:var(--navy)}
.form-card{background:#fff;border-radius:var(--radius);padding:1.5rem;box-shadow:var(--shadow);display:grid;gap:.95rem}label{font-weight:800;color:var(--navy);font-size:.9rem}input,textarea{width:100%;margin-top:.25rem;border:1px solid rgba(8,43,103,.18);border-radius:14px;padding:.85rem;font:inherit;background:#fffdf8}textarea{resize:vertical}
.donate-section{background:var(--navy);color:#fff}.donate-section h2,.donate-section .eyebrow,.donate-section p{color:#fff}.giving-levels{display:flex;flex-wrap:wrap;justify-content:center;gap:.7rem;margin:1.3rem 0}.giving-levels span{background:#fff;color:var(--navy);border-radius:999px;padding:.7rem 1rem;font-weight:900;min-width:80px}
.contact-section{background:var(--paper)}.contact-placeholder{font-weight:800;color:var(--navy)}
.site-footer{background:#061f4d;color:#fff;padding:2rem 0}.footer-grid{display:grid;grid-template-columns:120px 1fr 1.4fr;gap:1.25rem;align-items:center}.footer-grid img{background:#fff;border-radius:16px;padding:.25rem}.site-footer p{margin:0;font-size:.93rem}.disclaimer{color:rgba(255,255,255,.78)}
@media (max-width:1000px){.hero{grid-template-columns:1fr;min-height:auto}.hero-image{min-height:620px;background-position:center top}.hero-content{padding:2rem 5vw 4rem}.desktop-nav{display:none}.menu-button{display:block}.brand img{width:92px}.card-grid.five{grid-template-columns:repeat(2,1fr)}.gallery-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:720px){.hero-image{min-height:520px}.hero-logo{width:125px}.button-row{display:grid}.button{width:100%}.three-col,.split,.split.reverse,.two-cards,.footer-grid{grid-template-columns:1fr}.section{padding:4rem 0}.card-grid.five,.gallery-grid{grid-template-columns:1fr}.priority-card{min-height:auto}.footer-grid img{width:120px}.site-footer{text-align:left}p{font-size:1rem}h1{font-size:2.55rem}.election-banner{max-width:none}}


/* Responsive Google Calendar embed */
.calendar-embed {
  position: relative;
  width: 100%;
  min-height: 600px;
  margin-top: 1.5rem;
  overflow: hidden;
  border-radius: 18px;
  background: #fff;
  box-shadow: 0 10px 30px rgba(8, 43, 99, 0.10);
}
.calendar-embed iframe {
  width: 100%;
  height: 600px;
  border: 0;
  display: block;
}
.events-panel {
  grid-column: span 1;
}
@media (max-width: 760px) {
  .calendar-embed,
  .calendar-embed iframe {
    min-height: 520px;
    height: 520px;
  }
}

/* Hidden spam-trap field for public forms */
.form-honeypot {
  position: absolute !important;
  left: -9999px !important;
  width: 1px !important;
  height: 1px !important;
  opacity: 0 !important;
  pointer-events: none !important;
}
