/* ═══════════════════════════════════════════
   sparego Theme – main.css
   Mobile-First · Performance-optimiert
   Version: 1.0.0
═══════════════════════════════════════════ */

/* ── TYPOGRAFIE ── */
h1{font-size:clamp(1.6rem,4.5vw,2.7rem);line-height:1.2;font-weight:800}
h2{font-size:clamp(1.2rem,3vw,1.85rem);line-height:1.25;font-weight:700;margin-bottom:12px}
h3{font-size:clamp(1rem,2vw,1.2rem);font-weight:700;margin-bottom:8px}
h4{font-size:.95rem;font-weight:700;margin-bottom:5px}
p{color:var(--sm);margin-bottom:14px;line-height:1.75}
p:last-child{margin-bottom:0}
strong{color:var(--sl)}

/* ── HILFKLASSEN ── */
.eyebrow{display:inline-block;font-size:.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--blue);background:var(--bl);padding:5px 12px;border-radius:999px;margin-bottom:14px}
.section{padding:48px 0}
@media(min-width:768px){.section{padding:64px 0}}
.section--alt{background:#fff}
.section--dark{background:var(--sl);color:rgba(255,255,255,.85)}
.text-center{text-align:center}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* ── GRID ── */
.grid-2{display:grid;grid-template-columns:1fr;gap:20px}
.grid-3{display:grid;grid-template-columns:1fr;gap:16px}
.grid-4{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(min-width:600px){.grid-3{grid-template-columns:1fr 1fr}}
@media(min-width:768px){.grid-2{grid-template-columns:1fr 1fr}.grid-3{grid-template-columns:1fr 1fr 1fr}}
@media(min-width:960px){.grid-4{grid-template-columns:repeat(4,1fr)}}

/* ── HEADER / NAV ── */
.nav-links{display:none}
@media(min-width:900px){
  .nav-links{display:flex;align-items:center;gap:20px}
  .nav-links a{font-size:.84rem;font-weight:600;color:var(--sm);transition:color .2s}
  .nav-links a:hover{color:var(--blue)}
}
.nav-cta{background:var(--orange);color:#fff!important;padding:8px 18px;border-radius:var(--rr);font-weight:700!important}
.nav-cta:hover{background:var(--od)!important}

/* Mobiles Hamburger-Menü */
.menu-toggle{display:flex;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px;-webkit-tap-highlight-color:transparent}
.menu-toggle span{display:block;width:24px;height:2px;background:var(--sl);transition:all .3s;border-radius:2px}
.menu-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.menu-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.menu-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
@media(min-width:900px){.menu-toggle{display:none}}

.mobile-menu{display:none;position:fixed;top:64px;left:0;right:0;bottom:0;background:#fff;z-index:99;overflow-y:auto;padding:24px 20px}
.mobile-menu.is-open{display:block}
.mobile-menu a{display:block;padding:13px 0;border-bottom:1px solid var(--border);font-size:.95rem;font-weight:600;color:var(--sl)}
.mobile-menu a:last-child{border-bottom:none}
.mobile-menu .menu-category{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--ss);margin:20px 0 8px;padding-bottom:4px;border-bottom:2px solid var(--border)}

/* ── HERO ── */
.hero::before{content:'';position:absolute;top:-60px;right:-40px;width:320px;height:320px;background:radial-gradient(circle,rgba(247,168,0,.2),transparent 70%);border-radius:50%;pointer-events:none}
@media(min-width:860px){
  .hero-inner{display:grid;grid-template-columns:1.15fr 1fr;gap:48px;align-items:center}
}
.hero-eyebrow{display:inline-flex;align-items:center;gap:6px;background:rgba(247,168,0,.2);border:1px solid rgba(247,168,0,.4);color:#FFD54F;border-radius:999px;font-size:.78rem;font-weight:700;padding:5px 14px;margin-bottom:14px}
.hero-lead{color:rgba(255,255,255,.82);font-size:.95rem;margin-bottom:20px}
.hero-pills{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:24px}
.pill{display:inline-flex;align-items:center;gap:5px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.2);border-radius:999px;padding:4px 13px;font-size:.76rem;color:rgba(255,255,255,.85)}
.pill-tick{color:var(--orange)}
.hero-btns{display:flex;flex-direction:column;gap:10px;flex-wrap:wrap}
@media(min-width:480px){.hero-btns{flex-direction:row}}
.btn-primary{background:var(--orange);color:#fff;padding:14px 26px;font-size:.95rem;border-radius:var(--rr);box-shadow:0 4px 14px rgba(247,168,0,.4)}
.btn-primary:hover{background:var(--od)}
.btn-secondary{background:rgba(255,255,255,.12);color:#fff;border:1.5px solid rgba(255,255,255,.3);padding:13px 22px;font-size:.9rem;border-radius:var(--rr)}
.btn-secondary:hover{background:rgba(255,255,255,.22)}

/* Spar-Box im Hero */
.hero-savings{background:#fff;border-radius:var(--rl);box-shadow:0 10px 40px rgba(43,157,212,.18);overflow:hidden;margin-top:28px}
@media(min-width:860px){.hero-savings{margin-top:0}}
.hs-head{background:var(--orange);padding:13px 18px;font-size:.8rem;font-weight:700;color:#fff}
.hs-body{padding:16px 18px}
.hs-row{display:flex;justify-content:space-between;align-items:center;padding:8px 10px;border-radius:6px;background:var(--bg);margin-bottom:5px;font-size:.8rem}
.hs-lbl{color:var(--sm)}
.hs-val{font-weight:800;color:var(--blue)}
.hs-row.hl{background:var(--gp);border:1px solid #A7E8C7}
.hs-row.hl .hs-val{color:var(--green);font-size:.92rem}
.hs-note{font-size:.68rem;color:var(--ss);margin-top:8px;text-align:center}

/* ── ANCHOR NAV ── */
.anchor-nav{background:#fff;border-bottom:2px solid var(--border);position:sticky;top:64px;z-index:90}
.anav-scroll{max-width:1140px;margin:0 auto;display:flex;overflow-x:auto;scrollbar-width:none;-webkit-overflow-scrolling:touch;padding:0 16px}
.anav-scroll::-webkit-scrollbar{display:none}
.anav-scroll a{padding:13px 16px;font-size:.8rem;font-weight:600;color:var(--ss);white-space:nowrap;border-bottom:3px solid transparent;transition:color .2s,border-color .2s;-webkit-tap-highlight-color:transparent}
.anav-scroll a:hover,.anav-scroll a.active{color:var(--blue);border-color:var(--blue)}

/* ── VERGLEICHS-WIDGET (Check24) ── */
.widget-card{background:#fff;border:2px solid var(--blue);border-radius:var(--rl);overflow:hidden;margin-bottom:32px;box-shadow:var(--shadow)}
.wc-head{background:linear-gradient(90deg,var(--blue),var(--bd));padding:16px 22px;display:flex;align-items:center;gap:12px}
.wc-head-icon{width:40px;height:40px;background:rgba(255,255,255,.18);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:1.3rem;flex-shrink:0}
.wc-head h2{color:#fff;margin:0;font-size:1rem}
.wc-head p{color:rgba(255,255,255,.75);font-size:.78rem;margin:2px 0 0}
.wc-body{background:#fff;overflow:hidden}
.wc-foot{display:flex;gap:12px;flex-wrap:wrap;padding:10px 22px;background:var(--bg);border-top:1px solid var(--border);font-size:.72rem;color:var(--ss);font-weight:600}
.wc-foot span{display:flex;align-items:center;gap:4px}

/* ── STROMPREIS-RECHNER ── */
.rechner-card{background:#fff;border:2px solid var(--orange);border-radius:var(--rl);overflow:hidden;margin-bottom:32px;box-shadow:var(--shadow)}
.rc-head{background:linear-gradient(90deg,var(--orange),var(--od));padding:16px 22px;display:flex;align-items:center;gap:12px}
.rc-head h2{color:#fff;margin:0;font-size:1rem}
.rc-head p{color:rgba(255,255,255,.78);font-size:.78rem;margin:2px 0 0}
.rc-body{padding:20px 22px}
.rc-grid{display:grid;grid-template-columns:1fr;gap:12px;margin-bottom:16px}
@media(min-width:480px){.rc-grid{grid-template-columns:1fr 1fr}}
@media(min-width:768px){.rc-grid{grid-template-columns:1fr 1fr 1fr}}
.rc-field label{display:block;font-size:.72rem;font-weight:700;color:var(--ss);text-transform:uppercase;letter-spacing:.07em;margin-bottom:5px}
.rc-input-wrap{display:flex;align-items:center;border:1.5px solid var(--border);border-radius:var(--rr);overflow:hidden;transition:border-color .2s}
.rc-input-wrap:focus-within{border-color:var(--orange);box-shadow:0 0 0 3px rgba(247,168,0,.12)}
.rc-input-wrap input{flex:1;border:none;outline:none;padding:10px;font-size:.95rem;font-weight:700;font-family:inherit;color:var(--sl);min-width:0;background:#fff;-webkit-appearance:none}
.rc-unit{padding:10px;background:var(--bg);color:var(--ss);font-size:.78rem;font-weight:700;border-left:1px solid var(--border);white-space:nowrap}
.btn-berechnen{width:100%;background:linear-gradient(135deg,var(--orange),var(--od));color:#fff;border:none;border-radius:var(--rr);padding:14px;font-size:.95rem;font-weight:800;cursor:pointer;font-family:inherit;box-shadow:0 4px 14px rgba(247,168,0,.35);-webkit-tap-highlight-color:transparent;touch-action:manipulation}
.btn-berechnen:active{opacity:.88}
.rc-result{display:none;margin-top:16px;border-radius:var(--rm);overflow:hidden}
.rc-result-head{background:var(--sl);padding:14px 20px;display:flex;align-items:flex-start;justify-content:space-between;flex-wrap:wrap;gap:10px}
.rr-lbl{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:rgba(255,255,255,.5);margin-bottom:3px}
.rr-val{font-size:1.8rem;font-weight:800;color:#fff;line-height:1}
.rr-val sup{font-size:.9rem;color:var(--orange)}
.rr-sub{font-size:.7rem;color:rgba(255,255,255,.4);margin-top:2px}
.rc-result-body{display:grid;grid-template-columns:1fr;background:#fff;border:1.5px solid var(--border);border-top:none}
@media(min-width:600px){.rc-result-body{grid-template-columns:1fr 1fr}}
.rr-col{padding:14px 18px}
.rr-col:first-child{border-bottom:1px solid var(--border)}
@media(min-width:600px){.rr-col:first-child{border-bottom:none;border-right:1px solid var(--border)}}
.rr-title{font-size:.67rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--ss);margin-bottom:8px}
.rr-row{display:flex;justify-content:space-between;font-size:.82rem;padding:4px 0;border-bottom:1px solid var(--bg)}
.rr-row span{color:var(--sm)}
.rr-row strong{color:var(--sl);font-weight:700}
.rc-saving{background:var(--gp);border:1.5px solid #A7E8C7;border-top:none;padding:12px 18px;display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.rc-saving-txt{flex:1;min-width:160px;font-size:.82rem;color:#166534}
.rc-saving-txt strong{font-size:1rem;color:var(--green)}
.btn-zum-vergleich{display:inline-flex;align-items:center;gap:6px;background:var(--green);color:#fff;border-radius:var(--rr);padding:10px 16px;font-size:.82rem;font-weight:700;white-space:nowrap;-webkit-tap-highlight-color:transparent}

/* ── KARTEN ── */
.card{background:#fff;border:1.5px solid var(--border);border-radius:var(--rm);overflow:hidden;transition:box-shadow .2s,border-color .2s,transform .15s}
.card:hover{box-shadow:0 8px 30px rgba(43,157,212,.15);border-color:var(--bm);transform:translateY(-2px)}
.card-body{padding:18px}
.card-foot{padding:12px 18px;background:var(--bg);border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:8px}
.card-foot-lbl{font-size:.72rem;color:var(--ss);font-weight:600}
.btn-card{display:inline-flex;align-items:center;gap:5px;background:var(--blue);color:#fff;border-radius:var(--rr);padding:7px 14px;font-size:.76rem;font-weight:700;white-space:nowrap;-webkit-tap-highlight-color:transparent}
.btn-card:hover{background:var(--bd)}

/* Kategorie-Karten (Startseite) */
.cat-card{background:#fff;border:1.5px solid var(--border);border-radius:var(--rl);overflow:hidden;display:flex;flex-direction:column;text-decoration:none;-webkit-tap-highlight-color:transparent;transition:box-shadow .2s,border-color .2s,transform .15s}
.cat-card:hover{box-shadow:0 8px 30px rgba(43,157,212,.15);border-color:var(--bm);transform:translateY(-3px)}
.cat-icon-wrap{height:80px;display:flex;align-items:center;justify-content:center;font-size:2.6rem}
.cat-icon-wrap.c-blue  {background:var(--bl)}
.cat-icon-wrap.c-orange{background:var(--ol)}
.cat-icon-wrap.c-green {background:var(--gp)}
.cat-icon-wrap.c-slate {background:#edf2f7}
.cat-body{padding:16px 18px;flex:1}
.cat-title{font-size:.92rem;font-weight:800;color:var(--sl);margin-bottom:4px}
.cat-desc{font-size:.78rem;color:var(--sm);line-height:1.55;margin-bottom:0}
.cat-foot{padding:10px 18px;background:var(--bg);border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;font-size:.8rem;font-weight:700;color:var(--blue)}

/* ── INFO BOXES ── */
.info-box{border-radius:var(--rm);padding:16px 20px;margin:16px 0}
.info-box.blue  {background:var(--bl);border:1.5px solid var(--bm)}
.info-box.orange{background:var(--ol);border:1.5px solid #FDEAB0}
.info-box.green {background:var(--gp);border:1.5px solid #A7E8C7}
.info-box.red   {background:#FEF2F2;border:1.5px solid #FECACA}
.ib-title{font-size:.76rem;font-weight:800;text-transform:uppercase;letter-spacing:.07em;margin-bottom:7px}
.info-box.blue   .ib-title{color:var(--bd)}
.info-box.orange .ib-title{color:var(--od)}
.info-box.green  .ib-title{color:var(--green)}
.info-box p{font-size:.83rem;margin-bottom:0}
.info-box.blue   p{color:var(--bd)}
.info-box.orange p{color:#92400E}
.info-box.green  p{color:#166534}

/* ── BLOG-GRID ── */
.post-card{background:#fff;border:1.5px solid var(--border);border-radius:var(--rm);overflow:hidden;display:flex;flex-direction:column;transition:box-shadow .2s,transform .15s}
.post-card:hover{box-shadow:var(--shadow);transform:translateY(-2px)}
.post-card-img{position:relative;overflow:hidden;aspect-ratio:16/9}
.post-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.post-card:hover .post-card-img img{transform:scale(1.04)}
.post-card-cat{position:absolute;top:10px;left:10px;background:var(--orange);color:#fff;border-radius:999px;padding:3px 10px;font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em}
.post-card-body{padding:16px;flex:1;display:flex;flex-direction:column}
.post-card-title{font-size:.9rem;font-weight:700;color:var(--sl);margin-bottom:6px;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.post-card-title a{color:inherit}
.post-card-title a:hover{color:var(--blue)}
.post-card-excerpt{font-size:.78rem;color:var(--sm);line-height:1.6;flex:1;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;margin-bottom:12px}
.post-meta{font-size:.72rem;color:var(--ss);display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.post-meta time{font-weight:600}
.post-meta-sep{color:var(--border)}
.post-meta a{color:var(--blue)}

/* ── REVIEWS / TESTIMONIALS ── */
.review-card{background:#fff;border:1.5px solid var(--border);border-radius:var(--rm);padding:18px;display:flex;flex-direction:column;gap:10px}
.review-stars{color:#F59E0B;font-size:.9rem}
.review-saving{background:var(--gp);color:var(--green);border-radius:4px;padding:2px 8px;font-size:.7rem;font-weight:800;align-self:flex-start}
.review-txt{font-size:.82rem;color:var(--sm);line-height:1.65;font-style:italic;flex:1}
.review-author{display:flex;align-items:center;gap:9px}
.review-av{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.82rem;font-weight:800;color:#fff;flex-shrink:0}
.review-name{font-size:.78rem;font-weight:700;color:var(--sl)}
.review-meta-txt{font-size:.7rem;color:var(--ss)}

/* ── CONTENT LAYOUT (Sidebar) ── */
.content-layout{display:grid;grid-template-columns:1fr;gap:32px}
@media(min-width:900px){.content-layout{grid-template-columns:1fr 300px}}
.sidebar{display:flex;flex-direction:column;gap:16px}
@media(min-width:900px){.sidebar{position:sticky;top:130px}}
.sb-card{background:#fff;border:1.5px solid var(--border);border-radius:var(--rm);overflow:hidden}
.sb-head{padding:10px 14px;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;background:var(--bg);border-bottom:1px solid var(--border);color:var(--ss)}
.sb-body{padding:12px 14px}
.sb-cta{background:linear-gradient(135deg,var(--orange),var(--od));border-radius:var(--rm);padding:18px;text-align:center}
.sb-cta .sc-icon{font-size:1.8rem;margin-bottom:7px;display:block}
.sb-cta h3{color:#fff;font-size:.92rem;margin-bottom:5px}
.sb-cta p{color:rgba(255,255,255,.8);font-size:.76rem;margin-bottom:12px}
.sb-cta-btn{display:block;background:#fff;color:var(--od);border-radius:var(--rr);padding:10px 16px;font-size:.82rem;font-weight:800;text-align:center;-webkit-tap-highlight-color:transparent}
.sb-list{display:flex;flex-direction:column}
.sb-item{display:flex;align-items:center;gap:8px;padding:9px 0;border-bottom:1px solid var(--border);font-size:.8rem;color:var(--sm);text-decoration:none;-webkit-tap-highlight-color:transparent;touch-action:manipulation}
.sb-item:last-child{border-bottom:none}
.sb-item:hover{color:var(--blue)}
.sb-item-arrow{margin-left:auto;color:var(--bm);font-size:.73rem}
.sb-fact{display:flex;justify-content:space-between;padding:6px 0;border-bottom:1px solid var(--border);font-size:.78rem}
.sb-fact:last-child{border-bottom:none}
.sb-fact .lbl{color:var(--ss)}
.sb-fact .val{font-weight:700;color:var(--sl)}

/* ── BREADCRUMB ── */
.breadcrumb{background:#fff;border-bottom:1px solid var(--border);padding:8px 20px;font-size:.78rem;color:var(--ss)}
.breadcrumb ol{list-style:none;display:flex;flex-wrap:wrap;gap:6px;align-items:center;max-width:1140px;margin:0 auto}
.breadcrumb li::after{content:'›';margin-left:6px;color:var(--border)}
.breadcrumb li:last-child::after{display:none}
.breadcrumb a{color:var(--ss)}
.breadcrumb a:hover{color:var(--blue)}
.breadcrumb li:last-child span{color:var(--sm);font-weight:600}

/* ── PROSE (Artikel-Inhalt) ── */
.prose h2{margin-top:32px;margin-bottom:10px}
.prose h3{margin-top:24px;margin-bottom:8px;color:var(--sl)}
.prose p{font-size:.88rem;line-height:1.8}
.prose ul,.prose ol{margin:10px 0 16px;padding-left:24px}
.prose ul li,.prose ol li{font-size:.87rem;color:var(--sm);padding:3px 0;line-height:1.7}
.prose a{color:var(--blue);text-decoration:underline;text-decoration-color:rgba(43,157,212,.35);text-underline-offset:2px}
.prose a:hover{color:var(--bd);text-decoration-color:var(--bd)}
.prose blockquote{border-left:4px solid var(--orange);padding:12px 20px;background:var(--ol);border-radius:0 var(--rr) var(--rr) 0;margin:20px 0;font-style:italic;color:var(--sm)}
.prose table{width:100%;border-collapse:collapse;border-radius:var(--rm);overflow:hidden;margin:16px 0;font-size:.84rem;display:block;overflow-x:auto;-webkit-overflow-scrolling:touch}
@media(min-width:600px){.prose table{display:table}}
.prose thead tr{background:var(--blue)}
.prose thead th{padding:11px 14px;text-align:left;color:rgba(255,255,255,.9);font-size:.74rem;font-weight:700;letter-spacing:.04em;white-space:nowrap}
.prose tbody tr{background:#fff;border-bottom:1px solid var(--border)}
.prose tbody tr:hover{background:var(--bl)}
.prose td{padding:10px 14px;color:var(--sm)}
.prose td:first-child{font-weight:700;color:var(--sl)}

/* ── STEPS ── */
.steps{display:flex;flex-direction:column;gap:14px;margin:16px 0}
.step{display:flex;gap:14px;align-items:flex-start}
.step-num{width:32px;height:32px;border-radius:50%;background:var(--orange);color:#fff;font-size:.84rem;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:2px;box-shadow:0 2px 8px rgba(247,168,0,.3)}
.step-body h4{font-size:.88rem;font-weight:700;color:var(--sl);margin-bottom:3px}
.step-body p{font-size:.8rem;color:var(--sm);margin:0;line-height:1.65}

/* ── FAQ ── */
.faq-list{display:flex;flex-direction:column;gap:8px}
.faq-item{background:#fff;border:1.5px solid var(--border);border-radius:var(--rm);overflow:hidden;transition:border-color .2s}
.faq-item.open{border-color:var(--blue)}
.faq-q{padding:15px 18px;font-weight:700;font-size:.87rem;color:var(--sl);cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:12px;user-select:none;-webkit-tap-highlight-color:transparent;touch-action:manipulation}
.faq-item.open .faq-q{color:var(--blue)}
.faq-chev{width:24px;height:24px;flex-shrink:0;background:var(--bg);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.68rem;transition:transform .25s;color:var(--ss)}
.faq-item.open .faq-chev{transform:rotate(180deg);background:var(--bl);color:var(--blue)}
.faq-a{display:none;padding:0 18px 14px;font-size:.84rem;color:var(--sm);line-height:1.75}
.faq-item.open .faq-a{display:block}

/* ── CHECKLISTE (interaktiv) ── */
.cl-header{background:linear-gradient(135deg,#0F172A,#1a3a4a);border-radius:var(--rl) var(--rl) 0 0;padding:24px 22px 0;position:relative;overflow:hidden}
.cl-header::before{content:'';position:absolute;top:-40px;right:-40px;width:180px;height:180px;background:radial-gradient(circle,rgba(247,168,0,.12),transparent 70%);border-radius:50%;pointer-events:none}
.cl-header-inner{display:flex;align-items:flex-start;gap:14px;flex-wrap:wrap;position:relative;z-index:1}
.cl-hdr-icon{width:50px;height:50px;border-radius:var(--rm);background:rgba(247,168,0,.15);border:1px solid rgba(247,168,0,.3);display:flex;align-items:center;justify-content:center;font-size:1.8rem;flex-shrink:0}
.cl-hdr-ey{font-size:.68rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--orange);margin-bottom:5px}
.cl-hdr-h{color:#fff;font-size:clamp(1rem,2.5vw,1.25rem);font-weight:800;margin-bottom:5px}
.cl-hdr-p{color:rgba(255,255,255,.65);font-size:.82rem;margin:0}
.cl-progress{margin:18px 0 0;padding-bottom:18px;border-bottom:1px solid rgba(255,255,255,.1);position:relative;z-index:1}
.cl-prog-labels{display:flex;justify-content:space-between;font-size:.7rem;color:rgba(255,255,255,.5);margin-bottom:5px}
.cl-prog-track{background:rgba(255,255,255,.1);border-radius:6px;height:7px;overflow:hidden}
.cl-prog-fill{height:100%;background:linear-gradient(90deg,var(--orange),var(--green));border-radius:6px;width:0%;transition:width .4s ease}
.cl-body{background:#fff;border:1.5px solid var(--border);border-top:none;border-radius:0 0 var(--rl) var(--rl);overflow:hidden}
.cl-row{display:flex;align-items:flex-start;border-bottom:1px solid var(--border);transition:background .2s}
.cl-row.done{background:var(--gp)}
.cl-check-label{display:flex;align-items:flex-start;justify-content:center;padding:18px 0 18px 16px;cursor:pointer;flex-shrink:0;-webkit-tap-highlight-color:transparent;touch-action:manipulation}
.cl-cb{display:none}
.cl-cbox{width:24px;height:24px;border:2px solid var(--border);border-radius:6px;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0;margin-top:2px;background:#fff;color:#fff;font-size:.85rem;font-weight:800;line-height:1}
.cl-cb:checked+.cl-cbox{background:var(--green);border-color:var(--green)}
.cl-cb:checked+.cl-cbox::after{content:'✓'}
.cl-row-content{flex:1;padding:16px 16px 16px 12px;min-width:0}
.cl-row-head{display:flex;align-items:center;gap:7px;flex-wrap:wrap;margin-bottom:4px}
.cl-row-head strong{font-size:.88rem;color:var(--sl);font-weight:700}
.cl-badge{width:22px;height:22px;border-radius:50%;background:var(--orange);color:#fff;font-size:.7rem;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.cl-tag{font-size:.64rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;border-radius:999px;padding:2px 7px;background:var(--bl);color:var(--bd)}
.cl-tag.warn{background:#FFFBEB;color:#92400E}
.cl-tag.green{background:var(--gp);color:#166534}
.cl-hint{font-size:.76rem;color:var(--ss);margin:0 0 10px;line-height:1.5}
.cl-inputs{display:grid;grid-template-columns:1fr;gap:8px}
@media(min-width:480px){.cl-inputs{grid-template-columns:1fr 1fr}}
@media(min-width:768px){.cl-inputs.cols-3{grid-template-columns:1fr 1fr 1fr}}
.cl-field{display:flex;flex-direction:column;gap:3px}
.cl-field label{font-size:.7rem;font-weight:700;color:var(--ss);text-transform:uppercase;letter-spacing:.05em}
.cl-field input,.cl-field select{border:1.5px solid var(--border);border-radius:var(--rr);padding:9px 10px;font-size:.85rem;font-family:inherit;color:var(--sl);background:#fff;outline:none;transition:border-color .2s;width:100%;-webkit-appearance:none;appearance:none}
.cl-field select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%238FA5B4' d='M6 8L0 0h12z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:28px}
.cl-field input:focus,.cl-field select:focus{border-color:var(--orange)}
.cl-euro-wrap{display:flex;align-items:center;border:1.5px solid var(--border);border-radius:var(--rr);overflow:hidden;transition:border-color .2s}
.cl-euro-wrap:focus-within{border-color:var(--orange)}
.cl-euro-wrap input{flex:1;border:none;outline:none;padding:9px 10px;font-size:.85rem;font-family:inherit;color:var(--sl);min-width:0;-webkit-appearance:none}
.cl-euro-wrap span{padding:9px 10px;background:var(--bg);color:var(--ss);font-size:.76rem;font-weight:700;border-left:1px solid var(--border);white-space:nowrap}
.cl-actions{padding:18px 16px;background:var(--bg);border-top:2px solid var(--border);display:flex;flex-direction:column;gap:10px}
@media(min-width:480px){.cl-actions{flex-direction:row;flex-wrap:wrap;align-items:center}}
.btn-cl-pdf{background:linear-gradient(135deg,var(--orange),var(--od));color:#fff;border:none;border-radius:var(--rr);padding:13px 22px;font-size:.9rem;font-weight:800;cursor:pointer;font-family:inherit;box-shadow:0 4px 14px rgba(247,168,0,.3);display:flex;align-items:center;gap:8px;-webkit-tap-highlight-color:transparent;touch-action:manipulation;width:100%}
@media(min-width:480px){.btn-cl-pdf{width:auto}}
.btn-cl-share{background:var(--blue);color:#fff;border:none;border-radius:var(--rr);padding:13px 22px;font-size:.9rem;font-weight:800;cursor:pointer;font-family:inherit;display:flex;align-items:center;gap:8px;-webkit-tap-highlight-color:transparent;touch-action:manipulation;width:100%}
@media(min-width:480px){.btn-cl-share{width:auto}}
.btn-cl-reset{background:#fff;color:var(--sm);border:1.5px solid var(--border);border-radius:var(--rr);padding:12px 20px;font-size:.86rem;font-weight:600;cursor:pointer;font-family:inherit;display:flex;align-items:center;gap:7px;-webkit-tap-highlight-color:transparent;touch-action:manipulation;width:100%}
@media(min-width:480px){.btn-cl-reset{width:auto}}
.cl-share-msg{display:none;font-size:.8rem;color:var(--green);font-weight:700}

/* ── CTA BAND ── */
.cta-band{background:linear-gradient(135deg,var(--orange),var(--od));padding:48px 20px;text-align:center}
.cta-band h2{color:#fff;margin-bottom:10px}
.cta-band p{color:rgba(255,255,255,.82);max-width:480px;margin:0 auto 20px;font-size:.92rem}
.cta-grp{display:flex;flex-direction:column;gap:10px;align-items:center}
@media(min-width:480px){.cta-grp{flex-direction:row;justify-content:center}}
.btn-dark{background:var(--bd);color:#fff;border:none;border-radius:var(--rr);padding:13px 26px;font-size:.92rem;font-weight:700;text-decoration:none;display:inline-flex;align-items:center;gap:7px;-webkit-tap-highlight-color:transparent}
.btn-white{background:#fff;color:var(--od);border:none;border-radius:var(--rr);padding:13px 24px;font-size:.92rem;font-weight:700;text-decoration:none;display:inline-flex;align-items:center;gap:7px;-webkit-tap-highlight-color:transparent}

/* ── FOOTER ── */
.site-footer{background:var(--sl);padding:40px 20px 24px}
.ft-inner{max-width:1140px;margin:0 auto}
.ft-top{display:grid;grid-template-columns:1fr;gap:28px;padding-bottom:24px;border-bottom:1px solid rgba(255,255,255,.08);margin-bottom:20px}
@media(min-width:640px){.ft-top{grid-template-columns:1.5fr 1fr 1fr 1fr}}
.ft-brand .tagline{font-size:.78rem;color:rgba(255,255,255,.4);margin-top:8px}
.ft-col h4{color:rgba(255,255,255,.7);font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;margin-bottom:12px}
.ft-col a{display:block;font-size:.82rem;color:rgba(255,255,255,.5);margin-bottom:6px;transition:color .2s;-webkit-tap-highlight-color:transparent}
.ft-col a:hover{color:#fff}
.ft-bottom{display:flex;justify-content:space-between;flex-wrap:wrap;gap:8px;font-size:.72rem;color:rgba(255,255,255,.3)}
.ft-bottom a{color:rgba(255,255,255,.4)}
.ft-bottom a:hover{color:rgba(255,255,255,.7)}

/* ── SEARCH FORM ── */
.search-form{display:flex;gap:0;border:2px solid var(--border);border-radius:var(--rr);overflow:hidden;background:#fff}
.search-form input{flex:1;border:none;outline:none;padding:11px 14px;font-size:.9rem;font-family:inherit;color:var(--sl);min-width:0}
.search-form button{background:var(--blue);color:#fff;border:none;padding:11px 18px;cursor:pointer;font-size:.9rem;-webkit-tap-highlight-color:transparent;touch-action:manipulation;white-space:nowrap}
.search-form button:hover{background:var(--bd)}

/* ── TAG CLOUD ── */
.tag-cloud{display:flex;flex-wrap:wrap;gap:7px}
.tag{background:#fff;border:1.5px solid var(--border);border-radius:999px;padding:5px 12px;font-size:.74rem;color:var(--sm);font-weight:600;-webkit-tap-highlight-color:transparent}
.tag:hover{background:var(--bl);border-color:var(--blue);color:var(--blue)}

/* ── PAGINATION ── */
.pagination{display:flex;justify-content:center;gap:8px;flex-wrap:wrap;margin:32px 0}
.page-numbers{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:var(--rr);background:#fff;border:1.5px solid var(--border);font-size:.84rem;font-weight:600;color:var(--sm);-webkit-tap-highlight-color:transparent;transition:all .2s}
.page-numbers.current{background:var(--blue);border-color:var(--blue);color:#fff}
.page-numbers:hover{border-color:var(--blue);color:var(--blue)}
.page-numbers.dots{border:none;background:none;width:auto;padding:0 4px}

/* ── SKIP TO CONTENT (Barrierefreiheit) ── */
.skip-link{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden}
.skip-link:focus{position:fixed;top:0;left:0;z-index:999;background:var(--blue);color:#fff;padding:12px 18px;font-weight:700;width:auto;height:auto}

/* ── ANIMATIONEN ── */
@keyframes fadeUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}
.animate-up{animation:fadeUp .4s ease both}
@media(prefers-reduced-motion:reduce){
  *{animation-duration:.01ms!important;transition-duration:.01ms!important}
}

/* ═══════════════════════════════════════════
   SPAREGO PORTAL – Startseiten-Styles
   Ergänzung zu main.css
═══════════════════════════════════════════ */

/* ── HERO HOME ── */
.hero-home {
  background: linear-gradient(135deg, #1a3a4a 0%, var(--blue) 50%, #1E7EAC 100%);
  padding: 52px 0 64px;
  position: relative;
  overflow: hidden;
}
.hero-home::before {
  content: '';
  position: absolute;
  top: -80px; right: -60px;
  width: 420px; height: 420px;
  background: radial-gradient(circle, rgba(247,168,0,.18), transparent 70%);
  border-radius: 50%;
  pointer-events: none;
}
.hero-home::after {
  content: '';
  position: absolute;
  bottom: -60px; left: -40px;
  width: 300px; height: 300px;
  background: radial-gradient(circle, rgba(255,255,255,.05), transparent 70%);
  border-radius: 50%;
  pointer-events: none;
}
.hero-home__inner {
  display: grid;
  grid-template-columns: 1fr;
  gap: 40px;
  align-items: center;
  position: relative;
  z-index: 1;
}
@media(min-width:900px) {
  .hero-home__inner { grid-template-columns: 1.1fr 1fr; gap: 52px; }
}
.hero-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  background: rgba(247,168,0,.2);
  border: 1px solid rgba(247,168,0,.4);
  color: #FFD54F;
  border-radius: 999px;
  font-size: .78rem;
  font-weight: 700;
  padding: 5px 14px;
  margin-bottom: 16px;
}
.hero-home h1 {
  color: #fff;
  font-size: clamp(1.7rem, 4.5vw, 2.8rem);
  line-height: 1.18;
  font-weight: 800;
  margin-bottom: 16px;
}
.hero-home h1 .accent { color: var(--orange); }
.hero-lead {
  color: rgba(255,255,255,.82);
  font-size: clamp(.9rem, 2vw, 1.05rem);
  line-height: 1.7;
  margin-bottom: 22px;
}
.hero-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 26px;
}
.pill {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  background: rgba(255,255,255,.12);
  border: 1px solid rgba(255,255,255,.22);
  border-radius: 999px;
  padding: 5px 13px;
  font-size: .76rem;
  color: rgba(255,255,255,.88);
}
.pill-tick { color: var(--orange); }
.hero-btns {
  display: flex;
  flex-direction: column;
  gap: 10px;
  flex-wrap: wrap;
}
@media(min-width:480px) { .hero-btns { flex-direction: row; } }

/* Hero Visual Card */
.hero-visual-card {
  background: #fff;
  border-radius: var(--rl);
  overflow: hidden;
  box-shadow: 0 20px 60px rgba(0,0,0,.2);
}
.hvc-header {
  background: var(--orange);
  padding: 12px 18px;
  font-size: .8rem;
  font-weight: 700;
  color: #fff;
}
.hvc-body { padding: 14px 16px; display: flex; flex-direction: column; gap: 8px; }
.hvc-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 10px;
  background: var(--bg);
  border-radius: 8px;
}
.hvc-item--total {
  background: var(--gp);
  border: 1px solid #A7E8C7;
  margin-top: 4px;
}
.hvc-icon { font-size: 1.2rem; flex-shrink: 0; width: 28px; text-align: center; }
.hvc-info { flex: 1; min-width: 0; }
.hvc-label { display: block; font-size: .72rem; color: var(--ss); font-weight: 600; }
.hvc-val { display: block; font-size: .82rem; font-weight: 700; color: var(--sl); }
.hvc-val--big { font-size: .95rem; color: var(--green); }
.hvc-badge {
  font-size: .65rem;
  font-weight: 800;
  border-radius: 4px;
  padding: 2px 7px;
  flex-shrink: 0;
}
.hvc-badge.green { background: var(--gp); color: var(--green); }
.hvc-badge.orange { background: var(--ol); color: var(--od); }
.hvc-cta {
  display: block;
  text-align: center;
  padding: 12px 16px;
  background: var(--blue);
  color: #fff;
  font-size: .84rem;
  font-weight: 700;
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
  transition: background .2s;
}
.hvc-cta:hover { background: var(--bd); color: #fff; }

/* ── SECTION HELPERS ── */
.section--white { background: #fff; }
.section--bg    { background: var(--bg); }
.section--cream { background: #FAFBF8; }
.section--newsletter { background: linear-gradient(135deg, var(--blue), var(--bd)); }
.section-header { margin-bottom: 36px; }
.section-header h2 { margin-bottom: 10px; }
.section-lead {
  font-size: .92rem;
  color: var(--sm);
  max-width: 560px;
  margin: 0 auto;
  line-height: 1.7;
}
.section-header-flex {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
  margin-bottom: 28px;
}
.section-header-flex h2 { margin: 0; }

/* ── BUTTONS ── */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
  border-radius: var(--rr);
  font-weight: 700;
  font-family: inherit;
  border: none;
  cursor: pointer;
  text-decoration: none;
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
  transition: opacity .15s, transform .15s, background .2s;
  white-space: nowrap;
}
.btn:active { opacity: .88; transform: scale(.98); }
.btn-primary {
  background: var(--orange);
  color: #fff;
  padding: 13px 24px;
  font-size: .92rem;
  box-shadow: 0 4px 14px rgba(247,168,0,.4);
}
.btn-primary:hover { background: var(--od); color: #fff; }
.btn-secondary {
  background: rgba(255,255,255,.12);
  color: #fff;
  border: 1.5px solid rgba(255,255,255,.3);
  padding: 12px 22px;
  font-size: .92rem;
}
.btn-secondary:hover { background: rgba(255,255,255,.22); color: #fff; }
.btn-outline {
  background: transparent;
  color: var(--blue);
  border: 1.5px solid var(--blue);
  padding: 9px 18px;
  font-size: .84rem;
}
.btn-outline:hover { background: var(--bl); }
.btn-lg { padding: 15px 28px; font-size: 1rem; }

/* ── QUICK-ACCESS KACHELN ── */
.qa-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
}
@media(min-width:480px) { .qa-grid { grid-template-columns: 1fr 1fr; } }
@media(min-width:900px) { .qa-grid { grid-template-columns: repeat(3, 1fr); } }

.qa-card {
  background: #fff;
  border: 1.5px solid var(--border);
  border-radius: var(--rl);
  overflow: hidden;
  display: flex;
  align-items: flex-start;
  gap: 14px;
  padding: 18px;
  text-decoration: none;
  position: relative;
  transition: box-shadow .2s, border-color .2s, transform .15s;
  -webkit-tap-highlight-color: transparent;
}
.qa-card:hover {
  box-shadow: 0 8px 32px rgba(43,157,212,.14);
  border-color: var(--bm);
  transform: translateY(-3px);
}
.qa-icon-wrap {
  width: 52px; height: 52px;
  border-radius: var(--rm);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.6rem;
  flex-shrink: 0;
}
.qa--blue   { background: var(--bl); }
.qa--orange { background: var(--ol); }
.qa--green  { background: var(--gp); }
.qa--purple { background: #F3E8FF; }
.qa--red    { background: #FEF2F2; }
.qa--teal   { background: #E0F7FA; }
.qa-body { flex: 1; min-width: 0; }
.qa-body h3 { font-size: .9rem; font-weight: 700; color: var(--sl); margin-bottom: 4px; line-height: 1.3; }
.qa-body p  { font-size: .78rem; color: var(--sm); line-height: 1.55; margin-bottom: 8px; }
.qa-cta { font-size: .78rem; font-weight: 700; color: var(--blue); }
.qa-tag {
  position: absolute;
  top: 10px; right: 10px;
  background: var(--orange);
  color: #fff;
  font-size: .62rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .06em;
  border-radius: 4px;
  padding: 2px 6px;
}
.qa-tag--new { background: var(--green); }

/* ── PROBLEM SECTION ── */
.two-col {
  display: grid;
  grid-template-columns: 1fr;
  gap: 40px;
  align-items: center;
}
@media(min-width:860px) {
  .two-col { grid-template-columns: 1fr 1fr; }
  .two-col--flip .two-col__visual { order: -1; }
}
.problem-list { display: flex; flex-direction: column; gap: 18px; margin-top: 24px; }
.problem-item {
  display: flex;
  gap: 14px;
  align-items: flex-start;
}
.problem-icon {
  font-size: 1.6rem;
  flex-shrink: 0;
  margin-top: 2px;
}
.problem-item strong {
  display: block;
  font-size: .88rem;
  color: var(--sl);
  margin-bottom: 3px;
}
.problem-item p {
  font-size: .8rem;
  color: var(--sm);
  margin: 0;
  line-height: 1.6;
}
.stats-card {
  background: #fff;
  border: 1.5px solid var(--border);
  border-radius: var(--rl);
  overflow: hidden;
  box-shadow: var(--shadow);
}
.stats-card__head {
  background: linear-gradient(90deg, var(--sl), #2d4a5a);
  padding: 14px 18px;
  font-size: .82rem;
  font-weight: 700;
  color: #fff;
}
.stats-card__body { padding: 14px 18px; display: flex; flex-direction: column; gap: 6px; }
.stat-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 8px 10px;
  background: var(--bg);
  border-radius: 6px;
  font-size: .82rem;
}
.stat-label { color: var(--sm); }
.stat-val   { font-weight: 700; color: var(--sl); }
.stat-row--total { background: var(--gp); border: 1px solid #A7E8C7; margin-top: 4px; }
.stat-val--big   { color: var(--green); font-size: .95rem; }
.stats-card__cta {
  display: block;
  text-align: center;
  padding: 12px 18px;
  background: var(--bg);
  border-top: 1px solid var(--border);
  font-size: .82rem;
  font-weight: 700;
  color: var(--blue);
  -webkit-tap-highlight-color: transparent;
}
.stats-card__cta:hover { background: var(--bl); }

/* ── 3-SCHRITTE LÖSUNG ── */
.steps-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 24px;
  margin-top: 8px;
  counter-reset: steps;
}
@media(min-width:640px) { .steps-grid { grid-template-columns: repeat(3, 1fr); } }
.step-card {
  background: #fff;
  border: 1.5px solid var(--border);
  border-radius: var(--rl);
  padding: 24px 20px;
  text-align: center;
  position: relative;
  transition: box-shadow .2s, transform .15s;
}
.step-card:hover { box-shadow: var(--shadow); transform: translateY(-3px); }
.step-num {
  width: 36px; height: 36px;
  border-radius: 50%;
  background: var(--orange);
  color: #fff;
  font-size: .88rem;
  font-weight: 800;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 14px;
  box-shadow: 0 3px 10px rgba(247,168,0,.35);
}
.step-icon { font-size: 2.2rem; margin-bottom: 12px; display: block; }
.step-card h3 { font-size: .95rem; font-weight: 700; color: var(--sl); margin-bottom: 8px; }
.step-card p  { font-size: .82rem; color: var(--sm); line-height: 1.65; margin-bottom: 14px; }
.step-link { font-size: .8rem; font-weight: 700; color: var(--blue); -webkit-tap-highlight-color: transparent; }
.step-link:hover { color: var(--bd); }

/* Verbindungslinie zwischen Steps (Desktop) */
@media(min-width:640px) {
  .steps-grid { position: relative; }
  .steps-grid::before {
    content: '';
    position: absolute;
    top: 56px;
    left: calc(16.67% + 18px);
    right: calc(16.67% + 18px);
    height: 2px;
    background: linear-gradient(90deg, var(--orange), var(--blue));
    border-radius: 2px;
    pointer-events: none;
  }
}

/* ── TOOLS GRID ── */
.tools-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
}
@media(min-width:640px) { .tools-grid { grid-template-columns: 1fr 1fr; } }
@media(min-width:900px) { .tools-grid { grid-template-columns: repeat(3, 1fr); } }

.tool-card {
  background: #fff;
  border: 1.5px solid var(--border);
  border-radius: var(--rl);
  padding: 22px 20px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  text-decoration: none;
  position: relative;
  transition: box-shadow .2s, border-color .2s, transform .15s;
  -webkit-tap-highlight-color: transparent;
}
.tool-card:hover {
  box-shadow: 0 8px 32px rgba(43,157,212,.14);
  border-color: var(--bm);
  transform: translateY(-3px);
}
.tool-card--featured {
  border-color: var(--orange);
  background: linear-gradient(145deg, #fff, var(--ol));
}
.tool-card--featured:hover { border-color: var(--od); }
.tool-card__badge {
  position: absolute;
  top: -10px; left: 18px;
  background: var(--orange);
  color: #fff;
  font-size: .62rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .06em;
  border-radius: 4px;
  padding: 3px 8px;
}
.tool-card__icon { font-size: 2rem; display: block; }
.tool-card h3    { font-size: .9rem; font-weight: 700; color: var(--sl); margin: 0; line-height: 1.3; }
.tool-card p     { font-size: .8rem; color: var(--sm); line-height: 1.6; margin: 0; flex: 1; }
.tool-features {
  display: flex;
  flex-direction: column;
  gap: 3px;
  margin-top: 2px;
}
.tool-features span { font-size: .74rem; color: var(--green); font-weight: 600; }
.tool-cta {
  font-size: .8rem;
  font-weight: 700;
  color: var(--blue);
  margin-top: 4px;
}

/* ── CONTENT HUBS ── */
.hubs-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
}
@media(min-width:640px) { .hubs-grid { grid-template-columns: 1fr 1fr; } }
@media(min-width:900px) { .hubs-grid { grid-template-columns: repeat(3, 1fr); } }

.hub-card {
  border-radius: var(--rl);
  overflow: hidden;
  display: flex;
  align-items: flex-start;
  gap: 0;
  text-decoration: none;
  transition: box-shadow .2s, transform .15s;
  -webkit-tap-highlight-color: transparent;
  position: relative;
  padding: 22px 20px;
  border: 1.5px solid transparent;
}
.hub-card:hover { box-shadow: 0 10px 36px rgba(0,0,0,.1); transform: translateY(-3px); }
.hub-card--blue   { background: linear-gradient(135deg, #EBF6FC, #D4EEF9); border-color: var(--bm); }
.hub-card--orange { background: linear-gradient(135deg, var(--ol), #FDE9A8); border-color: var(--om); }
.hub-card--green  { background: linear-gradient(135deg, #ECFDF5, #D1FAE5); border-color: #A7E8C7; }
.hub-card--purple { background: linear-gradient(135deg, #F5F0FF, #EDE0FF); border-color: #C4B5FD; }
.hub-card--teal   { background: linear-gradient(135deg, #E0F7FA, #B2EBF2); border-color: #80DEEA; }
.hub-card--red    { background: linear-gradient(135deg, #FFF5F5, #FFE4E1); border-color: #FECACA; }
.hub-card__icon {
  font-size: 2.4rem;
  flex-shrink: 0;
  margin-right: 14px;
  margin-top: 2px;
}
.hub-card__body { flex: 1; min-width: 0; }
.hub-card__body h3 {
  font-size: .92rem;
  font-weight: 800;
  color: var(--sl);
  margin-bottom: 6px;
  line-height: 1.3;
}
.hub-card__body p { font-size: .78rem; color: var(--sm); line-height: 1.6; margin-bottom: 10px; }
.hub-links {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
}
.hub-links span {
  background: rgba(255,255,255,.7);
  border-radius: 4px;
  padding: 2px 8px;
  font-size: .68rem;
  font-weight: 700;
  color: var(--sl);
}
.hub-arrow {
  position: absolute;
  bottom: 18px;
  right: 18px;
  font-size: 1rem;
  color: var(--ss);
  transition: transform .2s;
}
.hub-card:hover .hub-arrow { transform: translateX(4px); }

/* ── BLOG / SPARTIPPS GRID ── */
.posts-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 18px;
}
@media(min-width:640px) { .posts-grid { grid-template-columns: 1fr 1fr; } }
@media(min-width:900px) { .posts-grid { grid-template-columns: repeat(3, 1fr); } }

.post-card-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  flex-wrap: wrap;
  margin-top: auto;
  padding-top: 10px;
  border-top: 1px solid var(--border);
}
.post-card-read {
  font-size: .76rem;
  font-weight: 700;
  color: var(--blue);
  white-space: nowrap;
  -webkit-tap-highlight-color: transparent;
}
.post-card-read:hover { color: var(--bd); }

/* ── TRUST GRID ── */
.trust-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 18px;
  margin-bottom: 28px;
}
@media(min-width:640px) { .trust-grid { grid-template-columns: 1fr 1fr; } }
@media(min-width:900px) { .trust-grid { grid-template-columns: repeat(3, 1fr); } }

.trust-card {
  background: var(--bg);
  border: 1.5px solid var(--border);
  border-radius: var(--rm);
  padding: 20px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.trust-icon { font-size: 1.8rem; }
.trust-card h3 { font-size: .88rem; font-weight: 700; color: var(--sl); margin: 0; }
.trust-card p  { font-size: .8rem; color: var(--sm); line-height: 1.65; margin: 0; }

.affiliate-notice {
  display: flex;
  gap: 12px;
  align-items: flex-start;
  background: var(--bl);
  border: 1.5px solid var(--bm);
  border-radius: var(--rm);
  padding: 16px 20px;
  font-size: .78rem;
  color: var(--bd);
  line-height: 1.65;
}
.affiliate-notice span { font-size: 1.1rem; flex-shrink: 0; margin-top: 2px; }
.affiliate-notice p  { margin: 0; }
.affiliate-notice strong { color: var(--sl); }

/* ── NEWSLETTER ── */
.newsletter-box {
  display: flex;
  flex-direction: column;
  gap: 24px;
  align-items: flex-start;
  max-width: 700px;
  margin: 0 auto;
}
@media(min-width:640px) {
  .newsletter-box { flex-direction: row; align-items: center; gap: 40px; }
}
.nl-text {
  display: flex;
  gap: 14px;
  align-items: flex-start;
  flex: 1;
}
.nl-text span { font-size: 2rem; flex-shrink: 0; margin-top: 4px; }
.nl-text h2 { color: #fff; font-size: 1rem; margin-bottom: 5px; }
.nl-text p  { color: rgba(255,255,255,.78); font-size: .8rem; margin: 0; line-height: 1.6; }
.nl-form,
.nl-placeholder { flex: 1; min-width: 220px; }
.nl-placeholder {
  background: rgba(255,255,255,.1);
  border-radius: var(--rm);
  border: 1px solid rgba(255,255,255,.2);
}

/* ── INTERNE VERLINKUNG GRID ── */
.internal-links-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
}
@media(min-width:640px) { .internal-links-grid { grid-template-columns: repeat(2, 1fr); } }
@media(min-width:900px) { .internal-links-grid { grid-template-columns: repeat(4, 1fr); } }

.il-group h3 {
  font-size: .78rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .07em;
  color: var(--ss);
  margin-bottom: 10px;
  padding-bottom: 6px;
  border-bottom: 1.5px solid var(--border);
}
.il-group a {
  display: block;
  font-size: .82rem;
  color: var(--sm);
  padding: 5px 0;
  border-bottom: 1px solid var(--bg);
  transition: color .2s;
  -webkit-tap-highlight-color: transparent;
}
.il-group a:hover { color: var(--blue); }

/* ── FAQ CONTAINER ── */
.faq-container { max-width: 760px; }

/* ── HERO BILD ── */
.hero-home__visual {
  display: flex;
  align-items: center;
  justify-content: center;
}
.hero-img {
  width: 100%;
  max-width: 540px;
  height: auto;
  border-radius: var(--rl);
  box-shadow: 0 20px 60px rgba(0,0,0,.25);
  display: block;
}
@media(max-width:899px) {
  .hero-img { max-width: 400px; margin: 0 auto; }
}

/* ── ALTES ZERIF-MENÜ KOMPLETT ÜBERSCHREIBEN ── */
/* Alle alten Theme-Nav-Styles auf null setzen */
#site-navigation,
.main-navigation,
.zerif-main-navigation,
ul.nav-menu,
ul.sub-menu,
.menu-primary-container {
  display: none !important;
}

/* Unser nav-wrap darf nicht überschrieben werden */
.site-header .nav-wrap { display: flex !important; }
.site-header .nav-links { display: none; }
@media(min-width:900px) {
  .site-header .nav-links {
    display: flex !important;
    align-items: center;
    gap: 18px;
  }
}

/* ── FORCE: Nav-Links korrekt rendern ── */
.nav-links a {
  font-size: .84rem !important;
  font-weight: 600 !important;
  color: var(--sm) !important;
  text-decoration: none !important;
  background: none !important;
  padding: 0 !important;
  border: none !important;
  display: inline !important;
  transition: color .2s;
}
.nav-links a:hover { color: var(--blue) !important; }
.nav-links a.nav-cta {
  background: var(--orange) !important;
  color: #fff !important;
  padding: 8px 16px !important;
  border-radius: var(--rr) !important;
  font-weight: 700 !important;
}
.nav-links a.nav-cta:hover { background: var(--od) !important; }
.nav-links a.active { color: var(--blue) !important; }

/* ── MENU-TOGGLE sichtbar auf mobil ── */
@media(min-width:900px) { .menu-toggle { display: none !important; } }
@media(max-width:899px)  { .menu-toggle { display: flex !important; } }

/* ════════════════════════════════════════
   NUCLEAR MENÜ-RESET: Alle alten WP/Zerif
   Navigations-Strukturen ausblenden
   Höchste Spezifität + !important
════════════════════════════════════════ */
html body #zerif-frontpage .main-navigation,
html body .zerif-main-navigation,
html body #site-navigation,
html body .menu-primary-container,
html body ul.nav-menu:not(.nav-links ul),
html body .widget_nav_menu ul {
  display: none !important;
  visibility: hidden !important;
  height: 0 !important;
  overflow: hidden !important;
  pointer-events: none !important;
}

/* Sicherstellen: Unser site-header bleibt sichtbar */
html body .site-header { display: block !important; visibility: visible !important; }
html body .nav-wrap    { display: flex   !important; visibility: visible !important; }
html body .site-logo   { display: block  !important; visibility: visible !important; }
