/* ===========================================================================
   Elektrorettung24 — main.css  (Aesthetic: "Emergency Dispatch / Control-Panel")
   System-Font only · EIN CSS · Tokens + Base + Header + Hero + Module + Footer
   =========================================================================== */
:root{
  --c-primary:#232426; --c-primary-700:#141517; --c-primary-300:#3a3c3f;
  --c-accent:#D90812; --c-accent-700:#B00710; --c-accent-300:#ff5a52;
  --c-ink:#1a1b1d; --c-muted:#5c5f63; --c-line:#e6e7e9; --c-surface:#F6F7F8; --c-bg:#fff;
  --c-on-dark:#cfd2d6; --c-on-dark-muted:#9498a0;
  --font:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  --mono:ui-monospace,"Cascadia Code","Segoe UI Mono",Menlo,Consolas,monospace;
  --wrap:1180px; --radius:13px; --shadow:0 8px 30px rgba(20,21,23,.08);
}
*{box-sizing:border-box} html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{margin:0;font-family:var(--font);color:var(--c-ink);background:var(--c-bg);line-height:1.6;
  font-size:17px;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{color:var(--c-accent-700)}
h1,h2,h3,h4{line-height:1.15;letter-spacing:-.02em;margin:0 0 .5em}
h2{font-size:clamp(1.45rem,3.2vw,2rem);font-weight:800}
h3{font-size:1.2rem;font-weight:800}
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 20px}
.sect{padding:54px 0}
[id]{scroll-margin-top:84px}   /* Sticky-Header-Offset für Sprungmarken */
.sect--grey{background:var(--c-surface)}
.sect--dark{background:var(--c-primary);color:var(--c-on-dark)}
.sect--dark h2,.sect--dark h3{color:#fff}
.eyebrow{display:inline-flex;align-items:center;gap:8px;font:800 .74rem/1 var(--font);
  letter-spacing:.16em;text-transform:uppercase;color:var(--c-accent-700);margin-bottom:.7em}
.sect--dark .eyebrow{color:var(--c-accent-300)}
.lede{font-size:1.08rem;color:var(--c-primary-300);max-width:60ch}
.sect--dark .lede{color:var(--c-on-dark)}
.center{text-align:center}.center .lede{margin-inline:auto}
.skip{position:absolute;left:-999px}.skip:focus{left:8px;top:8px;background:#fff;padding:8px 14px;z-index:200;border-radius:8px}

/* live dot */
.live{display:inline-flex;align-items:center;gap:8px;font:800 .72rem/1 var(--font);
  letter-spacing:.14em;text-transform:uppercase;color:var(--c-accent-300)}
.live .dot{width:9px;height:9px;border-radius:50%;background:#ff3b30;animation:pulse 1.9s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(255,59,48,.6)}70%{box-shadow:0 0 0 9px rgba(255,59,48,0)}100%{box-shadow:0 0 0 0 rgba(255,59,48,0)}}
@media(prefers-reduced-motion:reduce){.live .dot{animation:none}}

/* hazard divider */
.hazard{height:7px;background:repeating-linear-gradient(135deg,#141517 0 14px,#D90812 14px 28px)}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;font-weight:800;
  border-radius:11px;padding:15px 22px;text-decoration:none;font-size:1.02rem;border:0;cursor:pointer;
  letter-spacing:.01em;transition:transform .08s ease,box-shadow .2s ease}
.btn:active{transform:translateY(1px)}
.btn-notruf{background:var(--c-accent-700);color:#fff;box-shadow:0 6px 18px rgba(176,7,16,.32)}
.btn-notruf:hover{background:#9c0610}
.btn-ghost{background:transparent;color:var(--c-primary);border:2px solid var(--c-primary)}
.btn-ghost.on-dark{color:#fff;border-color:rgba(255,255,255,.55)}
.btn-block{width:100%}
.cta-row{display:flex;gap:12px;flex-wrap:wrap;margin-top:22px}

/* ---------- icon bullets ---------- */
ul.bul{list-style:none;padding:0;margin:18px 0 0;display:grid;gap:11px}
ul.bul li{display:flex;align-items:flex-start;gap:11px;font-weight:600}
ul.bul svg{flex:0 0 22px;width:22px;height:22px;margin-top:2px;stroke:var(--c-accent);fill:none}
.on-dark ul.bul li,.sect--dark ul.bul li{color:#eef0f2}

/* ===================== HEADER ===================== */
.topbar{background:var(--c-primary-700);color:#fff;font-size:.82rem;font-weight:600}
.topbar .in{max-width:var(--wrap);margin:0 auto;padding:8px 20px;display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.topbar .ph{margin-left:auto;color:#fff;text-decoration:none;font-weight:800;white-space:nowrap}
.topbar .live{color:var(--c-accent-300)}
.site-header{background:var(--c-primary);position:sticky;top:0;z-index:90}
.site-header .in{max-width:var(--wrap);margin:0 auto;padding:11px 20px;display:flex;align-items:center;gap:14px}
.brand{display:flex;align-items:center;gap:11px;text-decoration:none}
.brand img{width:42px;height:42px}
.brand .bn{font-weight:850;font-size:1.18rem;color:#fff;letter-spacing:-.01em}
.brand .bn .r{color:var(--c-accent)}
.nav{margin-left:auto;display:flex;gap:20px;align-items:center}
.nav a{color:var(--c-on-dark);text-decoration:none;font-weight:600;font-size:.95rem}
.nav a:hover{color:#fff}
.header-cta{background:var(--c-accent-700);color:#fff;padding:11px 17px;border-radius:9px;font-weight:800;
  text-decoration:none;font-size:.92rem;white-space:nowrap}
.header-cta:hover{background:#9c0610}
.burger{display:none;margin-left:auto;background:transparent;border:0;width:44px;height:44px;cursor:pointer;
  flex-direction:column;justify-content:center;gap:5px;padding:0}
.burger span{display:block;height:3px;width:26px;background:#fff;border-radius:2px;transition:.25s}
.burger[aria-expanded=true] span:nth-child(1){transform:translateY(8px) rotate(45deg)}
.burger[aria-expanded=true] span:nth-child(2){opacity:0}
.burger[aria-expanded=true] span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}
@media(max-width:860px){
  .nav{position:fixed;inset:auto 0 0 0;top:var(--hdr-h,108px);background:var(--c-primary);
    flex-direction:column;align-items:stretch;gap:0;padding:8px 0 18px;transform:translateY(-130%);
    transition:transform .3s ease;box-shadow:0 18px 30px rgba(0,0,0,.4);max-height:calc(100vh - var(--hdr-h,108px));overflow:auto}
  .nav.open{transform:translateY(0)}
  .nav a{padding:14px 22px;border-bottom:1px solid rgba(255,255,255,.08);font-size:1.05rem}
  .nav .header-cta{margin:14px 22px 0;text-align:center}
  .burger{display:flex}
}
@media(max-width:380px){.brand .bn{font-size:1.02rem}}

/* ===================== HERO (V1 full-bleed) ===================== */
.hero{position:relative;color:#fff;isolation:isolate}
.hero__img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:-2}
.hero__ov{position:absolute;inset:0;z-index:-1;
  background:linear-gradient(90deg,rgba(20,21,23,.94) 0%,rgba(20,21,23,.8) 44%,rgba(20,21,23,.34) 100%)}
.hero__in{max-width:var(--wrap);margin:0 auto;padding:48px 20px 40px}
.hero__col{max-width:660px}
.hero h1{font-size:clamp(1.85rem,5vw,3rem);font-weight:850;line-height:1.05;margin:.3em 0}
.hero h1 .r{color:var(--c-accent-300)}
.hero .lede{color:#d3d6da}
.hero .eyebrow{color:var(--c-accent-300)}
.statbar{display:flex;flex-wrap:wrap;border-top:1px solid rgba(255,255,255,.18);margin-top:26px;max-width:660px}
.statbar .s{flex:1;min-width:90px;padding:14px 14px 6px}
.statbar .s:first-child{padding-left:0}
.statbar .s+.s{border-left:1px solid rgba(255,255,255,.18)}
.statbar .n{font-family:var(--mono);font-weight:700;font-size:1.2rem;color:#fff}
.statbar .n .r{color:var(--c-accent-300)}
.statbar .l{font-size:.72rem;letter-spacing:.05em;text-transform:uppercase;color:#a7abb0;margin-top:3px}

/* ===================== generic modules ===================== */
.grid{display:grid;gap:20px}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
@media(max-width:820px){.grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}

.card{background:#fff;border:1px solid var(--c-line);border-radius:var(--radius);padding:22px;box-shadow:var(--shadow)}
.card h3{margin-bottom:.35em}
.card .ic{width:42px;height:42px;border-radius:10px;background:rgba(217,8,18,.1);display:flex;align-items:center;justify-content:center;margin-bottom:12px}
.card .ic svg{width:24px;height:24px;stroke:var(--c-accent);fill:none}

/* step timeline */
.steps{counter-reset:s;display:grid;gap:18px}
.steps .step{display:flex;gap:16px;align-items:flex-start}
.steps .step .num{counter-increment:s;flex:0 0 46px;height:46px;border-radius:12px;background:var(--c-primary);
  color:#fff;font-family:var(--mono);font-weight:700;font-size:1.2rem;display:flex;align-items:center;justify-content:center}
.steps .step .num::before{content:counter(s,decimal-leading-zero)}
.steps .step h3{margin:.1em 0 .25em}

/* do / dont */
.dodont{display:grid;grid-template-columns:1fr 1fr;gap:18px}
@media(max-width:620px){.dodont{grid-template-columns:1fr}}
.dd{border-radius:var(--radius);padding:22px;border:1px solid var(--c-line)}
.dd--do{background:#f1f8f2;border-color:#cfe8d3}
.dd--dont{background:#fdf1f1;border-color:#f3cccc}
.dd h3{display:flex;align-items:center;gap:8px}
.dd ul{list-style:none;padding:0;margin:10px 0 0;display:grid;gap:9px}
.dd li{display:flex;gap:9px;align-items:flex-start;font-weight:500}
.dd--do li::before{content:"✓";color:#1f9d3a;font-weight:800}
.dd--dont li::before{content:"✕";color:var(--c-accent);font-weight:800}

/* split text+image */
.split{display:grid;grid-template-columns:1fr 1fr;gap:34px;align-items:center}
.split img{border-radius:var(--radius);box-shadow:var(--shadow);width:100%;object-fit:cover}
@media(max-width:760px){.split{grid-template-columns:1fr;gap:22px}}

/* stat band */
.statband{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border:1px solid rgba(255,255,255,.16);border-radius:var(--radius);overflow:hidden}
.statband .s{padding:24px 18px;text-align:center}
.statband .s+.s{border-left:1px solid rgba(255,255,255,.16)}
.statband .n{font-family:var(--mono);font-weight:700;font-size:1.9rem;color:#fff}
.statband .n .r{color:var(--c-accent-300)}
.statband .l{color:var(--c-on-dark-muted);font-size:.82rem;margin-top:4px}
@media(max-width:620px){.statband{grid-template-columns:1fr 1fr}.statband .s:nth-child(3){border-left:0}}

/* FAQ accordion */
.faq{display:grid;gap:12px;max-width:880px;margin:0 auto}
.faq details{background:#fff;border:1px solid var(--c-line);border-radius:var(--radius);overflow:hidden}
.faq summary{cursor:pointer;padding:18px 50px 18px 20px;font-weight:700;list-style:none;position:relative}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";position:absolute;right:20px;top:16px;font-size:1.5rem;color:var(--c-accent);font-weight:400}
.faq details[open] summary::after{content:"–"}
.faq .a{padding:0 20px 18px;color:var(--c-primary-300)}

/* PDF offer */
.pdf-offer{display:flex;gap:18px;align-items:center;flex-wrap:wrap;background:#fff;border:1px dashed var(--c-accent);
  border-radius:var(--radius);padding:22px}
.pdf-offer .pic{flex:0 0 64px;height:64px;border-radius:10px;background:rgba(217,8,18,.1);display:flex;align-items:center;justify-content:center}
.pdf-offer .pic svg{width:34px;height:34px;stroke:var(--c-accent);fill:none}
.pdf-offer .tx{flex:1;min-width:200px}
.pdf-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px}
.pdf-card{display:flex;gap:12px;align-items:center;background:#fff;border:1px solid var(--c-line);border-radius:12px;padding:14px;text-decoration:none;color:var(--c-ink)}
.pdf-card:hover{border-color:var(--c-accent)}
.pdf-card svg{width:28px;height:28px;stroke:var(--c-accent);fill:none;flex:0 0 28px}

/* ===================== notruf banners (2 variants) ===================== */
.notruf-a{position:relative;color:#fff;border-radius:var(--radius);overflow:hidden;padding:40px 28px;isolation:isolate}
.notruf-a img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:-2}
.notruf-a::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(90deg,rgba(176,7,16,.93),rgba(20,21,23,.82))}
.notruf-a h3{font-size:1.5rem}
/* CTA auf rotem Banner A: weiß mit rotem Text, damit er sich klar abhebt */
.notruf-a .btn-notruf{background:#fff;color:var(--c-accent-700);box-shadow:0 6px 18px rgba(0,0,0,.25)}
.notruf-a .btn-notruf:hover{background:#f1f1f1}
.notruf-b{display:grid;grid-template-columns:1.1fr .9fr;gap:0;border-radius:var(--radius);overflow:hidden;border:1px solid var(--c-line)}
.notruf-b .tx{background:var(--c-primary);color:#fff;padding:32px 28px}
.notruf-b .md{position:relative;min-height:220px}
.notruf-b .md img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
@media(max-width:680px){.notruf-b{grid-template-columns:1fr}.notruf-b .md{min-height:170px}}

/* ===================== rating strip + badge ===================== */
.rating-strip{background:#1c1d1f;padding:24px 18px;display:flex;justify-content:center}
.rating-badge{display:inline-flex;align-items:center;gap:13px;background:#fff;border-radius:999px;padding:11px 20px;
  text-decoration:none;color:#1a1b1d;box-shadow:0 4px 14px rgba(0,0,0,.18)}
.rating-badge .stars{color:#FCC53D;letter-spacing:1px;font-size:1.05rem}
.rating-badge b{font-weight:800}.rating-badge .meta{color:#5c5f63;font-size:.78rem}

/* ===================== blog teasers ===================== */
.bt-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media(max-width:820px){.bt-grid{grid-template-columns:1fr}}
.bt{background:#fff;border:1px solid var(--c-line);border-radius:var(--radius);overflow:hidden;text-decoration:none;color:var(--c-ink);box-shadow:var(--shadow);transition:transform .15s ease}
.bt:hover{transform:translateY(-3px)}
.bt img{aspect-ratio:16/9;object-fit:cover;width:100%}
.bt .b{padding:16px 18px}.bt .b h3{font-size:1.05rem;margin:0 0 .3em}
.bt .b span{color:var(--c-muted);font-size:.82rem}

/* ===================== FOOTER (Footer 2) ===================== */
.notruf-band{background:var(--c-accent-700);color:#fff;padding:22px 20px}
.notruf-band .in{max-width:var(--wrap);margin:0 auto;display:flex;align-items:center;gap:18px;flex-wrap:wrap;justify-content:center;text-align:center}
.notruf-band b{font-size:1.12rem}
.notruf-band .b{background:#fff;color:var(--c-accent-700);font-weight:800;padding:12px 20px;border-radius:10px;text-decoration:none;white-space:nowrap}
.site-footer{background:var(--c-primary);color:var(--c-on-dark);border-top:4px solid var(--c-accent);font-size:.93rem}
.site-footer a{color:var(--c-on-dark);text-decoration:none}.site-footer a:hover{color:#fff}
.site-footer .in{max-width:var(--wrap);margin:0 auto;padding:42px 20px}
.foot-cols{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.4fr;gap:30px}
@media(max-width:760px){.foot-cols{grid-template-columns:1fr 1fr}}
@media(max-width:480px){.foot-cols{grid-template-columns:1fr}}
.site-footer h4{color:#fff;font-size:.82rem;letter-spacing:.12em;text-transform:uppercase;margin:0 0 14px}
.site-footer .bn{font-weight:850;font-size:1.3rem;color:#fff}.site-footer .bn .r{color:var(--c-accent)}
.site-footer ul{list-style:none;padding:0;margin:0;display:grid;gap:9px}
.foot-tel{display:inline-flex;align-items:center;gap:9px;color:#fff;font-weight:800;font-size:1.12rem;margin-top:8px;text-decoration:none}
.chips{display:flex;flex-wrap:wrap;gap:8px}
.chips a{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.1);padding:6px 11px;border-radius:7px;font-size:.84rem}
.chips a:hover{background:rgba(217,8,18,.22);border-color:var(--c-accent);color:#fff}
/* Footer „Beliebte Städte": max. ~4 Zeilen (überzählige Links bleiben im HTML für interne Verlinkung) */
.chips--clamp{max-height:9.2em;overflow:hidden}
.foot-disc{border-top:1px solid rgba(255,255,255,.1);margin-top:28px;padding-top:20px;color:var(--c-on-dark-muted);font-size:.78rem;line-height:1.65}
.foot-bottom{background:var(--c-primary-700);color:var(--c-on-dark-muted);font-size:.8rem;padding:14px 20px;text-align:center}
.foot-bottom a{color:#c9ccd1}

/* ===================== sticky mobile CTA ===================== */
.sticky-notruf{display:none}
@media(max-width:860px){
  .sticky-notruf{display:flex;position:fixed;left:0;right:0;bottom:0;z-index:120;gap:0;
    box-shadow:0 -6px 20px rgba(0,0,0,.18)}
  .sticky-notruf a{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:14px;font-weight:800;text-decoration:none}
  .sticky-notruf .call{background:var(--c-accent-700);color:#fff}
  .sticky-notruf .help{background:var(--c-primary);color:#fff}
  body{padding-bottom:58px}
}

/* ===================== soforthilfe wizard ===================== */
.wizard{background:#fff;border:1px solid var(--c-line);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;max-width:760px;margin:0 auto}
.wizard__head{background:var(--c-primary);color:#fff;padding:18px 22px;display:flex;align-items:center;gap:12px}
.wizard__head .live{color:var(--c-accent-300)}
.wizard__body{padding:24px 22px}
.wizard__q{font-weight:800;font-size:1.15rem;margin:0 0 16px}
.wizard__opts{display:grid;gap:10px}
.wizard__opt{text-align:left;background:var(--c-surface);border:1px solid var(--c-line);border-radius:10px;padding:14px 16px;font-weight:600;cursor:pointer;font-size:1rem;display:flex;align-items:center;gap:10px;transition:.15s}
.wizard__opt:hover{border-color:var(--c-accent);background:#fff}
.wizard__opt .k{font-family:var(--mono);color:var(--c-accent-700);font-weight:700}
.wizard__step{display:none}.wizard__step.active{display:block;animation:fade .25s ease}
@keyframes fade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.wizard__result{background:#fdf1f1;border:1px solid #f3cccc;border-radius:10px;padding:18px;margin-bottom:16px}
.wizard__result h4{margin:0 0 8px;color:var(--c-accent-700)}
.wizard__steps-list{list-style:none;padding:0;margin:0 0 16px;display:grid;gap:8px}
.wizard__steps-list li{display:flex;gap:10px;align-items:flex-start}
.wizard__steps-list .n{font-family:var(--mono);color:var(--c-accent-700);font-weight:700}
.wizard__back{background:transparent;border:0;color:var(--c-muted);cursor:pointer;font-size:.86rem;margin-top:6px;text-decoration:underline}
.wizard__disclaimer{color:var(--c-muted);font-size:.76rem;margin-top:14px;padding-top:12px;border-top:1px solid var(--c-line)}

/* ===================== generated rich content (Stadt/Region) ===================== */
.rich-card{padding:30px 36px;border-top:4px solid var(--c-accent)}
@media(max-width:560px){.rich-card{padding:24px 20px}}
/* split reverse (Bild links) */
.split--rev > div:first-child{order:2}
@media(max-width:760px){.split--rev > div:first-child{order:0}}
/* CTA-Band zwischen Rich-Abschnitten */
.rich-cta{display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap;
  background:var(--c-primary);color:#fff;border-radius:var(--radius);padding:22px 30px;border-left:5px solid var(--c-accent)}
.rich-cta strong{display:block;font-size:1.18rem}
.rich-cta span{color:var(--c-on-dark-muted);font-size:.92rem}
.rich-cta .btn-notruf{background:#fff;color:var(--c-accent-700)}
/* Callout-Card (getönt) */
.rich-callout{background:#fff;border:1px solid var(--c-line);border-left:5px solid var(--c-accent);
  border-radius:var(--radius);padding:28px 32px;box-shadow:var(--shadow)}
.sect--grey .rich-callout{background:#fff}
@media(max-width:560px){.rich-callout{padding:22px 20px}}
.rich{font-size:1.02rem}
.rich h3{font-size:1.22rem;font-weight:800;margin:1.4em 0 .4em;color:var(--c-primary);position:relative;padding-left:16px}
.rich h3::before{content:"";position:absolute;left:0;top:.18em;bottom:.18em;width:5px;border-radius:3px;background:var(--c-accent)}
.rich p{margin:.6em 0}
.rich ul.check-list,ul.check-list{list-style:none;padding:0;margin:16px 0;display:grid;gap:10px}
.rich ul.check-list li,ul.check-list li{position:relative;padding-left:32px;font-weight:500}
.rich ul.check-list li::before,ul.check-list li::before{content:"";position:absolute;left:0;top:2px;width:20px;height:20px;border-radius:50%;
  background:rgba(217,8,18,.1) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M6 12.5l3.5 3.5L18 7.5' fill='none' stroke='%23D90812' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") center/13px no-repeat}
.rich a{color:var(--c-accent-700);font-weight:600}

/* region hero (BL/LK) */
.rhero{position:relative;color:#fff;isolation:isolate}
.rhero__img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:-2}
.rhero__ov{position:absolute;inset:0;z-index:-1;background:linear-gradient(90deg,rgba(20,21,23,.93) 0%,rgba(20,21,23,.78) 50%,rgba(20,21,23,.45) 100%)}
.rhero__in{max-width:var(--wrap);margin:0 auto;padding:46px 20px 38px;max-width:760px}
.rhero h1{font-size:clamp(1.7rem,4.4vw,2.6rem);font-weight:850;margin:.3em 0;line-height:1.08}
.rhero h1 .r{color:var(--c-accent-300)}
.city-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:10px;margin-top:20px}
.city-grid a{display:flex;align-items:center;gap:9px;background:#fff;border:1px solid var(--c-line);border-radius:10px;
  padding:12px 14px;text-decoration:none;color:var(--c-ink);font-weight:600;transition:.15s}
.city-grid a:hover{border-color:var(--c-accent);box-shadow:var(--shadow);transform:translateY(-2px)}
.city-grid a::before{content:"⚡";color:var(--c-accent)}

/* Stadt-Feature-Karten (Region-Seiten mit wenigen Städten, z.B. Stadtstaat Bremen) */
.city-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:18px;margin-top:20px}
.city-cards a{display:block;text-decoration:none;color:var(--c-ink);background:#fff;border:1px solid var(--c-line);
  border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);transition:transform .15s ease}
.city-cards a:hover{transform:translateY(-3px)}
.city-cards img{width:100%;aspect-ratio:16/10;object-fit:cover;display:block}
.city-cards .b{padding:15px 18px}
.city-cards h3{margin:0 0 .15em;font-size:1.12rem}
.city-cards .sub{color:var(--c-muted);font-size:.86rem}
.city-cards .go{display:inline-flex;align-items:center;gap:6px;margin-top:10px;color:var(--c-accent-700);font-weight:800;font-size:.9rem}

/* breadcrumb-less drill-up block */
.drillup{display:flex;flex-wrap:wrap;gap:8px;align-items:center;color:var(--c-muted);font-size:.9rem}
.drillup a{color:var(--c-accent-700);text-decoration:none;font-weight:600}
.ortsteil-note{color:var(--c-muted);font-size:.92rem}
