@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,700;0,900;1,400;1,700&family=Source+Sans+3:wght@400;600;700&display=swap');

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  --deep:#2b4633;
  --sage:#3d5a47;
  --mid:#4f6d58;
  --light:#6a8a74;
  --pale:#dce5de;
  --cream:#f0ece4;
  --red:#d63031;
  --red-dark:#b52526;
  --text-light:#f0ece4;
  --text-dark:#1e3326;
  --BIG:clamp(40px,7vw,72px);
  --MED:clamp(28px,4.5vw,44px);
  --body:clamp(17px,2vw,20px);
}

html{scroll-behavior:smooth}
body{font-family:'Source Sans 3',sans-serif;background:var(--sage);color:var(--text-light);font-size:var(--body);line-height:1.7;overflow-x:hidden}

body{animation:fadeIn .4s ease}
@keyframes fadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}

/* ── NAV ── */
nav{background:var(--deep);display:flex;align-items:center;justify-content:space-between;padding:0 clamp(20px,4vw,48px);height:60px;position:sticky;top:0;z-index:100;border-bottom:3px solid var(--red)}
.nav-logo{color:var(--cream);font-family:'Playfair Display',serif;font-size:20px;font-weight:700;letter-spacing:.02em;text-decoration:none}
.nav-links{display:flex;align-items:center;gap:clamp(16px,2.5vw,32px)}
.nav-links a{color:rgba(240,236,228,.6);font-size:14px;font-weight:700;text-decoration:none;text-transform:uppercase;letter-spacing:.08em;transition:color .2s}
.nav-links a:hover,.nav-links a.active{color:var(--cream)}
.nav-donate{background:var(--red)!important;color:var(--cream)!important;padding:7px 18px;border-radius:2px;transition:background .2s!important}
.nav-donate:hover{background:var(--red-dark)!important}
.nav-toggle{display:none;background:none;border:none;cursor:pointer;padding:4px}
.nav-toggle span{display:block;width:24px;height:2px;background:var(--cream);margin:5px 0;border-radius:1px}

/* ── BLOCKS ── */
.block{padding:clamp(52px,8vw,88px) clamp(24px,6vw,80px)}
.block-deep{background:var(--deep)}
.block-sage{background:var(--sage)}
.block-mid{background:var(--mid)}
.block-light{background:var(--light)}
.block-pale{background:var(--pale);color:var(--text-dark)}
.block-red{background:var(--red)}

.ruled{border-top:2px solid rgba(240,236,228,.1)}

/* ── TYPOGRAPHY ── */
.big{font-family:'Playfair Display',serif;font-size:var(--BIG);line-height:1.05;letter-spacing:-.01em;font-weight:700;color:var(--cream)}
.med{font-family:'Playfair Display',serif;font-size:var(--MED);line-height:1.15;font-weight:700;color:var(--cream)}
.lead{font-size:clamp(17px,2.2vw,21px);line-height:1.7;max-width:640px;font-weight:400;color:rgba(240,236,228,.75)}
.body-text{font-size:clamp(17px,1.8vw,20px);line-height:1.8;max-width:720px;color:rgba(240,236,228,.8)}
.body-text+.body-text{margin-top:16px}
.body-text a{color:var(--cream);font-weight:700;text-decoration:underline;text-decoration-color:var(--red);text-underline-offset:3px}

/* pale block overrides */
.block-pale .big,.block-pale .med{color:var(--text-dark)}
.block-pale .lead{color:rgba(30,51,38,.6)}
.block-pale .body-text{color:rgba(30,51,38,.75)}
.block-pale .body-text a{color:var(--red)}

/* ── PILL ── */
.pill{display:inline-block;font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;padding:5px 14px;border-radius:2px;margin-bottom:14px;border:2px solid rgba(240,236,228,.25);color:rgba(240,236,228,.6)}
.pill.red{color:var(--red);border-color:var(--red)}
.block-pale .pill{border-color:rgba(30,51,38,.2);color:rgba(30,51,38,.5)}

