/* =========================================================================
   The Death Penalty Party — mock site styled after tpusa.com
   Dark, bold, condensed-caps, red accent. Parody/demonstration only.
   ========================================================================= */

:root{
  --black:#0a0c10;
  --panel:#10131b;
  --panel-2:#161a24;
  --navy:#0e1c33;
  --red:#d11f2d;
  --red-dark:#a8161f;
  --gold:#f2b705;
  --white:#ffffff;
  --muted:#a7b0bf;
  --line:#232a38;
  --maxw:72rem;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  background:var(--black);
  color:var(--white);
  font-family:'Inter',system-ui,sans-serif;
  line-height:1.6;
}
h1,h2,h3,h4,h5,.band-title,.brand-text,.stat-num{
  font-family:'Oswald',Impact,sans-serif;
  text-transform:uppercase;
  letter-spacing:.01em;
  font-weight:700;
  line-height:1.05;
  margin:0;
}
a{color:inherit;text-decoration:none;}
p{margin:0 0 1rem;}
strong{color:var(--white);}
em{color:var(--gold);font-style:normal;}

/* ---------- buttons ---------- */
.btn{
  display:inline-block;
  font-family:'Oswald',sans-serif;
  text-transform:uppercase;
  letter-spacing:.04em;
  font-weight:600;
  padding:.7rem 1.4rem;
  border:2px solid transparent;
  border-radius:2px;
  cursor:pointer;
  transition:.15s;
}
.btn-donate{background:var(--red);color:#fff;}
.btn-donate:hover{background:var(--red-dark);}
.btn-ghost{border-color:rgba(255,255,255,.55);color:#fff;}
.btn-ghost:hover{background:#fff;color:var(--black);}
.btn-light{background:#fff;color:var(--black);}
.btn-light:hover{background:var(--gold);}
.btn-lg{padding:.95rem 2rem;font-size:1.05rem;}

/* ---------- utility bar ---------- */
.util-bar{
  background:var(--red);
  color:#fff;
  font-size:.72rem;
  letter-spacing:.12em;
  text-transform:uppercase;
  display:flex;justify-content:space-between;align-items:center;
  padding:.45rem 1.5rem;
  font-weight:600;
}
.util-links a{opacity:.95;}
.util-links a:hover{text-decoration:underline;}

/* ---------- header ---------- */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(10,12,16,.92);
  backdrop-filter:blur(6px);
  border-bottom:1px solid var(--line);
  display:flex;align-items:center;justify-content:space-between;
  padding:.85rem 1.5rem;
}
.brand{display:flex;align-items:center;gap:.7rem;}
.brand-mark{
  background:var(--red);color:#fff;
  font-family:'Oswald',sans-serif;font-weight:700;
  padding:.25rem .55rem;border-radius:2px;font-size:1.05rem;letter-spacing:.04em;
}
.brand-text{font-size:1.05rem;letter-spacing:.03em;}
.site-nav{display:flex;align-items:center;gap:1.6rem;}
.site-nav a{
  font-family:'Oswald',sans-serif;text-transform:uppercase;
  font-size:.92rem;letter-spacing:.04em;color:var(--muted);font-weight:500;
}
.site-nav a:hover{color:#fff;}
.site-nav .btn-donate{color:#fff;}
.nav-toggle{display:none;background:none;border:0;color:#fff;font-size:1.6rem;cursor:pointer;}

/* ---------- hero ---------- */
.hero{
  position:relative;
  background:
    radial-gradient(120% 90% at 70% -10%, rgba(209,31,45,.30), transparent 55%),
    linear-gradient(180deg,#0e1424 0%,#0a0c10 70%);
  padding:6rem 1.5rem 7rem;
  overflow:hidden;
}
.hero-inner{max-width:var(--maxw);margin:0 auto;position:relative;z-index:2;}
.kicker{color:var(--gold);text-transform:uppercase;letter-spacing:.18em;font-size:.8rem;font-weight:600;margin-bottom:1rem;}
.hero h1{font-size:clamp(2.6rem,7vw,5.5rem);}
.hero h1 .hl{color:var(--red);}
.hero-sub{max-width:42rem;color:var(--muted);font-size:1.15rem;margin:1.5rem 0 2rem;}
.hero-stripe{
  position:absolute;left:0;right:0;bottom:0;height:8px;
  background:linear-gradient(90deg,var(--red) 0 33%,#fff 33% 66%,var(--navy) 66% 100%);
  opacity:.9;
}
.cta-row{display:flex;gap:1rem;flex-wrap:wrap;}
.cta-row.center{justify-content:center;}

/* ---------- generic band ---------- */
.band{max-width:var(--maxw);margin:0 auto;padding:5rem 1.5rem;}
.band.dark{max-width:none;background:var(--panel);}
.band.dark>*{max-width:var(--maxw);margin-left:auto;margin-right:auto;}
.eyebrow{color:var(--red);text-transform:uppercase;letter-spacing:.16em;font-size:.78rem;font-weight:700;margin-bottom:.8rem;}
.eyebrow.light{color:var(--gold);}
.band-title{font-size:clamp(1.7rem,3.6vw,2.8rem);max-width:34ch;margin-bottom:1.8rem;}
.band-title.light{color:#fff;}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:2.5rem;color:var(--muted);font-size:1.05rem;}

/* ---------- stats ---------- */
.stats{
  background:var(--red);
  display:grid;grid-template-columns:repeat(4,1fr);
  text-align:center;
}
.stat{padding:2.6rem 1rem;border-right:1px solid rgba(255,255,255,.18);}
.stat:last-child{border-right:0;}
.stat-num{display:block;font-size:3.4rem;color:#fff;}
.stat-label{display:block;text-transform:uppercase;letter-spacing:.05em;font-size:.82rem;color:rgba(255,255,255,.9);font-weight:600;margin-top:.4rem;}

/* ---------- quote band ---------- */
.quote-band{
  background:linear-gradient(180deg,#0e1c33,#0a0c10);
  text-align:center;padding:5.5rem 1.5rem;
}
.quote-band blockquote{
  font-family:'Oswald',sans-serif;font-weight:600;text-transform:uppercase;
  font-size:clamp(1.5rem,3.4vw,2.5rem);line-height:1.2;
  max-width:50rem;margin:0 auto 1.2rem;border-left:4px solid var(--red);padding-left:1.5rem;text-align:left;
}
.quote-cite{color:var(--muted);max-width:46rem;margin:0 auto;}

/* ---------- pillar / issue / canon cards ---------- */
.card-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;}
.card{background:var(--panel-2);border:1px solid var(--line);border-top:3px solid var(--red);padding:1.8rem;}
.card h3{font-size:1.4rem;margin-bottom:.7rem;color:#fff;}
.card p{color:var(--muted);margin:0;}

.issue-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem;}
.issue{border:1px solid var(--line);background:var(--panel);padding:1.8rem;}
.issue h3{font-size:1.5rem;color:#fff;margin-bottom:.6rem;}
.issue p{color:var(--muted);}
.tag{display:inline-block;background:rgba(209,31,45,.15);color:#ff8a93;border:1px solid rgba(209,31,45,.4);
  font-family:'Oswald',sans-serif;text-transform:uppercase;letter-spacing:.05em;font-size:.72rem;padding:.25rem .6rem;border-radius:2px;}

.canon-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;}
.canon-card{background:var(--panel-2);border:1px solid var(--line);padding:1.3rem;transition:.15s;}
.canon-card:hover{border-color:var(--red);transform:translateY(-3px);}
.canon-card h4{font-size:1.15rem;color:var(--gold);margin-bottom:.4rem;}
.canon-card p{color:var(--muted);font-size:.92rem;margin:0;}

/* ---------- statute (flagship) ---------- */
.statute{background:
   linear-gradient(180deg,rgba(209,31,45,.12),transparent 40%),var(--navy);
  padding:5.5rem 1.5rem;}
.statute-inner{max-width:var(--maxw);margin:0 auto;}
.statute-lede{color:#d7deea;font-size:1.12rem;max-width:50rem;margin-bottom:2.5rem;}
.statute-cols{display:grid;grid-template-columns:1fr 1fr;gap:2rem;}
.statute-block{background:rgba(0,0,0,.3);border:1px solid rgba(255,255,255,.12);padding:1.8rem;}
.statute-block h3{color:var(--gold);font-size:1.3rem;margin-bottom:1rem;}
.statute-block ul{margin:0;padding-left:1.1rem;color:var(--muted);}
.statute-block li{margin-bottom:.8rem;}

/* ---------- name band ---------- */
.name-band{background:var(--panel);padding:5rem 1.5rem;max-width:none;text-align:center;}
.name-band>*{max-width:54rem;margin-left:auto;margin-right:auto;}
.name-text{color:var(--muted);font-size:1.15rem;}

/* ---------- CTA band ---------- */
.cta-band{
  background:
    radial-gradient(100% 120% at 50% 0,rgba(209,31,45,.4),transparent 60%),var(--black);
  text-align:center;padding:5rem 1.5rem;border-top:1px solid var(--line);
}
.cta-band h2{font-size:clamp(2rem,5vw,3.5rem);margin-bottom:.8rem;}
.cta-band p{color:var(--muted);max-width:42rem;margin:0 auto 2rem;}

/* ---------- footer ---------- */
.site-footer{background:#06080c;border-top:1px solid var(--line);padding:3.5rem 1.5rem 2rem;}
.footer-cols{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:2rem;}
.footer-brand p{color:var(--muted);font-size:.92rem;margin:1rem 0;max-width:24rem;}
.social{display:flex;gap:.6rem;}
.social a{width:2.1rem;height:2.1rem;display:grid;place-items:center;background:var(--panel-2);border:1px solid var(--line);
  font-family:'Oswald',sans-serif;font-size:.85rem;border-radius:2px;}
.social a:hover{background:var(--red);}
.footer-col h5{color:#fff;font-size:1rem;margin-bottom:.9rem;}
.footer-col a{display:block;color:var(--muted);font-size:.92rem;margin-bottom:.5rem;}
.footer-col a:hover{color:#fff;}
.footer-fine{max-width:var(--maxw);margin:2.5rem auto 0;color:var(--muted);font-size:.85rem;border-top:1px solid var(--line);padding-top:1.5rem;}
.footer-fine.muted{opacity:.6;margin-top:.6rem;border:0;padding:0;}

/* ---------- responsive ---------- */
@media(max-width:860px){
  .two-col,.card-grid,.issue-grid,.statute-cols{grid-template-columns:1fr;}
  .canon-grid{grid-template-columns:repeat(2,1fr);}
  .stats{grid-template-columns:repeat(2,1fr);}
  .stat:nth-child(2){border-right:0;}
  .footer-cols{grid-template-columns:1fr 1fr;}
}
@media(max-width:640px){
  .brand-text{display:none;}
  .nav-toggle{display:block;}
  .site-nav{
    display:none;position:absolute;top:100%;left:0;right:0;
    flex-direction:column;align-items:flex-start;gap:0;
    background:var(--black);border-bottom:1px solid var(--line);padding:1rem 1.5rem;
  }
  .site-nav.open{display:flex;}
  .site-nav a{padding:.6rem 0;width:100%;}
  .footer-cols{grid-template-columns:1fr;}
  .canon-grid{grid-template-columns:1fr;}
}
