:root{
  --blue-900:#0a2540;
  --blue-800:#0a3b73;
  --blue-700:#0b4aa3;
  --blue-500:#1976d2;
  --blue-400:#2a8be0;
  --blue-300:#5fb1ed;
  --blue-100:#e6f1fb;
  --blue-50:#f3f8fd;
  --ink:#0a2540;
  --ink-soft:#445872;
  --line:#dfeaf6;
  --white:#ffffff;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:'Inter',system-ui,sans-serif;
  color:var(--ink);
  background:linear-gradient(180deg,#fff 0,var(--blue-50) 360px,var(--blue-50) 100%);
  -webkit-font-smoothing:antialiased;
  line-height:1.5;
}
.page{max-width:1280px;margin:0 auto;padding:40px 32px 96px}

/* Topbar */
.topbar{
  display:flex;align-items:center;justify-content:space-between;
  padding-bottom:20px;border-bottom:1px solid var(--line);
}
.mark{display:flex;align-items:center;gap:12px;font-family:'Archivo',sans-serif;font-weight:900;font-size:17px;color:var(--blue-900);letter-spacing:-0.01em}
.mark-logo{display:block;height:50px;width:auto;flex:none}
.nav-desktop{display:flex;gap:24px;font-size:14px;color:var(--ink-soft)}
.nav-desktop a{color:inherit;text-decoration:none}
.nav-desktop a:hover{color:var(--blue-700)}
.nav-mobile{display:none;gap:8px;flex-wrap:wrap;padding-bottom:16px;margin-top:-4px;border-bottom:1px solid var(--line)}
.nav-mobile a{
  font-family:'Archivo',sans-serif;font-size:12px;font-weight:700;
  padding:6px 12px;border-radius:999px;background:#fff;
  border:1px solid var(--line);color:var(--blue-700);text-decoration:none;
}
.nav-mobile a:hover{color:var(--blue-800);border-color:var(--blue-300)}

/* Hero */
.hero{
  margin-top:56px;
  display:grid;grid-template-columns:1.15fr 0.85fr;gap:48px;align-items:end;
}
.eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  font-size:12px;font-weight:700;letter-spacing:0.16em;text-transform:uppercase;
  color:var(--blue-700);padding:6px 12px;border:1px solid var(--blue-300);
  border-radius:999px;background:#fff;
}
.pulse{width:8px;height:8px;border-radius:50%;background:var(--blue-500);box-shadow:0 0 0 0 rgba(25,118,210,.5);animation:pulse 2s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(25,118,210,.5)}70%{box-shadow:0 0 0 10px rgba(25,118,210,0)}100%{box-shadow:0 0 0 0 rgba(25,118,210,0)}}
h1{
  font-family:'Archivo',sans-serif;font-weight:900;
  font-size:clamp(40px,5.6vw,76px);line-height:0.98;letter-spacing:-0.025em;
  margin:18px 0 0;color:var(--blue-900);
}
h1 .accent{color:var(--blue-500)}
.hero p.lead{max-width:48ch;font-size:18px;color:var(--ink-soft);margin-top:20px}
.hero-meta{
  display:flex;flex-direction:column;gap:12px;padding:24px;background:#fff;
  border:1px solid var(--line);border-radius:16px;
  box-shadow:0 20px 40px -28px rgba(10,37,64,0.25);
}
.meta-row{display:flex;justify-content:space-between;font-size:14px}
.meta-row .k{color:var(--ink-soft)}
.meta-row .v{color:var(--blue-900);font-weight:600}
.meta-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:6px;padding-top:14px;border-top:1px dashed var(--line)}
.stat .big{font-family:'Archivo',sans-serif;font-weight:800;font-size:30px;color:var(--blue-700);letter-spacing:-0.02em;line-height:1}
.stat .lbl{font-size:11px;color:var(--ink-soft);font-weight:600;text-transform:uppercase;letter-spacing:0.12em;margin-top:6px}

/* Section header */
.section-bar{
  margin:88px 0 28px;
  display:flex;align-items:flex-end;justify-content:space-between;gap:24px;
  border-bottom:1px solid var(--line);padding-bottom:16px;
}
.section-bar .lead-block{display:flex;flex-direction:column;gap:6px}
.section-bar h2{
  font-family:'Archivo',sans-serif;font-weight:800;font-size:38px;
  letter-spacing:-0.02em;margin:0;color:var(--blue-900);
}
.section-num{
  font-family:'Archivo',sans-serif;font-weight:800;font-size:13px;
  color:var(--blue-500);letter-spacing:0.16em;text-transform:uppercase;
}
.section-sub{color:var(--ink-soft);font-size:15px;max-width:52ch;margin:0}
.section-meta{
  display:flex;gap:16px;align-items:center;font-size:13px;color:var(--ink-soft);
  font-family:'Archivo',sans-serif;
}
.section-meta .pill{
  background:#fff;border:1px solid var(--line);padding:6px 12px;border-radius:999px;
  color:var(--blue-700);font-weight:700;letter-spacing:0.04em;
}