/* ── BUTTONS ── */
.btn{display:inline-block;font-size:14px;font-weight:700;padding:13px 30px;border-radius:2px;text-decoration:none;text-transform:uppercase;letter-spacing:.08em;transition:.2s;border:none;font-family:'Source Sans 3',sans-serif;cursor:pointer}
.btn-red{background:var(--red);color:var(--cream)}
.btn-red:hover{background:var(--red-dark)}
.btn-deep{background:var(--deep);color:var(--cream)}
.btn-deep:hover{background:#1e3326}
.btn-outline{background:transparent;border:2px solid rgba(240,236,228,.3);color:var(--cream)}
.btn-outline:hover{background:rgba(240,236,228,.08)}
.block-pale .btn-outline{border-color:rgba(30,51,38,.25);color:var(--text-dark)}
.block-pale .btn-outline:hover{background:rgba(30,51,38,.06)}
.btns{display:flex;gap:12px;flex-wrap:wrap;margin-top:28px}

/* ── ISSUE BLOCKS ── */
.issue-num{font-family:'Playfair Display',serif;font-size:64px;line-height:1;color:rgba(240,236,228,.06);font-weight:900;margin-bottom:-8px}
.issue-title{font-family:'Playfair Display',serif;font-size:clamp(32px,5vw,52px);line-height:1.05;margin-bottom:18px;font-weight:700;color:var(--cream)}
.issue-sub{display:flex;flex-direction:column;gap:18px}
.pledge{border-left:3px solid var(--red);padding:16px 24px;background:rgba(240,236,228,.06);border-radius:0 3px 3px 0}
.pledge strong{display:block;font-size:13px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--red);margin-bottom:6px}
.pledge p{font-size:clamp(16px,1.8vw,19px);line-height:1.7;color:rgba(240,236,228,.8)}

.block-pale .issue-num{color:rgba(30,51,38,.05)}
.block-pale .issue-title{color:var(--text-dark)}
.block-pale .pledge{background:rgba(30,51,38,.04)}
.block-pale .pledge p{color:rgba(30,51,38,.75)}

/* ── CONTACT ── */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(32px,6vw,72px);align-items:start}
.form-group{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}
.form-group label{font-size:12px;font-weight:700;color:rgba(240,236,228,.5);text-transform:uppercase;letter-spacing:.1em}
.form-group input,.form-group textarea{padding:12px 16px;border:2px solid rgba(240,236,228,.15);border-radius:2px;font-size:16px;font-family:'Source Sans 3',sans-serif;color:var(--cream);background:rgba(240,236,228,.07);outline:none;transition:border-color .2s}
.form-group input::placeholder,.form-group textarea::placeholder{color:rgba(240,236,228,.25)}
.form-group input:focus,.form-group textarea:focus{border-color:var(--red)}
.form-group textarea{resize:vertical;min-height:140px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-check{display:flex;align-items:center;gap:10px;font-size:15px;color:rgba(240,236,228,.6)}
.form-check input{width:18px;height:18px;accent-color:var(--red)}
.contact-info{display:flex;flex-direction:column;gap:20px}
.contact-card{background:rgba(0,0,0,.15);color:var(--cream);padding:28px 32px;border-radius:3px}
.contact-card h3{font-family:'Playfair Display',serif;font-size:24px;color:var(--cream);margin-bottom:6px;font-weight:700}
.contact-card a{font-size:18px;font-weight:600;color:var(--cream);text-decoration:none;display:block;opacity:.85}
.contact-card a:hover{opacity:1}
.contact-card p{font-size:15px;color:rgba(240,236,228,.5);margin-top:8px;line-height:1.6}
.contact-card.red-card{background:var(--red)}

/* ── WARD FINDER ── */
.map-wrap{border:3px solid rgba(240,236,228,.12);border-radius:4px;overflow:hidden;margin-top:36px}
.map-wrap iframe{display:block;width:100%;height:680px;border:none}

/* ── CANDIDATE PHOTO ── */
.candidate-photo{width:100%;max-width:400px;border-radius:4px;display:block;margin-bottom:40px;border:3px solid rgba(240,236,228,.1)}

/* ── HERO IMAGE ── */
.hero-img-wrap{margin-top:40px;border-radius:4px;overflow:hidden;max-width:720px;border:3px solid rgba(240,236,228,.1)}
.hero-img-wrap img{display:block;width:100%;height:auto}

/* ── SIGNUP ── */
.signup-row{display:flex;max-width:460px;border:2px solid rgba(240,236,228,.2);border-radius:2px;overflow:hidden}
.signup-row input{flex:1;padding:13px 16px;font-size:16px;font-family:'Source Sans 3',sans-serif;border:none;outline:none;background:rgba(240,236,228,.07);color:var(--cream)}
.signup-row input::placeholder{color:rgba(240,236,228,.25)}
.signup-row button{background:var(--red);color:var(--cream);font-size:13px;font-weight:700;padding:13px 20px;border:none;font-family:'Source Sans 3',sans-serif;text-transform:uppercase;letter-spacing:.08em;cursor:pointer;white-space:nowrap;transition:background .2s}
.signup-row button:hover{background:var(--red-dark)}

/* ── COMMITMENT GRID ── */
.commit-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:12px}
.commit-item{padding:18px 22px;border-left:3px solid var(--red);background:rgba(240,236,228,.06);border-radius:0 3px 3px 0}
.commit-item p{font-size:16px;color:var(--cream);font-weight:600;line-height:1.5}

