@import url('https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,400;9..144,600;9..144,700;9..144,900&family=Plus+Jakarta+Sans:wght@400;500;600;700&display=swap');

:root {
  --bg: #F9F7F4;
  --bg-section: #F0ECE6;
  --white: #FFFFFF;
  --primary: #0E2340;
  --primary-mid: #163762;
  --accent: #E8610A;
  --accent-hover: #C84E08;
  --accent-light: #FFF0E6;
  --green: #1A6B3C;
  --green-light: #E6F4EC;
  --text: #1C1C2E;
  --text-mid: #4A5568;
  --text-light: #9CA3AF;
  --border: #E2DED8;
  --shadow-sm: 0 2px 8px rgba(14,35,64,.06);
  --shadow: 0 4px 20px rgba(14,35,64,.1);
  --shadow-lg: 0 8px 40px rgba(14,35,64,.15);
  --radius: 12px;
  --radius-lg: 20px;
  --radius-xl: 28px;
  --font-display: 'Fraunces', serif;
  --font-body: 'Plus Jakarta Sans', sans-serif;
  --max: 1200px;
  --sp: 80px 0;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font-body);background:var(--bg);color:var(--text);line-height:1.6;font-size:16px}
img{max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
h1,h2,h3{font-family:var(--font-display);line-height:1.12}
h1{font-size:clamp(2.1rem,5vw,3.6rem);font-weight:700;color:var(--primary)}
h2{font-size:clamp(1.8rem,3.5vw,2.6rem);font-weight:700;color:var(--primary)}
h3{font-size:clamp(1.1rem,2vw,1.4rem);font-weight:600;color:var(--primary)}
p{color:var(--text-mid)}

/* LAYOUT */
.container{max-width:var(--max);margin:0 auto;padding:0 24px}
.section{padding:var(--sp)}
.section-header{text-align:center;margin-bottom:52px}
.section-badge{display:inline-block;background:var(--accent-light);color:var(--accent);padding:5px 14px;border-radius:100px;font-size:.8rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;margin-bottom:14px}
.section-title{font-size:clamp(1.8rem,3.5vw,2.6rem);font-weight:700;color:var(--primary);margin-bottom:12px}
.section-sub{font-size:1.05rem;color:var(--text-mid);max-width:560px;margin:0 auto}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;gap:8px;padding:14px 28px;border-radius:var(--radius);font-family:var(--font-body);font-weight:700;font-size:1rem;cursor:pointer;border:none;transition:all .2s ease;text-decoration:none}
.btn-primary{background:var(--accent);color:#fff;box-shadow:0 4px 16px rgba(232,97,10,.35)}
.btn-primary:hover{background:var(--accent-hover);transform:translateY(-2px);box-shadow:0 6px 24px rgba(232,97,10,.45)}
.btn-secondary{background:transparent;color:var(--primary);border:2px solid var(--primary)}
.btn-secondary:hover{background:var(--primary);color:#fff}
.btn-white{background:#fff;color:var(--accent);box-shadow:var(--shadow)}
.btn-white:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}
.btn-lg{padding:18px 40px;font-size:1.1rem;border-radius:16px}

/* NAV */
.nav{position:fixed;top:0;left:0;right:0;z-index:200;background:rgba(249,247,244,.95);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);transition:box-shadow .3s}
.nav.scrolled{box-shadow:var(--shadow)}
.nav-inner{max-width:var(--max);margin:0 auto;padding:0 24px;display:flex;align-items:center;justify-content:space-between;height:72px}
.nav-logo{font-family:var(--font-display);font-size:1.5rem;font-weight:700;color:var(--primary)}
.nav-logo span{color:var(--accent)}
.nav-links{display:flex;align-items:center;gap:4px;list-style:none}
.nav-links a{padding:8px 13px;border-radius:8px;font-weight:500;font-size:.9rem;color:var(--text-mid);transition:all .2s}
.nav-links a:hover{color:var(--primary);background:var(--bg-section)}
.nav-links a.active{color:var(--primary);font-weight:600}
.nav-cta a{background:var(--accent)!important;color:#fff!important;padding:10px 20px!important;border-radius:10px!important}
.nav-cta a:hover{background:var(--accent-hover)!important}
.hamburger{display:none;background:none;border:none;cursor:pointer;padding:4px;flex-direction:column;gap:5px}
.hamburger span{display:block;width:22px;height:2px;background:var(--primary);transition:all .3s}

/* HERO */
.hero{background:var(--primary);padding:136px 0 96px;position:relative;overflow:hidden}
.hero::before{content:'';position:absolute;top:-80px;right:-80px;width:480px;height:480px;background:radial-gradient(circle,rgba(232,97,10,.18) 0%,transparent 70%);border-radius:50%}
.hero::after{content:'';position:absolute;bottom:-60px;left:5%;width:360px;height:360px;background:radial-gradient(circle,rgba(26,107,60,.12) 0%,transparent 70%);border-radius:50%}
.hero-inner{display:grid;grid-template-columns:1.1fr .9fr;gap:56px;align-items:center;position:relative;z-index:1}
.hero-badge{display:inline-flex;align-items:center;gap:6px;background:rgba(232,97,10,.15);color:#FF9055;padding:6px 14px;border-radius:100px;font-size:.82rem;font-weight:700;margin-bottom:20px;border:1px solid rgba(232,97,10,.3);letter-spacing:.02em}
.hero h1{color:#fff;margin-bottom:18px}
.hero h1 em{color:var(--accent);font-style:normal}
.hero-sub{font-size:1.05rem;color:rgba(255,255,255,.72);margin-bottom:32px;line-height:1.75}
.hero-bullets{list-style:none;margin-bottom:36px}
.hero-bullets li{display:flex;align-items:center;gap:10px;color:rgba(255,255,255,.88);font-weight:500;font-size:.95rem;margin-bottom:10px}
.hero-bullets li::before{content:'✓';display:flex;align-items:center;justify-content:center;width:22px;height:22px;min-width:22px;background:var(--green);color:#fff;border-radius:50%;font-size:.7rem;font-weight:800}
.hero-btns{display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.hero-note{font-size:.82rem;color:rgba(255,255,255,.45);margin-top:14px}

/* FORM CARD */
.form-card{background:#fff;border-radius:var(--radius-xl);box-shadow:0 24px 64px rgba(0,0,0,.22);overflow:hidden}
.form-top{background:var(--primary);padding:22px 28px;border-bottom:1px solid rgba(255,255,255,.1)}
.form-top h3{color:#fff;font-size:1.05rem;font-weight:700;font-family:var(--font-display)}
.form-top p{color:rgba(255,255,255,.6);font-size:.82rem;margin-top:3px}
.progress-wrap{display:flex;align-items:center;padding:18px 28px;background:#F8F5F1;border-bottom:1px solid var(--border)}
.prog-step{display:flex;flex-direction:column;align-items:center;gap:3px;flex:0 0 auto}
.prog-dot{width:28px;height:28px;border-radius:50%;background:#fff;border:2px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:.72rem;font-weight:700;color:var(--text-light);transition:all .3s;position:relative;z-index:1}
.prog-dot.active{border-color:var(--accent);background:var(--accent);color:#fff}
.prog-dot.done{border-color:var(--green);background:var(--green);color:#fff}
.prog-label{font-size:.65rem;font-weight:600;color:var(--text-light);white-space:nowrap;text-align:center;max-width:64px}
.prog-label.active{color:var(--accent)}
.prog-label.done{color:var(--green)}
.prog-line{flex:1;height:2px;background:var(--border);margin:0 4px;margin-bottom:14px;transition:background .3s}
.prog-line.done{background:var(--green)}
.form-body{padding:24px 28px}
.form-step{display:none}
.form-step.active{display:block;animation:fadeSlide .3s ease}
@keyframes fadeSlide{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
.step-q{font-size:.92rem;font-weight:700;color:var(--primary);margin-bottom:14px}
.opt-grid{display:grid;grid-template-columns:1fr 1fr;gap:9px;margin-bottom:18px}
.opt-btn{display:flex;flex-direction:column;align-items:center;gap:6px;padding:14px 10px;background:var(--bg);border:2px solid var(--border);border-radius:var(--radius);cursor:pointer;transition:all .2s;text-align:center;font-family:var(--font-body)}
.opt-btn:hover{border-color:var(--accent);background:var(--accent-light)}
.opt-btn.selected{border-color:var(--accent);background:var(--accent-light)}
.opt-btn .oicon{font-size:1.7rem;line-height:1}
.opt-btn .olabel{font-size:.75rem;font-weight:700;color:var(--primary)}
.form-field{margin-bottom:14px}
.form-field label{display:block;font-size:.83rem;font-weight:700;color:var(--text);margin-bottom:5px}
.form-field input,.form-field select{width:100%;padding:11px 15px;border:2px solid var(--border);border-radius:var(--radius);font-family:var(--font-body);font-size:.95rem;color:var(--text);background:var(--bg);transition:border-color .2s}
.form-field input:focus,.form-field select:focus{outline:none;border-color:var(--accent);background:#fff}
.field-hint{font-size:.75rem;color:var(--text-light);margin-top:3px}
.form-field input[type=tel]{letter-spacing:.02em}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.opt-label-sm{display:block;font-size:.83rem;font-weight:700;color:var(--text);margin-bottom:10px}
.form-nav{display:flex;gap:10px;margin-top:20px}
.btn-back{background:transparent;border:2px solid var(--border);color:var(--text-mid);padding:12px 18px;border-radius:10px;font-family:var(--font-body);font-weight:700;cursor:pointer;transition:all .2s;font-size:.9rem}
.btn-back:hover{border-color:var(--primary);color:var(--primary)}
.btn-next{flex:1;background:var(--accent);color:#fff;border:none;padding:13px 20px;border-radius:10px;font-family:var(--font-body);font-weight:700;font-size:.95rem;cursor:pointer;transition:all .2s}
.btn-next:hover{background:var(--accent-hover);transform:translateY(-1px)}
.form-success{display:none;text-align:center;padding:36px 28px}
.form-success.show{display:block;animation:fadeSlide .3s ease}
.success-icon{font-size:3.5rem;margin-bottom:12px}
.form-success h3{font-family:var(--font-display);font-size:1.5rem;color:var(--primary);margin-bottom:8px}
.form-success p{color:var(--text-mid)}

/* TRUST BAR */
.trust-bar{background:#fff;border-bottom:1px solid var(--border);padding:18px 0}
.trust-inner{display:flex;align-items:center;justify-content:center;gap:36px;flex-wrap:wrap}
.trust-item{display:flex;align-items:center;gap:8px;font-size:.88rem;font-weight:600;color:var(--text-mid)}
.trust-item .ti{font-size:1.2rem;color:var(--green)}

/* STATS */
.stats-band{background:var(--primary);padding:56px 0}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;text-align:center}
.stat-num{font-family:var(--font-display);font-size:2.8rem;font-weight:700;color:var(--accent);display:block;line-height:1;margin-bottom:6px}
.stat-lbl{font-size:.88rem;color:rgba(255,255,255,.65);line-height:1.5}

/* HOW IT WORKS */
.how-card{background:#fff;border-radius:var(--radius-lg);padding:32px 24px;text-align:center;box-shadow:var(--shadow-sm);transition:all .25s;position:relative}
.how-card:hover{box-shadow:var(--shadow);transform:translateY(-4px)}
.how-num{width:48px;height:48px;background:var(--accent);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.2rem;font-weight:700;font-family:var(--font-display);margin:0 auto 16px}
.how-icon{font-size:2.4rem;margin-bottom:12px}
.how-card h3{margin-bottom:8px}
.how-card p{font-size:.9rem}

/* FEAR BUSTERS */
.feat-card{display:flex;gap:18px;padding:24px;background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:box-shadow .2s}
.feat-card:hover{box-shadow:var(--shadow)}
.feat-icon{width:50px;height:50px;min-width:50px;background:var(--accent-light);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.5rem}
.feat-text h3{font-size:1rem;margin-bottom:5px}
.feat-text p{font-size:.88rem}

/* TESTIMONIALS */
.testi-card{background:#fff;border-radius:var(--radius-lg);padding:28px;box-shadow:var(--shadow-sm);border-left:4px solid var(--accent)}
.testi-stars{color:#F59E0B;font-size:.95rem;margin-bottom:12px}
.testi-text{font-size:.92rem;color:var(--text-mid);font-style:italic;margin-bottom:18px;line-height:1.75}
.testi-author{display:flex;align-items:center;gap:12px}
.testi-avatar{width:42px;height:42px;border-radius:50%;background:var(--primary);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:.95rem;font-family:var(--font-display)}
.testi-info strong{display:block;color:var(--primary);font-size:.88rem}
.testi-info span{font-size:.78rem;color:var(--text-light)}

/* ACCORDION */
.faq-sec{background:var(--bg-section)}
.accordion{max-width:800px;margin:0 auto}
.acc-item{background:#fff;border-radius:var(--radius);margin-bottom:8px;overflow:hidden}
.acc-btn{width:100%;display:flex;align-items:center;justify-content:space-between;padding:18px 22px;background:none;border:none;cursor:pointer;text-align:left;font-family:var(--font-body);font-size:.97rem;font-weight:600;color:var(--primary);transition:background .2s}
.acc-btn:hover{background:var(--bg)}
.acc-icon{width:24px;height:24px;min-width:24px;background:var(--bg);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.95rem;color:var(--accent);transition:all .3s}
.acc-btn.open .acc-icon{transform:rotate(45deg);background:var(--accent);color:#fff}
.acc-body{display:none;padding:0 22px 18px;color:var(--text-mid);font-size:.93rem;line-height:1.75}
.acc-body.open{display:block}

/* CTA BAND */
.cta-band{background:var(--accent);padding:72px 0;text-align:center;position:relative;overflow:hidden}
.cta-band::before{content:'';position:absolute;inset:0;background:repeating-linear-gradient(45deg,rgba(255,255,255,.03) 0,rgba(255,255,255,.03) 1px,transparent 1px,transparent 16px)}
.cta-band h2{color:#fff;margin-bottom:12px;position:relative}
.cta-band p{color:rgba(255,255,255,.8);font-size:1.05rem;margin-bottom:32px;position:relative}

/* PRICE TABLE */
.price-tbl{width:100%;border-collapse:separate;border-spacing:0;background:#fff;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow)}
.price-tbl thead tr{background:var(--primary)}
.price-tbl th{padding:15px 20px;text-align:left;font-size:.83rem;font-weight:700;color:rgba(255,255,255,.8);letter-spacing:.03em}
.price-tbl td{padding:14px 20px;border-bottom:1px solid var(--border);font-size:.92rem}
.price-tbl tr:last-child td{border-bottom:none}
.price-tbl tr:hover td{background:var(--bg)}
.td-price{font-weight:700;color:var(--primary);font-size:1rem}
.td-after{color:var(--green);font-weight:700}
.pill{display:inline-block;padding:2px 10px;border-radius:100px;font-size:.72rem;font-weight:700}
.pill-green{background:var(--green-light);color:var(--green)}
.pill-blue{background:#EFF4FF;color:#2B4CB5}
.pill-orange{background:var(--accent-light);color:var(--accent)}

/* RECHNER */
.rechner-card{background:var(--primary);border-radius:var(--radius-xl);padding:40px}
.rechner-card h3{font-family:var(--font-display);color:#fff;font-size:1.6rem;margin-bottom:8px}
.rechner-card>p{color:rgba(255,255,255,.65);margin-bottom:32px}
.slider-group{margin-bottom:22px}
.slider-lbl{display:flex;justify-content:space-between;margin-bottom:8px}
.slider-lbl span{font-size:.88rem;color:rgba(255,255,255,.65)}
.slider-lbl strong{color:#fff;font-weight:700}
input[type=range]{width:100%;height:6px;background:rgba(255,255,255,.2);border-radius:3px;appearance:none;outline:none;cursor:pointer}
input[type=range]::-webkit-slider-thumb{appearance:none;width:20px;height:20px;background:var(--accent);border-radius:50%;box-shadow:0 2px 8px rgba(0,0,0,.3)}
.rechner-res{background:rgba(255,255,255,.1);border-radius:var(--radius-lg);padding:24px;margin-top:24px;border:1px solid rgba(255,255,255,.1)}
.rr-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;text-align:center}
.rr-item span{font-size:.75rem;color:rgba(255,255,255,.55);display:block;margin-bottom:4px;line-height:1.3}
.rr-item strong{font-size:1.3rem;font-weight:700;color:#fff;font-family:var(--font-display)}
.rr-item.highlight strong{color:var(--accent);font-size:1.5rem}
.rr-divider{border:none;border-top:1px solid rgba(255,255,255,.1);margin:16px 0}

/* PAGE HERO */
.page-hero{background:var(--primary);padding:120px 0 60px;position:relative;overflow:hidden}
.page-hero::after{content:'';position:absolute;right:0;bottom:0;width:400px;height:300px;background:radial-gradient(circle,rgba(232,97,10,.1) 0%,transparent 70%)}
.page-hero-inner{position:relative;z-index:1}
.breadcrumb{display:flex;gap:6px;align-items:center;color:rgba(255,255,255,.45);font-size:.82rem;margin-bottom:14px}
.breadcrumb a{color:rgba(255,255,255,.45)}
.breadcrumb a:hover{color:#fff}
.breadcrumb span{color:rgba(255,255,255,.25)}
.page-hero h1{color:#fff;margin-bottom:14px}
.page-hero-sub{font-size:1.1rem;color:rgba(255,255,255,.72);max-width:580px;line-height:1.7}

/* INFO CARDS */
.info-card{background:#fff;border-radius:var(--radius-lg);padding:28px;box-shadow:var(--shadow-sm);height:100%;transition:all .25s;border-top:4px solid transparent}
.info-card:hover{box-shadow:var(--shadow);transform:translateY(-3px);border-top-color:var(--accent)}
.card-icon{font-size:2.4rem;margin-bottom:14px}
.card-price{margin-top:14px;padding-top:14px;border-top:1px solid var(--border);font-size:.88rem;color:var(--text-mid)}
.card-price strong{color:var(--accent);font-size:1.25rem;display:block}

/* COMPARE TABLE */
.cmp-tbl{width:100%;border-collapse:separate;border-spacing:0;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow)}
.cmp-tbl th{background:var(--primary);color:#fff;padding:16px 18px;font-size:.85rem;font-weight:700;text-align:center}
.cmp-tbl th:first-child{text-align:left}
.cmp-tbl td{padding:13px 18px;border-bottom:1px solid var(--border);background:#fff;font-size:.88rem;text-align:center;color:var(--text-mid)}
.cmp-tbl td:first-child{font-weight:700;color:var(--text);text-align:left}
.cmp-tbl tr:last-child td{border-bottom:none}
.cmp-tbl tr:nth-child(even) td{background:var(--bg)}
.chk{color:var(--green);font-size:1.1rem}
.xmark{color:#DC2626;font-size:1.1rem}
.partial{color:#F59E0B;font-size:1.1rem}

/* FOOTER */
.footer{background:#07101E;color:rgba(255,255,255,.6);padding:60px 0 24px}
.footer-grid{display:grid;grid-template-columns:1.8fr 1fr 1fr 1fr;gap:48px;margin-bottom:48px}
.footer-logo{font-family:var(--font-display);font-size:1.55rem;font-weight:700;color:#fff;margin-bottom:12px}
.footer-logo span{color:var(--accent)}
.footer-desc{font-size:.88rem;line-height:1.75;margin-bottom:20px}
.footer-col h4{color:#fff;font-size:.78rem;font-weight:700;margin-bottom:16px;letter-spacing:.07em;text-transform:uppercase}
.footer-links{list-style:none}
.footer-links li{margin-bottom:9px}
.footer-links a{font-size:.88rem;color:rgba(255,255,255,.5);transition:color .2s}
.footer-links a:hover{color:#fff}
.footer-bottom{border-top:1px solid rgba(255,255,255,.07);padding-top:22px;display:flex;justify-content:space-between;align-items:center;font-size:.82rem;flex-wrap:wrap;gap:12px}
.footer-bottom-links{display:flex;gap:18px;flex-wrap:wrap}
.footer-bottom-links a{color:rgba(255,255,255,.35);transition:color .2s}
.footer-bottom-links a:hover{color:#fff}

/* UTILS */
.text-center{text-align:center}
.bg-white{background:#fff}
.bg-section{background:var(--bg-section)}
.bg-primary{background:var(--primary)}
.text-white{color:#fff}
.text-accent{color:var(--accent)}
.text-green{color:var(--green)}
.mt-4{margin-top:4px}.mt-8{margin-top:8px}.mt-12{margin-top:12px}.mt-16{margin-top:16px}.mt-24{margin-top:24px}.mt-32{margin-top:32px}
.mb-8{margin-bottom:8px}.mb-12{margin-bottom:12px}.mb-16{margin-bottom:16px}.mb-24{margin-bottom:24px}.mb-32{margin-bottom:32px}
.green-check-list{list-style:none}
.green-check-list li{padding:5px 0 5px 24px;position:relative;color:var(--text-mid);font-size:.95rem}
.green-check-list li::before{content:'✓';position:absolute;left:0;color:var(--green);font-weight:800}
.highlight-box{background:var(--accent-light);border-left:4px solid var(--accent);border-radius:0 var(--radius) var(--radius) 0;padding:18px 22px}
.highlight-box p{color:var(--text)}
.info-box{background:var(--green-light);border-left:4px solid var(--green);border-radius:0 var(--radius) var(--radius) 0;padding:18px 22px}
.info-box p{color:var(--text)}
hr.divider{border:none;border-top:1px solid var(--border);margin:36px 0}

/* MOBILE NAV */
.nav-links.mobile-open{display:flex!important;position:absolute;top:72px;left:0;right:0;flex-direction:column;background:rgba(249,247,244,.98);border-bottom:1px solid var(--border);padding:16px;gap:4px}

/* ANIMATIONS */
.fade-up{opacity:0;transform:translateY(24px);transition:opacity .55s ease,transform .55s ease}
.fade-up.visible{opacity:1;transform:translateY(0)}

/* RESPONSIVE */
@media(max-width:960px){
  .grid-2,.grid-3,.grid-4{grid-template-columns:1fr}
  .stats-grid{grid-template-columns:1fr 1fr}
  .hero-inner{grid-template-columns:1fr;gap:40px}
  .footer-grid{grid-template-columns:1fr 1fr}
  .nav-links{display:none}
  .hamburger{display:flex}
  .rr-grid{grid-template-columns:1fr}
}
@media(max-width:600px){
  :root{--sp:56px 0}
  .hero{padding:100px 0 56px}
  .page-hero{padding:100px 0 44px}
  .stats-grid{grid-template-columns:1fr 1fr}
  .footer-grid{grid-template-columns:1fr}
  .trust-inner{gap:18px}
  .opt-grid{grid-template-columns:1fr 1fr}
  .rechner-card{padding:28px 20px}
  .form-row{grid-template-columns:1fr}
}

/* ===========================
   BLOG STYLES
   =========================== */
.blog-hero { background: var(--primary); padding: 100px 0 48px; }
.blog-hero h1 { color: #fff; margin-bottom: 12px; }
.blog-hero p { color: rgba(255,255,255,.7); font-size: 1.05rem; }

.blog-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.blog-card { background: #fff; border-radius: var(--radius-lg); overflow: hidden; box-shadow: var(--shadow-sm); transition: all .25s; display: flex; flex-direction: column; }
.blog-card:hover { box-shadow: var(--shadow); transform: translateY(-3px); }
.blog-card-img { height: 180px; background: var(--primary); display: flex; align-items: center; justify-content: center; font-size: 3.5rem; position: relative; overflow: hidden; }
.blog-card-img::after { content: ''; position: absolute; inset: 0; background: linear-gradient(135deg, rgba(14,35,64,.7) 0%, rgba(232,97,10,.3) 100%); }
.blog-card-body { padding: 24px; flex: 1; display: flex; flex-direction: column; }
.blog-tag { display: inline-block; background: var(--accent-light); color: var(--accent); font-size: .72rem; font-weight: 700; padding: 3px 10px; border-radius: 100px; margin-bottom: 10px; letter-spacing: .04em; text-transform: uppercase; }
.blog-card h3 { font-size: 1.05rem; color: var(--primary); margin-bottom: 8px; line-height: 1.3; }
.blog-card p { font-size: .88rem; flex: 1; margin-bottom: 16px; }
.blog-card .read-more { font-size: .85rem; font-weight: 700; color: var(--accent); display: flex; align-items: center; gap: 4px; transition: gap .2s; }
.blog-card:hover .read-more { gap: 8px; }
.blog-meta { display: flex; gap: 16px; font-size: .78rem; color: var(--text-light); margin-bottom: 8px; }
.blog-meta span { display: flex; align-items: center; gap: 4px; }

/* Article layout */
.article-wrap { display: grid; grid-template-columns: 1fr 300px; gap: 48px; align-items: start; }
.article-body { background: #fff; border-radius: var(--radius-xl); padding: 48px; box-shadow: var(--shadow-sm); }
.article-body h2 { font-size: 1.6rem; color: var(--primary); margin: 36px 0 14px; padding-top: 8px; }
.article-body h3 { font-size: 1.2rem; color: var(--primary); margin: 24px 0 10px; }
.article-body p { color: var(--text-mid); line-height: 1.8; margin-bottom: 16px; }
.article-body ul, .article-body ol { color: var(--text-mid); padding-left: 20px; margin-bottom: 16px; line-height: 1.8; }
.article-body li { margin-bottom: 6px; }
.article-body strong { color: var(--text); }
.article-body table { width: 100%; border-collapse: collapse; margin: 20px 0; font-size: .9rem; }
.article-body table th { background: var(--primary); color: #fff; padding: 12px 14px; text-align: left; font-size: .82rem; }
.article-body table td { padding: 11px 14px; border-bottom: 1px solid var(--border); }
.article-body table tr:nth-child(even) td { background: var(--bg); }
.article-header { margin-bottom: 32px; padding-bottom: 24px; border-bottom: 1px solid var(--border); }
.article-header h1 { font-size: clamp(1.7rem, 3vw, 2.2rem); margin-bottom: 12px; }
.article-author { display: flex; align-items: center; gap: 12px; margin-top: 16px; }
.author-dot { width: 36px; height: 36px; border-radius: 50%; background: var(--primary); color: #fff; display: flex; align-items: center; justify-content: center; font-size: .85rem; font-weight: 700; font-family: var(--font-display); }
.article-author span { font-size: .82rem; color: var(--text-light); }

/* Sidebar */
.article-sidebar { position: sticky; top: 90px; }
.sidebar-card { background: #fff; border-radius: var(--radius-lg); padding: 24px; box-shadow: var(--shadow-sm); margin-bottom: 20px; }
.sidebar-card h4 { font-size: .95rem; color: var(--primary); margin-bottom: 14px; font-family: var(--font-display); }
.sidebar-toc { list-style: none; }
.sidebar-toc li { padding: 6px 0; border-bottom: 1px solid var(--border); }
.sidebar-toc li:last-child { border-bottom: none; }
.sidebar-toc a { font-size: .85rem; color: var(--text-mid); transition: color .2s; }
.sidebar-toc a:hover { color: var(--accent); }
.sidebar-cta { background: var(--primary); border-radius: var(--radius-lg); padding: 24px; color: #fff; }
.sidebar-cta h4 { color: #fff; margin-bottom: 10px; }
.sidebar-cta p { color: rgba(255,255,255,.7); font-size: .88rem; margin-bottom: 16px; }

/* Article inline CTA box */
.article-cta-box { background: var(--accent-light); border: 2px solid var(--accent); border-radius: var(--radius-lg); padding: 24px; margin: 32px 0; }
.article-cta-box h3 { color: var(--primary); margin-bottom: 8px; font-size: 1.1rem; }
.article-cta-box p { margin-bottom: 16px; font-size: .92rem; }

/* Article FAQ */
.article-faq { background: var(--bg-section); border-radius: var(--radius-lg); padding: 28px; margin: 32px 0; }
.article-faq h2 { font-size: 1.3rem; margin-bottom: 20px; }

/* Related posts */
.related-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }

@media(max-width: 900px) {
  .article-wrap { grid-template-columns: 1fr; }
  .article-sidebar { position: static; }
  .blog-grid { grid-template-columns: 1fr 1fr; }
  .related-grid { grid-template-columns: 1fr; }
}
@media(max-width: 600px) {
  .blog-grid { grid-template-columns: 1fr; }
  .article-body { padding: 24px 18px; }
}


  .cookie-btns { width: 100%; }
  .cookie-btn { flex: 1; text-align: center; }
}

/* ── oicon-pro: professionelle Abkürzungs-Badges im Formular ─────────────── */
.oicon-pro {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 44px;
  height: 26px;
  padding: 0 8px;
  background: var(--primary);
  color: #fff;
  border-radius: 6px;
  font-size: .65rem;
  font-weight: 800;
  letter-spacing: .06em;
  font-family: var(--font-body);
  text-transform: uppercase;
  transition: background .2s;
}
.opt-btn:hover .oicon-pro,
.opt-btn.selected .oicon-pro { background: var(--accent); }

/* ── ti-check: Trust-Bar Häkchen ──────────────────────────────────────────── */
.ti-check {
  display: inline-block;
  width: 18px;
  height: 18px;
  min-width: 18px;
  border-radius: 50%;
  background: var(--green);
  position: relative;
}
.ti-check::after {
  content: '';
  position: absolute;
  left: 5px;
  top: 3px;
  width: 6px;
  height: 9px;
  border: 2px solid #fff;
  border-top: none;
  border-left: none;
  transform: rotate(45deg);
}

/* ── feat-icon SVG: stroke inherits color ────────────────────────────────── */
.feat-icon svg { stroke: var(--accent); }

/* ── Cookie Modal (Centered, must-dismiss) ──────────────────────────────── */
#cookie-overlay {
  position: fixed;
  inset: 0;
  background: rgba(10,20,40,.65);
  backdrop-filter: blur(4px);
  z-index: 9990;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
  opacity: 0;
  visibility: hidden;
  transition: opacity .3s ease, visibility .3s ease;
}
#cookie-overlay.show {
  opacity: 1;
  visibility: visible;
}
#cookie-modal {
  background: #fff;
  border-radius: 20px;
  padding: 36px;
  max-width: 480px;
  width: 100%;
  box-shadow: 0 24px 64px rgba(0,0,0,.25);
  transform: translateY(16px) scale(.97);
  transition: transform .35s ease;
}
#cookie-overlay.show #cookie-modal {
  transform: translateY(0) scale(1);
}
#cookie-modal h3 {
  font-family: var(--font-display);
  font-size: 1.3rem;
  color: var(--primary);
  margin-bottom: 10px;
}
#cookie-modal > p {
  font-size: .88rem;
  color: var(--text-mid);
  line-height: 1.65;
  margin-bottom: 22px;
}
#cookie-modal > p a { color: var(--accent); text-decoration: underline; }
.cookie-option {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 14px 16px;
  border-radius: 12px;
  border: 2px solid var(--border);
  margin-bottom: 10px;
  cursor: pointer;
  transition: border-color .2s, background .2s;
}
.cookie-option:hover { border-color: var(--primary); background: var(--bg); }
.cookie-option input[type=checkbox] {
  width: 18px;
  height: 18px;
  min-width: 18px;
  margin-top: 1px;
  cursor: pointer;
  accent-color: var(--accent);
}
.cookie-option input:disabled { opacity: .5; cursor: not-allowed; }
.cookie-option-text strong {
  display: block;
  font-size: .9rem;
  font-weight: 700;
  color: var(--primary);
  margin-bottom: 2px;
}
.cookie-option-text span {
  font-size: .78rem;
  color: var(--text-light);
  line-height: 1.5;
}
.cookie-required-badge {
  display: inline-block;
  background: var(--green-light);
  color: var(--green);
  font-size: .66rem;
  font-weight: 700;
  padding: 1px 7px;
  border-radius: 100px;
  margin-left: 6px;
  vertical-align: middle;
}
.cookie-modal-btns {
  display: flex;
  gap: 10px;
  margin-top: 20px;
}
.cookie-modal-btns button {
  flex: 1;
  padding: 13px 16px;
  border-radius: 12px;
  font-family: var(--font-body);
  font-size: .9rem;
  font-weight: 700;
  cursor: pointer;
  border: none;
  transition: all .2s;
}
#cookie-btn-necessary {
  background: var(--bg-section);
  color: var(--text);
  border: 2px solid var(--border);
}
#cookie-btn-necessary:hover { border-color: var(--primary); }
#cookie-btn-all {
  background: var(--accent);
  color: #fff;
  box-shadow: 0 4px 14px rgba(232,97,10,.3);
}
#cookie-btn-all:hover { background: var(--accent-hover); }
.cookie-footer-text {
  text-align: center;
  font-size: .72rem;
  color: var(--text-light);
  margin-top: 14px;
}
.cookie-footer-text a { color: var(--text-light); text-decoration: underline; }

#cookie-settings-btn {
  position: fixed;
  bottom: 14px;
  left: 14px;
  z-index: 9989;
  width: 38px;
  height: 38px;
  background: var(--primary);
  border: none;
  border-radius: 50%;
  cursor: pointer;
  font-size: .9rem;
  box-shadow: 0 2px 10px rgba(0,0,0,.2);
  color: #fff;
  display: none;
  align-items: center;
  justify-content: center;
  transition: transform .2s;
  font-family: sans-serif;
}
#cookie-settings-btn:hover { transform: scale(1.1); }
#cookie-settings-btn.visible { display: flex; }

@media(max-width:480px) {
  #cookie-modal { padding: 24px 20px; }
  .cookie-modal-btns { flex-direction: column; }
}