/* Gemeinde block */
.gemeinde-block{margin-top:36px}
.gemeinde-head{
  display:flex;align-items:center;gap:14px;margin-bottom:18px;
}
.gem-line{width:36px;height:2px;background:var(--blue-500);border-radius:2px}
.gem-title{
  font-family:'Archivo',sans-serif;font-weight:800;font-size:22px;
  letter-spacing:-0.01em;color:var(--blue-900);margin:0;
}
.gem-count{
  font-size:12px;color:var(--ink-soft);font-weight:600;
  background:#fff;border:1px solid var(--line);padding:4px 10px;border-radius:999px;
}

/* Card grid */
.grid{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}
@media (max-width:980px){.grid{grid-template-columns:1fr}}

/* Stadtrat: mehrspaltig statt volle Breite pro Karte */
#delmenhorst ~ .gemeinde-block > .grid{
  grid-template-columns:repeat(auto-fill,minmax(min(100%,340px),1fr));
}
@media (max-width:980px){
  #delmenhorst ~ .gemeinde-block > .grid{grid-template-columns:1fr}
}

.card{
  position:relative;background:#fff;border-radius:18px;
  border:1px solid var(--line);
  box-shadow:0 18px 40px -30px rgba(10,37,64,0.25);
  padding:24px;display:flex;flex-direction:column;gap:18px;
  transition:transform .25s ease, box-shadow .25s ease;
}
.card::before{
  content:"";position:absolute;left:0;top:24px;bottom:24px;width:3px;
  background:var(--region-color,var(--blue-500));border-radius:0 3px 3px 0;
}
.card:hover{transform:translateY(-2px);box-shadow:0 28px 50px -30px rgba(10,37,64,0.35)}

.card-head{display:flex;gap:16px;align-items:flex-start}
.avatar{
  flex:none;width:64px;height:64px;border-radius:50%;
  background:linear-gradient(140deg,var(--blue-300),var(--region-color,var(--blue-700)));
  color:#fff;font-family:'Archivo',sans-serif;font-weight:800;font-size:22px;
  display:grid;place-items:center;letter-spacing:0;
  box-shadow:inset 0 -2px 8px rgba(0,0,0,0.12);
  position:relative;overflow:hidden;
}
.avatar::after{
  content:"";position:absolute;inset:0;
  background:
    repeating-linear-gradient(135deg,rgba(255,255,255,0.08) 0 6px,transparent 6px 12px);
  mix-blend-mode:overlay;
}
.avatar.has-photo{width:72px;height:72px;background:#fff;box-shadow:inset 0 0 0 2px var(--region-color,var(--blue-500))}
.avatar.has-photo::after{display:none}
.avatar.has-photo img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;border-radius:50%;display:block}

/* Featured card with full poster image */
.card.card--featured{
  padding:24px;
  overflow:hidden;
  display:flex;
  flex-direction:column;
  gap:18px;
}
.card.card--featured .featured-top{
  display:grid;
  grid-template-columns:1fr;
  gap:14px;
  align-items:flex-start;
}
.card.card--featured .poster{
  position:relative;
  background:#0a3b73;
  width:100%;
  max-width:200px;
  margin:0 auto;
  aspect-ratio:4 / 5;
  border-radius:10px;
  overflow:hidden;
  flex:none;
}
.card.card--featured .poster img{
  position:absolute;inset:0;
  display:block;width:100%;height:100%;object-fit:contain;object-position:center;
}
.poster--placeholder{
  display:grid;place-items:center;align-content:center;gap:8px;
  background:linear-gradient(140deg,var(--blue-300),var(--region-color,var(--blue-700)));
}
.poster-initials{
  font-family:'Archivo',sans-serif;font-weight:900;font-size:clamp(36px,10vw,48px);
  color:rgba(255,255,255,0.92);letter-spacing:-0.02em;
}
.poster-label{
  font-size:10px;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;
  color:rgba(255,255,255,0.78);
}
.card.card--featured .featured-body{
  display:flex;flex-direction:column;gap:14px;
  min-width:0;
}
.card.card--featured .featured-head{display:flex;flex-direction:column;gap:4px}
.card.card--featured .card-num{
  font-family:'Archivo',sans-serif;font-weight:700;font-size:11px;
  color:var(--region-color,var(--blue-500));letter-spacing:0.18em;text-transform:uppercase;
}
.card.card--featured .cname{
  font-family:'Archivo',sans-serif;font-weight:800;font-size:22px;
  line-height:1.15;letter-spacing:-0.01em;color:var(--blue-900);margin:0;
}
.cwohnort{font-size:14px;color:var(--ink-soft);font-weight:500;margin-top:2px}
.ckandidaturen{display:flex;flex-direction:column;gap:4px;margin-top:6px}
.ckandidatur{font-size:13px;color:var(--blue-700);font-weight:600;line-height:1.4}
.card.card--featured .cwohnort{font-size:13px}
.card.card--featured .ckandidaturen{margin-top:4px}
.card.card--featured .ckandidatur{font-size:12.5px}
.card.card--featured .facts{border-top:1px solid var(--line);padding-top:14px;gap:10px 22px;margin:0}
.head-text{display:flex;flex-direction:column;gap:2px;min-width:0;flex:1}
.card-num{
  font-family:'Archivo',sans-serif;font-weight:700;font-size:11px;
  color:var(--region-color,var(--blue-500));letter-spacing:0.18em;text-transform:uppercase;
}
.cname{
  font-family:'Archivo',sans-serif;font-weight:800;font-size:22px;
  line-height:1.15;letter-spacing:-0.01em;color:var(--blue-900);margin:0;
}

