/* Editorial Design — realschulabschluss-nachholen.de */
:root{
  --green:#89bc1f;
  --green-dark:#5d8316;
  --green-darker:#3d6919;
  --green-light:#f0f7e0;
  --ink:#1c1c1c;
  --ink-soft:#6a6a6a;
  --line:#e6e6e6;
  --bg:#fafaf7;
  --paper:#fff;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--ink);font:16px/1.65 -apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,sans-serif;-webkit-font-smoothing:antialiased}
a{color:var(--green-dark);text-decoration:none}
a:hover{text-decoration:underline}
img{max-width:100%;height:auto}

/* === HEADER === */
.bar{background:var(--paper);border-bottom:1px solid var(--line)}
.bar-inner{max-width:1240px;margin:0 auto;padding:14px 24px;display:flex;align-items:center;gap:24px}
.logo{display:flex;align-items:center;gap:12px;font-weight:800;font-size:18px;color:var(--ink);text-decoration:none}
.logo img{display:block;height:50px;width:auto}
nav.main{margin-left:auto;display:flex;gap:6px;font-size:15px;font-weight:500;align-items:center;flex-wrap:wrap}
nav.main a{color:var(--ink);padding:8px 14px;border-radius:6px}
nav.main a:hover{color:var(--green-dark);text-decoration:none;background:var(--green-light)}
nav.main a.active{background:var(--green);color:#fff}
nav.main a.active:hover{background:var(--green-dark)}
nav.main a.cta{background:var(--green);color:#fff;padding:8px 18px;border-radius:99px;font-weight:600;margin-left:8px}
nav.main a.cta:hover{background:var(--green-dark);text-decoration:none}
.nav-toggle{display:none;margin-left:auto;width:44px;height:40px;flex-direction:column;justify-content:center;gap:5px;background:#fff;border:1px solid var(--line);border-radius:9px;cursor:pointer;padding:0}
.nav-toggle span{display:block;width:20px;height:2px;background:var(--ink);margin:0 auto;border-radius:2px}

/* === HERO (Startseite) === */
.hero{background:linear-gradient(115deg,#1f3a0c 0%,#3d6919 60%,var(--green) 100%);color:#fff;padding:80px 24px 90px;position:relative;overflow:hidden}
.hero::after{content:"";position:absolute;right:-100px;top:-50px;width:500px;height:500px;background:radial-gradient(circle,rgba(255,255,255,.1),transparent 70%);pointer-events:none}
.hero-inner{max-width:1240px;margin:0 auto;position:relative}
.eyebrow{font-size:13px;letter-spacing:2px;text-transform:uppercase;opacity:.85;margin:0 0 16px;font-weight:600}
.hero-title{font-size:60px;line-height:1.05;margin:0 0 22px;max-width:900px;letter-spacing:-1px;font-weight:800}
.hero-lead{font-size:22px;line-height:1.5;max-width:720px;margin:0 0 36px;opacity:.95}
.hero-cta{display:inline-block;background:#fff;color:var(--green-dark);padding:14px 28px;border-radius:99px;font-weight:700;font-size:16px}
.hero-cta:hover{background:var(--green-light);text-decoration:none}

/* === HERO (Stadtseite, kleiner) === */
.hero-city{background:linear-gradient(135deg,#1f3a0c,#5d8316);color:#fff;padding:60px 24px 50px}
.hero-city .inner{max-width:880px;margin:0 auto}
.bc{font-size:13px;letter-spacing:1.5px;text-transform:uppercase;opacity:.8;margin:0 0 16px;font-weight:600}
.bc a{color:#cfe1a3;text-decoration:none}
.bc a:hover{color:#fff}
.city-title{font-size:46px;line-height:1.1;margin:0 0 22px;letter-spacing:-.7px;font-weight:800}
.facts{display:flex;flex-wrap:wrap;gap:22px 28px}
.fact b{display:block;font-size:11px;text-transform:uppercase;letter-spacing:1.5px;opacity:.75;margin-bottom:3px;font-weight:600}
.fact span{font-size:17px;font-weight:700}

/* === SECTION (Startseite) === */
.section{max-width:1240px;margin:0 auto;padding:70px 24px}
.section-head{text-align:center;margin-bottom:48px}
.section-head .eyebrow{color:var(--green-dark);opacity:1}
.section-head h2{font-size:40px;margin:8px 0 14px;letter-spacing:-.5px;font-weight:800;line-height:1.15}
.section-head p{font-size:18px;color:var(--ink-soft);max-width:600px;margin:0 auto}

/* Card-Grid */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.ccard{background:var(--paper);border-radius:16px;padding:32px;border:1px solid var(--line);transition:transform .2s,box-shadow .2s}
.ccard:hover{transform:translateY(-4px);box-shadow:0 16px 40px rgba(0,0,0,.08)}
.ccard .num{display:inline-block;font-size:13px;font-weight:700;color:var(--green-dark);background:var(--green-light);padding:4px 12px;border-radius:99px;margin-bottom:18px}
.ccard h3{font-size:22px;margin:0 0 10px;font-weight:700;line-height:1.25}
.ccard p{margin:0 0 16px;color:var(--ink-soft);font-size:15px}
.ccard a.more{font-weight:600;color:var(--green-dark)}
.ccard a.more::after{content:" →"}

/* Städte-Grid */
.cities-section{background:var(--paper);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.city-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border:1px solid var(--line);border-radius:12px;overflow:hidden}
.city{padding:22px 24px;border-right:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--paper);text-decoration:none;color:var(--ink);transition:background .15s}
.city:last-child{border-right:0}
.city:hover{background:var(--green-light);color:var(--green-dark);text-decoration:none}
.city b{display:block;font-weight:700;font-size:16px;margin-bottom:2px}
.city small{font-size:12px;color:var(--ink-soft)}
@media(min-width:901px){.city-grid > .city:nth-child(4n){border-right:0}}

/* === ARTICLE (Redaktion / Stadt) === */
.article{max-width:880px;margin:0 auto;padding:50px 24px 80px}
.article h1{font-size:42px;line-height:1.15;margin:0 0 18px;letter-spacing:-.5px;font-weight:800}
.article > p:first-of-type, .article .lead{font-size:21px;line-height:1.6;color:var(--ink-soft);margin:0 0 26px;font-weight:300}
.article h2{font-size:30px;margin:56px 0 16px;letter-spacing:-.4px;font-weight:800;line-height:1.2;position:relative;padding-top:14px}
.article h2::before{content:"";display:block;width:48px;height:4px;background:var(--green);margin-bottom:14px;border-radius:99px}
.article h3{font-size:22px;margin:36px 0 10px;font-weight:700}
.article h4{font-size:17px;margin:24px 0 8px;font-weight:700;color:var(--green-dark)}
.article p{margin:0 0 20px}
.article ul,.article ol{margin:0 0 22px;padding-left:24px}
.article ul li,.article ol li{margin-bottom:6px}
.article img{margin:16px 0;border-radius:8px}
.article a{text-decoration:underline;text-underline-offset:3px}
.article strong{color:var(--ink)}

/* AdSense-Inline (nach H1) */
.ad-inline{margin:0 0 36px;padding:18px;background:#fffbeb;border:1px solid #f7e3b0;border-radius:10px;text-align:center;min-height:120px}
.ad-label{display:block;font-size:10px;color:#8a7715;letter-spacing:1.5px;text-transform:uppercase;font-weight:600;margin-bottom:8px}

/* TOC */
.toc{background:var(--paper);border-radius:14px;padding:22px 26px;margin:30px 0;border:1px solid var(--line);box-shadow:0 4px 16px rgba(0,0,0,.04)}
.toc h4{margin:0 0 12px;font-size:12px;text-transform:uppercase;letter-spacing:1.5px;color:var(--green-dark);font-weight:700}
.toc ol{margin:0;padding-left:22px;font-size:16px;line-height:1.95}
.toc a{color:var(--ink)}
.toc a:hover{color:var(--green-dark)}

/* Tipp / Callout */
.callout{background:var(--green-light);border-radius:14px;padding:20px 24px;margin:24px 0;border-left:4px solid var(--green)}
.callout .label{display:inline-block;background:var(--green);color:#fff;font-size:11px;padding:3px 10px;border-radius:99px;letter-spacing:1px;text-transform:uppercase;font-weight:700;margin-bottom:8px}
.callout p{margin:0;font-size:16px}
.callout b{color:var(--green-dark)}

/* Bild-Figur */
figure.illu{margin:30px 0;padding:0}
figure.illu img{width:100%;border-radius:14px;display:block}
figure.illu figcaption{margin-top:10px;font-size:13px;color:var(--ink-soft);text-align:center}

/* === Article-Home: Volltext-Startseite === */
.article-home{max-width:880px;margin:0 auto;padding:50px 24px 80px}
.article-home > .lead{font-size:21px;line-height:1.6;color:var(--ink-soft);margin:0 0 26px;font-weight:300}
.article-home h2{font-size:30px;margin:56px 0 16px;letter-spacing:-.4px;font-weight:800;line-height:1.2;padding-top:14px}
.article-home h2::before{content:"";display:block;width:48px;height:4px;background:var(--green);margin-bottom:14px;border-radius:99px}
.article-home h3{font-size:22px;margin:36px 0 10px;font-weight:700}
.article-home h4{font-size:17px;margin:24px 0 8px;font-weight:700;color:var(--green-dark)}
.article-home p{margin:0 0 20px}
.article-home ul,.article-home ol{margin:0 0 22px;padding-left:24px}
.article-home ul li,.article-home ol li{margin-bottom:6px}
.article-home strong,.article-home b{color:var(--ink)}

/* Bild-Figur — Hero-Image im Article (volle Breite) */
.article-home figure.illu{margin:18px 0 26px}
.article-home figure.illu img{width:100%;height:auto;display:block;border-radius:12px}

/* Bild-Figur — seitlich (illu-right) — native 200px */
figure.illu.illu-right{float:right;width:200px;max-width:40%;margin:6px 0 18px 28px}
figure.illu.illu-right img{width:100%;height:auto;border-radius:10px}
@media(max-width:720px){figure.illu.illu-right{float:none;width:100%;max-width:280px;margin:18px auto;display:block}}

/* Info-Banner — zentriert, max 560px */
figure.info-banner{margin:18px 0 6px;text-align:center}
figure.info-banner img{max-width:560px;width:100%;height:auto;display:inline-block}

/* === Anbieter-Vergleich (Karten-Grid) === */
.anbieter-lead-in{font-size:16px;color:var(--ink);margin:30px 0 16px;max-width:680px;line-height:1.6}
.cta-inline-wrap{margin:18px 0 6px}
.cta-btn{display:inline-flex;align-items:center;gap:8px;background:var(--green);color:#fff;padding:14px 26px;border-radius:99px;font-weight:700;font-size:15px;text-decoration:none;line-height:1.2;box-shadow:0 6px 16px rgba(137,188,31,.32);transition:background .15s,transform .15s,box-shadow .15s;letter-spacing:.2px}
.cta-btn::after{content:"›";font-size:18px;font-weight:700;transition:transform .15s}
.cta-btn:hover{background:var(--green-dark);text-decoration:none;transform:translateY(-1px);box-shadow:0 10px 22px rgba(137,188,31,.42)}
.cta-btn:hover::after{transform:translateX(3px)}
.cta-band{margin:36px 0;padding:24px 26px;background:var(--green-light);border:1px solid var(--line);border-radius:14px;display:flex;flex-direction:column;gap:16px;align-items:flex-start}
.cta-band-text{margin:0;font-size:16px;color:var(--ink);line-height:1.6;max-width:620px}
.cta-band-actions{margin:0;display:flex;flex-wrap:wrap;align-items:center;gap:8px 18px}
.cta-compare{font-size:14px;color:var(--green-dark);text-decoration:underline;text-underline-offset:2px}
.cta-compare:hover{color:var(--green-darker)}
.weg-featured{position:relative}
.weg-badge{display:inline-block;margin-left:6px;padding:2px 9px;background:var(--green-light);color:var(--green-darker);border:1px solid var(--green);border-radius:99px;font-size:11px;font-weight:700;letter-spacing:.3px;vertical-align:middle}

/* === Content-Tabellen (schön + responsive) === */
.table-wrap{margin:24px 0;overflow-x:auto;-webkit-overflow-scrolling:touch}
.article table{border-collapse:separate;border-spacing:0;width:100%;font-size:15px;background:#fff;border:1px solid var(--line);border-radius:12px;overflow:hidden}
.article thead th{background:var(--green-light);color:var(--green-darker);text-align:left;font-weight:700;font-size:12.5px;letter-spacing:.4px;text-transform:uppercase;padding:13px 16px;border-bottom:2px solid var(--green);white-space:nowrap}
.article tbody td{padding:13px 16px;border-bottom:1px solid var(--line);vertical-align:top;line-height:1.5}
.article tbody tr:last-child td{border-bottom:none}
.article tbody tr:nth-child(even){background:#faf9f4}
.article tbody tr:hover{background:var(--green-light)}
.article table a{color:var(--green-dark);font-weight:600}

@media(max-width:640px){
  .table-wrap{overflow:visible}
  .article table{border:0;border-radius:0;background:transparent}
  .article thead{position:absolute;width:1px;height:1px;margin:-1px;padding:0;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}
  .article table,.article tbody,.article tbody tr,.article tbody td{display:block;width:100%}
  .article tbody tr{margin:0 0 16px;border:1px solid var(--line);border-radius:12px;overflow:hidden;background:#fff}
  .article tbody tr:nth-child(even){background:#fff}
  .article tbody tr:hover{background:#fff}
  .article tbody td{display:flex;justify-content:space-between;align-items:baseline;gap:16px;padding:11px 14px;border-bottom:1px solid var(--line);text-align:right}
  .article tbody td:last-child{border-bottom:0}
  .article tbody td::before{content:attr(data-label);flex:0 0 40%;text-align:left;font-weight:700;font-size:12.5px;color:var(--green-darker);text-transform:uppercase;letter-spacing:.3px}
  .article tbody td:not([data-label]){text-align:left}
}

/* === Eingebettete Rechtstexte (Impressum/Datenschutz via [show_file]) === */
.embed-legal{font-size:15px;line-height:1.7}
.embed-legal h1{font-size:24px;margin:32px 0 12px}
.embed-legal h2{font-size:20px;margin:28px 0 10px}
.embed-legal h3{font-size:16px;margin:20px 0 8px}
.embed-legal ul{margin:10px 0 10px 20px}
.embed-legal a{word-break:break-word}
.anbieter-ad-label{display:block;font-size:10px;color:#8a7715;letter-spacing:1.5px;text-transform:uppercase;font-weight:600;margin:0 0 4px}
.anbieter-disclosure{font-size:12px;color:var(--ink-soft);line-height:1.5;margin:18px 0 0;max-width:680px}
.anbieter-intro{font-size:16px;color:var(--ink-soft);margin:6px 0 24px;max-width:680px}

.anbieter-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin:0 0 40px;align-items:stretch}

.anbieter-card{position:relative;display:flex;flex-direction:column;align-items:center;text-align:center;background:var(--paper);border:1px solid var(--line);border-radius:18px;padding:34px 24px 28px;transition:transform .2s,box-shadow .2s,border-color .2s;box-shadow:0 4px 18px rgba(0,0,0,.04)}
.anbieter-card:hover{transform:translateY(-4px);box-shadow:0 18px 40px rgba(0,0,0,.08);border-color:#d8e8b6}

.anbieter-card--featured{border-color:var(--green);box-shadow:0 12px 32px rgba(137,188,31,.18);background:linear-gradient(180deg,#fbfff4 0%,var(--paper) 38%)}
.anbieter-card--featured:hover{border-color:var(--green-dark);box-shadow:0 22px 48px rgba(137,188,31,.25)}

.anbieter-badge{position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:var(--green);color:#fff;font-size:11px;letter-spacing:1.5px;text-transform:uppercase;font-weight:700;padding:6px 14px;border-radius:99px;box-shadow:0 6px 14px rgba(137,188,31,.4);white-space:nowrap}

.anbieter-logo{display:flex;align-items:center;justify-content:center;height:80px;margin:6px 0 16px}
.anbieter-logo img{width:140px;height:auto;max-height:70px;object-fit:contain;display:block}

.anbieter-name{font-size:18px;font-weight:800;margin:0 0 12px;line-height:1.25;color:var(--ink)}
.anbieter-name span{display:block;font-size:13px;font-weight:500;color:var(--ink-soft);margin-top:2px;letter-spacing:0;text-transform:none}

.anbieter-trust{display:flex;align-items:center;justify-content:center;gap:8px;margin:0 0 18px;padding:11px 12px;border-top:1px dashed var(--line);border-bottom:1px dashed var(--line);width:100%;font-size:13px;font-weight:600;color:var(--ink);text-align:center;line-height:1.3}
.anbieter-trust-ico{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;background:var(--green);color:#fff;font-size:11px;font-weight:700;flex-shrink:0}

.anbieter-features{list-style:none;padding:0;margin:0 0 22px;width:100%;text-align:left}
.anbieter-features li{position:relative;padding:6px 0 6px 26px;font-size:14px;color:var(--ink);line-height:1.4}
.anbieter-features li::before{content:"";position:absolute;left:0;top:11px;width:14px;height:8px;border-left:2.5px solid var(--green);border-bottom:2.5px solid var(--green);transform:rotate(-45deg)}

.anbieter-cta{display:inline-flex;align-items:center;justify-content:center;gap:6px;background:var(--green);color:#fff;padding:14px 26px;border-radius:99px;font-weight:700;font-size:15px;text-decoration:none;line-height:1;width:100%;box-shadow:0 6px 16px rgba(137,188,31,.32);transition:background .15s,transform .15s,box-shadow .15s;letter-spacing:.2px}
.anbieter-cta::after{content:"›";font-size:18px;font-weight:700;transition:transform .15s}
.anbieter-cta:hover{background:var(--green-dark);text-decoration:none;transform:translateY(-1px);box-shadow:0 10px 22px rgba(137,188,31,.42)}
.anbieter-cta:hover::after{transform:translateX(3px)}
.anbieter-card--featured .anbieter-cta{background:var(--green-darker)}
.anbieter-card--featured .anbieter-cta:hover{background:#2c4e12}

.anbieter-meta{margin:10px 0 0;font-size:12px;color:var(--ink-soft);letter-spacing:.3px}

.anbieter-address{font-style:normal;font-size:12px;color:var(--ink-soft);margin:0 0 16px;padding:8px 12px;background:#f9fbf4;border-radius:6px;line-height:1.5;width:100%;text-align:center;letter-spacing:.1px}

/* Responsive */
@media(max-width:980px){
  .anbieter-cards{grid-template-columns:1fr;gap:24px;max-width:480px;margin-left:auto;margin-right:auto}
  .anbieter-card{padding:32px 24px 26px}
}

/* === Adressblock (lokale Anlaufstellen) === */
.adresse-cards{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin:18px 0 32px}
.adresse-card{background:var(--paper);border:1px solid var(--line);border-radius:14px;padding:18px 20px;box-shadow:0 3px 14px rgba(0,0,0,.04)}
.adresse-rolle{font-size:11px;letter-spacing:1.2px;text-transform:uppercase;color:var(--green-dark);font-weight:700;margin:0 0 4px}
.adresse-name{font-size:16px;font-weight:700;margin:0 0 8px;line-height:1.3;color:var(--ink)}
.adresse-name a{color:var(--ink);text-decoration:none;border-bottom:1px solid var(--line)}
.adresse-name a:hover{color:var(--green-dark);border-color:var(--green)}
.adresse-meta{margin:0;font-size:14px;color:var(--ink-soft);line-height:1.5}
.adresse-meta dd{margin:0}
.adresse-tel a{color:var(--ink-soft);text-decoration:none}
.adresse-tel a:hover{color:var(--green-dark)}
@media(max-width:720px){.adresse-cards{grid-template-columns:1fr}}

/* === Pro-Contra Tabelle === */
.procon{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin:18px 0 28px}
.procon-col{padding:22px 24px;border-radius:14px;border:1px solid var(--line);background:var(--paper)}
.procon-col h4{margin:0 0 12px;font-size:15px;text-transform:uppercase;letter-spacing:1.2px;font-weight:700}
.procon-col ul{margin:0;padding-left:20px}
.procon-col li{margin-bottom:8px}
.procon-pro{background:#f4faea;border-color:#cfe1a3}
.procon-pro h4{color:var(--green-darker)}
.procon-pro li::marker{color:var(--green-dark)}
.procon-contra{background:#fdf2f0;border-color:#f1c4ba}
.procon-contra h4{color:#a13d24}
.procon-contra li::marker{color:#a13d24}
@media(max-width:720px){.procon{grid-template-columns:1fr}}

/* === Byline (Trust-Signal direkt nach H1) === */
.byline{font-size:13px;color:var(--ink-soft);margin:0 0 22px;padding:8px 14px;background:#f4faea;border-left:3px solid var(--green);border-radius:4px;display:inline-block}
.byline time{font-weight:600;color:var(--green-darker)}

/* === Callout für Infos im Body (z.B. KMK-Link) === */
.callout-info{background:#f9fbf4;border:1px solid #d8e8b6;border-radius:10px;padding:14px 18px;margin:14px 0 24px;font-size:15px;color:var(--ink)}
.callout-info a{color:var(--green-dark);font-weight:600;border-bottom:1px solid var(--green);text-decoration:none}
.callout-info a:hover{background:var(--green);color:#fff;text-decoration:none}

/* === FAQ-Block (Accordion via <details>) === */
.faq-section{margin:60px 0 20px;padding:36px 0 0;border-top:2px solid var(--line)}
.faq-section h2{font-size:28px;margin:0 0 24px;font-weight:800;letter-spacing:-.4px;padding-top:0}
.faq-section h2::before{display:none}
.faq-list{display:flex;flex-direction:column;gap:10px}
.faq-item{background:var(--paper);border:1px solid var(--line);border-radius:12px;overflow:hidden;transition:border-color .15s,box-shadow .15s}
.faq-item[open]{border-color:var(--green);box-shadow:0 8px 24px rgba(137,188,31,.08)}
.faq-item summary{list-style:none;cursor:pointer;padding:16px 56px 16px 20px;font-weight:700;font-size:16px;color:var(--ink);line-height:1.4;position:relative;user-select:none}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:"+";position:absolute;right:20px;top:50%;transform:translateY(-50%);width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:var(--green-light);color:var(--green-darker);border-radius:50%;font-size:18px;font-weight:700;line-height:1;transition:transform .2s,background .15s}
.faq-item[open] summary::after{content:"–";transform:translateY(-50%) rotate(0deg);background:var(--green);color:#fff}
.faq-item summary:hover{color:var(--green-dark)}
.faq-item summary:hover::after{background:var(--green);color:#fff}
.faq-item p{padding:0 20px 18px;margin:0;color:var(--ink);font-size:15px;line-height:1.6}

/* === Layout mit Sidebar === */
.layout-with-sidebar{
  max-width:1240px;margin:0 auto;padding:0 24px;
  display:grid;grid-template-columns:1fr 280px;gap:56px;
  align-items:stretch
}
.layout-with-sidebar > .article,
.layout-with-sidebar > .article-home{
  max-width:none;margin:0;padding-left:0;padding-right:0;min-width:0
}

/* === Sidebar — scrollt normal mit dem Article === */
.sidebar{padding-top:50px;font-size:14px}
.sidebar-inner{padding:22px 22px 24px;background:var(--paper);border:1px solid var(--line);border-radius:14px;box-shadow:0 4px 16px rgba(0,0,0,.04)}

.sidebar-block{margin-bottom:22px}
.sidebar-block:last-child{margin-bottom:0}
.sidebar-title{
  margin:0 0 10px;padding:0 6px;
  font-size:11px;letter-spacing:1.5px;text-transform:uppercase;
  color:var(--green-darker);font-weight:700
}
.sidebar-list{list-style:none;padding:0;margin:0}
.sidebar-list li{margin:0}
.sidebar-list a{
  display:block;padding:7px 12px;border-radius:8px;
  color:var(--ink);font-size:14px;line-height:1.35;
  text-decoration:none;transition:background .12s,color .12s
}
.sidebar-list a:hover{background:var(--green-light);color:var(--green-dark);text-decoration:none}
.sidebar-list a.is-active{background:var(--green);color:#fff;font-weight:600}
.sidebar-list a.is-active:hover{background:var(--green-dark);color:#fff}

/* Bundesländer-Aufklappbar */
.sidebar-collapse{margin-top:4px}
.sidebar-collapse summary{
  list-style:none;cursor:pointer;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 6px 10px;
  font-size:11px;letter-spacing:1.5px;text-transform:uppercase;
  color:var(--green-darker);font-weight:700;
  border-bottom:1px dashed var(--line);
  user-select:none
}
.sidebar-collapse summary::-webkit-details-marker{display:none}
.sidebar-collapse summary em{
  background:var(--green-light);color:var(--green-darker);
  padding:2px 8px;border-radius:99px;font-size:10px;font-style:normal;
  letter-spacing:.5px
}
.sidebar-collapse summary::after{
  content:"+";display:inline-block;margin-left:8px;
  font-size:18px;line-height:1;font-weight:700;color:var(--green-dark);
  transition:transform .15s
}
.sidebar-collapse[open] summary::after{transform:rotate(45deg)}
.sidebar-collapse summary span{flex:1}
.sidebar-collapse[open] summary{margin-bottom:6px}
.sidebar-collapse .sidebar-list{margin-top:4px}

/* Sidebar-CTA: Infomaterial-Banner — eigenständig, sticky (wandert über volle Spaltenhöhe mit) */
.sidebar-cta{position:sticky;top:24px;margin-top:24px}
.sidebar-cta-link{display:block;border-radius:10px;overflow:hidden;text-decoration:none;background:#fff;border:1px solid var(--line);transition:transform .15s,box-shadow .15s,border-color .15s}
.sidebar-cta-link:hover{transform:translateY(-2px);box-shadow:0 10px 22px rgba(137,188,31,.18);border-color:var(--green);text-decoration:none}
.sidebar-cta-link img{display:block;max-width:200px;width:100%;height:auto;margin:18px auto 14px}
.sidebar-cta-hint{display:block;padding:9px 12px;font-size:12px;font-weight:700;color:var(--green-dark);text-align:center;background:var(--green-light);letter-spacing:.2px}
.sidebar-cta-link:hover .sidebar-cta-hint{background:var(--green);color:#fff}

/* Sidebar Responsive */
@media(max-width:980px){
  .layout-with-sidebar{grid-template-columns:1fr;gap:0;padding:0}
  .layout-with-sidebar > .article,
  .layout-with-sidebar > .article-home{padding-left:24px;padding-right:24px}
  .sidebar{padding:0 24px 48px;margin-top:-16px}
  .sidebar-inner{padding:20px 20px 22px}
  .sidebar-cta{position:static}  /* Mobile: nicht sticky */
}

/* === Hero-Home Modifikator === */
.hero-home{padding:60px 24px 70px}
.hero-home .hero-title{font-size:48px;max-width:820px}
@media(max-width:720px){.hero-home .hero-title{font-size:30px}}

/* === FOOTER === */
.site-footer{background:#1c1c1c;color:#aaa;padding:50px 24px 30px;margin-top:60px}
.footer-inner{max-width:1240px;margin:0 auto;display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:32px}
.footer-col h4{color:#fff;font-size:15px;margin:0 0 10px;font-weight:700}
.footer-col h5{color:#fff;font-size:12px;letter-spacing:2px;text-transform:uppercase;margin:0 0 12px;font-weight:700}
.footer-col p.footer-tag{font-size:14px;margin:0;line-height:1.6}
.footer-col ul{list-style:none;margin:0;padding:0}
.footer-col li{margin-bottom:6px;font-size:14px}
.footer-col a{color:#cfe1a3}
.footer-bottom{max-width:1240px;margin:30px auto 0;padding-top:20px;border-top:1px solid #333;font-size:12px;opacity:.6;text-align:center}

/* === RESPONSIVE === */
@media(max-width:1000px){
  .cards{grid-template-columns:repeat(2,1fr)}
  .city-grid{grid-template-columns:repeat(2,1fr)}
  .hero-title{font-size:42px}
  .footer-inner{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:720px){
  .bar-inner{position:relative}
  .nav-toggle{display:flex}
  nav.main{display:none;position:absolute;top:100%;left:0;right:0;flex-direction:column;align-items:stretch;gap:2px;background:var(--paper);border-top:1px solid var(--line);border-bottom:1px solid var(--line);box-shadow:0 16px 30px rgba(0,0,0,.10);padding:10px 20px 16px;z-index:60}
  .bar.nav-open nav.main{display:flex}
  nav.main a{padding:12px 12px;border-radius:8px}
  nav.main a.cta{margin:8px 0 0;text-align:center}
  .site-search-wrap{display:block;margin:10px 0 0}
  #site-search{width:100%;max-width:none}
  .site-search-results{position:static;width:auto;max-width:none;margin-top:6px;box-shadow:none}
  .hero{padding:50px 20px 60px}
  .hero-title{font-size:32px}
  .hero-lead{font-size:17px}
  .section{padding:50px 20px}
  .section-head h2{font-size:30px}
  .cards{grid-template-columns:1fr}
  .city-grid{grid-template-columns:1fr}
  .article{padding:36px 20px 60px}
  .article h1, .city-title{font-size:30px}
  .article h2{font-size:22px}
  .hero-city{padding:40px 20px 36px}
  .footer-inner{grid-template-columns:1fr}
  .facts{gap:16px}
}

/* === NACHBARSTÄDTE === */
.neighbors-section{margin:48px 0 16px;padding:32px 0 0;border-top:2px solid var(--line)}
.neighbors-section h2{font-size:24px;margin:0 0 18px;font-weight:800;letter-spacing:-.3px;padding-top:0}
.neighbors-section h2::before{display:none}
.neighbors-section .city-grid{grid-template-columns:repeat(4,1fr)}
.neighbors-section .city{padding:16px 18px}
.neighbors-section .city small{display:block;margin-top:2px}
@media(max-width:900px){.neighbors-section .city-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.neighbors-section .city-grid{grid-template-columns:1fr}}

/* === Hero Bundesland→Stadt-Selektor === */
.hero-selector{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin:22px 0 12px}
.hero-selector select{font:inherit;font-size:15px;padding:13px 16px;border:1px solid var(--line);border-radius:12px;background:#fff;color:var(--ink);min-width:210px;max-width:100%;cursor:pointer}
.hero-selector select:disabled{opacity:.55;cursor:not-allowed}
.hero-selector .hero-cta{border:none;cursor:pointer}
.hero-featured{font-size:14px;color:var(--ink-soft);margin:8px 0 0}
.hero-featured a{color:var(--ink-soft);text-decoration:underline;text-underline-offset:2px}
.hero-featured a:hover{color:var(--green-dark)}

/* === Header-Suche (Autocomplete) === */
.site-search-wrap{position:relative;margin-left:14px}
#site-search{font:inherit;font-size:14px;padding:9px 14px;border:1px solid var(--line);border-radius:99px;background:#fff;width:210px;max-width:46vw}
#site-search:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 3px rgba(137,188,31,.18)}
.site-search-results{position:absolute;top:calc(100% + 6px);right:0;width:320px;max-width:80vw;background:#fff;border:1px solid var(--line);border-radius:12px;box-shadow:0 12px 32px rgba(0,0,0,.12);overflow:hidden;z-index:50}
.site-search-results a{display:flex;justify-content:space-between;align-items:baseline;gap:10px;padding:10px 14px;text-decoration:none;color:var(--ink);font-size:14px;border-bottom:1px solid var(--line)}
.site-search-results a:last-child{border-bottom:none}
.site-search-results a:hover{background:#f6faef}
.site-search-results small{color:var(--ink-soft);font-size:12px;white-space:nowrap}

/* === Städte-Verzeichnis === */
.staedte-wrap{max-width:1080px;margin:0 auto;padding:28px 24px 56px}
.staedte-filter{width:100%;font:inherit;font-size:16px;padding:15px 18px;border:1px solid var(--line);border-radius:14px;background:#fff;margin:6px 0 14px}
.staedte-filter:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 3px rgba(137,188,31,.18)}
.staedte-empty{color:var(--ink-soft);margin:0 0 18px}
.staedte-jump{display:flex;flex-wrap:wrap;gap:6px 10px;margin:0 0 28px}
.staedte-jump a{font-size:13px;color:var(--ink-soft);text-decoration:none;padding:4px 10px;border:1px solid var(--line);border-radius:99px}
.staedte-jump a:hover{border-color:var(--green);color:var(--green-dark)}
.staedte-land{margin:0 0 30px;scroll-margin-top:80px}
.staedte-land h2{font-size:19px;margin:0 0 12px;display:flex;align-items:center;gap:10px}
.staedte-land h2 a{color:var(--ink);text-decoration:none}
.staedte-land h2 a:hover{color:var(--green-dark)}
.staedte-count{font-size:12px;font-weight:600;color:var(--ink-soft);background:#f0f4e6;border-radius:99px;padding:2px 9px}
.staedte-list{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:repeat(4,1fr);gap:4px 18px}
.staedte-list a{color:var(--ink);text-decoration:none;font-size:14px;line-height:1.9;border-bottom:1px solid transparent}
.staedte-list a:hover{color:var(--green-dark);border-bottom-color:var(--green)}
@media(max-width:880px){.staedte-list{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.staedte-list{grid-template-columns:1fr}}
