/* ============================================================
   stromvergleich-dresden.de — Main Stylesheet
   Generated from actual template class names
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Bricolage+Grotesque:opsz,wght@12..96,400;12..96,600;12..96,700;12..96,800&family=Hanken+Grotesk:wght@400;500;600;700&family=JetBrains+Mono:wght@400;600&display=swap');

/* ── Reset ───────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--font-body);font-size:var(--text-base);
  line-height:1.65;color:var(--color-text);background:var(--color-bg);
  display:flex;flex-direction:column;min-height:100vh;
}
main{flex:1}
img{max-width:100%;height:auto;display:block}
a{color:var(--color-primary);text-decoration:none}
a:hover{text-decoration:underline}
ul{list-style:none}
h1,h2,h3,h4{font-family:var(--font-display);font-weight:700;line-height:1.2;color:var(--color-heading)}
h1{font-size:clamp(1.8rem,4vw,2.8rem)}
h2{font-size:clamp(1.4rem,3vw,2rem)}
h3{font-size:clamp(1rem,2vw,1.3rem)}
p{margin-bottom:1rem}
p:last-child{margin-bottom:0}
.mono{font-family:var(--font-mono)}

/* ── Skip link ───────────────────────────────────────────── */
.skip-link{position:absolute;left:-9999px;top:1rem;background:var(--color-primary);color:#fff;padding:.5rem 1rem;border-radius:var(--radius-sm);font-weight:600;z-index:9999}
.skip-link:focus{left:1rem}

/* ── Container / Layout ──────────────────────────────────── */
.container{width:100%;max-width:var(--container-max);margin:0 auto;padding:0 1.25rem}
.section{padding:4rem 0}
.section-dark{background:var(--color-navy);color:#fff}
.section-dark h2,.section-dark h3{color:#fff}
.section-light{background:var(--color-surface-muted)}
.section-header{margin-bottom:2.5rem}
.section-header-light h2,.section-header-light p{color:#fff}
.section-header-light p{color:rgba(255,255,255,.7)}
.section-cta{margin-top:2rem;text-align:center}

/* ── Buttons ─────────────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;gap:.5rem;
  padding:.75rem 1.5rem;border-radius:var(--radius-md);
  font-family:var(--font-body);font-weight:600;font-size:.95rem;
  border:2px solid transparent;cursor:pointer;
  transition:all .2s;white-space:nowrap;text-decoration:none;
}
.btn:hover{text-decoration:none}
.btn-primary{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}
.btn-primary:hover{background:var(--color-primary-dark);border-color:var(--color-primary-dark);transform:translateY(-1px);box-shadow:0 4px 16px rgba(11,107,83,.3)}
.btn-volt{background:var(--color-lime);color:var(--color-navy);border-color:var(--color-lime)}
.btn-volt:hover{background:var(--color-lime-dark);transform:translateY(-1px)}
.btn-outline{background:transparent;color:var(--color-primary);border-color:var(--color-primary)}
.btn-outline:hover{background:var(--color-primary);color:#fff}
.btn-ghost{background:transparent;color:var(--color-text);border-color:var(--color-border)}
.btn-ghost:hover{background:var(--color-surface-muted)}
.btn-sm{padding:.5rem 1rem;font-size:.875rem}
.btn-lg{padding:1rem 2rem;font-size:1.05rem}
.btn-block{width:100%;justify-content:center}

/* ── Badges ──────────────────────────────────────────────── */
.badge{display:inline-flex;align-items:center;gap:.3rem;padding:.2rem .6rem;border-radius:var(--radius-full);font-size:.75rem;font-weight:600}
.badge-oeko{background:#dcfce7;color:#166534}
.badge-default{background:var(--color-surface-muted);color:var(--color-text-muted)}
.badge-green{background:#dcfce7;color:#166534}
.badge-lime{background:var(--color-lime);color:var(--color-navy)}
.badge-blue{background:#dbeafe;color:#1e40af}
.badge-gray{background:var(--color-surface-muted);color:var(--color-text-muted)}

/* ══════════════════════════════════════════════════════════
   HEADER
   .site-header > .container.header-inner
     .logo | nav.main-nav ul li.has-dropdown ul.dropdown
     a.header-cta | button.nav-toggle
   ══════════════════════════════════════════════════════════ */
.site-header{background:var(--color-navy);position:sticky;top:0;z-index:1000;box-shadow:0 2px 12px rgba(0,0,0,.15)}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:var(--header-h);gap:1rem}
.logo{display:flex;align-items:center;flex-shrink:0;text-decoration:none}
.logo:hover{text-decoration:none}

.main-nav{flex:1;display:flex;justify-content:center}
.main-nav>ul{display:flex;align-items:center;gap:.25rem;list-style:none}
.main-nav>ul>li>a{
  display:flex;align-items:center;gap:.25rem;
  color:rgba(255,255,255,.8);font-size:.9rem;font-weight:500;
  padding:.5rem .75rem;border-radius:var(--radius-sm);transition:all .15s;white-space:nowrap;
}
.main-nav>ul>li>a:hover{color:#fff;background:rgba(255,255,255,.1);text-decoration:none}

.has-dropdown{position:relative}
.has-dropdown>a::after{content:'▾';font-size:.65rem;opacity:.7;margin-left:.25rem}
.dropdown{
  position:absolute;top:calc(100% + .5rem);left:50%;transform:translateX(-50%);
  background:#fff;border-radius:var(--radius-md);
  box-shadow:var(--shadow-lg);border:1px solid var(--color-border);
  padding:.5rem;min-width:180px;
  opacity:0;visibility:hidden;transition:all .15s;z-index:100;
  list-style:none;max-height:70vh;overflow-y:auto;
}
.has-dropdown:hover .dropdown,.has-dropdown:focus-within .dropdown{opacity:1;visibility:visible}
.dropdown li a{display:block;padding:.45rem .75rem;color:var(--color-text);font-size:.875rem;border-radius:var(--radius-sm)}
.dropdown li a:hover{background:var(--color-surface-muted);color:var(--color-primary);text-decoration:none}

.header-cta{flex-shrink:0}
.nav-toggle{display:none;background:none;border:none;cursor:pointer;padding:.5rem;color:#fff;flex-direction:column;gap:5px}
.nav-toggle span{display:block;width:22px;height:2px;background:currentColor;border-radius:2px;transition:all .2s}

/* ══════════════════════════════════════════════════════════
   COOKIE BANNER
   .cookie-banner > .cookie-inner > p + .cookie-actions
   ══════════════════════════════════════════════════════════ */
.cookie-banner{position:fixed;bottom:0;left:0;right:0;background:var(--color-navy);color:#fff;padding:1rem 0;z-index:9999;border-top:3px solid var(--color-lime)}
.cookie-inner{max-width:var(--container-max);margin:0 auto;padding:0 1.25rem;display:flex;align-items:center;gap:1.5rem;flex-wrap:wrap}
.cookie-inner p{flex:1;min-width:200px;font-size:.875rem;line-height:1.5}
.cookie-inner a{color:var(--color-lime)}
.cookie-actions{display:flex;gap:.75rem;flex-shrink:0}

/* ══════════════════════════════════════════════════════════
   HERO
   ══════════════════════════════════════════════════════════ */
.hero{
  background:linear-gradient(135deg,var(--color-navy) 0%,#0d2d42 55%,var(--color-primary-dark) 100%);
  color:#fff;padding:4rem 0 3rem;position:relative;overflow:hidden;
}
.hero::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background:url("data:image/svg+xml,%3Csvg width='60' height='60' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M0 60L60 0' stroke='rgba(200,242,92,.04)' stroke-width='1'/%3E%3C/svg%3E") repeat;
}
.hero-inner{position:relative;z-index:1;display:grid;grid-template-columns:1fr 360px;gap:3rem;align-items:center}

.hero-badge{
  display:inline-flex;align-items:center;gap:.5rem;
  background:rgba(200,242,92,.15);border:1px solid rgba(200,242,92,.3);
  border-radius:var(--radius-full);padding:.35rem .9rem;
  font-family:var(--font-mono);font-size:.72rem;color:var(--color-lime);
  letter-spacing:.08em;text-transform:uppercase;margin-bottom:1.25rem;
}
.hero h1{font-size:clamp(2rem,4.5vw,3rem);font-weight:800;color:#fff;margin-bottom:1rem;line-height:1.15}
.hero-savings{color:var(--color-lime)}
.hero-sub{font-size:1rem;color:rgba(255,255,255,.75);margin-bottom:2rem;line-height:1.7}
.hero-sub strong{color:#fff}

.hero-stats{display:flex;gap:2rem;flex-wrap:wrap}
.hero-stat{display:flex;flex-direction:column}
.stat-num{font-family:var(--font-mono);font-size:1.5rem;font-weight:600;color:var(--color-lime)}
.stat-label{font-size:.8rem;color:rgba(255,255,255,.6)}

/* Hero visual right side */
.hero-visual{
  display:flex;flex-direction:column;align-items:center;gap:1rem;
  background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);
  border-radius:var(--radius-xl);padding:1.75rem;
}
.hero-city-badge{display:flex;flex-direction:column;align-items:center;gap:.5rem;margin-bottom:.5rem}
.hero-city-badge span{font-family:var(--font-display);font-weight:700;font-size:1.2rem;color:#fff}
.price-bubble{
  width:100%;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);
  border-radius:var(--radius-md);padding:.875rem 1rem;
  display:flex;align-items:center;justify-content:space-between;
}
.price-bubble.grundversorger{border-color:rgba(255,100,100,.3);background:rgba(200,57,26,.08)}
.price-bubble.wechsel{border-color:rgba(200,242,92,.3);background:rgba(200,242,92,.08)}
.price-label{font-size:.8rem;color:rgba(255,255,255,.7)}
.price-value{font-family:var(--font-mono);font-weight:600;color:#fff;font-size:1.1rem}
.price-bubble.wechsel .price-value{color:var(--color-lime)}
.savings-arrow{
  display:flex;align-items:center;gap:.5rem;
  font-family:var(--font-mono);font-size:.85rem;color:var(--color-lime);font-weight:600;
}

/* ══════════════════════════════════════════════════════════
   VERGLEICHSFORMULAR
   ══════════════════════════════════════════════════════════ */
.compare-section{padding:3rem 0}
.compare-card{
  background:#fff;border-radius:var(--radius-xl);
  box-shadow:var(--shadow-lg);border:1.5px solid var(--color-border);
  overflow:hidden;max-width:860px;margin:0 auto;
}
.compare-card-header{
  background:linear-gradient(135deg,var(--color-navy),var(--color-primary-dark));
  color:#fff;padding:1.75rem 2rem;
}
.compare-card-header h2{color:#fff;margin-bottom:.35rem;font-size:1.4rem}
.compare-card-header p{color:rgba(255,255,255,.75);font-size:.9rem;margin:0}

.compare-form{padding:1.75rem 2rem}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem}
.form-group{display:flex;flex-direction:column;gap:.4rem}
.form-group label{
  font-size:.82rem;font-weight:600;color:var(--color-text-muted);
  text-transform:uppercase;letter-spacing:.05em;
  display:flex;align-items:center;gap:.35rem;
}
.form-group input,.form-group select{
  padding:.75rem 1rem;border:1.5px solid var(--color-border);
  border-radius:var(--radius-md);font-family:var(--font-body);
  font-size:1rem;color:var(--color-text);background:#fff;
  transition:border-color .15s,box-shadow .15s;
}
.form-group input:focus,.form-group select:focus{
  outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(11,107,83,.12);
}
.form-group input::placeholder{color:#bbb}
.form-submit{margin-top:.5rem}
.form-hint{font-size:.78rem;color:var(--color-text-muted);margin-top:.75rem;display:flex;align-items:center;gap:.35rem}

.compare-quick-plz{padding:0 2rem 1.5rem;display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}
.compare-quick-plz span{font-size:.82rem;color:var(--color-text-muted);white-space:nowrap}
.plz-pill{
  padding:.3rem .8rem;border:1.5px solid var(--color-border);border-radius:var(--radius-full);
  font-family:var(--font-mono);font-size:.8rem;color:var(--color-text-muted);
  cursor:pointer;transition:all .15s;background:#fff;
}
.plz-pill:hover,.plz-pill.active{border-color:var(--color-primary);color:var(--color-primary);background:rgba(11,107,83,.06)}

/* Trust bar */
.trust-bar{background:var(--color-surface-muted);border-top:1px solid var(--color-border);border-bottom:1px solid var(--color-border);padding:1.25rem 0}
.trust-bar-inner{display:flex;align-items:center;justify-content:center;gap:2.5rem;flex-wrap:wrap}
.trust-item{display:flex;align-items:center;gap:.6rem;font-size:.88rem;color:var(--color-text-muted);font-weight:500}
.trust-item svg{color:var(--color-primary);flex-shrink:0}

/* ══════════════════════════════════════════════════════════
   ANBIETER CARDS
   ══════════════════════════════════════════════════════════ */
.anbieter-preview{background:var(--color-bg)}
.anbieter-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:1.25rem}
.anbieter-card{
  background:#fff;border-radius:var(--radius-lg);border:1.5px solid var(--color-border);
  padding:1.5rem;transition:all .2s;display:flex;flex-direction:column;gap:.875rem;
  color:var(--color-text);
}
.anbieter-card:hover{border-color:var(--color-primary);box-shadow:0 4px 20px rgba(11,107,83,.12);transform:translateY(-2px);text-decoration:none}
.anbieter-card-top{display:flex;align-items:flex-start;gap:1rem}
.anbieter-icon{
  width:48px;height:48px;border-radius:var(--radius-md);
  background:var(--color-surface-muted);border:1px solid var(--color-border);
  display:flex;align-items:center;justify-content:center;
  color:var(--color-primary);flex-shrink:0;
}
.anbieter-info{flex:1}
.anbieter-info strong{font-family:var(--font-display);font-weight:700;font-size:1rem;color:var(--color-heading);display:block;margin-bottom:.25rem}
.anbieter-price{display:flex;align-items:baseline;gap:.25rem}
.price-ct{font-family:var(--font-mono);font-size:1.5rem;font-weight:600;color:var(--color-primary)}
.price-unit{font-size:.8rem;color:var(--color-text-muted)}
.anbieter-desc-kurz{font-size:.875rem;color:var(--color-text-muted);line-height:1.55;flex:1}
.anbieter-card-footer{display:flex;align-items:center;justify-content:space-between;padding-top:.75rem;border-top:1px solid var(--color-border);margin-top:auto}
.jahres-kosten{font-family:var(--font-mono);font-size:.85rem;font-weight:600;color:var(--color-heading)}
.card-link{font-size:.82rem;font-weight:600;color:var(--color-primary)}

/* ══════════════════════════════════════════════════════════
   SPARRECHNER — slider-based version from index.php
   ══════════════════════════════════════════════════════════ */
.sparrechner-section{padding:4rem 0}
.sparrechner-card{
  background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.12);
  border-radius:var(--radius-xl);overflow:hidden;max-width:780px;margin:0 auto;
}
.sparrechner-inner{padding:2rem}
.geraete-list{display:flex;flex-direction:column;gap:0}
.geraet-row{
  display:grid;grid-template-columns:1fr 200px 100px;
  align-items:center;gap:1rem;
  padding:.875rem 0;border-bottom:1px solid rgba(255,255,255,.08);
}
.geraet-row:last-child{border-bottom:none}
.geraet-info strong{display:block;font-size:.9rem;color:#fff;font-weight:600;margin-bottom:.1rem}
.geraet-info small{font-size:.78rem;color:rgba(255,255,255,.5)}
.geraet-control{display:flex;flex-direction:column;gap:.3rem}
.geraet-slider{
  width:100%;accent-color:var(--color-lime);
  height:4px;cursor:pointer;
}
.geraet-val{font-family:var(--font-mono);font-size:.78rem;color:rgba(255,255,255,.6)}
.geraet-ersparnis{
  font-family:var(--font-mono);font-size:.9rem;font-weight:600;
  color:var(--color-lime);text-align:right;
}
.sparrechner-result{
  background:rgba(200,242,92,.08);border-top:1px solid rgba(200,242,92,.2);
  padding:1.25rem 2rem;
}
.result-row{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.35rem 0}
.result-row span{font-size:.9rem;color:rgba(255,255,255,.75)}
.result-total{font-family:var(--font-mono);font-size:1.4rem;color:var(--color-lime)}
.result-row-sub span{font-size:.82rem;color:rgba(255,255,255,.5)}
.disclaimer{font-size:.75rem;color:rgba(255,255,255,.35)!important}

/* ══════════════════════════════════════════════════════════
   STADTTEILE
   ══════════════════════════════════════════════════════════ */
.stadtteile-section{background:var(--color-surface-muted)}
.stadtteile-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem}
.stadtteil-card{
  background:#fff;border-radius:var(--radius-md);border:1.5px solid var(--color-border);
  padding:1.1rem 1.25rem;transition:all .2s;display:flex;flex-direction:column;gap:.25rem;
  color:var(--color-text);
}
.stadtteil-card:hover{border-color:var(--color-primary);box-shadow:0 2px 12px rgba(11,107,83,.1);text-decoration:none;transform:translateY(-1px)}
.stadtteil-plz{font-family:var(--font-mono);font-size:.78rem;color:var(--color-lime);background:rgba(11,107,83,.08);padding:.15rem .5rem;border-radius:var(--radius-sm);display:inline-block;width:fit-content;margin-bottom:.1rem}
.stadtteil-card strong{font-weight:600;color:var(--color-heading);font-size:.95rem}
.stadtteil-ew{font-size:.78rem;color:var(--color-text-muted)}

/* ══════════════════════════════════════════════════════════
   RATGEBER
   ══════════════════════════════════════════════════════════ */
.ratgeber-section{background:var(--color-bg)}
.ratgeber-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.25rem}
.ratgeber-card{
  background:#fff;border-radius:var(--radius-lg);border:1.5px solid var(--color-border);
  padding:1.5rem;transition:all .2s;display:flex;flex-direction:column;gap:.75rem;
  color:var(--color-text);
}
.ratgeber-card:hover{border-color:var(--color-primary);box-shadow:var(--shadow-md);transform:translateY(-2px);text-decoration:none}
.ratgeber-icon{
  width:44px;height:44px;background:rgba(11,107,83,.08);border-radius:var(--radius-md);
  display:flex;align-items:center;justify-content:center;
  color:var(--color-primary);flex-shrink:0;
}
.ratgeber-tag{font-family:var(--font-mono);font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--color-primary)}
.ratgeber-card h3{font-size:1rem;color:var(--color-heading);margin:0}
.ratgeber-card p{font-size:.875rem;color:var(--color-text-muted);line-height:1.6;flex:1}
.ratgeber-meta{display:flex;align-items:center;justify-content:space-between;font-size:.78rem;color:var(--color-text-muted);padding-top:.5rem;border-top:1px solid var(--color-border);margin-top:auto}
.read-more{color:var(--color-primary);font-weight:600}

/* ══════════════════════════════════════════════════════════
   FAQ
   ══════════════════════════════════════════════════════════ */
.faq-section{background:var(--color-bg)}
.faq-container{max-width:760px}
.faq-list{display:flex;flex-direction:column;gap:.75rem}
.faq-item{background:#fff;border:1.5px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden;transition:border-color .15s}
.faq-item.open{border-color:var(--color-primary)}
.faq-question{
  width:100%;padding:1.1rem 1.4rem;background:none;border:none;cursor:pointer;
  display:flex;align-items:center;justify-content:space-between;gap:1rem;text-align:left;
  font-family:var(--font-body);font-size:.95rem;font-weight:600;color:var(--color-heading);
}
.faq-chevron{transition:transform .25s;flex-shrink:0;color:var(--color-primary)}
.faq-item.open .faq-chevron{transform:rotate(180deg)}
.faq-answer{padding:0 1.4rem;max-height:0;overflow:hidden;transition:max-height .3s ease}
.faq-answer>div{padding-bottom:1.1rem;font-size:.9rem;color:var(--color-text-muted);line-height:1.7}
.faq-item.open .faq-answer{max-height:500px}

/* ══════════════════════════════════════════════════════════
   CTA BAND
   ══════════════════════════════════════════════════════════ */
.cta-band{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-dark) 100%);color:#fff;padding:3.5rem 0;text-align:center}
.cta-band-inner{max-width:640px;margin:0 auto}
.cta-band-text h2{color:#fff;margin-bottom:.75rem}
.cta-band-text p{color:rgba(255,255,255,.8);font-size:1.05rem;margin-bottom:2rem}

/* ══════════════════════════════════════════════════════════
   FOOTER
   ══════════════════════════════════════════════════════════ */
.site-footer{background:var(--color-navy);color:rgba(255,255,255,.65);font-size:.875rem;padding:3rem 0 0}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:2rem;padding-bottom:2rem}
.footer-brand{}
.footer-logo{display:flex;align-items:center;gap:.6rem;text-decoration:none;margin-bottom:1rem}
.footer-logo:hover{text-decoration:none}
.footer-tagline{color:rgba(255,255,255,.55);font-size:.875rem;line-height:1.65;margin-bottom:1rem}
.footer-partner{font-size:.78rem;color:rgba(255,255,255,.35)}
.footer-col{}
.footer-col h4{font-family:var(--font-display);font-weight:700;font-size:.88rem;color:#fff;text-transform:uppercase;letter-spacing:.06em;margin-bottom:1rem}
.footer-col ul{display:flex;flex-direction:column;gap:.5rem}
.footer-col ul a{color:rgba(255,255,255,.6);font-size:.85rem;transition:color .15s}
.footer-col ul a:hover{color:var(--color-lime);text-decoration:none}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding:1.25rem 0;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.75rem}
.footer-disclaimer{font-size:.78rem;color:rgba(255,255,255,.4)}
.footer-bottom a{color:rgba(255,255,255,.5);font-size:.8rem;margin-left:1.25rem}
.footer-bottom a:hover{color:var(--color-lime);text-decoration:none}

/* ══════════════════════════════════════════════════════════
   INNER PAGE COMPONENTS (stadtteile, anbieter, ratgeber templates)
   ══════════════════════════════════════════════════════════ */
.page-hero{background:linear-gradient(135deg,var(--color-navy),var(--color-primary-dark));color:#fff;padding:3rem 0}
.page-hero h1{color:#fff;margin-bottom:.5rem}
.breadcrumb{display:flex;align-items:center;gap:.5rem;font-size:.82rem;color:rgba(255,255,255,.5);margin-bottom:1rem}
.breadcrumb a{color:var(--color-lime)}
.breadcrumb a:hover{color:#fff;text-decoration:none}
.breadcrumb-sep{opacity:.4}

.content-layout{display:grid;grid-template-columns:1fr 300px;gap:2.5rem;align-items:start}
.content-main{min-width:0}
.sidebar-card{background:#fff;border-radius:var(--radius-lg);border:1.5px solid var(--color-border);overflow:hidden;margin-bottom:1.5rem}
.sidebar-card-header{background:var(--color-navy);color:#fff;padding:1rem 1.25rem;font-family:var(--font-display);font-weight:700;font-size:.88rem}
.sidebar-card-body{padding:1.25rem}
.sidebar-link-list{display:flex;flex-direction:column;gap:.4rem}
.sidebar-link-list a{font-size:.875rem;color:var(--color-text);display:flex;align-items:center;gap:.4rem;padding:.35rem 0;border-bottom:1px solid var(--color-border)}
.sidebar-link-list a:last-child{border-bottom:none}
.sidebar-link-list a:hover{color:var(--color-primary);text-decoration:none}

/* Spec table */
.spec-table{width:100%;border-collapse:collapse}
.spec-table tr{border-bottom:1px solid var(--color-border)}
.spec-table tr:last-child{border-bottom:none}
.spec-table td{padding:.75rem 1rem;font-size:.9rem}
.spec-table td:first-child{color:var(--color-text-muted);font-weight:500;width:45%}
.spec-table td:last-child{font-weight:600;color:var(--color-heading)}

/* Steps */
.steps{display:flex;flex-direction:column;gap:1.25rem}
.step{display:flex;gap:1rem;align-items:flex-start}
.step-number{width:32px;height:32px;background:var(--color-primary);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-weight:700;font-size:.85rem;flex-shrink:0}
.step-content h4{font-size:.95rem;margin-bottom:.25rem}
.step-content p{font-size:.875rem;color:var(--color-text-muted)}

/* Article body */
.article-toc{background:var(--color-surface-muted);border:1.5px solid var(--color-border);border-radius:var(--radius-md);padding:1.25rem;margin-bottom:2rem}
.article-toc h3{font-size:.88rem;text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-muted);margin-bottom:.75rem}
.article-toc ol{list-style:decimal;padding-left:1.25rem;display:flex;flex-direction:column;gap:.4rem}
.article-toc ol li a{font-size:.875rem;color:var(--color-primary)}
.article-body h2{margin-top:2.5rem;margin-bottom:1rem;padding-top:1rem;border-top:2px solid var(--color-lime)}
.article-body h3{margin-top:1.5rem;margin-bottom:.75rem}
.article-body p{color:var(--color-text);line-height:1.75;margin-bottom:1rem}
.article-body ul{list-style:disc;padding-left:1.5rem;margin-bottom:1rem}
.article-body ul li{margin-bottom:.4rem;font-size:.95rem;color:var(--color-text)}
.article-info-box{background:#eff6ff;border:1.5px solid #93c5fd;border-radius:var(--radius-md);padding:1.25rem;margin:1.5rem 0}
.article-info-box p{font-size:.9rem;color:#1e3a5f}
.article-warning-box{background:#fff7ed;border:1.5px solid #fed7aa;border-radius:var(--radius-md);padding:1.25rem;margin:1.5rem 0}
.article-warning-box p{font-size:.9rem;color:#7c2d12}

/* Ergebnis / Widget */
.ergebnis-hero{background:var(--color-navy);color:#fff;padding:2.5rem 0;text-align:center}
.ergebnis-hero h1{color:#fff;margin-bottom:.5rem}
.ergebnis-hero p{color:rgba(255,255,255,.7)}
.check24-frame-wrap{background:#fff;border-radius:var(--radius-xl);overflow:hidden;box-shadow:var(--shadow-lg);min-height:600px;margin-top:2rem}

/* Overview table */
.overview-table-wrap{overflow-x:auto;border-radius:var(--radius-lg);border:1.5px solid var(--color-border)}
.overview-table{width:100%;border-collapse:collapse;font-size:.9rem}
.overview-table th{background:var(--color-navy);color:#fff;padding:.875rem 1rem;text-align:left;font-family:var(--font-display);font-weight:600;font-size:.82rem;white-space:nowrap}
.overview-table td{padding:.875rem 1rem;border-bottom:1px solid var(--color-border);vertical-align:middle}
.overview-table tr:last-child td{border-bottom:none}
.overview-table tr:hover td{background:var(--color-surface-muted)}
.overview-table .price-cell{font-family:var(--font-mono);font-weight:600;color:var(--color-primary)}
.overview-table .savings-cell{font-family:var(--font-mono);font-weight:600;color:#166534}

/* Filter */
.filter-bar{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:1.5rem}
.filter-btn{padding:.4rem 1rem;border:1.5px solid var(--color-border);border-radius:var(--radius-full);font-size:.85rem;font-weight:500;cursor:pointer;background:#fff;color:var(--color-text-muted);transition:all .15s}
.filter-btn:hover,.filter-btn.active{border-color:var(--color-primary);background:var(--color-primary);color:#fff}

/* Legal */
.legal-content{max-width:760px}
.legal-content h2{margin-top:2rem;margin-bottom:.75rem;font-size:1.2rem}
.legal-content h3{margin-top:1.25rem;margin-bottom:.5rem;font-size:1rem}
.legal-content p,.legal-content li{font-size:.9rem;color:var(--color-text-muted);line-height:1.7;margin-bottom:.75rem}
.legal-content ul{padding-left:1.25rem;list-style:disc}

/* ══════════════════════════════════════════════════════════
   RESPONSIVE
   ══════════════════════════════════════════════════════════ */
@media(max-width:1024px){
  .hero-inner{grid-template-columns:1fr}
  .hero-visual{display:none}
  .footer-grid{grid-template-columns:1fr 1fr}
  .content-layout{grid-template-columns:1fr}
  .sidebar-card{display:none}
}

@media(max-width:768px){
  .main-nav{display:none}
  .header-cta{display:none}
  .nav-toggle{display:flex}

  .main-nav.open{
    display:flex;flex-direction:column;
    position:fixed;top:var(--header-h);left:0;right:0;bottom:0;
    background:var(--color-navy);padding:1rem;
    overflow-y:auto;z-index:999;align-items:stretch;
    border-top:1px solid rgba(255,255,255,.1);
  }
  .main-nav.open>ul{flex-direction:column;align-items:stretch;gap:.25rem;width:100%}
  .main-nav.open>ul>li>a{font-size:1rem;padding:.75rem 1rem}
  .main-nav.open .dropdown{
    position:static;transform:none;box-shadow:none;border:none;
    background:rgba(255,255,255,.05);opacity:1;visibility:visible;display:none;
    padding:.25rem 0 .25rem 1rem;max-height:none;
  }
  .main-nav.open .has-dropdown.open .dropdown{display:block}
  .main-nav.open .dropdown li a{color:rgba(255,255,255,.7)}
  .main-nav.open .dropdown li a:hover{color:var(--color-lime);background:transparent}

  .form-row{grid-template-columns:1fr}
  .geraet-row{grid-template-columns:1fr;gap:.5rem}
  .geraet-ersparnis{text-align:left}
  .sparrechner-result{padding:1rem}
  .footer-grid{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column;align-items:flex-start}
  .trust-bar-inner{gap:1.25rem;justify-content:flex-start}
  .section{padding:2.5rem 0}
  .hero{padding:2.5rem 0}
  .hero-stats{gap:1.25rem}
  .cookie-inner{flex-direction:column}
}

@media(max-width:480px){
  .anbieter-grid{grid-template-columns:1fr}
  .stadtteile-grid{grid-template-columns:repeat(2,1fr)}
  .ratgeber-grid{grid-template-columns:1fr}
}

/* ══════════════════════════════════════════════════════════
   FOOTER FIX
   footer.php: .footer-grid hat 5 cols (brand + 4 footer-col)
   footer-col h3 (nicht h4)
   footer-bottom > .container mit flex-Inhalt
   ══════════════════════════════════════════════════════════ */
.site-footer{background:var(--color-navy);color:rgba(255,255,255,.65);font-size:.875rem;padding:2.5rem 0 0}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr 1fr;gap:2rem;padding-bottom:2rem}
.footer-brand{}
.footer-col h3{font-family:var(--font-display);font-weight:700;font-size:.82rem;color:#fff;text-transform:uppercase;letter-spacing:.07em;margin-bottom:.875rem}
.footer-col ul{display:flex;flex-direction:column;gap:.4rem;list-style:none}
.footer-col ul a{color:rgba(255,255,255,.55);font-size:.82rem;line-height:1.4;transition:color .15s}
.footer-col ul a:hover{color:var(--color-lime);text-decoration:none}
.footer-bottom{background:rgba(0,0,0,.2);margin-top:0}
.footer-bottom .container{
  display:flex;align-items:center;justify-content:space-between;
  flex-wrap:wrap;gap:.75rem;padding-top:1rem;padding-bottom:1rem;
}
.footer-bottom span{font-size:.78rem;color:rgba(255,255,255,.4)}
.footer-bottom .footer-partner{color:rgba(255,255,255,.4)}
.footer-bottom .footer-partner strong{color:rgba(255,255,255,.6)}

/* CTA Band fix */
.cta-band{background:linear-gradient(135deg,var(--color-primary),var(--color-primary-dark));color:#fff;padding:3rem 0}
.cta-band-inner{display:flex;align-items:center;justify-content:space-between;gap:2rem;flex-wrap:wrap}
.cta-band-text h2{color:#fff;margin-bottom:.5rem;font-size:1.6rem}
.cta-band-text p{color:rgba(255,255,255,.8);margin:0;font-size:1rem}

/* Cookie banner "nur notwendige" button fix */
.btn-ghost{background:rgba(255,255,255,.1);color:#fff;border-color:rgba(255,255,255,.3)}
.btn-ghost:hover{background:rgba(255,255,255,.2);text-decoration:none}

/* page-hero-sm variant */
.page-hero-sm{padding:2.25rem 0}

/* section-hint */
.section-hint{
  display:flex;align-items:flex-start;gap:.6rem;
  margin-top:2rem;padding:1rem 1.25rem;
  background:var(--color-surface-muted);border-radius:var(--radius-md);
  border:1px solid var(--color-border);
  font-size:.85rem;color:var(--color-text-muted);
}
.section-hint svg{flex-shrink:0;color:var(--color-primary);margin-top:.1rem}
.section-hint a{color:var(--color-primary)}

/* ══════════════════════════════════════════════════════════
   STADTTEILE OVERVIEW (stadtteile/index.php)
   .stadtteile-overview-grid > a.stadtteil-overview-card
     .soc-plz | h2 | p | .soc-meta > span + .soc-savings
   ══════════════════════════════════════════════════════════ */
.stadtteile-overview-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.25rem}
.stadtteil-overview-card{
  background:#fff;border-radius:var(--radius-lg);border:1.5px solid var(--color-border);
  padding:1.5rem;display:flex;flex-direction:column;gap:.6rem;
  color:var(--color-text);transition:all .2s;
}
.stadtteil-overview-card:hover{border-color:var(--color-primary);box-shadow:var(--shadow-md);transform:translateY(-2px);text-decoration:none}
.soc-plz{font-family:var(--font-mono);font-size:.75rem;font-weight:600;color:var(--color-primary);background:rgba(11,107,83,.08);padding:.2rem .6rem;border-radius:var(--radius-full);display:inline-block;width:fit-content}
.stadtteil-overview-card h2{font-size:1.1rem;color:var(--color-heading);margin:0}
.stadtteil-overview-card p{font-size:.875rem;color:var(--color-text-muted);line-height:1.55;flex:1;margin:0}
.soc-meta{display:flex;align-items:center;justify-content:space-between;gap:.5rem;padding-top:.75rem;border-top:1px solid var(--color-border);font-size:.8rem;color:var(--color-text-muted);margin-top:auto}
.soc-savings{font-family:var(--font-mono);font-weight:600;color:#166534;background:#f0fdf4;padding:.15rem .5rem;border-radius:var(--radius-sm)}

/* ══════════════════════════════════════════════════════════
   RATGEBER OVERVIEW (ratgeber/index.php)
   .ratgeber-overview-grid > a.ratgeber-overview-card
     .roc-icon | .roc-tag | h2 | p | .roc-footer
   ══════════════════════════════════════════════════════════ */
.ratgeber-overview-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.25rem}
.ratgeber-overview-card{
  background:#fff;border-radius:var(--radius-lg);border:1.5px solid var(--color-border);
  padding:1.5rem;display:flex;flex-direction:column;gap:.65rem;
  color:var(--color-text);transition:all .2s;
}
.ratgeber-overview-card:hover{border-color:var(--color-primary);box-shadow:var(--shadow-md);transform:translateY(-2px);text-decoration:none}
.roc-icon{
  width:48px;height:48px;background:linear-gradient(135deg,var(--color-navy),var(--color-primary-dark));
  border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:var(--color-lime);
}
.roc-tag{font-family:var(--font-mono);font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--color-primary)}
.ratgeber-overview-card h2{font-size:1rem;color:var(--color-heading);margin:0;line-height:1.3}
.ratgeber-overview-card p{font-size:.875rem;color:var(--color-text-muted);line-height:1.6;flex:1;margin:0}
.roc-footer{display:flex;align-items:center;justify-content:space-between;padding-top:.75rem;border-top:1px solid var(--color-border);font-size:.78rem;color:var(--color-text-muted);margin-top:auto}
.roc-footer span:last-child{color:var(--color-primary);font-weight:600}
.roc-footer time{color:var(--color-text-muted)}

/* ══════════════════════════════════════════════════════════
   ANBIETER OVERVIEW (anbieter/index.php)
   .anbieter-full-grid > a.anbieter-full-card
     .afc-header (.afc-icon | div>h2+.afc-badges | .afc-rating)
     p | .afc-pricing > .afc-price-item | .afc-footer
   ══════════════════════════════════════════════════════════ */
.anbieter-filter-bar{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:1.5rem}
.anbieter-full-grid{display:flex;flex-direction:column;gap:1rem}
.anbieter-full-card{
  background:#fff;border-radius:var(--radius-lg);border:1.5px solid var(--color-border);
  padding:1.5rem;display:flex;flex-direction:column;gap:1rem;
  color:var(--color-text);transition:all .2s;
}
.anbieter-full-card:hover{border-color:var(--color-primary);box-shadow:var(--shadow-md);text-decoration:none}
.anbieter-full-card.is-oeko{border-left:3px solid var(--color-primary)}

.afc-header{display:flex;align-items:flex-start;gap:1rem}
.afc-icon{
  width:52px;height:52px;background:var(--color-surface-muted);border:1px solid var(--color-border);
  border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;
  color:var(--color-primary);flex-shrink:0;
}
.afc-header>div:nth-child(2){flex:1}
.afc-header h2{font-size:1.15rem;color:var(--color-heading);margin-bottom:.35rem}
.afc-badges{display:flex;flex-wrap:wrap;gap:.35rem}
.badge-typ{background:#f0f4ff;color:#3b4abf}
.badge-regional{background:#fef3c7;color:#92400e}
.afc-rating{display:flex;flex-direction:column;align-items:flex-end;gap:.2rem;flex-shrink:0}
.rating-num{font-size:1.1rem;font-weight:600;color:var(--color-heading)}
.rating-stars{font-size:.9rem;color:#f59e0b;letter-spacing:-.05em}

.anbieter-full-card>p{font-size:.9rem;color:var(--color-text-muted);line-height:1.6;margin:0}

.afc-pricing{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:.5rem}
.afc-price-item{background:var(--color-surface-muted);border-radius:var(--radius-sm);padding:.6rem .875rem;display:flex;flex-direction:column;gap:.15rem}
.afc-price-item span{font-size:.75rem;color:var(--color-text-muted)}
.afc-price-item strong{font-size:.95rem;color:var(--color-heading)}
.highlight-price{color:var(--color-primary)!important}
.afc-ersparnis{background:#f0fdf4;border:1px solid #bbf7d0}
.afc-ersparnis span{color:#166534!important}
.ersparnis-value{color:#166534!important}

.afc-footer{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding-top:.875rem;border-top:1px solid var(--color-border)}
.afc-meta{font-size:.82rem;color:var(--color-text-muted)}

/* ══════════════════════════════════════════════════════════
   RATGEBER TEMPLATE (ratgeber/template.php)
   Sidebar + content layout used on detail pages
   ══════════════════════════════════════════════════════════ */
.ratgeber-sidebar-cta{
  background:linear-gradient(135deg,var(--color-primary),var(--color-primary-dark));
  color:#fff;border-radius:var(--radius-lg);padding:1.5rem;margin-bottom:1.5rem;text-align:center;
}
.ratgeber-sidebar-cta h3{color:#fff;font-size:1rem;margin-bottom:.5rem}
.ratgeber-sidebar-cta p{color:rgba(255,255,255,.8);font-size:.85rem;margin-bottom:1rem}
.quick-compare{background:var(--color-surface-muted);border-radius:var(--radius-md);padding:1rem;margin-bottom:1.5rem}
.quick-compare h4{font-size:.85rem;margin-bottom:.75rem;color:var(--color-heading)}
.qc-row{display:flex;justify-content:space-between;align-items:center;padding:.4rem 0;border-bottom:1px solid var(--color-border);font-size:.85rem}
.qc-row:last-child{border-bottom:none}
.qc-label{color:var(--color-text-muted)}
.qc-val{font-family:var(--font-mono);font-weight:600;color:var(--color-heading)}
.qc-val.best{color:var(--color-primary)}

/* ══════════════════════════════════════════════════════════
   RESPONSIVE ADDITIONS
   ══════════════════════════════════════════════════════════ */
@media(max-width:1024px){
  .footer-grid{grid-template-columns:1fr 1fr 1fr}
  .footer-brand{grid-column:1/-1}
}
@media(max-width:768px){
  .footer-grid{grid-template-columns:1fr 1fr}
  .footer-brand{grid-column:1/-1}
  .cta-band-inner{flex-direction:column;text-align:center}
  .afc-pricing{grid-template-columns:1fr 1fr}
  .stadtteile-overview-grid{grid-template-columns:1fr}
  .ratgeber-overview-grid{grid-template-columns:1fr}
}
@media(max-width:480px){
  .footer-grid{grid-template-columns:1fr}
  .afc-pricing{grid-template-columns:1fr}
  .afc-header{flex-wrap:wrap}
}

/* ══════════════════════════════════════════════════════════
   DETAIL PAGE SHARED
   ══════════════════════════════════════════════════════════ */
.text-primary{color:var(--color-primary)}
.text-muted{color:var(--color-text-muted)}
.ersparnis-color{color:#166534}
.page-hero-sub{font-size:.95rem;color:rgba(255,255,255,.75);margin-bottom:.5rem}
.page-hero .text-primary{color:var(--color-lime)}

/* details-table — used in both anbieter + stadtteil templates */
.details-table{width:100%;border-collapse:collapse;font-size:.9rem}
.details-table tr{border-bottom:1px solid var(--color-border)}
.details-table tr:last-child{border-bottom:none}
.details-table th{padding:.65rem 1rem;text-align:left;font-weight:600;color:var(--color-text-muted);width:45%;background:var(--color-surface-muted)}
.details-table td{padding:.65rem 1rem;color:var(--color-heading);font-weight:500}
.stars-sm{font-size:.9rem;color:#f59e0b;margin-left:.4rem}

/* sidebar-widget — shared across all detail pages */
.sidebar-widget{
  background:#fff;border:1.5px solid var(--color-border);
  border-radius:var(--radius-lg);padding:1.25rem;margin-bottom:1.25rem;
}
.sidebar-widget h3{font-size:.9rem;font-weight:700;color:var(--color-heading);margin-bottom:.875rem;padding-bottom:.5rem;border-bottom:1px solid var(--color-border)}
.widget-cta{background:linear-gradient(135deg,var(--color-primary),var(--color-primary-dark));border-color:transparent}
.widget-cta h3{color:#fff;border-bottom-color:rgba(255,255,255,.2)}
.widget-cta p{font-size:.85rem;color:rgba(255,255,255,.8);margin-bottom:1rem}
.sidebar-link{display:inline-block;font-size:.82rem;font-weight:600;color:var(--color-primary);margin-top:.75rem}
.sidebar-link:hover{text-decoration:underline}

.sidebar-anbieter-list,.sidebar-stadtteile-list,.sidebar-ratgeber-list{display:flex;flex-direction:column;gap:.4rem;list-style:none}
.sidebar-anbieter-list li a,.sidebar-stadtteile-list li a,.sidebar-ratgeber-list li a{
  display:flex;align-items:center;justify-content:space-between;
  font-size:.85rem;color:var(--color-text);padding:.35rem 0;
  border-bottom:1px solid var(--color-border);
}
.sidebar-anbieter-list li:last-child a,.sidebar-stadtteile-list li:last-child a,.sidebar-ratgeber-list li:last-child a{border-bottom:none}
.sidebar-anbieter-list li a:hover,.sidebar-stadtteile-list li a:hover,.sidebar-ratgeber-list li a:hover{color:var(--color-primary);text-decoration:none}
.sidebar-ratgeber-list li a{display:block;justify-content:unset;font-size:.82rem;line-height:1.4}

/* ══════════════════════════════════════════════════════════
   ANBIETER DETAIL PAGE
   provider-layout > provider-main + provider-sidebar
   ══════════════════════════════════════════════════════════ */
.provider-layout{display:grid;grid-template-columns:1fr 280px;gap:2.5rem;align-items:start}
.provider-main{display:flex;flex-direction:column;gap:2rem;min-width:0}
.provider-sidebar{position:sticky;top:calc(var(--header-h) + 1rem)}

/* Hero inner */
.provider-hero-inner{display:flex;align-items:flex-start;gap:1.25rem;margin-top:.5rem}
.provider-icon-lg{
  width:64px;height:64px;background:rgba(200,242,92,.15);border:1px solid rgba(200,242,92,.3);
  border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;
  color:var(--color-lime);flex-shrink:0;
}
.provider-badges{display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:.5rem}
.badge-zertifikat{background:#fef9c3;color:#713f12}
.provider-hero-inner h1{color:#fff;font-size:clamp(1.4rem,3vw,1.9rem);margin-bottom:.35rem}
.provider-hero-inner p{color:rgba(255,255,255,.75);font-size:.9rem;margin:0}

/* Price box */
.price-box{
  background:#fff;border:1.5px solid var(--color-border);
  border-radius:var(--radius-lg);padding:1.75rem;
}
.price-box h2{font-size:1.15rem;margin-bottom:1.25rem}
.price-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:.75rem;margin-bottom:1rem}
.price-cell{
  background:var(--color-surface-muted);border-radius:var(--radius-md);
  padding:.875rem 1rem;display:flex;flex-direction:column;gap:.25rem;
}
.price-cell span{font-size:.75rem;color:var(--color-text-muted)}
.price-big{font-family:var(--font-mono);font-size:1.05rem;font-weight:600;color:var(--color-heading)}
.price-highlight{color:var(--color-primary)!important}
.price-cell-ersparnis{background:#f0fdf4;border:1px solid #bbf7d0}
.price-cell-ersparnis span{color:#166534}
.price-disclaimer{
  font-size:.78rem;color:var(--color-text-muted);
  display:flex;align-items:center;gap:.4rem;margin-bottom:1rem;
}
.price-disclaimer svg{flex-shrink:0}

/* Provider sections */
.provider-beschreibung h2,.provider-details h2,.how-to-switch h2{font-size:1.2rem;margin-bottom:1rem}
.provider-beschreibung p{font-size:.95rem;line-height:1.75;color:var(--color-text)}
.provider-details,.provider-beschreibung,.how-to-switch{
  background:#fff;border:1.5px solid var(--color-border);
  border-radius:var(--radius-lg);padding:1.75rem;
}

/* Steps list */
.steps-list{list-style:none;display:flex;flex-direction:column;gap:1.25rem}
.steps-list li{display:flex;gap:1rem;align-items:flex-start}
.step-num{
  width:30px;height:30px;background:var(--color-primary);color:#fff;
  border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-family:var(--font-mono);font-weight:700;font-size:.82rem;flex-shrink:0;
}
.steps-list li strong{display:block;font-size:.95rem;margin-bottom:.25rem;color:var(--color-heading)}
.steps-list li p{font-size:.875rem;color:var(--color-text-muted);margin:0}

/* Sidebar compare-mini */
.compare-mini{display:flex;flex-direction:column;gap:.35rem}
.compare-mini-row{
  display:flex;align-items:center;justify-content:space-between;
  padding:.45rem .5rem;border-radius:var(--radius-sm);font-size:.875rem;
  background:var(--color-surface-muted);
}
.highlight-row{background:rgba(11,107,83,.08);border:1px solid rgba(11,107,83,.15)}
.ersparnis-row{background:#f0fdf4;border:1px solid #bbf7d0}
.compare-mini-row span{color:var(--color-text-muted)}
.compare-mini-row strong{font-size:.9rem}
.ersparnis-row span,.ersparnis-row strong{color:#166534}

/* ══════════════════════════════════════════════════════════
   STADTTEIL DETAIL PAGE
   stadtteil-layout > stadtteil-main + stadtteil-sidebar
   ══════════════════════════════════════════════════════════ */
.stadtteil-layout{display:grid;grid-template-columns:1fr 280px;gap:2.5rem;align-items:start}
.stadtteil-main{display:flex;flex-direction:column;gap:2rem;min-width:0}
.stadtteil-sidebar{position:sticky;top:calc(var(--header-h) + 1rem)}

/* Inline compare card on stadtteil pages */
.compare-card-inline{
  background:#fff;border:1.5px solid var(--color-border);
  border-radius:var(--radius-lg);padding:1.5rem;
}
.compare-card-inline h2{font-size:1.1rem;margin-bottom:1rem}
.compare-card-inline .form-row{grid-template-columns:1fr 1fr auto;align-items:end}

/* Stadtteil info sections */
.stadtteil-info-box,.stadtteil-text-block{
  background:#fff;border:1.5px solid var(--color-border);
  border-radius:var(--radius-lg);padding:1.75rem;
}
.stadtteil-info-box h2,.stadtteil-text-block h2{font-size:1.2rem;margin-bottom:1rem}
.stadtteil-info-box p{font-size:.95rem;color:var(--color-text);margin-bottom:1.25rem}
.stadtteil-text-block p{font-size:.95rem;line-height:1.75;color:var(--color-text)}

/* ══════════════════════════════════════════════════════════
   RATGEBER DETAIL PAGE
   article-layout > article-body + article-sidebar
   ══════════════════════════════════════════════════════════ */
.ratgeber-article{}
.article-layout{display:grid;grid-template-columns:1fr 280px;gap:2.5rem;align-items:start;padding-top:2.5rem;padding-bottom:3rem}
.article-body{min-width:0}
.article-sidebar{position:sticky;top:calc(var(--header-h) + 1rem)}

/* Article hero meta */
.article-meta-top{display:flex;align-items:center;gap:1rem;margin-bottom:.875rem}
.article-tag{
  display:inline-flex;align-items:center;gap:.4rem;
  background:rgba(200,242,92,.15);border:1px solid rgba(200,242,92,.3);
  border-radius:var(--radius-full);padding:.25rem .75rem;
  font-family:var(--font-mono);font-size:.72rem;color:var(--color-lime);
  text-transform:uppercase;letter-spacing:.08em;
}
.article-meta-top time{font-size:.82rem;color:rgba(255,255,255,.55)}
.ratgeber-article .page-hero h1{font-size:clamp(1.5rem,3.5vw,2.2rem)}
.article-lead{color:rgba(255,255,255,.75);font-size:1rem;line-height:1.65;margin-top:.5rem}

/* Article ToC */
.article-toc{
  background:var(--color-surface-muted);border:1.5px solid var(--color-border);
  border-radius:var(--radius-md);padding:1.25rem;margin-bottom:2rem;
}
.article-toc strong{display:block;font-size:.82rem;text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-muted);margin-bottom:.75rem}
.article-toc ol{list-style:decimal;padding-left:1.25rem;display:flex;flex-direction:column;gap:.4rem}
.article-toc ol li a{font-size:.875rem;color:var(--color-primary)}
.article-toc ol li a:hover{text-decoration:underline}

/* Article intro + sections */
.article-intro p{font-size:1rem;line-height:1.8;color:var(--color-text);margin-bottom:1.5rem}
.article-section{margin-bottom:2rem}
.article-section h2{
  font-size:1.25rem;color:var(--color-heading);margin-bottom:.875rem;
  padding-top:1.25rem;padding-bottom:.5rem;
  border-top:2px solid var(--color-lime);
}
.article-section p{font-size:.95rem;line-height:1.8;color:var(--color-text)}

/* Article inline CTA */
.article-cta-box{
  background:linear-gradient(135deg,var(--color-primary),var(--color-primary-dark));
  border-radius:var(--radius-lg);padding:1.75rem;margin-top:2rem;
}
.article-cta-box h3{color:#fff;margin-bottom:.5rem}
.article-cta-box p{color:rgba(255,255,255,.8);font-size:.9rem;margin-bottom:1rem}

/* Sidebar quick compare */
.sidebar-quick-compare{display:flex;flex-direction:column;gap:.5rem}
.sqc-row{
  display:flex;align-items:center;justify-content:space-between;
  padding:.5rem .5rem;border-radius:var(--radius-sm);
  background:var(--color-surface-muted);font-size:.85rem;
}
.sqc-row span{color:var(--color-text-muted)}
.sqc-row strong{font-size:.9rem}
.text-primary{color:var(--color-primary)!important}

/* ══════════════════════════════════════════════════════════
   RESPONSIVE — detail pages
   ══════════════════════════════════════════════════════════ */
@media(max-width:1024px){
  .provider-layout,.stadtteil-layout,.article-layout{grid-template-columns:1fr}
  .provider-sidebar,.stadtteil-sidebar,.article-sidebar{display:none}
  .price-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:768px){
  .provider-hero-inner{flex-direction:column;gap:.875rem}
  .compare-card-inline .form-row{grid-template-columns:1fr}
  .price-grid{grid-template-columns:1fr}
}

/* Dropdown: divider + alle-anzeigen Link */
.dropdown-divider{border-top:1px solid var(--color-border);margin:.35rem 0;padding:0!important}
.dropdown-divider a{display:none}
.dropdown-all{font-weight:600!important;color:var(--color-primary)!important}
.dropdown-all:hover{color:var(--color-primary)!important;background:rgba(11,107,83,.08)!important}

/* Footer logo (new HTML structure) */
.footer-logo-mark{
  width:32px;height:32px;background:var(--color-lime);border-radius:7px;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.footer-logo-text{
  font-family:var(--font-display);font-size:.95rem;color:rgba(255,255,255,.7);
  line-height:1;
}
.footer-logo-text strong{color:#fff;display:block;font-weight:700}

/* Header logo fix */
.logo svg text{ font-family: system-ui, sans-serif !important; }

/* Header logo — pure CSS, always readable */
.logo-mark{
  width:34px;height:34px;background:var(--color-lime);border-radius:8px;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.logo-text{display:flex;flex-direction:column;gap:0;line-height:1}
.logo-top{
  font-family:var(--font-display);font-size:.95rem;font-weight:700;
  color:rgba(255,255,255,.7);letter-spacing:.12em;
}
.logo-city{
  font-family:var(--font-display);font-size:.95rem;font-weight:800;
  color:#fff;letter-spacing:.04em;
}

/* ══════════════════════════════════════════════════════════
   WARUM ES SICH LOHNT
   .why-section > .why-grid > .why-card
   ══════════════════════════════════════════════════════════ */
.why-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1.25rem}
.why-card{
  background:#fff;border-radius:var(--radius-lg);border:1.5px solid var(--color-border);
  padding:1.5rem;display:flex;flex-direction:column;gap:.875rem;
  transition:all .2s;
}
.why-card:hover{border-color:var(--color-primary);box-shadow:0 4px 20px rgba(11,107,83,.12);transform:translateY(-2px)}
.why-icon{
  width:48px;height:48px;border-radius:var(--radius-md);
  background:rgba(11,107,83,.08);border:1px solid var(--color-border);
  display:flex;align-items:center;justify-content:center;
  color:var(--color-primary);flex-shrink:0;
}
.why-card h3{font-size:1rem;color:var(--color-heading);margin:0;line-height:1.35}
.why-card p{font-size:.875rem;color:var(--color-text-muted);line-height:1.65;margin:0}

/* ══════════════════════════════════════════════════════════
   SO EINFACH LÄUFT DER WECHSEL
   .how-section > .steps-grid > .step-card
   ══════════════════════════════════════════════════════════ */
.how-section{background:var(--color-navy)}
.steps-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.25rem}
.step-card{
  background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);
  border-radius:var(--radius-lg);padding:1.5rem;display:flex;flex-direction:column;gap:.875rem;
  transition:background .2s;
}
.step-card:hover{background:rgba(255,255,255,.08)}
.step-num{
  width:36px;height:36px;border-radius:50%;flex-shrink:0;
  background:var(--color-lime);color:var(--color-navy);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--font-mono);font-weight:700;font-size:.85rem;
}
.step-card h3{font-size:1rem;color:#fff;margin:0;line-height:1.35}
.step-card p{font-size:.875rem;color:rgba(255,255,255,.6);line-height:1.65;margin:0}

/* ══════════════════════════════════════════════════════════
   WORAUF DU BEIM STROMVERGLEICH ACHTEN SOLLTEST
   .tips-section > .tips-grid > .tip-card
   ══════════════════════════════════════════════════════════ */
.tips-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1.25rem}
.tip-card{
  background:#fff;border-radius:var(--radius-lg);border:1.5px solid var(--color-border);
  border-top:3px solid var(--color-primary);
  padding:1.5rem;display:flex;flex-direction:column;gap:.75rem;
  transition:all .2s;
}
.tip-card:hover{box-shadow:0 4px 20px rgba(11,107,83,.12);transform:translateY(-2px)}
.tip-label{
  font-family:var(--font-mono);font-size:.72rem;font-weight:600;
  color:var(--color-primary);letter-spacing:.08em;
}
.tip-card h3{font-size:1rem;color:var(--color-heading);margin:0;line-height:1.35}
.tip-card p{font-size:.875rem;color:var(--color-text-muted);line-height:1.65;margin:0}

/* ══════════════════════════════════════════════════════════
   WIE GEHT ES NACH DEM WECHSEL WEITER
   .after-section > .after-grid > .after-card
   ══════════════════════════════════════════════════════════ */
.after-section{background:var(--color-surface-muted)}
.after-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1.25rem}
.after-card{
  background:#fff;border-radius:var(--radius-lg);border:1.5px solid var(--color-border);
  padding:1.5rem;display:flex;flex-direction:column;gap:.875rem;
  transition:all .2s;
}
.after-card:hover{border-color:var(--color-primary);box-shadow:0 4px 20px rgba(11,107,83,.12);transform:translateY(-2px)}
.after-icon{
  width:48px;height:48px;border-radius:var(--radius-md);
  background:rgba(11,107,83,.08);border:1px solid var(--color-border);
  display:flex;align-items:center;justify-content:center;
  color:var(--color-primary);flex-shrink:0;
}
.after-card h3{font-size:1rem;color:var(--color-heading);margin:0;line-height:1.35}
.after-card p{font-size:.875rem;color:var(--color-text-muted);line-height:1.65;margin:0}

/* ── Responsive neue Sektionen ──────────────────────────── */
@media(max-width:768px){
  .why-grid,.steps-grid,.tips-grid,.after-grid{grid-template-columns:1fr}
}