.facts{
  margin:0;display:grid;grid-template-columns:1fr 1fr;gap:12px 22px;
  border-top:1px solid var(--line);padding-top:16px;
}
.facts > div{display:flex;flex-direction:column;gap:2px;min-width:0}
.facts > div.full{grid-column:1/-1}
.facts dt{
  font-size:10.5px;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;
  color:var(--blue-500);margin:0;
}
.facts dd{margin:0;font-size:14px;color:var(--blue-900);font-weight:500;line-height:1.4}

.points{
  margin:0;padding:14px 16px;background:var(--blue-50);
  border-left:3px solid var(--region-color,var(--blue-500));border-radius:0 8px 8px 0;
  font-size:14.5px;color:var(--ink);line-height:1.55;
}

.hobbies{display:flex;flex-direction:column;gap:8px}
.h-label{
  font-size:10.5px;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;
  color:var(--blue-500);
}
.chips{display:flex;flex-wrap:wrap;gap:6px}
.chip{
  font-size:12px;font-weight:600;padding:5px 10px;border-radius:999px;
  background:#fff;border:1px solid var(--blue-100);color:var(--blue-700);
}

/* Wahltermin Band */
.band{
  margin-top:96px;
  background:linear-gradient(120deg,var(--blue-800),var(--blue-500));
  border-radius:24px;color:#fff;padding:48px;
  display:grid;grid-template-columns:1.4fr 1fr;gap:32px;align-items:center;
  position:relative;overflow:hidden;
}
.band::before{
  content:"";position:absolute;right:-12%;top:-30%;width:60%;height:160%;
  background:linear-gradient(180deg,rgba(255,255,255,0.10),rgba(255,255,255,0));
  transform:rotate(-12deg);
}
.band-eyebrow{
  font-size:12px;letter-spacing:0.18em;font-weight:700;
  color:rgba(255,255,255,0.7);text-transform:uppercase;
  margin-bottom:10px;position:relative;
}
.band h3{
  font-family:'Archivo',sans-serif;font-weight:900;
  font-size:clamp(28px,3.4vw,46px);line-height:1.05;letter-spacing:-0.02em;margin:0;position:relative;
}
.band p{margin:14px 0 0;color:rgba(255,255,255,0.85);max-width:50ch;font-size:16px;position:relative}
.date-card{
  background:#fff;color:var(--blue-900);border-radius:16px;padding:24px;text-align:center;
  box-shadow:0 24px 50px -20px rgba(0,0,0,0.25);position:relative;
}
.date-card .month{font-size:13px;font-weight:700;letter-spacing:0.18em;text-transform:uppercase;color:var(--blue-500)}
.date-card .day{font-family:'Archivo',sans-serif;font-weight:900;font-size:96px;line-height:1;letter-spacing:-0.04em;color:var(--blue-900);margin:4px 0}
.date-card .year{font-size:14px;color:var(--ink-soft);font-weight:500}

footer{
  margin-top:56px;padding-top:24px;border-top:1px solid var(--line);
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;
  font-size:13px;color:var(--ink-soft);
}

@media (max-width:820px){
  .hero{grid-template-columns:1fr}
  .band{grid-template-columns:1fr;padding:32px}
  .nav-desktop{display:none}
  .nav-mobile{display:flex}
  .facts{grid-template-columns:1fr}
  .page{padding:32px 20px 72px}
}

@media (max-width:640px){
  .section-bar{flex-direction:column;align-items:flex-start;gap:12px}
  .section-meta{flex-wrap:wrap;gap:8px}
  .card.card--featured .poster{max-width:280px}
}