/* VoxPopli — Activist Style (static site) */
:root{
  --bg:#0b0b0d;
  --ink:#0e0e12;
  --paper:#f3f0e8;
  --paper2:#ece7dc;
  --text:#f2f2f2;
  --muted:rgba(242,242,242,.72);
  --line:rgba(255,255,255,.14);
  --shadow:rgba(0,0,0,.55);
  --red:#e10600;
  --red2:#b10000;
  --accent:#ff2a1f;
  --max:1120px;

  --hfont: Impact, Haettenschweiler, "Arial Narrow Bold", "Franklin Gothic Condensed", Arial, sans-serif;
  --bfont: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  background:
    radial-gradient(900px 500px at 20% -10%, rgba(225,6,0,.18), transparent 60%),
    radial-gradient(800px 520px at 90% 10%, rgba(255,255,255,.06), transparent 60%),
    var(--bg);
  color:var(--text);
  font-family:var(--bfont);
  overflow-x:hidden;
}

.wrap{max-width:var(--max); margin:0 auto; padding:0 18px}

.grain{
  pointer-events:none;
  position:fixed; inset:0;
  background-image:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="180" height="180"><filter id="n"><feTurbulence type="fractalNoise" baseFrequency=".9" numOctaves="2" stitchTiles="stitch"/></filter><rect width="180" height="180" filter="url(%23n)" opacity=".18"/></svg>');
  mix-blend-mode:overlay;
  opacity:.22;
  z-index:1;
}

.nav{
  position:sticky; top:0; z-index:50;
  display:flex; align-items:center; justify-content:space-between;
  padding:14px 18px;
  border-bottom:1px solid rgba(255,255,255,.10);
  background:rgba(0,0,0,.55);
  backdrop-filter: blur(10px);
}

.brand{display:flex; gap:12px; align-items:center; color:var(--text); text-decoration:none}
.brandMark{
  width:42px; height:42px; border-radius:12px;
  display:grid; place-items:center;
  font-family:var(--hfont);
  letter-spacing:.04em;
  font-size:22px;
  border:1px solid rgba(255,255,255,.16);
  background:linear-gradient(180deg, rgba(225,6,0,.25), rgba(255,255,255,.06));
  box-shadow: 0 10px 28px rgba(0,0,0,.35);
}
.brandText{display:flex; flex-direction:column; line-height:1.05}
.brandName{
  font-family:var(--hfont);
  letter-spacing:.08em;
  font-size:18px;
}
.brandTag{font-size:12px; color:var(--muted)}

.navLinks{display:flex; align-items:center; gap:14px}
.navLinks a{
  color:var(--text);
  text-decoration:none;
  opacity:.9;
  font-weight:650;
}
.navLinks a:hover{opacity:1}

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  padding:12px 14px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.18);
  background:rgba(255,255,255,.06);
  color:var(--text);
  text-decoration:none;
  font-weight:800;
  letter-spacing:.02em;
  cursor:pointer;
}
.btn:hover{transform: translateY(-1px); transition: .15s ease; border-color: rgba(255,255,255,.28)}
.btn-red{
  border-color: rgba(225,6,0,.60);
  background: linear-gradient(180deg, rgba(225,6,0,.92), rgba(177,0,0,.92));
  box-shadow: 0 12px 28px rgba(0,0,0,.45);
}
.btn-red:hover{border-color: rgba(255,42,31,.8)}
.btn-ghost{
  background: transparent;
  border-color: rgba(255,255,255,.22);
}

.hero{
  position:relative;
  padding:84px 0 44px;
  border-bottom: 1px solid rgba(255,255,255,.08);
  isolation:isolate;
}
.heroBackdrop{
  position:absolute; inset:-1px;
  background:
    linear-gradient(180deg, rgba(0,0,0,.72), rgba(0,0,0,.90)),
    url("assets/platform_values.jpg") center/cover no-repeat;
  filter: saturate(1.05) contrast(1.05);
  opacity:.9;
  z-index:-2;
}
.hero:after{
  content:"";
  position:absolute; inset:0;
  background:
    radial-gradient(900px 480px at 20% 0%, rgba(225,6,0,.30), transparent 60%),
    radial-gradient(900px 520px at 80% 30%, rgba(255,255,255,.06), transparent 60%);
  z-index:-1;
}

.kicker{
  display:inline-block;
  font-family:var(--hfont);
  letter-spacing:.16em;
  text-transform:uppercase;
  font-size:12px;
  padding:8px 10px;
  border:1px solid rgba(255,255,255,.16);
  background: rgba(0,0,0,.35);
  border-radius:999px;
}

.heroInner h1{
  margin:14px 0 10px;
  font-family:var(--hfont);
  letter-spacing:.04em;
  text-transform:uppercase;
  font-size:54px;
  line-height:1.02;
  text-shadow: 0 12px 30px var(--shadow);
}
.lead{
  max-width:760px;
  color:var(--muted);
  font-size:16px;
  line-height:1.65;
  margin:0 0 18px;
}

.ctaRow{display:flex; gap:12px; flex-wrap:wrap; margin:18px 0 8px}

.statsRow{
  margin-top:18px;
  display:grid;
  grid-template-columns: repeat(5, minmax(0,1fr));
  gap:10px;
}
.stat{
  border:1px solid rgba(255,255,255,.14);
  border-radius:14px;
  background: rgba(0,0,0,.35);
  padding:12px;
}
.statNum{
  display:block;
  font-family:var(--hfont);
  letter-spacing:.12em;
  color: rgba(255,255,255,.75);
  font-size:12px;
}
.statLbl{
  display:block;
  margin-top:6px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.05em;
  font-size:12px;
}