/* ── PLEDGE CARDS ── */
.pledge-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:20px}
.pledge-card{background:rgba(0,0,0,.15);border-radius:3px;padding:30px 26px;border-top:3px solid var(--red)}
.pledge-card .num{font-family:'Playfair Display',serif;font-size:44px;color:var(--red);line-height:1;font-weight:900;opacity:.4}
.pledge-card .card-title{font-family:'Playfair Display',serif;font-size:26px;color:var(--cream);margin-bottom:10px;font-weight:700}
.pledge-card p{font-size:16px;line-height:1.7;color:rgba(240,236,228,.7)}
.pledge-card a{display:inline-block;margin-top:12px;font-size:13px;font-weight:700;color:var(--red);text-transform:uppercase;letter-spacing:.08em;text-decoration:none;transition:opacity .2s}
.pledge-card a:hover{opacity:.7}

/* ── FORM STATUS ── */
.form-status{padding:16px 20px;border-radius:3px;font-size:16px;font-weight:600;margin-top:16px;display:none}
.form-status.success{display:block;background:rgba(240,236,228,.1);color:var(--cream)}
.form-status.error{display:block;background:rgba(214,48,49,.2);color:var(--cream)}

/* ── FOOTER ── */
footer{background:var(--deep);border-top:3px solid var(--red);padding:36px clamp(24px,6vw,80px);display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap}
footer strong{display:block;color:var(--cream);font-family:'Playfair Display',serif;font-size:20px;margin-bottom:4px}
footer p,footer a{color:rgba(240,236,228,.4);font-size:13px;text-decoration:none;line-height:1.7}
.foot-links{display:flex;gap:20px;flex-wrap:wrap}
.foot-links a{color:rgba(240,236,228,.45);font-size:13px;font-weight:700;text-decoration:none;text-transform:uppercase;letter-spacing:.06em;transition:color .2s}
.foot-links a:hover{color:var(--cream)}

/* ── RESPONSIVE ── */
@media(max-width:840px){
  nav{padding:0 20px}
  .nav-links{display:none;flex-direction:column;position:absolute;top:60px;left:0;right:0;background:var(--deep);padding:20px;gap:14px;border-bottom:3px solid var(--red);z-index:99}
  .nav-links.open{display:flex}
  .nav-toggle{display:block}
  .contact-grid,.form-row{grid-template-columns:1fr}
  footer{flex-direction:column;align-items:flex-start}
  .issue-num{font-size:44px}
}
