/* ============================================================
   internet-verfuegbarkeit.de | style.css v8
   Fixes: CTA-Button sichtbar, Bubbles korrekte Farben,
          Widget volle Artikelbreite, Professionelles Design
   ============================================================ */

:root {
  --bg:     #f7f8fc;
  --card:   #ffffff;
  --text:   #0d1526;
  --text2:  #334155;
  --muted:  #64748b;
  --line:   #e2e8f0;
  --brand:  #1a56db;
  --brandh: #1344b5;
  --brand2: #f97316;
  --brand2h:#ea6c0a;
  --success:#16a34a;
  --shadow: 0 2px 8px rgba(0,0,0,.06),0 8px 24px rgba(0,0,0,.08);
  --shadow-s:0 1px 4px rgba(0,0,0,.05),0 4px 12px rgba(0,0,0,.06);
  --r:14px; --r-lg:20px; --r-xl:28px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;overflow-x:hidden}
body{overflow-x:hidden}
body{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Helvetica,Arial,sans-serif;color:var(--text);background:var(--bg);line-height:1.6;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto;display:block}
ul{list-style:none;padding:0;margin:0}

/* Skip */
.skip-link{position:absolute;left:-9999px}
.skip-link:focus{position:fixed;top:0;left:0;z-index:9999;padding:10px 18px;background:var(--brand);color:#fff;font-weight:700;border-radius:0 0 10px 0;width:auto;height:auto}

/* Container */
.container{max-width:1140px;margin:0 auto;padding:0 24px;box-sizing:border-box}
@media(max-width:640px){.container{padding:0 12px}}
@media(max-width:400px){.container{padding:0 8px}}

/* ── HEADER ── */
.header{position:sticky;top:0;z-index:200;background:rgba(255,255,255,.97);border-bottom:1px solid var(--line);backdrop-filter:blur(16px)}
.header-inner{height:64px;display:flex;align-items:center;justify-content:space-between;gap:20px}
.brand{display:flex;align-items:center;gap:10px}
.brand-icon{width:38px;height:38px;border-radius:10px;background:var(--brand);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.brand-icon svg{width:22px;height:22px}
.brand-name{font-size:15px;font-weight:800;color:var(--text);letter-spacing:-.2px}
.brand-tagline{font-size:11px;color:var(--muted);display:block;font-weight:400}
.nav{display:flex;gap:2px}
.nav a{font-size:13px;font-weight:500;color:var(--muted);padding:8px 14px;border-radius:10px;transition:background .15s,color .15s}
.nav a:hover{background:#f1f5f9;color:var(--text)}
.nav .nav-cta{background:var(--brand);color:#fff !important;font-weight:700;border-radius:10px}
.nav .nav-cta:hover{background:var(--brandh)}
@media(max-width:640px){.nav a:not(.nav-cta){display:none}}

/* ── HERO ── */
.hero{position:relative;overflow:hidden;background:#060f22;border-radius:var(--r-xl);margin:20px 0;color:#fff}
.hero::before{content:"";position:absolute;inset:0;background:url("/assets/hero-bg.jpg") center/cover no-repeat;opacity:.5}
.hero::after{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(0,82,204,.4) 0%,rgba(0,163,255,.12) 60%,transparent 100%)}
.hero-inner{position:relative;z-index:2;display:grid;grid-template-columns:1fr 400px;gap:32px;padding:48px 40px;align-items:start}
@media(max-width:900px){.hero-inner{grid-template-columns:1fr;padding:32px 24px}}
.hero-badge{display:inline-flex;align-items:center;gap:7px;background:rgba(249,115,22,.15);border:1px solid rgba(249,115,22,.35);padding:5px 12px;border-radius:999px;font-size:12px;color:#fb923c;font-weight:600;margin-bottom:16px}
.hero-badge-dot{width:6px;height:6px;border-radius:50%;background:#38bdf8}
.hero h1{font-size:38px;font-weight:800;line-height:1.08;letter-spacing:-.6px;margin-bottom:16px}
.hero h1 span{color:#fb923c}
.hero-lead{font-size:16px;color:rgba(255,255,255,.75);line-height:1.7;margin-bottom:24px;max-width:50ch}
.hero-trust{display:flex;gap:20px;flex-wrap:wrap;font-size:12px;color:rgba(255,255,255,.6)}
.hero-trust-item{display:flex;align-items:center;gap:6px}
@media(max-width:640px){.hero h1{font-size:26px}.hero-inner{padding:28px 16px}.hero{border-radius:14px;margin:12px 0}}

/* ── SUCHKARTE ── */
.search-card{background:#fff;border-radius:var(--r-lg);padding:24px;box-shadow:0 4px 24px rgba(0,0,0,.18);color:var(--text)}
.search-card-title{font-size:17px;font-weight:800;margin-bottom:3px;color:var(--text)}
.search-card-sub{font-size:12px;color:var(--muted);margin-bottom:18px}
.form-row{display:flex;gap:10px;flex-wrap:wrap}
.form-group{flex:1;min-width:140px}
.form-label{display:block;font-size:11px;color:var(--muted);margin-bottom:5px;font-weight:700;text-transform:uppercase;letter-spacing:.4px}
.form-control,select{width:100%;border:1.5px solid var(--line);border-radius:10px;padding:11px 13px;font-size:14px;font-weight:500;outline:none;background:#fff;color:var(--text);font-family:inherit;transition:border-color .15s,box-shadow .15s}
.form-control:focus,select:focus{border-color:var(--brand);box-shadow:0 0 0 3px rgba(26,86,219,.14)}
.select-wrap{position:relative}
.select-wrap select{appearance:none;-webkit-appearance:none;padding-right:32px}
.select-wrap::after{content:"";position:absolute;right:12px;top:50%;transform:translateY(-50%) rotate(45deg);width:7px;height:7px;border-right:2px solid var(--muted);border-bottom:2px solid var(--muted);pointer-events:none}
.filter-toggle-btn{font-size:12px;color:var(--brand);font-weight:600;cursor:pointer;background:none;border:none;padding:6px 0;display:flex;align-items:center;gap:4px;font-family:inherit}
.filter-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:12px}

/* ── BUTTONS ── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;font-size:14px;font-weight:700;font-family:inherit;border-radius:10px;padding:12px 22px;cursor:pointer;border:none;transition:transform .1s,box-shadow .15s,background .15s,color .15s;text-decoration:none;white-space:nowrap;line-height:1}
.btn:active{transform:scale(.98)}
/* Primär: IMMER weißer Text */
.btn-primary{background:var(--brand);color:#fff !important;box-shadow:0 4px 14px rgba(26,86,219,.3)}
.btn-primary:hover{background:var(--brandh);color:#fff !important;box-shadow:0 6px 20px rgba(26,86,219,.4)}
.btn-cta{background:var(--brand2);color:#fff !important;box-shadow:0 4px 14px rgba(249,115,22,.4);font-weight:700}
.btn-cta:hover{background:var(--brand2h);color:#fff !important;box-shadow:0 6px 20px rgba(249,115,22,.5)}
/* Outline */
.btn-outline{background:#fff;color:var(--brand) !important;border:2px solid var(--brand);font-weight:600}
.btn-outline:hover{background:#eff6ff}
/* Ghost für dunkle Backgrounds */
.btn-ghost-dark{background:rgba(255,255,255,.12);color:#fff !important;border:1px solid rgba(255,255,255,.2)}
.btn-ghost-dark:hover{background:rgba(255,255,255,.22)}
/* Größen */
.btn-lg{padding:15px 30px;font-size:16px;border-radius:12px}
.btn-sm{padding:8px 16px;font-size:12px;border-radius:8px}
.btn-full{width:100%}
.btn-submit{background:linear-gradient(135deg,#f97316,#ea6c0a);color:#fff !important;font-size:16px;font-weight:800;padding:15px 28px;border-radius:12px;box-shadow:0 6px 20px rgba(249,115,22,.45);border:none;cursor:pointer;width:100%;font-family:inherit;margin-top:14px;transition:transform .1s,box-shadow .15s;display:block;text-align:center}
.btn-submit:hover{box-shadow:0 8px 28px rgba(249,115,22,.55);transform:translateY(-1px)}

/* ── CARDS ── */
.card{background:var(--card);border:1px solid rgba(0,0,0,.06);border-radius:var(--r);box-shadow:var(--shadow-s)}
.card-content{padding:28px;min-width:0;overflow:hidden}
@media(max-width:640px){.card-content{padding:18px}}
@media(max-width:400px){.card-content{padding:12px 10px}}

/* ── BUBBLES ── */
.bubbles{display:flex;flex-wrap:wrap;gap:8px;margin:14px 0}
/* Auf dunklem Hintergrund */
.bubbles-dark .bubble{background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.18);color:rgba(255,255,255,.90);padding:6px 12px;border-radius:999px;font-size:12px;font-weight:500;display:inline-flex;align-items:center;gap:7px}
.bubbles-dark .bubble .dot{width:6px;height:6px;border-radius:50%;background:#60a5fa;flex-shrink:0}
/* Auf hellem Hintergrund */
.bubbles-light .bubble{background:#eff6ff;border:1px solid #bfdbfe;color:var(--brand);padding:6px 12px;border-radius:999px;font-size:12px;font-weight:600;display:inline-flex;align-items:center;gap:7px}
.bubbles-light .bubble .dot{width:6px;height:6px;border-radius:50%;background:var(--brand);flex-shrink:0}

/* ── MAIN-GRID ── */
.main-grid{display:grid;grid-template-columns:1fr 320px;gap:24px;margin:0 0 40px;align-items:start}
@media(max-width:920px){.main-grid{grid-template-columns:1fr;min-width:0}.sidebar{display:grid;grid-template-columns:1fr 1fr;gap:16px}}
@media(max-width:560px){.sidebar{grid-template-columns:1fr}}

/* ── WIDGET: volle Artikelbreite, INNERHALB des Grids ── */
.widget-section{margin:24px -28px;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
@media(max-width:640px){.widget-section{margin:16px -20px}}
@media(max-width:400px){.widget-section{margin:16px -12px}}
.widget-head{display:flex;align-items:center;justify-content:space-between;padding:10px 20px;background:#f8fafc;border-bottom:1px solid var(--line)}
.widget-badge{display:inline-flex;align-items:center;gap:6px;font-size:11px;font-weight:600;color:var(--muted);background:#fff;border:1px solid var(--line);padding:4px 10px;border-radius:999px}
.widget-badge-dot{width:6px;height:6px;border-radius:50%;background:var(--brand)}
.widget-powered{font-size:11px;color:#94a3b8}
.widget-body iframe{width:100%;height:2700px;border:0;display:block;background:#fff}
@media(max-width:640px){.widget-body iframe{height:3100px}}
.widget-disclaimer{padding:10px 20px;font-size:11px;color:var(--muted);background:#f8fafc;border-top:1px solid var(--line);line-height:1.5}

/* ── BREADCRUMBS ── */
.breadcrumbs{display:flex;align-items:center;flex-wrap:wrap;gap:6px;font-size:12px;color:var(--muted);margin:18px 0 14px}
.breadcrumbs a{color:var(--muted)}
.breadcrumbs a:hover{color:var(--brand)}
.breadcrumbs .sep{color:#cbd5e1}
.breadcrumbs .current{color:var(--text);font-weight:600}

/* ── CTA-BOX ── */
.cta-box{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:18px 22px;background:#f0f7ff;border:1.5px solid #bfdbfe;border-radius:var(--r);margin:22px 0;flex-wrap:wrap}
.cta-box-text{flex:1;min-width:0}
.cta-box-text strong{display:block;font-size:15px;font-weight:700;color:var(--text)}
.cta-box-text span{font-size:13px;color:var(--muted);display:block;margin-top:3px}
.cta-box .btn-primary{flex-shrink:0}
.cta-box .btn-outline{flex-shrink:0}
@media(max-width:560px){.cta-box{flex-direction:column}.cta-box .btn-primary,.cta-box .btn-outline{width:100%;text-align:center}}

/* ── CONTENT-TYPOGRAFIE ── */
.article-content h1{font-size:26px;font-weight:800;margin-bottom:14px;line-height:1.2;color:var(--text)}
.article-content h2{font-size:20px;font-weight:700;margin:30px 0 10px;color:var(--text);border-bottom:2px solid #f1f5f9;padding-bottom:6px}
.article-content h3{font-size:16px;font-weight:700;margin:22px 0 8px;color:var(--text)}
.article-content p{margin-bottom:13px;line-height:1.75;color:var(--text2)}
.article-content ul li{position:relative;padding-left:18px;margin-bottom:8px;line-height:1.65;color:var(--text2);font-size:14px}
.article-content ul li::before{content:"›";position:absolute;left:0;color:var(--brand);font-weight:700}
.article-content a{color:var(--brand);text-decoration:underline;text-underline-offset:2px}

/* ── HOWTO ── */
.howto-step{display:flex;gap:14px;align-items:flex-start;margin-bottom:14px}
.howto-num{width:30px;height:30px;flex-shrink:0;border-radius:50%;background:var(--brand);color:#fff;font-size:13px;font-weight:800;display:flex;align-items:center;justify-content:center;margin-top:1px}
.howto-body strong{display:block;font-size:14px;font-weight:700;color:var(--text);margin-bottom:3px}
.howto-body p{margin:0;font-size:14px;color:var(--text2);line-height:1.65}

/* ── FAQ ── */
.faq-item{border:1px solid var(--line);border-radius:var(--r);background:#fff;margin-bottom:8px;overflow:hidden;transition:border-color .15s}
.faq-item[open]{border-color:#bfdbfe}
.faq-item summary{cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;padding:15px 18px;font-weight:700;font-size:14px;color:var(--text);gap:12px;user-select:none}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:"+";font-size:22px;font-weight:300;color:var(--brand);flex-shrink:0;width:22px;text-align:center}
.faq-item[open] summary::after{content:"−"}
.faq-answer{padding:0 18px 16px;font-size:14px;color:var(--text2);line-height:1.75}

/* ── SIDEBAR ── */
.sidebar>*+*{margin-top:16px}
.sidebar-card{padding:20px}
.sidebar-card h3{font-size:15px;font-weight:800;margin-bottom:12px;color:var(--text)}
.sidebar-links li{margin-bottom:0}
.sidebar-links li a{font-size:13px;color:var(--brand);font-weight:500;display:flex;align-items:center;gap:6px;padding:8px 0;border-bottom:1px solid #f1f5f9;transition:color .15s}
.sidebar-links li:last-child a{border-bottom:none}
.sidebar-links li a:hover{color:var(--brandh)}
.sidebar-links li a::before{content:"›";font-size:16px;color:var(--brand2)}
.sidebar-note{font-size:11px;color:var(--muted);line-height:1.55;margin-top:12px}

/* ── STATS ── */
.stats-bar{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin:24px 0}
.stat-card{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:18px 16px;text-align:center;box-shadow:var(--shadow-s)}
.stat-num{font-size:15px;font-weight:700;color:var(--brand);line-height:1.3;letter-spacing:-.2px}
.stat-label{font-size:12px;color:var(--muted);margin-top:4px;font-weight:500}
@media(max-width:480px){.stats-bar{grid-template-columns:1fr}}

/* ── TECH-KARTEN ── */
.tech-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:14px;margin:16px 0}
.tech-card{padding:18px;background:#fff;border:1px solid var(--line);border-radius:var(--r);transition:border-color .15s,box-shadow .15s}
.tech-card:hover{border-color:#bfdbfe;box-shadow:var(--shadow-s)}
.tech-tag{display:inline-block;font-size:10px;font-weight:700;padding:3px 9px;border-radius:999px;margin-bottom:8px;text-transform:uppercase;letter-spacing:.3px}
.tag-dsl{background:#e0f2fe;color:#0369a1}
.tag-kabel{background:#fef9c3;color:#854d0e}
.tag-ftth{background:#dcfce7;color:#166534}
.tag-lte{background:#fce7f3;color:#9d174d}
.tech-card h4{font-size:14px;font-weight:700;margin-bottom:6px;color:var(--text)}
.tech-card p{font-size:13px;color:var(--muted);line-height:1.6;margin:0}

/* ── ORT-GRID ── */
.ort-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:8px;margin:14px 0}
.ort-grid a{display:block;padding:10px 14px;background:#fff;border:1px solid var(--line);border-radius:10px;font-size:13px;font-weight:500;color:var(--brand);transition:border-color .15s,box-shadow .15s}
.ort-grid a:hover{border-color:var(--brand);box-shadow:var(--shadow-s)}

/* ── FOOTER ── */
.footer{background:#0d1526;color:rgba(255,255,255,.65);padding:48px 0 28px;margin-top:48px}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:28px}
@media(max-width:700px){.footer-grid{grid-template-columns:1fr;gap:28px}}
.footer-brand{display:flex;align-items:center;gap:10px;margin-bottom:14px}
.footer-brand-icon{width:36px;height:36px;border-radius:9px;background:var(--brand);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.footer-brand-icon svg{width:20px;height:20px}
.footer-brand-name{font-size:15px;font-weight:800;color:#fff}
.footer p{font-size:13px;line-height:1.7}
.footer h4{color:#fff;font-size:13px;font-weight:700;margin-bottom:12px}
.footer-links li{margin-bottom:8px}
.footer-links li a{font-size:13px;color:rgba(255,255,255,.55);transition:color .15s}
.footer-links li a:hover{color:#fff}
.footer-bottom{border-top:1px solid rgba(255,255,255,.08);margin-top:36px;padding-top:22px;display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap;font-size:12px;color:rgba(255,255,255,.35)}
.footer-bottom a{color:rgba(255,255,255,.45)}
.footer-bottom a:hover{color:rgba(255,255,255,.75)}

/* ── COOKIE ── */
.cookie-banner{display:none;position:fixed;bottom:20px;left:50%;transform:translateX(-50%);z-index:9999;width:min(540px,calc(100vw - 32px));background:#0d1526;color:rgba(255,255,255,.8);padding:18px 22px;border-radius:16px;box-shadow:0 8px 48px rgba(0,0,0,.4);border:1px solid rgba(255,255,255,.08)}
.cookie-banner p{font-size:13px;line-height:1.65;margin:0 0 14px}
.cookie-banner p a{color:#93c5fd}
.cookie-actions{display:flex;gap:8px;justify-content:flex-end}

.kicker{font-size:11px;color:var(--muted);line-height:1.55}

/* Accessibility */
a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible{outline:3px solid var(--brand);outline-offset:2px;border-radius:4px}

/* Print */
@media print{.header,.footer,.cookie-banner,.cta-box,.hero,.sidebar,.widget-section{display:none !important}.main-grid{grid-template-columns:1fr}}

/* ── Ergebnisseite: einspaltig, volle Breite ── */
.result-article {
  max-width: 100%;
  margin-bottom: 40px;
}
@media(max-width:768px){
  .result-widget-card{
    margin-left:-12px;
    margin-right:-12px;
    border-radius:0;
  }
}
@media(max-width:400px){
  .result-widget-card{
    margin-left:-8px;
    margin-right:-8px;
  }
}
.result-widget-card .widget-head {
  padding: 10px 20px;
  background: #f8fafc;
  border-bottom: 1px solid var(--line);
  display: flex;
  align-items: center;
  justify-content: space-between;
}

/* ── PLZ-Nachbar & Partner-Vergleiche Blöcke ── */
.city-links-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:20px 24px;margin-bottom:20px}
.city-links-card h3{font-size:.9rem;font-weight:700;color:var(--gray-700);margin-bottom:14px}
.city-links-list{display:flex;flex-wrap:wrap;gap:8px}
.city-links-list a{display:inline-flex;align-items:center;padding:5px 13px;border-radius:999px;font-size:13px;font-weight:600;border:1px solid var(--line);color:var(--brand);background:#fff;text-decoration:none;transition:background .15s,color .15s}
.city-links-list a:hover{background:var(--brand);color:#fff;border-color:var(--brand)}
.city-links-list a.current{background:var(--brand);color:#fff;border-color:var(--brand)}

.compare-partners{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:20px 24px;margin-bottom:20px}
.compare-partners-title{display:flex;align-items:center;gap:8px;font-size:.9rem;font-weight:700;color:var(--gray-700);margin-bottom:14px}
.compare-partners-title svg{width:16px;height:16px;flex-shrink:0;color:var(--brand)}
.compare-partners-grid{display:flex;flex-wrap:wrap;gap:8px}
.compare-btn{display:inline-flex;align-items:center;gap:5px;padding:6px 14px;border-radius:999px;font-size:13px;font-weight:600;text-decoration:none;transition:opacity .15s;white-space:nowrap}
.compare-btn:hover{opacity:.82}
.compare-btn-strom{background:#fef3c7;color:#92400e}
.compare-btn-gas{background:#fee2e2;color:#991b1b}
.compare-btn-auto{background:#dbeafe;color:#1e40af}
.compare-btn-solar{background:#fef9c3;color:#854d0e}
.compare-btn-giro{background:#ede9fe;color:#5b21b6}
.compare-btn-kredit{background:#dcfce7;color:#166534}

/* ── MINI-HERO ── */
.mini-hero{background:linear-gradient(135deg,#0d1526 0%,#1a2d52 100%);padding:28px 0;margin:0 0 0;border-bottom:3px solid var(--brand2)}
.mini-hero-inner{display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap}
.mini-hero-label{display:flex;align-items:center;gap:7px;font-size:11px;font-weight:700;color:#fb923c;text-transform:uppercase;letter-spacing:.8px;margin-bottom:6px}
.mini-hero-dot{width:6px;height:6px;border-radius:50%;background:#f97316;flex-shrink:0;box-shadow:0 0 6px #f97316}
.mini-hero-title{font-size:clamp(1.05rem,2.5vw,1.4rem);font-weight:800;color:#fff;line-height:1.25}
.mini-hero-form{flex-shrink:0}
.mini-hero-fields{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.mini-hero-input-wrap{position:relative}
.mini-hero-pin{position:absolute;left:12px;top:50%;transform:translateY(-50%);width:16px;height:16px;color:#64748b;pointer-events:none}
.mini-hero-input{padding:11px 14px 11px 34px;border-radius:10px;border:1.5px solid rgba(255,255,255,.15);background:rgba(255,255,255,.1);color:#fff;font-size:14px;font-weight:600;width:170px;outline:none;font-family:inherit;transition:border-color .15s,background .15s}
.mini-hero-input::placeholder{color:rgba(255,255,255,.45);font-weight:400}
.mini-hero-input:focus{border-color:var(--brand2);background:rgba(255,255,255,.14)}
.btn-submit-mini{background:linear-gradient(135deg,#f97316,#ea6c0a);color:#fff !important;font-size:14px;font-weight:700;padding:11px 20px;border-radius:10px;border:none;cursor:pointer;font-family:inherit;white-space:nowrap;box-shadow:0 4px 14px rgba(249,115,22,.4);transition:box-shadow .15s,transform .1s}
.btn-submit-mini:hover{box-shadow:0 6px 20px rgba(249,115,22,.55);transform:translateY(-1px)}
@media(max-width:640px){.mini-hero-inner{flex-direction:column;align-items:flex-start;gap:12px}.mini-hero-input{width:100%;box-sizing:border-box}.mini-hero-input-wrap{width:100%}.mini-hero-fields{width:100%;flex-direction:column}.btn-submit-mini{width:100%;text-align:center}}

/* Widget-Card volle Breite mobile */
@media(max-width:640px){.article-content .card:has(script[id^="twl-fixed"]){margin-left:-20px;margin-right:-20px;border-radius:0}}
@media(max-width:400px){.article-content .card:has(script[id^="twl-fixed"]){margin-left:-12px;margin-right:-12px}}

/* Ergebnisseite: Cards auf Mobile volle Breite */
@media(max-width:768px){
  article > .card:not(.card-content){
    border-radius:0;
    margin-left:-12px;
    margin-right:-12px;
  }
}

/* ── A-Z ORTSLISTE ── */
.az-bar{display:flex;flex-wrap:wrap;gap:6px;margin:16px 0 12px}
.az-btn{padding:6px 11px;border-radius:8px;border:1.5px solid var(--line);background:#fff;color:var(--text2);font-size:13px;font-weight:600;cursor:pointer;font-family:inherit;transition:background .12s,color .12s,border-color .12s}
.az-btn:hover{background:var(--brand);color:#fff;border-color:var(--brand)}
.az-btn.active{background:var(--brand);color:#fff;border-color:var(--brand)}
.az-all{background:#f1f5f9;border-color:#e2e8f0}
.az-all.active{background:var(--brand2);border-color:var(--brand2);color:#fff}
.az-search-wrap{margin-bottom:14px}
.az-search{width:100%;padding:10px 14px;border:1.5px solid var(--line);border-radius:10px;font-size:14px;font-family:inherit;outline:none;transition:border-color .15s}
.az-search:focus{border-color:var(--brand)}
.az-letter-head{font-size:11px;font-weight:800;color:var(--muted);text-transform:uppercase;letter-spacing:.8px;padding:10px 0 4px;border-bottom:1px solid var(--line);margin-bottom:4px}
.az-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:4px;width:100%;max-width:100%;overflow-x:clip}
.az-entry{display:flex;align-items:center;gap:8px;padding:7px 10px;border-radius:8px;border:1px solid transparent;transition:background .1s,border-color .1s;text-decoration:none;color:var(--text);min-width:0;overflow:hidden}
.az-entry:hover{background:#eff6ff;border-color:#c7d7f8}
.az-plz{font-size:12px;font-weight:700;color:var(--brand);min-width:46px;flex-shrink:0;font-variant-numeric:tabular-nums}
.az-city{font-size:13px;color:var(--text2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;min-width:0}
.az-empty{color:var(--muted);font-size:14px;padding:16px 0}
.az-letter-head{grid-column:1/-1}
@media(max-width:480px){.az-list{grid-template-columns:1fr 1fr}.az-btn{padding:5px 9px;font-size:12px}}

/* ── BUNDESLAND-GRID auf Deutschland-Seite ── */
.bl-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:8px;margin:16px 0 24px;max-width:100%}
.bl-card{display:flex;align-items:center;padding:10px 14px;border-radius:10px;border:1.5px solid var(--line);background:#fff;font-size:13px;font-weight:600;color:var(--brand);transition:background .12s,border-color .12s,color .12s}
.bl-card:hover{background:var(--brand);color:#fff;border-color:var(--brand)}
@media(max-width:480px){.bl-grid{grid-template-columns:1fr 1fr}}

/* az-state label */
.az-state{font-size:11px;color:var(--muted);padding-left:8px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100px;flex-shrink:0}

/* ── PROVIDER LOGO auf Anbieter-Seiten ── */
.provider-logo-wrap{display:flex;align-items:center;margin-bottom:20px;padding:16px 0 4px}
.provider-logo{max-height:60px;width:auto;max-width:200px;object-fit:contain}

/* ── PROVIDER GRID auf dsl-anbieter Seite ── */
.provider-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:12px;margin:16px 0 28px}
.provider-card{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:14px 10px;border-radius:12px;border:1.5px solid var(--line);background:#fff;text-decoration:none;color:var(--text2);font-size:13px;font-weight:600;transition:border-color .15s,box-shadow .15s}
.provider-card:hover{border-color:var(--brand);box-shadow:0 2px 8px rgba(37,99,235,.1);color:var(--brand)}
.provider-card img{max-height:36px;width:auto;max-width:100px;object-fit:contain;filter:grayscale(20%)}
.provider-card:hover img{filter:none}
@media(max-width:480px){.provider-grid{grid-template-columns:repeat(3,1fr)}.provider-card{padding:10px 6px;font-size:12px}.provider-card img{max-height:28px}}