.section{padding:54px 0; position:relative; z-index:2}
.section-dark{
  background:
    radial-gradient(900px 520px at 20% 0%, rgba(225,6,0,.18), transparent 60%),
    linear-gradient(180deg, rgba(0,0,0,.62), rgba(0,0,0,.88));
  border-top:1px solid rgba(255,255,255,.08);
  border-bottom:1px solid rgba(255,255,255,.08);
}

.sectionHead{display:flex; align-items:flex-end; justify-content:space-between; gap:12px; flex-wrap:wrap}
.sectionHead h2{
  margin:0;
  font-family:var(--hfont);
  letter-spacing:.06em;
  text-transform:uppercase;
  font-size:32px;
}
.muted{color:var(--muted)}
.tiny{font-size:12px}

.cardGrid{
  margin-top:18px;
  display:grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap:12px;
}
.card{
  border:1px solid rgba(255,255,255,.14);
  border-radius:18px;
  background: rgba(255,255,255,.06);
  padding:16px 16px 14px;
  box-shadow: 0 10px 28px rgba(0,0,0,.22);
}
.card h3{
  margin:8px 0 8px;
  font-family:var(--hfont);
  letter-spacing:.05em;
  text-transform:uppercase;
  font-size:18px;
}
.card p{margin:0; color:var(--muted); line-height:1.6}
.icon{
  width:44px; height:44px; border-radius:14px;
  display:grid; place-items:center;
  border:1px solid rgba(255,255,255,.16);
  background: rgba(0,0,0,.30);
  font-size:20px;
}

.poster{
  margin:22px 0 0;
  border-radius:22px;
  overflow:hidden;
  border:1px solid rgba(255,255,255,.14);
  background: rgba(0,0,0,.25);
}
.poster img{width:100%; height:auto; display:block}
.poster figcaption{padding:10px 12px}

.manifesto{
  margin-top:18px;
  padding:18px 18px 16px;
  border-radius:20px;
  border:1px solid rgba(255,255,255,.14);
  background:
    linear-gradient(180deg, rgba(255,255,255,.08), rgba(0,0,0,.20));
}
.manifesto p{margin:0 0 12px; color:rgba(242,242,242,.88); line-height:1.75}
.dropcap{
  float:left;
  font-family:var(--hfont);
  font-size:38px;
  line-height:1;
  margin:4px 10px 0 0;
  color: var(--accent);
}
.manifestoLine{margin-top:10px}

.split{
  margin-top:18px;
  display:grid;
  grid-template-columns: 1.08fr .92fr;
  gap:16px;
  align-items:start;
}
.framed{
  width:100%;
  height:auto;
  display:block;
  border-radius:22px;
  border:1px solid rgba(255,255,255,.14);
  box-shadow: 0 16px 44px rgba(0,0,0,.35);
}

.bullets{
  margin:10px 0 0;
  padding-left:18px;
  color: rgba(242,242,242,.86);
  line-height:1.75;
}
.bullets li{margin:8px 0}

.miniGrid{
  margin-top:14px;
  display:grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap:10px;
}
.mini{
  border:1px solid rgba(255,255,255,.12);
  border-radius:16px;
  background: rgba(255,255,255,.05);
  padding:12px;
}
.miniTitle{
  display:block;
  font-weight:950;
  text-transform:uppercase;
  letter-spacing:.05em;
  font-size:12px;
}
.miniTxt{display:block; margin-top:6px; color:var(--muted); font-size:13px; line-height:1.55}

.joinBox{
  border:1px solid rgba(255,255,255,.14);
  border-radius:22px;
  background:
    linear-gradient(180deg, rgba(0,0,0,.45), rgba(0,0,0,.75)),
    radial-gradient(900px 520px at 20% 0%, rgba(225,6,0,.18), transparent 60%);
  padding:18px;
  box-shadow: 0 18px 60px rgba(0,0,0,.45);
}
.form{
  margin-top:12px;
  display:grid;
  grid-template-columns: 1fr 1fr auto;
  gap:10px;
}
input{
  width:100%;
  padding:12px 14px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.16);
  background: rgba(0,0,0,.35);
  color:var(--text);
  outline:none;
}
input:focus{border-color: rgba(255,42,31,.75); box-shadow: 0 0 0 4px rgba(225,6,0,.16)}
.srOnly{position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); border:0}

.footer{
  border-top:1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.55);
  padding:18px 0;
}
.footerInner{display:flex; justify-content:space-between; align-items:center; gap:12px; flex-wrap:wrap}
.footerLinks{display:flex; gap:12px}
.footer a{color:var(--muted); text-decoration:none}
.footer a:hover{color:var(--text)}

.pageHero{
  padding:70px 0 26px;
  border-bottom:1px solid rgba(255,255,255,.08);
  background:
    linear-gradient(180deg, rgba(0,0,0,.72), rgba(0,0,0,.92)),
    url("assets/logo_explainer.jpg") center/cover no-repeat;
}
.pageHero h1{
  margin:14px 0 10px;
  font-family:var(--hfont);
  text-transform:uppercase;
  letter-spacing:.05em;
  font-size:48px;
  line-height:1.02;
}
.page{min-height:70vh}
.subhead{
  margin:22px 0 10px;
  font-family:var(--hfont);
  letter-spacing:.06em;
  text-transform:uppercase;
}

/* Responsive */
@media (max-width: 980px){
  .statsRow{grid-template-columns: repeat(2, minmax(0,1fr))}
  .cardGrid{grid-template-columns:1fr}
  .split{grid-template-columns:1fr}
  .form{grid-template-columns:1fr}
  .heroInner h1{font-size:40px}
}
