/* wallbox.one — Ultra Minimal White Design */
html{scroll-behavior:smooth;scroll-padding-top:70px}
:root{
  --blue:#2563eb;--blue-d:#1d4ed8;--green:#16a34a;
  --text:#0f172a;--muted:#64748b;--border:#e2e8f0;
  --bg:#fff;--bg2:#f8fafc;--bg3:#f1f5f9;
  --radius:10px;--shadow:0 1px 3px rgba(0,0,0,.08),0 1px 2px rgba(0,0,0,.06);
  --shadow-md:0 4px 6px -1px rgba(0,0,0,.07),0 2px 4px -1px rgba(0,0,0,.05);
}
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
body{font-family:system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--text);font-size:16px;line-height:1.6;overflow-wrap:break-word}
button,a{touch-action:manipulation}
a{color:var(--blue);text-decoration:none}
a:hover{text-decoration:underline}
img{max-width:100%;height:auto}

/* NAV */
nav{background:#fff;border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100}
.nav-inner{max-width:1200px;margin:0 auto;padding:0 20px;display:flex;align-items:center;gap:32px;height:62px}
.nav-logo{font-weight:700;font-size:1.1rem;color:var(--text);display:flex;align-items:center;gap:8px;flex-shrink:0}
.nav-logo img{height:32px;width:auto}
.nav-links{display:flex;gap:0;flex:1}
.nav-links a{padding:8px 14px;color:var(--muted);font-size:.9rem;border-radius:6px;white-space:nowrap}
.nav-links a:hover{color:var(--text);background:var(--bg2);text-decoration:none}
.nav-cta{margin-left:auto;background:var(--blue);color:#fff!important;padding:8px 18px!important;border-radius:8px!important;font-weight:600;font-size:.88rem!important;flex-shrink:0}
.nav-cta:hover{background:var(--blue-d)!important;text-decoration:none!important}
.nav-cta:active{background:#1e40af!important;transform:scale(.97)}

/* BREADCRUMB */
.breadcrumb{max-width:1200px;margin:0 auto;padding:12px 20px;font-size:.82rem;color:var(--muted)}
.breadcrumb a{color:var(--muted)}
.breadcrumb span{margin:0 6px}
.bc-current{color:var(--text);font-weight:500}
main{display:block}

/* HERO */
.hero{background:linear-gradient(135deg,#0b1e45 0%,#1a3a8a 55%,#0b1e45 100%);border-bottom:none;padding:88px 20px}
.hero-inner{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.hero-label{display:inline-block;background:rgba(255,255,255,.15);color:#fff;font-size:.78rem;font-weight:600;padding:4px 12px;border-radius:20px;margin-bottom:16px;letter-spacing:.02em;text-transform:uppercase;border:1px solid rgba(255,255,255,.25)}
.hero h1{font-size:2.6rem;font-weight:800;line-height:1.18;margin-bottom:16px;color:#fff}
.hero-sub{font-size:1.05rem;color:rgba(255,255,255,.75);margin-bottom:28px;line-height:1.7}
.hero-btns{display:flex;gap:12px;flex-wrap:wrap}
.btn{display:inline-flex;align-items:center;gap:6px;padding:12px 24px;border-radius:8px;font-weight:600;font-size:.95rem;cursor:pointer;border:none;text-decoration:none!important;transition:background .15s,color .15s,border-color .15s,transform .1s,box-shadow .15s}
.btn-primary{background:var(--blue);color:#fff}
.btn-primary:hover{background:var(--blue-d)}
.btn-primary:active{background:#1e40af;transform:scale(.98)}
.btn-outline{background:#fff;color:var(--text);border:1.5px solid var(--border)}
.btn-outline:hover{border-color:var(--blue);color:var(--blue)}
.btn-outline:active{background:var(--bg2);border-color:var(--blue);transform:scale(.98)}
.hero .btn-outline{background:rgba(255,255,255,.1);color:#fff;border-color:rgba(255,255,255,.35)}
.hero .btn-outline:hover{background:rgba(255,255,255,.2);border-color:rgba(255,255,255,.65);color:#fff}
.hero .btn-outline:active{background:rgba(255,255,255,.15)}
.hero-card{background:#fff;border-radius:16px;padding:28px;box-shadow:0 8px 32px rgba(0,0,0,.35);border:1px solid rgba(255,255,255,.12)}
.hero-card h3{font-size:1rem;margin-bottom:20px;color:var(--text)}
.hero-stats{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.stat{background:var(--bg2);padding:14px;border-radius:8px;text-align:center}
.stat-val{font-size:1.5rem;font-weight:800;color:var(--blue)}
.stat-lab{font-size:.75rem;color:var(--muted);margin-top:2px}

/* SECTIONS */
.section{padding:56px 20px}
.section-alt{background:var(--bg2)}
.container{max-width:1200px;margin:0 auto}
.section-label{font-size:.78rem;font-weight:700;color:var(--blue);text-transform:uppercase;letter-spacing:.08em;margin-bottom:10px}
.section-title{font-size:1.85rem;font-weight:800;margin-bottom:12px;line-height:1.15}
.section-sub{color:var(--muted);font-size:1rem;margin-bottom:36px;max-width:600px}

/* GRID */
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}

/* CARD */
.card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow);display:flex;flex-direction:column;transition:box-shadow .15s,border-color .15s,transform .15s,background .15s}
.card:hover{box-shadow:var(--shadow-md);border-color:#c7d7fb;transform:translateY(-1px)}
.card:active{background:var(--bg2);transform:none;transition:none}
.card h3{font-size:1.05rem;font-weight:700;margin-bottom:8px}
.card p{font-size:.9rem;color:var(--muted);line-height:1.6}
.card-link{display:inline-flex;align-items:center;gap:4px;font-size:.85rem;font-weight:600;color:var(--blue);margin-top:auto;padding:14px 0 6px;min-height:44px;align-self:flex-start}
.card-link::after{content:'→'}

/* TABLE */
table{width:100%;border-collapse:collapse;font-size:.9rem}
th{background:var(--bg3);padding:10px 14px;text-align:left;font-weight:600;border-bottom:2px solid var(--border)}
td{padding:10px 14px;border-bottom:1px solid var(--border)}
.tag{display:inline-block;padding:2px 10px;border-radius:20px;font-size:.76rem;font-weight:600}
.tag-blue{background:#dbeafe;color:var(--blue)}
.tag-green{background:#dcfce7;color:var(--green)}
.tag-gray{background:var(--bg3);color:var(--muted)}
.stars{color:#f59e0b}

/* RECHNER */
.rechner-page-h1{font-size:2rem;font-weight:800;margin-bottom:8px;line-height:1.2}
.rechner-box{background:var(--bg2);border:1px solid var(--border);border-top:3px solid var(--blue);border-radius:14px;padding:32px}
.rechner-box h2{font-size:1.4rem;margin-bottom:8px;font-weight:800}
.rechner-box p{color:var(--muted);margin-bottom:24px;font-size:.95rem}
.input-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:16px;margin-bottom:20px}
.input-group{display:flex;flex-direction:column;gap:6px}
.input-group label{font-size:.85rem;font-weight:600;color:var(--text)}
.input-group input,.input-group select{padding:10px 14px;border:1.5px solid var(--border);border-radius:8px;font-size:.95rem;background:#fff;width:100%}
.input-group input:focus,.input-group select:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(37,99,235,.1)}
.rechner-result{background:linear-gradient(135deg,var(--blue),var(--blue-d));color:#fff;border-radius:12px;padding:24px;margin-top:20px;text-align:center;box-shadow:0 8px 24px rgba(37,99,235,.25)}
.rechner-result .result-val{font-size:2.4rem;font-weight:800;margin:4px 0}
.rechner-result .result-lab{font-size:.9rem;opacity:.85}
.rechner-result .result-sub{font-size:.8rem;opacity:.7;margin-top:8px;padding-top:8px;border-top:1px solid rgba(255,255,255,.2)}
.calc-btn{background:var(--blue);color:#fff;border:none;padding:12px 28px;border-radius:8px;font-size:.95rem;font-weight:600;cursor:pointer;margin-top:4px}
.calc-btn:hover{background:var(--blue-d)}
.calc-btn:active{background:#1e40af;transform:scale(.98)}
.rechner-page-desc{color:var(--muted);margin-bottom:24px}

/* HIDE NUMBER SPINNERS */
input[type="number"]::-webkit-outer-spin-button,
input[type="number"]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}
input[type="number"]{-moz-appearance:textfield;appearance:textfield}

/* CONTENT ARTICLE */
.article-wrap{max-width:1200px;margin:0 auto;padding:40px 20px;display:grid;grid-template-columns:1fr 300px;gap:40px;align-items:start}
.article-content h1{font-size:2rem;font-weight:800;margin-bottom:8px}
.article-content .article-meta{color:var(--muted);font-size:.85rem;margin-bottom:28px;padding-bottom:16px;border-bottom:1px solid var(--border)}
.article-content h2{font-size:1.35rem;font-weight:700;margin:32px 0 12px}
.article-content h3{font-size:1.1rem;font-weight:700;margin:24px 0 8px}
.article-content p{margin-bottom:16px;line-height:1.75;color:#1e293b}
.article-content ul,.article-content ol{padding-left:24px;margin-bottom:16px}
.article-content li{margin-bottom:6px;line-height:1.7}
.article-content table{margin:20px 0}
.sidebar{position:sticky;top:80px}
.sidebar-box{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:20px;margin-bottom:16px}
.sidebar-box h4{font-size:.9rem;font-weight:700;margin-bottom:12px}
.sidebar-box ul{list-style:none;padding:0}
.sidebar-box li a{font-size:.85rem;color:var(--muted);padding:6px 0;min-height:36px;display:flex;align-items:center}
.sidebar-box li a:hover{color:var(--blue)}
.sidebar-box li a:active{color:var(--blue-d)}
.info-box{background:#f0f7ff;border-left:4px solid var(--blue);border-radius:0 var(--radius) var(--radius) 0;padding:16px 18px;margin:24px 0}
.info-box strong{color:var(--blue)}

/* ARTICLE LINK UNDERLINES */
.article-content a:not(.card-link):not(.btn){text-decoration:underline;text-underline-offset:3px;text-decoration-thickness:1px}
.article-content a:not(.card-link):not(.btn):hover{color:var(--blue-d)}

/* SPECS TABLE */
.specs-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px;margin:20px 0}
.spec-item{background:var(--bg2);border-radius:8px;padding:14px;text-align:center;transition:.15s}
.spec-item:hover{background:var(--bg3);box-shadow:var(--shadow)}
.spec-val{font-size:1.3rem;font-weight:800;color:var(--blue)}
.spec-val-sub{font-size:.72rem;color:var(--muted);margin-top:3px;line-height:1.3}
.spec-lab{font-size:.75rem;color:var(--muted);margin-top:2px}

/* HERO SIMPLE (subpages) */
.page-hero{background:linear-gradient(180deg,#fff 0%,var(--bg2) 100%);border-bottom:1px solid var(--border);padding:40px 20px}
.page-hero h1{font-size:2rem;font-weight:800;max-width:1200px;margin:0 auto 8px}
.page-hero p{max-width:1200px;margin:0 auto;color:var(--muted);font-size:1rem}
.page-hero-label{display:inline-block;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--blue);background:#dbeafe;padding:3px 10px;border-radius:20px;margin-bottom:10px;margin-left:max(0px,calc((100% - 1200px) / 2))}

/* PROS CONS */
.pros-cons{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin:20px 0}
.pros{background:#f0fdf4;border:1px solid #bbf7d0;border-radius:var(--radius);padding:16px}
.cons{background:#fef2f2;border:1px solid #fecaca;border-radius:var(--radius);padding:16px}
.pros h4{color:var(--green);margin-bottom:10px;font-size:.9rem}
.cons h4{color:#dc2626;margin-bottom:10px;font-size:.9rem}
.pros li,.cons li{font-size:.88rem;margin-bottom:4px;list-style:none;padding-left:18px;position:relative}
.pros li::before{content:'✓';position:absolute;left:0;color:var(--green);font-weight:700}
.cons li::before{content:'✗';position:absolute;left:0;color:#dc2626;font-weight:700}

/* RATING */
.rating-badge{display:inline-flex;align-items:center;gap:6px;background:#fef9c3;border:1px solid #fde047;border-radius:20px;padding:4px 12px;font-size:.88rem;font-weight:700}

/* INDEX GRID CARDS */
.index-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:20px;display:flex;flex-direction:column;gap:8px;box-shadow:var(--shadow);overflow:hidden;transition:box-shadow .15s,border-color .15s,transform .15s,background .15s}
.index-card:hover{border-color:#c7d7fb;box-shadow:var(--shadow-md);transform:translateY(-1px)}
.index-card:active{background:var(--bg2);transform:none;transition:none}
.index-card h3{font-size:.95rem;font-weight:700}
.index-card p{font-size:.83rem;color:var(--muted);flex:1;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.index-card a.full{font-size:.82rem;font-weight:600;color:var(--blue);display:flex;align-items:center;padding-top:10px;margin-top:4px;border-top:1px solid var(--border);min-height:44px}

/* MOBILE HERSTELLER CARDS (hidden on desktop) */
.hb-cards{display:none}
.hb-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;display:flex;align-items:center;gap:14px;box-shadow:var(--shadow);transition:all .15s;text-decoration:none;color:inherit}
.hb-card:hover{text-decoration:none;color:inherit}
.hb-card:active{transform:translateX(3px);border-color:#c7d7fb;box-shadow:var(--shadow-md)}
.hb-card-img{width:72px;height:72px;object-fit:cover;border-radius:8px;flex-shrink:0;background:var(--bg2)}
.hb-card-body{flex:1;min-width:0}
.hb-card-body strong{display:block;font-size:.95rem}
.hb-card-meta{font-size:.78rem;color:var(--muted);margin-top:2px}
.hb-card-link{color:var(--blue);font-size:.82rem;font-weight:600;text-decoration:none;white-space:nowrap;flex-shrink:0}

/* FOOTER */
footer{background:#0f172a;color:#94a3b8;padding:48px 20px 24px}
.footer-inner{max-width:1200px;margin:0 auto}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px;margin-bottom:40px}
.footer-brand p{font-size:.85rem;margin-top:12px;line-height:1.6;max-width:260px}
@media(max-width:640px){.footer-brand p{max-width:none}}
.footer-col h4{color:#e2e8f0;font-size:.88rem;font-weight:700;margin-bottom:14px}
.footer-col a{display:block;font-size:.83rem;color:#64748b;margin-bottom:4px;padding:6px 0;min-height:36px;display:flex;align-items:center}
.footer-col a:hover{color:#e2e8f0;text-decoration:none}
.footer-col a:active{color:#e2e8f0}
.footer-bottom{border-top:1px solid #1e293b;padding-top:20px;font-size:.8rem;display:flex;justify-content:space-between;flex-wrap:wrap;gap:8px}
.footer-logo{font-weight:800;color:#e2e8f0;font-size:1.1rem}
.disclaimer{font-size:.75rem;color:#475569;margin-top:8px;font-style:italic}

/* VIDEO */
.hero-video{position:relative;overflow:hidden}
.hero-bg-video{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);min-width:100%;min-height:100%;z-index:0;opacity:.25;object-fit:cover;pointer-events:none;mix-blend-mode:screen}
.hero-video .hero-inner{position:relative;z-index:1}
.video-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin:24px 0}
.video-card{border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;background:#fff;box-shadow:var(--shadow);transition:all .15s}
.video-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}
.video-card:active{transform:scale(.99);transition:none}
.video-card video{width:100%;display:block;aspect-ratio:16/9;object-fit:cover;background:#0f172a}
.video-card-label{padding:10px 14px;font-size:.85rem;font-weight:600;color:#334155;background:var(--bg2)}
.video-full video{width:100%;display:block;border-radius:14px;box-shadow:var(--shadow-md);background:#0f172a;aspect-ratio:16/9;object-fit:cover}

/* BURGER NAV */
.nav-search-btn{display:flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:9px;background:none;border:none;cursor:pointer;color:var(--muted);flex-shrink:0;transition:background .15s,color .15s;margin-left:auto}
.nav-search-btn:hover{background:var(--bg2);color:var(--text)}
.nav-search-panel{position:fixed;top:62px;left:0;right:0;z-index:101;background:#fff;border-bottom:1px solid var(--border);box-shadow:0 8px 32px rgba(0,0,0,.1);max-height:0;overflow:hidden;transition:max-height .22s cubic-bezier(.4,0,.2,1),opacity .18s}
.nav-search-panel.open{max-height:500px}
.ns-bar{display:flex;align-items:center;gap:10px;padding:14px 20px;max-width:1200px;margin:0 auto}
.ns-input{flex:1;border:1.5px solid var(--border);border-radius:10px;padding:10px 16px;font-size:1rem;outline:none;background:#f8fafc;transition:border-color .15s,background .15s;font-family:inherit}
.ns-input:focus{border-color:var(--blue);background:#fff}
.ns-close-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:8px;background:var(--bg2);border:none;cursor:pointer;color:var(--muted);font-size:1.1rem;flex-shrink:0;line-height:1}
.ns-close-btn:hover{background:var(--bg3);color:var(--text)}
.ns-results{max-width:1200px;margin:0 auto;padding:0 20px 10px}
.ns-item{display:flex;align-items:center;gap:10px;padding:9px 10px;border-radius:8px;text-decoration:none;color:var(--text);transition:background .12s}
.ns-item:hover,.ns-item:focus{background:#f1f5f9;text-decoration:none;outline:none}
.ns-item.ns-active{background:#eff6ff}
.ns-cat{font-size:.62rem;font-weight:700;padding:2px 7px;border-radius:5px;flex-shrink:0;text-transform:uppercase;letter-spacing:.05em;white-space:nowrap}
.ns-cat-hub{background:#dbeafe;color:#1d4ed8}
.ns-cat-rechner{background:#e0e7ff;color:#3730a3}
.ns-cat-hersteller{background:#f1f5f9;color:#475569}
.ns-cat-e-auto{background:#e0f2fe;color:#0369a1}
.ns-cat-photovoltaik{background:#fef3c7;color:#b45309}
.ns-cat-foerderung{background:#d1fae5;color:#065f46}
.ns-cat-vergleich{background:#dbeafe;color:#1e40af}
.ns-cat-ratgeber{background:#ede9fe;color:#6d28d9}
.ns-cat-stecker{background:#ffedd5;color:#c2410c}
.ns-cat-bundesland{background:#ccfbf1;color:#0f766e}
.ns-cat-stadt{background:#fce7f3;color:#be185d}
.ns-title{font-size:.88rem;font-weight:500;flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ns-empty{padding:10px 10px 4px;color:var(--muted);font-size:.88rem}
.ns-hint{font-size:.75rem;color:#94a3b8;padding:0 10px 10px;text-align:center}
.nav-search-bg{display:none;position:fixed;inset:0;top:62px;z-index:100;background:rgba(15,23,42,.25);backdrop-filter:blur(2px)}
.nav-search-bg.open{display:block}
.nav-burger{display:none;flex-direction:column;justify-content:center;gap:5px;cursor:pointer;background:none;border:none;padding:8px;margin-left:8px;width:44px;height:44px;flex-shrink:0}
.nav-burger span{display:block;width:22px;height:2px;background:var(--text);border-radius:2px;transition:transform .2s,opacity .2s}
.nav-burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-burger.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.nav-burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.nav-mobile{display:flex;flex-direction:column;position:fixed;left:0;top:0;bottom:0;width:min(calc(100vw - 48px),400px);background:#fff;z-index:99;overflow-y:auto;transform:translateX(-100%);visibility:hidden;transition:transform .28s cubic-bezier(.4,0,.2,1),visibility 0s linear .28s;box-shadow:4px 0 32px rgba(0,0,0,.18)}
.nav-mobile.open{transform:translateX(0);visibility:visible;transition:transform .28s cubic-bezier(.4,0,.2,1),visibility 0s linear 0s}
.nav-backdrop{display:none;position:fixed;inset:0;top:0;background:rgba(15,23,42,.5);z-index:98;backdrop-filter:blur(3px)}
.nav-backdrop.open{display:block}
/* nm2 drawer layout */
.nm2-head{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid #f1f5f9;flex-shrink:0}
.nm2-brand{display:flex;align-items:center;gap:10px}
.nm2-logo-img{height:26px;width:auto}
.nm2-brand-name{font-size:1.05rem;font-weight:700;letter-spacing:-.01em;color:#0f172a}
.nm2-close{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:10px;background:#f1f5f9;border:none;cursor:pointer;color:#475569;flex-shrink:0}
.nm2-close:hover{background:#e2e8f0}
.nm2-body{flex:1;overflow-y:auto;padding:8px 0 16px}
.nm2-section-label{font-size:.62rem;font-weight:700;letter-spacing:.09em;color:#94a3b8;padding:18px 20px 6px;text-transform:uppercase}
.nm2-row{display:flex;align-items:center;gap:14px;padding:9px 20px;text-decoration:none;color:var(--text);transition:background .15s}
.nm2-row:hover,.nm2-row:active{background:#f8fafc;text-decoration:none}
.nm2-row.nm2-active{background:#eff6ff}
.nm2-icon{display:flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:12px;flex-shrink:0}
.nm2-row-text{flex:1;min-width:0}
.nm2-row-text strong{display:block;font-size:.88rem;font-weight:600;color:#0f172a}
.nm2-row-text span{display:block;font-size:.73rem;color:#64748b;margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.nm2-chev{color:#cbd5e1;flex-shrink:0}
.nm2-footer{display:flex;flex-direction:column;gap:10px;padding:16px 20px;border-top:1px solid #f1f5f9;flex-shrink:0;background:#fff;position:sticky;bottom:0}
.nm2-btn-fill{display:block;text-align:center;padding:13px 16px;border-radius:10px;background:var(--blue);color:#fff;font-weight:600;font-size:.9rem;text-decoration:none;transition:background .15s}
.nm2-btn-fill:hover{background:#1d4ed8;color:#fff;text-decoration:none}
.nm2-btn-out{display:block;text-align:center;padding:12px 16px;border-radius:10px;background:transparent;color:var(--blue);font-weight:600;font-size:.9rem;border:1.5px solid var(--blue);text-decoration:none;transition:background .15s,color .15s}
.nm2-btn-out:hover{background:#eff6ff;text-decoration:none}
.nm-link.nm-active{background:var(--bg2)}
.nm-link-blue{border-left:4px solid #2563eb}
.nm-link-green{border-left:4px solid #16a34a}
.nm-link-slate{border-left:4px solid #64748b}
.nm-link-sky{border-left:4px solid #0284c7}
.nm-link-amber{border-left:4px solid #d97706}
.nm-link-emerald{border-left:4px solid #059669}
.nm-link-violet{border-left:4px solid #7c3aed}
.footer-muted{color:var(--muted)}

/* TABLE RESPONSIVE */
.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:var(--radius)}
.table-wrap table{min-width:480px}
.table-wrap-wide table{min-width:640px}

/* CINEMATIC BANNER */
.cine-banner{position:relative;overflow:hidden;border-radius:16px;box-shadow:0 8px 24px rgba(0,0,0,.12)}
.cine-banner video{width:100%;display:block;max-height:420px;object-fit:cover}
.cine-overlay{position:absolute;inset:0;background:linear-gradient(to right,rgba(15,23,42,.88) 0%,rgba(15,23,42,.55) 55%,rgba(15,23,42,.1) 100%);display:flex;align-items:center;padding:48px 44px}
.cine-text{color:#fff;max-width:540px}
.cine-text h2{font-size:2.2rem;font-weight:800;line-height:1.2;margin-bottom:14px;color:#fff}
.cine-text p{font-size:1rem;opacity:.85;line-height:1.65;margin-bottom:24px}
.cine-btns{display:flex;gap:12px;flex-wrap:wrap}
.cine-btn-p{display:inline-block;background:#2563eb;color:#fff;padding:12px 24px;border-radius:8px;font-weight:600;text-decoration:none;font-size:.95rem}
.cine-btn-g{display:inline-block;background:rgba(255,255,255,.15);border:1.5px solid rgba(255,255,255,.4);color:#fff;padding:12px 24px;border-radius:8px;font-weight:600;text-decoration:none;font-size:.95rem}
.cine-btn-p:hover,.cine-btn-g:hover{text-decoration:none;color:#fff}

/* MOBILE HERO STATS */
.mobile-stats{display:none;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:20px;background:rgba(255,255,255,.12);border-radius:10px;padding:12px 10px;border:1px solid rgba(255,255,255,.2)}
.mobile-stats>div{text-align:center}
.ms-val{display:block;font-size:1.1rem;font-weight:800;color:#93c5fd}
.ms-lab{display:block;font-size:.67rem;color:rgba(255,255,255,.65);margin-top:1px;line-height:1.3}

/* ARTICLE HERO IMAGES */
.art-img{width:100%;border-radius:12px;object-fit:cover;display:block}

/* BACK TO TOP */
.back-top{position:fixed;bottom:max(20px,calc(env(safe-area-inset-bottom) + 12px));right:20px;background:var(--blue);color:#fff;width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.1rem;cursor:pointer;box-shadow:0 4px 12px rgba(37,99,235,.35);border:none;z-index:90;font-weight:700;line-height:1;opacity:0;visibility:hidden;transition:opacity .2s,visibility .2s,transform .1s,background .15s}
.back-top.visible{opacity:1;visibility:visible}
.back-top:hover{background:var(--blue-d)}
.back-top:active{background:#1e40af;transform:scale(.9)}

/* READING PROGRESS BAR */
.reading-bar{position:fixed;top:62px;left:0;height:3px;background:linear-gradient(to right,var(--blue),#60a5fa);z-index:98;width:0;transition:width .08s linear;pointer-events:none}

/* NAV ACTIVE STATE — bottom indicator */
.nav-links a.nav-active{color:var(--text);font-weight:600;background:transparent;position:relative}
.nav-links a.nav-active::after{content:'';position:absolute;bottom:-1px;left:8px;right:8px;height:2px;background:var(--blue);border-radius:2px}

/* Tablet nav: hide links at ≤840px, show burger */
@media(max-width:840px){
  .nav-links{display:none}
  .nav-cta{display:none!important}
  .nav-burger{display:flex;margin-left:0}
}
@media(min-width:841px){.nav-mobile{display:none!important}}

@media(max-width:900px){
  .hero-inner,.footer-grid,.article-wrap{grid-template-columns:1fr}
  .hero-inner .hero-card{display:none}
  .mobile-stats{display:grid}
  .footer-grid{grid-template-columns:1fr 1fr}
  .grid-4{grid-template-columns:repeat(2,1fr)}
  .nav-inner{gap:16px}
  .sidebar{position:static;margin-top:32px}
  .art-img{max-height:320px}
}
@media(max-width:640px){
  /* Typography */
  .hero h1{font-size:1.7rem}
  .section-title{font-size:1.4rem}
  .page-hero h1{font-size:1.55rem}
  .rechner-page-h1{font-size:1.6rem}

  /* Spacing */
  .hero{padding:60px 16px}
  .section{padding:36px 16px}
  .page-hero{padding:28px 16px}
  .article-wrap{padding:24px 16px;gap:24px}
  .rechner-box{padding:20px 16px}
  .breadcrumb{padding:8px 16px}
  .section-sub{display:none}

  /* Card description clamp */
  .grid-topic .card p,.grid-rechner .card p,.grid-hub .index-card p{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}

  /* Hero sub clamp */
  .hero-sub{font-size:.95rem;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}

  /* SEO links 2-col */
  .grid-seo{display:grid!important;grid-template-columns:repeat(2,1fr);gap:8px}

  /* Hero buttons: full-width on mobile */
  .hero-btns{flex-direction:column;gap:10px}
  .hero-btns .btn{width:100%;justify-content:center;padding:14px 20px;font-size:1rem}

  /* Nav */
  .nav-inner{gap:4px}

  /* Breadcrumb: truncate long last item */
  .breadcrumb>span:last-of-type{max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;display:inline-block;vertical-align:bottom}

  /* Grids: 1-col default, overrides for specific grids */
  .grid-2,.grid-3,.grid-4,.pros-cons{grid-template-columns:1fr}
  .grid-rechner{grid-template-columns:repeat(2,1fr)!important;gap:12px}
  .grid-topic{grid-template-columns:repeat(2,1fr)!important;gap:12px}
  .grid-topic .card img{height:120px!important}
  .grid-hub{grid-template-columns:repeat(2,1fr)!important;gap:12px}
  .grid-hub .index-card img{height:110px!important}

  /* Video */
  .video-grid{grid-template-columns:1fr}

  /* Tables */
  .hb-table{display:none}
  .hb-cards{display:flex;flex-direction:column;gap:10px}
  .article-content table,.article-content>table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch}

  /* Footer */
  .footer-grid{grid-template-columns:1fr 1fr}

  /* Cinematic banner: gradient from top+bottom, text at bottom */
  .cine-overlay{background:linear-gradient(to bottom,rgba(15,23,42,.45) 0%,rgba(15,23,42,.88) 55%,rgba(15,23,42,.97) 100%);align-items:flex-end;padding:20px}
  .cine-text{max-width:100%}
  .cine-text h2{font-size:1.3rem}
  .cine-text p{font-size:.88rem;margin-bottom:14px}
  .cine-banner video{max-height:260px}
  .cine-btns .cine-btn-p,.cine-btns .cine-btn-g{width:100%;text-align:center;padding:12px 16px}

  /* Article typography */
  .article-content h1{font-size:1.6rem;line-height:1.2}
  .article-content h2{font-size:1.15rem;margin:20px 0 10px;line-height:1.25}
  .article-content p{font-size:.95rem}

  /* Specs grid mobile */
  .spec-val{font-size:1.05rem}

  /* Page-hero */
  .page-hero h1{line-height:1.15}
  .page-hero p{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}

  /* Hero bg video: hide on mobile (bandwidth) */
  .hero-bg-video{display:none}

  /* Sidebar: show below article content on mobile, 2-col layout */
  .sidebar{border-top:1px solid var(--border);padding-top:20px;margin-top:4px;display:grid;grid-template-columns:1fr 1fr;gap:12px}
  .sidebar-box{margin-bottom:0}

  /* SEO links: remove double spacing from inline margin + grid gap */
  .grid-seo a{margin-bottom:0!important}

  /* Article hero images: capped height */
  .art-img{max-height:210px;margin-bottom:16px!important;margin-top:12px;border-radius:8px}

  /* Calc button full-width */
  .calc-btn{width:100%;padding:14px;font-size:1rem;border-radius:10px}

  /* iOS auto-zoom fix: inputs need 16px font + explicit touch height */
  .input-group input,.input-group select{font-size:16px!important;min-height:44px;padding:10px 14px}

  /* Page-hero: remove bg image on mobile (gradient too heavy on small screens) */
  .page-hero{background-image:none!important}

  /* Rechner result: smaller val on narrow screens */
  .rechner-result .result-val{font-size:2rem}

  /* Kill hover transforms on touch (no hover state on mobile) */
  .card:hover{transform:none;transition:none}
  .index-card:hover{transform:none;transition:none}
  .card:active{background:var(--bg2)}
  .index-card:active{background:var(--bg2)}
}
@media(max-width:480px){
  .footer-grid{grid-template-columns:1fr}
  .hero h1{font-size:1.5rem}
  .grid-topic{grid-template-columns:1fr!important}
  .grid-rechner{grid-template-columns:repeat(2,1fr)!important}
  .video-grid{grid-template-columns:1fr}
  .sidebar{grid-template-columns:1fr}
  .grid-seo{grid-template-columns:1fr!important}
}

/* TOUCH DEVICES: suppress hover lifts, add :active feedback */
@media(hover:none){
  .card:hover,.index-card:hover{transform:none!important;box-shadow:var(--shadow)!important;border-color:var(--border)!important;transition:none}
  .video-card:hover{transform:none!important;box-shadow:var(--shadow)!important}
}

/* R1: FOCUS-VISIBLE — keyboard & accessibility */
:focus-visible{outline:2px solid var(--blue);outline-offset:3px;border-radius:4px}
.btn:focus-visible,.calc-btn:focus-visible,.nav-cta:focus-visible{outline-offset:2px}
a:focus:not(:focus-visible){outline:none}
input:focus-visible,select:focus-visible{outline:none}

/* R2: INPUT TRANSITIONS — polished focus */
.input-group input,.input-group select{transition:border-color .15s,box-shadow .15s}

/* R3: NAV-LINKS TRANSITION — smoother hover */
.nav-links a{transition:background .15s,color .15s}

/* R4: ARTICLE PROSE MAX-WIDTH — better readability */
@media(min-width:901px){.article-content{max-width:740px}}

/* R5: TABLE ZEBRA ROWS — scannable without hover */
tr:nth-child(even) td{background:var(--bg2)}
tr:nth-child(odd) td{background:#fff}
tr:hover td{background:var(--bg3)!important}

/* R6: TABLE-WRAP SCROLL SHADOW — indicates overflow (inset works within overflow:auto) */
.table-wrap{box-shadow:inset -8px 0 8px -8px rgba(0,0,0,.08)}

/* R7: INFO-BOX LINKS — clearly clickable */
.info-box a{text-decoration:underline;text-underline-offset:2px;text-decoration-thickness:1px}

/* R8: SIDEBAR OVERFLOW — tall sidebars scroll */
@media(min-width:901px){.sidebar{max-height:calc(100vh - 100px);overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--border) transparent}}

/* R9: RECHNER RESULT FADE-IN */
@keyframes slideUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
.rechner-result{animation:slideUp .25s ease}

/* R10: SKIP-TO-CONTENT — accessibility */
.skip-link{position:absolute;top:-48px;left:16px;background:var(--blue);color:#fff;padding:10px 18px;border-radius:0 0 8px 8px;font-weight:600;font-size:.9rem;z-index:999;text-decoration:none;transition:top .15s}
.skip-link:focus{top:0;text-decoration:none;color:#fff}

/* R11 (B1): SPEC-ITEM ACTIVE — tap feedback on mobile */
.spec-item:active{transform:scale(.97);background:var(--bg3);transition:none}

/* R12 (B2): SUPPRESS HOVER LIFTS ON TOUCH — expand @hover:none */
@media(hover:none){
  .hb-card:hover{transform:none!important;border-color:var(--border)!important;box-shadow:var(--shadow)!important}
  .spec-item:hover{background:var(--bg2)!important;box-shadow:none!important}
}

/* R13 (B3): GLOBAL LINK COLOR TRANSITION */
a{transition:color .1s}
.btn{transition:background .15s,color .15s,border-color .15s,transform .1s,box-shadow .15s}

/* R14 (B4): ART-IMG LOADING BACKGROUND — no white flash */
.art-img{background:var(--bg2)}
img[loading="lazy"]{background:var(--bg2)}

/* R15 (B5): SAFE-AREA — footer + mobile nav CTA for iPhone notch */
footer{padding-bottom:max(24px,calc(env(safe-area-inset-bottom) + 24px))}
.nm-cta-wrap{padding-bottom:max(20px,calc(env(safe-area-inset-bottom) + 12px))}

/* R16 (B6): CTA-ROW UTILITY CLASS */
.cta-row{display:flex;gap:12px;flex-wrap:wrap;margin:20px 0}
@media(max-width:640px){.cta-row{flex-direction:column}.cta-row .btn{width:100%;justify-content:center}}

/* C1: CARD LINK WRAPPER — <a> wrapping full card */
.card-wrap{display:block;text-decoration:none!important;color:inherit}
.card-wrap:hover,.card-wrap:focus{text-decoration:none!important;color:inherit}

/* C2: CARD IMAGES */
.card-img-top{width:calc(100% + 40px);height:160px;object-fit:cover;border-radius:var(--radius) var(--radius) 0 0;margin:-20px -20px 14px;display:block;background:var(--bg2)}
.card-img-flat{width:100%;height:160px;object-fit:cover;display:block;background:var(--bg2)}
.rechner-img-mini{width:100%;height:110px;object-fit:cover;display:block;background:var(--bg2)}
.card-body{padding:20px}
.card-body-sm{padding:12px 14px}
.card-body-sm strong{font-size:.88rem;display:block;margin-bottom:2px}
.card-body-sm span{font-size:.78rem;color:var(--muted)}

/* C3: SEO LINK — "Beliebte Themen" list links */
.seo-link{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:11px 14px;background:#fff;border:1px solid var(--border);border-radius:8px;font-size:.88rem;color:var(--blue);text-decoration:none;transition:border-color .15s,background .15s,color .15s}
.seo-link:hover{border-color:#c7d7fb;background:var(--bg2);text-decoration:none;color:var(--blue-d)}
.seo-link:active{background:var(--bg3);transition:none}
.seo-link-arr{flex-shrink:0;opacity:.5;font-size:1rem;transition:transform .15s}
.seo-link:hover .seo-link-arr{transform:translateX(3px);opacity:.8}

/* C4: CTA ROW CENTERED VARIANT */
.cta-row-center{justify-content:center}

/* R18-00: COLOR TOKENS — extended palette */
:root{--amber:#d97706;--sky:#0284c7}

/* R18-01: CARD-TOP-* — colored top-border accent cards (hub sub-pages) */
.card-top-amber{border-top:3px solid var(--amber)}
.card-top-green{border-top:3px solid var(--green)}
.card-top-sky{border-top:3px solid var(--sky)}

/* R18-02: RECHNER-WRAP — centered narrow wrapper on rechner pages */
.rechner-wrap{max-width:700px;margin:0 auto}

/* R18-03: RELATED RECHNER GRID — top margin in context */
.rechner-related .grid-rechner{margin-top:12px}

/* R18-04: CARD STRONG+P — small desc below strong in plain cards */
.card strong+p{margin-top:4px}

/* R18-05: ERROR PAGE — 404 layout */
.error-section{text-align:center;padding:80px 20px}
.error-title{font-size:2rem;font-weight:800;margin:16px 0;line-height:1.2}
.error-desc{color:var(--muted);margin-bottom:24px}

/* CONNECTOR-NOTE — stecker/connector hint below specs grid */
.connector-note{font-size:.85rem;color:var(--muted);margin:8px 0 20px}

/* R18-0: SIDEBAR-IMG — image inside a sidebar-box */
.sidebar-img{width:100%;border-radius:8px;display:block;object-fit:cover;background:var(--bg2)}

/* R18-AA: POST-DATE — article date/meta in ratgeber hub cards */
.post-date{font-size:.78rem;color:#94a3b8;margin-top:4px}

/* R18-AB: ART-IMG-POST — post page hero image (larger than default art-img) */
.art-img-post{max-height:380px;margin:16px 0 28px}
@media(max-width:640px){.art-img-post{max-height:200px;margin:12px 0 20px}}

/* R18-AC: CARD-BADGE — colored text badge at top of recommendation cards */
.card-badge{font-size:.78rem;font-weight:700;color:#16a34a;margin-bottom:8px}

/* R18-AD: SECTION-H2 — standalone h2 inside .section (not article-content) */
.section-h2{font-size:1.35rem;font-weight:700;margin:32px 0 12px}
.section-h2-lg{font-size:1.35rem;font-weight:700;margin:40px 0 12px}

/* R18-AE: STARS-SM — stars at .9rem (table context) */
.stars-sm{color:#f59e0b;font-size:.9rem}

/* R18-AF: NARROW-SECTION — centered narrow content column */
.narrow-section{max-width:800px}

/* R18-A: INDEX-CARD-IMG — full-bleed image in secondary cross-link grids */
.index-card-img{width:calc(100% + 40px);height:130px;object-fit:cover;border-radius:var(--radius) var(--radius) 0 0;margin:-20px -20px 14px;display:block;background:var(--bg2)}
@media(max-width:640px){.index-card-img{height:100px}}

/* R18-B: SECTION-IMG — content image on bundesland / stadt / stecker / etc. pages */
.section-img{width:100%;border-radius:12px;margin:20px 0 24px;object-fit:cover;max-height:280px;display:block;background:var(--bg2)}
@media(max-width:640px){.section-img{max-height:180px;border-radius:8px}}

/* R18-C: VIDEO-FULL-MY — video-full with vertical margin */
.video-full-my{margin:32px 0}

/* R18-D: CARD-TITLE-LINK — link inside card heading that looks like text */
.card-title-link{color:inherit;text-decoration:none}
.card-title-link:hover{text-decoration:underline;color:inherit}

/* R18-E: SIDEBAR-FACTS — small key-value paragraph in sidebar */
.sidebar-facts{font-size:.85rem;line-height:1.7}

/* R18: BTN-SM — compact button variant */
.btn-sm{padding:6px 14px!important;font-size:.82rem!important}

/* R19: SECTION-MORE — "Alle ansehen" link row */
.section-more{margin-top:16px;font-size:.85rem;color:var(--muted)}
.section-more a{color:var(--blue);font-weight:600}
.section-more a:hover{color:var(--blue-d)}

/* R20: SECTION-TITLE-SM — smaller heading for in-page sections */
.section-title-sm{font-size:1.5rem;font-weight:800;margin-bottom:12px;line-height:1.15}

/* R21: CARD-MEDIA — card with full-bleed image (no padding, overflow hidden) */
.card.card-media{padding:0;overflow:hidden}

/* R22: CARD-BODY typography — body paragraph indent + strong size in cards */
.card-body p{margin-top:6px}
.card strong{font-size:.9rem;font-weight:700}

/* R23: RECHNER-HERO-IMG — hero image on rechner pages */
.rechner-hero-img{width:100%;border-radius:12px;margin-bottom:28px;object-fit:cover;max-height:220px;display:block;background:var(--bg2)}
@media(max-width:640px){.rechner-hero-img{max-height:160px;margin-bottom:18px;border-radius:8px}}

/* R24: CINE-LABEL — cinematic banner eyebrow label */
.cine-label{font-size:.74rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:#93c5fd;margin-bottom:14px}

/* R25: RECHNER-RELATED — related calculators section wrapper */
.rechner-related{margin-top:40px}

/* R26: VIDEO-FULL SPACING */
.video-full+.video-full,.video-full-mt{margin-top:20px}

/* R27: ART-IMG desktop max-height + margin-bottom */
.art-img{max-height:320px;margin-bottom:24px}

/* R17 (B7): PRINT STYLES */
@media print{
  nav,.nav-mobile,.nav-backdrop,.back-top,.reading-bar,.skip-link,.breadcrumb,footer,.sidebar-box img{display:none!important}
  .article-wrap{display:block;padding:0}
  .sidebar{display:none}
  body{font-size:12pt;color:#000}
  a{color:#000;text-decoration:underline}
  .article-content h1{font-size:18pt}
  .article-content h2{font-size:14pt}
}

/* NL: NEWSLETTER STRIP */
.nl-strip{background:#eff6ff;border-top:1px solid #dbeafe;padding:28px 0}
.nl-strip-inner{max-width:1100px;margin:0 auto;padding:0 24px;display:flex;align-items:center;gap:24px;flex-wrap:wrap}
.nl-strip-text{flex:1;min-width:180px}
.nl-strip-text strong{display:block;font-size:1rem;font-weight:700;color:#1d4ed8;margin-bottom:3px}
.nl-strip-text span{font-size:.86rem;color:#64748b}
.nl-form{display:flex;gap:8px;flex-shrink:0}
.nl-input{border:1px solid #cbd5e1;border-radius:8px;padding:9px 14px;font-size:.9rem;min-width:220px;outline:none;font-family:inherit}
.nl-input:focus{border-color:#2563eb;box-shadow:0 0 0 3px rgba(37,99,235,.12)}
.nl-btn{background:#2563eb;color:#fff;border:none;border-radius:8px;padding:9px 20px;font-size:.9rem;font-weight:600;cursor:pointer;white-space:nowrap}
.nl-btn:hover{background:#1d4ed8}
@media(max-width:640px){.nl-strip-inner{flex-direction:column;align-items:stretch;gap:16px}.nl-form{flex-direction:column}.nl-input{min-width:0;width:100%}.nl-btn{width:100%}}

/* NL-PAGE: Newsletter Landing Page Form */
.nl-page-form{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;padding:28px;max-width:480px;margin:28px 0}
.nl-page-input{width:100%;border:1px solid #cbd5e1;border-radius:8px;padding:10px 14px;font-size:.95rem;outline:none;box-sizing:border-box;font-family:inherit}
.nl-page-input:focus{border-color:#2563eb;box-shadow:0 0 0 3px rgba(37,99,235,.12)}
.nl-page-hint{font-size:.78rem;color:#94a3b8;margin-top:10px}

/* EXIT INTENT POPUP — LadeStationGuru */
.lsg-overlay{display:none;position:fixed;inset:0;z-index:9999;background:rgba(0,0,0,.55);backdrop-filter:blur(4px);align-items:center;justify-content:center;padding:16px}
.lsg-overlay.visible{display:flex}
.lsg-popup{background:#fff;border-radius:20px;padding:40px 36px;max-width:460px;width:100%;position:relative;box-shadow:0 20px 64px rgba(0,0,0,.3);text-align:center}
.lsg-popup-close{position:absolute;top:14px;right:16px;background:none;border:none;font-size:1.5rem;color:var(--muted);cursor:pointer;line-height:1;padding:4px 8px;border-radius:6px;transition:background .1s,color .1s}
.lsg-popup-close:hover{background:var(--bg2);color:var(--text)}
.lsg-badge{display:inline-block;background:#dcfce7;color:#15803d;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;padding:4px 12px;border-radius:20px;margin-bottom:18px}
.lsg-logo{font-size:1.7rem;font-weight:800;color:var(--text);margin-bottom:4px;letter-spacing:-.01em}
.lsg-domain{font-size:.85rem;color:var(--blue);font-weight:600;margin-bottom:14px}
.lsg-tagline{color:var(--muted);font-size:.95rem;line-height:1.65;margin-bottom:24px}
.lsg-stats{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px;margin-bottom:24px}
.lsg-stat{background:var(--bg2);border-radius:10px;padding:12px 8px}
.lsg-stat strong{display:block;font-size:1.1rem;font-weight:800;color:var(--blue);margin-bottom:2px}
.lsg-stat span{font-size:.72rem;color:var(--muted);line-height:1.3}
.lsg-cta{display:block;background:var(--blue);color:#fff;padding:14px 24px;border-radius:10px;font-weight:700;font-size:1rem;text-decoration:none;transition:background .15s}
.lsg-cta:hover{background:var(--blue-d);text-decoration:none;color:#fff}
.lsg-note{font-size:.78rem;color:var(--muted);margin-top:10px}
@media(max-width:480px){
  .lsg-popup{padding:28px 20px;border-radius:14px}
  .lsg-logo{font-size:1.4rem}
  .lsg-stats{grid-template-columns:1fr 1fr 1fr;gap:6px}
}
/* ── Cookie Banner ────────────────────────────────────────────── */
.cookie-banner{position:fixed;bottom:0;left:0;right:0;z-index:9997;background:#0f172a;color:#e2e8f0;padding:16px 20px;transform:translateY(110%);transition:transform .35s cubic-bezier(.4,0,.2,1);box-shadow:0 -4px 24px rgba(0,0,0,.35)}
.cookie-banner.show{transform:translateY(0)}
.cookie-inner{max-width:900px;margin:0 auto;display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.cookie-text{font-size:.82rem;line-height:1.55;margin:0;flex:1;min-width:220px;color:#cbd5e1}
.cookie-text strong{color:#f1f5f9}
.cookie-text a{color:#60a5fa;text-decoration:none}
.cookie-text a:hover{text-decoration:underline}
.cookie-btns{display:flex;gap:8px;flex-shrink:0}
.cookie-btn-ok{background:#2563eb;color:#fff;border:none;border-radius:8px;padding:8px 18px;font-size:.82rem;font-weight:600;cursor:pointer;transition:background .15s}
.cookie-btn-ok:hover{background:#1d4ed8}
.cookie-btn-min{background:transparent;color:#94a3b8;border:1px solid #334155;border-radius:8px;padding:8px 16px;font-size:.82rem;font-weight:500;cursor:pointer;transition:border-color .15s,color .15s}
.cookie-btn-min:hover{border-color:#64748b;color:#e2e8f0}
/* ── Push Prompt ──────────────────────────────────────────────── */
.push-prompt{position:fixed;bottom:24px;right:24px;z-index:9996;background:#fff;border-radius:16px;box-shadow:0 8px 40px rgba(0,0,0,.18);padding:22px 22px 18px;width:268px;transform:translateX(calc(100% + 40px));transition:transform .4s cubic-bezier(.4,0,.2,1);text-align:center}
.push-prompt.show{transform:translateX(0)}
.push-close{position:absolute;top:10px;right:12px;background:none;border:none;font-size:1.3rem;color:#94a3b8;cursor:pointer;line-height:1;padding:2px 6px;border-radius:6px;transition:color .15s,background .15s}
.push-close:hover{color:#1e293b;background:#f1f5f9}
.push-bell{width:48px;height:48px;background:#eff6ff;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 12px;color:#2563eb}
.push-prompt strong{display:block;font-size:.95rem;font-weight:700;color:#1e293b;margin-bottom:6px}
.push-prompt p{font-size:.78rem;color:#64748b;line-height:1.55;margin:0 0 14px}
.push-btn-yes{display:block;width:100%;background:#2563eb;color:#fff;border:none;border-radius:9px;padding:10px;font-size:.84rem;font-weight:600;cursor:pointer;margin-bottom:7px;transition:background .15s}
.push-btn-yes:hover{background:#1d4ed8}
.push-btn-no{display:block;width:100%;background:none;border:none;color:#94a3b8;font-size:.78rem;cursor:pointer;padding:4px;transition:color .15s}
.push-btn-no:hover{color:#475569}
.push-toast{position:fixed;bottom:80px;right:24px;z-index:9999;background:#16a34a;color:#fff;font-size:.85rem;font-weight:600;padding:12px 20px;border-radius:10px;box-shadow:0 4px 20px rgba(0,0,0,.2);animation:pushToastIn .4s ease forwards}
@keyframes pushToastIn{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
/* ── Newsletter Inline ────────────────────────────────────────── */
.nl-inline{background:linear-gradient(120deg,#1e3a8a 0%,#2563eb 100%);border-radius:16px;padding:32px 36px;display:flex;align-items:center;gap:32px;flex-wrap:wrap}
.nl-inline-text{flex:1;min-width:200px}
.nl-inline-text h3{font-size:1.2rem;font-weight:700;color:#fff;margin:0 0 6px}
.nl-inline-text p{font-size:.88rem;color:#bfdbfe;margin:0;line-height:1.55}
.nl-inline-form{display:flex;flex-wrap:wrap;gap:8px;align-items:flex-start;position:relative}
.nl-inline-input{flex:1;min-width:200px;padding:11px 16px;border:none;border-radius:9px;font-size:.9rem;background:#fff;color:#1e293b;outline:none;box-shadow:0 2px 8px rgba(0,0,0,.12)}
.nl-inline-input:focus{box-shadow:0 0 0 3px rgba(255,255,255,.4)}
.nl-inline-btn{background:#fff;color:#1d4ed8;border:none;border-radius:9px;padding:11px 22px;font-size:.9rem;font-weight:700;cursor:pointer;transition:background .15s,color .15s;white-space:nowrap}
.nl-inline-btn:hover{background:#eff6ff}
.nl-inline-note{width:100%;font-size:.73rem;color:#93c5fd;margin:2px 0 0;line-height:1.4}
@media(max-width:640px){
  .cookie-inner{flex-direction:column;align-items:flex-start;gap:12px}
  .cookie-btns{width:100%;justify-content:flex-end}
  .push-prompt{right:12px;bottom:12px;width:calc(100vw - 24px);max-width:320px}
  .nl-inline{padding:24px 20px;gap:20px}
  .nl-inline-text h3{font-size:1.05rem}
  .nl-inline-input{min-width:0}
}
