/* ══════════════════════════════════════════════════
   WUNDEX — SHARED STYLESHEET
   Used by: index.html, impressum.html, datenschutz.html
   ══════════════════════════════════════════════════ */

/* Poppins — self-hosted (no Google Fonts request, DSGVO-clean) */
@font-face {
  font-family: 'Poppins'; font-style: normal; font-weight: 400; font-display: swap;
  src: url('../assets/fonts/poppins-400-latin.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Poppins'; font-style: normal; font-weight: 400; font-display: swap;
  src: url('../assets/fonts/poppins-400-latin-ext.woff2') format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'Poppins'; font-style: normal; font-weight: 500; font-display: swap;
  src: url('../assets/fonts/poppins-500-latin.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Poppins'; font-style: normal; font-weight: 500; font-display: swap;
  src: url('../assets/fonts/poppins-500-latin-ext.woff2') format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'Poppins'; font-style: normal; font-weight: 600; font-display: swap;
  src: url('../assets/fonts/poppins-600-latin.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Poppins'; font-style: normal; font-weight: 600; font-display: swap;
  src: url('../assets/fonts/poppins-600-latin-ext.woff2') format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'Poppins'; font-style: normal; font-weight: 700; font-display: swap;
  src: url('../assets/fonts/poppins-700-latin.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Poppins'; font-style: normal; font-weight: 700; font-display: swap;
  src: url('../assets/fonts/poppins-700-latin-ext.woff2') format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

:root {
  --bg: #F3F7FB;
  --bg-warm: #E1E9FE;
  --bg-card: #FFFFFF;
  --primary: #41347F;
  --primary-dark: #2E2459;
  --primary-light: #E1E9FE;
  --accent: #1B5E20;
  --accent-light: #D9FFD8;
  --text: #252525;
  --text-soft: #4F5B6E;
  --text-muted: #8A8A8A;
  --border: #E0DDD8;
  --white: #FFFFFF;
  --green: #2D9B6E;
  --red-soft: #E85D5D;
  --font-d: 'Poppins', -apple-system, sans-serif;
  --font-b: 'Poppins', -apple-system, sans-serif;
  --r-sm: 8px;
  --r-md: 12px;
  --r-lg: 20px;
  --shadow: 0 2px 20px rgba(0,0,0,0.06);
  --shadow-c: 0 4px 30px rgba(0,0,0,0.08);
  --mw: 1120px;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font-b);color:var(--text);background:var(--bg);line-height:1.6;-webkit-font-smoothing:antialiased}

/* ── TOP BAR ── */
.top-bar{position:sticky;top:0;z-index:100;background:var(--white);border-bottom:1px solid var(--border);padding:12px 48px;display:flex;align-items:center;justify-content:space-between;gap:16px}
.top-bar-logo{display:inline-flex;align-items:center;text-decoration:none}
.top-bar-logo img{display:block;height:72px;width:auto}
.top-bar-right{display:flex;align-items:center;gap:20px}
.top-bar-phone{display:flex;align-items:center;gap:6px;font-weight:600;font-size:0.95rem;color:var(--primary);text-decoration:none}
.top-bar-phone:hover{color:var(--primary-dark)}
.top-bar-cta{background:var(--primary);color:var(--white);border:none;padding:10px 22px;border-radius:50px;font-family:var(--font-b);font-weight:600;font-size:0.9rem;cursor:pointer;text-decoration:none;transition:background 0.2s}
.top-bar-cta:hover{background:var(--primary-dark)}
.top-bar-back{color:var(--primary);font-weight:600;font-size:0.9rem;text-decoration:none;display:inline-flex;align-items:center;gap:6px;transition:color 0.2s}
.top-bar-back:hover{color:var(--primary-dark)}

/* ── HERO ── */
.hero{position:relative;padding:64px 24px 56px;background:linear-gradient(170deg,var(--primary-light) 0%,var(--bg) 60%);overflow:hidden}
.hero::before{content:'';position:absolute;top:-80px;right:-120px;width:400px;height:400px;background:radial-gradient(circle,rgba(65,52,127,0.08) 0%,transparent 70%);border-radius:50%;pointer-events:none}
.hero-inner{max-width:var(--mw);margin:0 auto;display:grid;grid-template-columns:1.1fr 1fr;gap:48px;align-items:start}
.hero-content{position:relative;z-index:1}
.hero-badge{display:inline-flex;align-items:center;gap:6px;background:var(--accent-light);color:var(--accent);font-size:0.82rem;font-weight:600;padding:6px 14px;border-radius:50px;margin-bottom:20px}
.hero h1{font-family:var(--font-d);font-size:clamp(2rem,4vw,2.75rem);font-weight:600;line-height:1.2;color:var(--text);margin-bottom:16px;letter-spacing:-0.02em}
.hero h1 em{font-style:normal;color:var(--primary)}
.hero-sub{font-size:1.1rem;color:var(--text-soft);line-height:1.65;margin-bottom:28px;max-width:520px}
.hero-pills{display:flex;flex-direction:column;gap:12px;margin-bottom:32px}
.hero-pill{display:flex;align-items:center;gap:10px;font-size:1rem;font-weight:500}
.footnote{font-size:0.78rem;font-weight:400;opacity:0.8}
.pill-icon{width:28px;height:28px;background:var(--primary);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.pill-icon svg{width:14px;height:14px}
.hero-cta-row{display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.btn-p{display:inline-flex;align-items:center;gap:8px;background:var(--primary);color:var(--white);font-family:var(--font-b);font-weight:600;font-size:1.05rem;padding:16px 32px;border-radius:50px;border:none;cursor:pointer;text-decoration:none;transition:background 0.2s,transform 0.15s;box-shadow:0 4px 16px rgba(65,52,127,0.25)}
.btn-p:hover{background:var(--primary-dark);transform:translateY(-1px)}
.btn-s{display:inline-flex;align-items:center;gap:8px;background:transparent;color:var(--primary);font-family:var(--font-b);font-weight:600;font-size:1rem;padding:14px 24px;border-radius:50px;border:2px solid var(--primary);cursor:pointer;text-decoration:none;transition:all 0.2s}
.btn-s:hover{background:var(--primary-light)}
.hero-visual{position:relative;max-width:540px;margin-left:auto;margin-right:-80px}
.hero-photo{display:block;width:100%;height:auto;border-radius:var(--r-lg);box-shadow:var(--shadow-c);object-fit:cover;aspect-ratio:1/1;position:relative;top:-24px}
.hero-trust-card{background:var(--white);border-radius:var(--r-lg);padding:32px;box-shadow:var(--shadow-c);position:absolute;left:-88px;bottom:-24px;max-width:420px;width:calc(100% + 24px)}
.trust-stat-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.trust-stat{text-align:center;padding:16px 8px;border-radius:var(--r-md);background:var(--bg)}
.trust-stat-number{font-family:var(--font-d);font-size:1.8rem;font-weight:700;color:var(--primary);line-height:1;margin-bottom:4px}
.trust-stat-label{font-size:0.82rem;color:var(--text-soft);line-height:1.3}
.trust-kasse{margin-top:20px;padding-top:20px;border-top:1px solid var(--border);text-align:center}
.trust-kasse-badge{display:inline-flex;align-items:center;gap:8px;background:var(--primary-light);color:var(--primary);font-weight:600;font-size:0.9rem;padding:10px 20px;border-radius:50px}

/* ── PROOF BAR ── */
.proof-bar{background:var(--white);border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:20px 24px}
.proof-bar-inner{max-width:var(--mw);margin:0 auto;display:flex;align-items:center;justify-content:center;gap:40px;flex-wrap:wrap}
.proof-item{display:flex;align-items:center;gap:8px;font-size:0.9rem;color:var(--text-soft);font-weight:500}
.proof-item strong{color:var(--text)}
@media(max-width:640px){
  .proof-bar{padding:16px 20px}
  .proof-bar-inner{display:grid;grid-template-columns:1fr 1fr;gap:12px 16px;justify-items:start}
  .proof-item{font-size:0.82rem;gap:6px;line-height:1.35}
  .proof-item svg{width:14px;height:14px;flex-shrink:0}
}

/* ── TRUST LOGOS ── */
.trust-logos{background:var(--white);padding:24px 24px 28px}
.trust-logos-inner{max-width:var(--mw);margin:0 auto;display:flex;flex-direction:column;align-items:center;gap:16px}
.trust-logos-label{font-size:0.72rem;font-weight:600;text-transform:uppercase;letter-spacing:0.14em;color:var(--text-muted);text-align:center}
.trust-logos-row{display:flex;align-items:center;justify-content:center;gap:clamp(24px,5vw,56px);flex-wrap:wrap}
.trust-logo{height:52px;width:auto;max-width:100%;opacity:0.9;transition:opacity 0.2s ease,transform 0.2s ease;filter:saturate(0.95)}
.trust-logo:hover{opacity:1;transform:translateY(-1px)}
.trust-logo--dekra{height:56px}
.trust-logo--wundwissen{height:40px}
.trust-divider{width:1px;height:36px;background:var(--border)}
@media(max-width:640px){
  .trust-logos{padding:20px 16px 22px}
  .trust-logos-inner{gap:14px}
  .trust-logos-label{font-size:0.68rem;letter-spacing:0.12em}
  .trust-logos-row{gap:22px 28px;row-gap:16px}
  .trust-divider{display:none}
  .trust-logo{height:40px}
  .trust-logo--dekra{height:44px}
  .trust-logo--wundwissen{height:30px}
}
@media(max-width:380px){
  .trust-logo{height:34px}
  .trust-logo--dekra{height:38px}
  .trust-logo--wundwissen{height:26px}
  .trust-logos-row{gap:18px}
}

/* ── SECTIONS ── */
.section-inner{max-width:var(--mw);margin:0 auto}
.s-label{font-size:0.8rem;font-weight:700;text-transform:uppercase;letter-spacing:0.1em;color:var(--primary);margin-bottom:8px}
.s-title{font-family:var(--font-d);font-size:clamp(1.6rem,3vw,2.2rem);font-weight:600;line-height:1.25;color:var(--text);margin-bottom:12px;letter-spacing:-0.02em}
.s-sub{font-size:1.05rem;color:var(--text-soft);max-width:600px;margin-bottom:48px;line-height:1.6}

/* ── HOW IT WORKS ── */
.how-section{padding:72px 24px;background:var(--bg)}
.steps-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;position:relative}
.steps-grid::before{content:'';position:absolute;top:40px;left:calc(16.66% + 24px);right:calc(16.66% + 24px);height:2px;background:var(--border);z-index:0}
.step-card{background:var(--white);border-radius:var(--r-lg);padding:32px 28px;text-align:center;position:relative;z-index:1;box-shadow:var(--shadow);transition:transform 0.2s}
.step-card:hover{transform:translateY(-4px)}
.step-num{width:52px;height:52px;background:var(--primary);color:var(--white);font-family:var(--font-d);font-weight:700;font-size:1.3rem;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 16px}
.step-t{font-family:var(--font-d);font-size:1.15rem;font-weight:600;color:var(--text);margin-bottom:8px}
.step-d{font-size:0.95rem;color:var(--text-soft);line-height:1.55}
.step-time{display:inline-flex;align-items:center;gap:4px;margin-top:12px;font-size:0.8rem;font-weight:600;color:var(--accent);background:var(--accent-light);padding:4px 12px;border-radius:50px}

/* ── WHY SECTION ── */
.why-section{padding:72px 24px;background:var(--bg-warm)}
.why-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start}
.why-list{display:flex;flex-direction:column;gap:20px;margin-top:32px}
.why-item{display:flex;gap:14px;align-items:flex-start}
.why-icon{width:40px;height:40px;background:var(--primary-light);border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:2px}
.why-icon svg{width:20px;height:20px;color:var(--primary)}
.why-item-t{font-weight:600;font-size:1rem;margin-bottom:2px}
.why-item-d{font-size:0.92rem;color:var(--text-soft);line-height:1.5}
.why-comp{background:var(--white);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-c)}
.comp-h{display:grid;grid-template-columns:1fr 1fr}
.comp-col{padding:16px 20px;font-weight:700;font-size:0.88rem;text-align:center;text-transform:uppercase;letter-spacing:0.04em}
.comp-col:first-child{background:#F0ECEA;color:var(--text-soft)}
.comp-col:last-child{background:var(--primary-dark);color:var(--white)}
.comp-row{display:grid;grid-template-columns:1fr 1fr;align-items:stretch}
.comp-cell{padding:14px 20px;font-size:0.9rem;line-height:1.4;display:flex;align-items:center;gap:8px;text-wrap:pretty}
.comp-row .comp-cell:first-child{border-top:1px solid var(--border)}
.comp-cell:last-child{background:var(--primary);color:var(--white);font-weight:600}
.x{color:#C44;font-weight:700}
.ck{color:var(--green);font-weight:700}
.comp-cell:last-child .ck{color:#D9FFD8}

/* ── CONDITIONS ── */
.cond-section{padding:72px 24px;background:var(--bg)}
.cond-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-top:40px}
.cond-card{background:var(--white);border-radius:var(--r-md);padding:28px;box-shadow:var(--shadow);border-left:4px solid var(--primary);transition:transform 0.2s}
.cond-card:hover{transform:translateY(-2px)}
.cond-t{font-family:var(--font-d);font-size:1.1rem;font-weight:600;margin-bottom:6px}
.cond-d{font-size:0.9rem;color:var(--text-soft);line-height:1.55}

/* ── TESTIMONIALS ── */
.test-section{padding:72px 24px;background:var(--bg-warm)}
.test-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:40px}
.test-card{background:var(--white);border-radius:var(--r-lg);padding:28px;box-shadow:var(--shadow)}
.test-stars{color:#E8A838;font-size:1.1rem;margin-bottom:12px;letter-spacing:2px}
.test-text{font-size:0.95rem;color:var(--text);line-height:1.6;margin-bottom:16px;font-style:italic}
.test-author{font-size:0.85rem;font-weight:600;color:var(--text-soft)}
.test-detail{font-size:0.78rem;color:var(--text-muted);margin-top:2px}

/* ══════════════════════════════════════════════════
   MULTI-STEP FORM
   ══════════════════════════════════════════════════ */
.form-section{padding:72px 24px;background:var(--bg);scroll-margin-top:60px}
.form-wrapper{max-width:720px;margin:0 auto}
.form-header{text-align:center;margin-bottom:36px}

/* Progress bar */
.progress-wrap{margin-bottom:40px;scroll-margin-top:96px}
.progress-steps{display:flex;justify-content:space-between;align-items:center;position:relative;margin-bottom:8px}
.progress-steps::before{content:'';position:absolute;top:50%;left:0;right:0;height:3px;background:var(--border);transform:translateY(-50%);border-radius:2px}
.progress-bar-fill{position:absolute;top:50%;left:0;height:3px;background:var(--primary);transform:translateY(-50%);border-radius:2px;transition:width 0.4s ease}
.progress-dot{width:32px;height:32px;border-radius:50%;background:var(--white);border:3px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:0.75rem;font-weight:700;color:var(--text-muted);position:relative;z-index:1;transition:all 0.3s}
.progress-dot.active{border-color:var(--primary);color:var(--primary);background:var(--primary-light)}
.progress-dot.done{border-color:var(--primary);background:var(--primary);color:var(--white)}
.progress-label{font-size:0.72rem;color:var(--text-muted);text-align:center;margin-top:4px;display:none}

/* Form card */
.form-card{background:var(--white);border-radius:var(--r-lg);box-shadow:var(--shadow-c);overflow:hidden;min-height:380px;position:relative}
.form-step{display:none;padding:48px 40px;animation:fadeStep 0.35s ease}
.form-step.active{display:block}
@keyframes fadeStep{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}

.form-step-q{font-family:var(--font-d);font-size:1.5rem;font-weight:600;color:var(--text);text-align:center;margin-bottom:8px;line-height:1.3}
.form-step-hint{font-size:0.95rem;color:var(--text-soft);text-align:center;margin-bottom:32px}

/* Option cards */
.opt-grid{display:grid;gap:12px}
.opt-grid-3{grid-template-columns:repeat(3,1fr)}
.opt-grid-3x3{grid-template-columns:repeat(3,1fr)}
.opt-card{background:var(--bg);border:2px solid var(--border);border-radius:var(--r-md);padding:20px 16px;text-align:center;cursor:pointer;transition:all 0.2s;display:flex;flex-direction:column;align-items:center;gap:8px;user-select:none}
.opt-card:hover{border-color:var(--primary);background:var(--primary-light)}
.opt-card.selected{border-color:var(--primary);background:var(--primary-light);box-shadow:0 0 0 1px var(--primary)}
.opt-card-icon{font-size:2rem;line-height:1}
.opt-card-label{font-weight:600;font-size:0.92rem;color:var(--text);line-height:1.3}
.opt-card-sub{font-size:0.78rem;color:var(--text-muted);line-height:1.3}

/* Contact form fields */
.field-group{margin-bottom:20px}
.field-label{font-weight:600;font-size:0.92rem;color:var(--text);margin-bottom:6px;display:block}
.field-input{width:100%;padding:14px 16px;border:2px solid var(--border);border-radius:var(--r-sm);font-family:var(--font-b);font-size:1rem;color:var(--text);background:var(--bg);transition:border-color 0.2s;outline:none}
.field-input:focus{border-color:var(--primary);background:var(--white)}
.field-input.error{border-color:var(--red-soft)}
.field-input:focus-visible{outline:3px solid color-mix(in srgb,var(--primary) 35%,transparent);outline-offset:1px}
.field-section-h{font-family:var(--font-d);font-size:1.05rem;font-weight:600;color:var(--text);margin:0 0 16px}
.field-label-opt{font-weight:400;color:var(--text-muted);font-size:0.82rem;margin-left:4px}
.time-opt:focus-visible{outline:3px solid color-mix(in srgb,var(--primary) 35%,transparent);outline-offset:1px}
.field-error{font-size:0.8rem;color:var(--red-soft);margin-top:4px;display:none}
.field-input.error + .field-error{display:block}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.time-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:8px}
.time-opt{padding:12px;border:2px solid var(--border);border-radius:var(--r-sm);text-align:center;cursor:pointer;font-weight:500;font-size:0.92rem;transition:all 0.2s;user-select:none}
.time-opt:hover{border-color:var(--primary);background:var(--primary-light)}
.time-opt.selected{border-color:var(--primary);background:var(--primary-light)}

/* Navigation */
.form-nav{display:flex;justify-content:space-between;align-items:center;padding:20px 40px 32px;gap:16px}
.form-nav-back{display:flex;align-items:center;gap:6px;background:none;border:none;color:var(--text-soft);font-family:var(--font-b);font-weight:600;font-size:0.92rem;cursor:pointer;padding:8px 0;transition:color 0.2s}
.form-nav-back:hover{color:var(--text)}
.form-nav-back.hidden{visibility:hidden}
.btn-submit{display:inline-flex;align-items:center;gap:8px;background:var(--primary);color:var(--white);font-family:var(--font-b);font-weight:600;font-size:1rem;padding:14px 32px;border-radius:50px;border:none;cursor:pointer;transition:background 0.2s,transform 0.15s;box-shadow:0 4px 16px rgba(65,52,127,0.25)}
.btn-submit:hover{background:var(--primary-dark);transform:translateY(-1px)}
.btn-submit:disabled{opacity:0.5;cursor:not-allowed;transform:none}

/* Trust row under form */
.form-trust{display:flex;justify-content:center;gap:28px;margin-top:20px;flex-wrap:wrap}
.form-trust-i{display:flex;align-items:center;gap:6px;font-size:0.82rem;color:var(--text-muted);font-weight:500}

/* Success state — viewport-centered modal so users can't miss it */
.form-success{display:none;position:fixed;inset:0;z-index:1100;background:rgba(37,37,37,0.55);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);align-items:center;justify-content:center;padding:24px;animation:successFade 0.25s ease}
.form-success.active{display:flex}
.form-success-card{position:relative;background:var(--white);border-radius:var(--r-lg);padding:56px 40px;text-align:center;max-width:520px;width:100%;box-shadow:0 24px 60px rgba(0,0,0,0.28);animation:successPop 0.4s cubic-bezier(.2,.8,.2,1)}
.form-success-close{position:absolute;top:14px;right:14px;width:36px;height:36px;border-radius:50%;background:transparent;border:none;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background 0.2s,color 0.2s}
.form-success-close:hover{background:var(--bg);color:var(--text)}
.form-success-close:focus-visible{outline:2px solid var(--primary);outline-offset:2px}
@keyframes successFade{from{opacity:0}to{opacity:1}}
@keyframes successPop{from{opacity:0;transform:translateY(16px) scale(0.96)}to{opacity:1;transform:translateY(0) scale(1)}}
.success-icon{width:72px;height:72px;background:var(--primary-light);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 20px}
.success-icon svg{width:36px;height:36px;color:var(--primary)}
@media(max-width:600px){
  .form-success-card{padding:44px 28px}
}
.form-error-banner{display:none;max-width:480px;margin:16px auto 0;padding:14px 18px;background:#FFEDED;color:#8A1F1F;border:1px solid #F5B4B4;border-radius:var(--r-md);font-size:0.92rem;line-height:1.5;text-align:left}
.form-error-banner.active{display:block}
.form-error-banner a{color:inherit;font-weight:600;text-decoration:underline}
.success-title{font-family:var(--font-d);font-size:1.6rem;font-weight:600;color:var(--text);margin-bottom:8px}
.success-text{font-size:1.05rem;color:var(--text-soft);max-width:420px;margin:0 auto;line-height:1.6}

/* ── FAQ ── */
.faq-section{padding:72px 24px;background:var(--bg-warm)}
.faq-list{max-width:720px;margin:40px auto 0;display:flex;flex-direction:column;gap:8px}
.faq-item{background:var(--white);border-radius:var(--r-md);overflow:hidden;box-shadow:var(--shadow)}
.faq-q{width:100%;padding:20px 24px;background:none;border:none;font-family:var(--font-b);font-size:1rem;font-weight:600;color:var(--text);text-align:left;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:12px;transition:background 0.2s}
.faq-q:hover{background:var(--bg)}
.faq-q .chev{transition:transform 0.3s;flex-shrink:0;color:var(--text-muted)}
.faq-item.open .faq-q .chev{transform:rotate(180deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height 0.35s ease}
.faq-a-inner{padding:0 24px 20px;font-size:0.92rem;color:var(--text-soft);line-height:1.65}

/* ── FINAL CTA ── */
.final-cta{padding:64px 24px;background:var(--primary);text-align:center}
.final-cta .s-title{color:var(--white);margin-bottom:8px}
.final-cta-sub{color:rgba(255,255,255,0.8);font-size:1.05rem;margin-bottom:28px}
.btn-w{display:inline-flex;align-items:center;gap:8px;background:var(--white);color:var(--primary);font-family:var(--font-b);font-weight:600;font-size:1.05rem;padding:16px 36px;border-radius:50px;border:none;cursor:pointer;text-decoration:none;transition:transform 0.15s,box-shadow 0.2s;box-shadow:0 4px 16px rgba(0,0,0,0.15)}
.btn-w:hover{transform:translateY(-2px);box-shadow:0 6px 24px rgba(0,0,0,0.2)}
.final-phone{margin-top:16px;color:rgba(255,255,255,0.7);font-size:0.92rem}
.final-phone a{color:var(--white);font-weight:600;text-decoration:none}

/* ── FOOTER ── */
footer{background:#1E1E1E;color:rgba(255,255,255,0.6);padding:40px 24px;font-size:0.82rem;text-align:center;line-height:1.8}
footer a{color:rgba(255,255,255,0.8);text-decoration:none}
footer a:hover{color:var(--white)}

/* ── MOBILE STICKY ── */
.mob-sticky{display:none;position:fixed;bottom:0;left:0;right:0;z-index:99;background:var(--white);border-top:1px solid var(--border);padding:12px 16px;box-shadow:0 -4px 20px rgba(0,0,0,0.1)}
.mob-sticky a{display:block;background:var(--primary);color:var(--white);text-align:center;padding:14px;border-radius:50px;font-weight:600;font-size:1rem;text-decoration:none}

/* ── SEO ACCORDION ── */
.seo-section{padding:72px 24px;background:var(--bg-warm)}
.seo-list{max-width:720px;margin:40px auto 0;display:flex;flex-direction:column;gap:8px}
.seo-item{background:var(--white);border-radius:var(--r-md);overflow:hidden;box-shadow:var(--shadow)}
.seo-q{width:100%;padding:20px 24px;background:none;border:none;font-family:var(--font-b);font-size:1rem;font-weight:600;color:var(--text);text-align:left;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:12px;transition:background 0.2s}
.seo-q:hover{background:var(--bg)}
.seo-q .chev{transition:transform 0.3s;flex-shrink:0;color:var(--text-muted)}
.seo-item.open .seo-q .chev{transform:rotate(180deg)}
.seo-a{max-height:0;overflow:hidden;transition:max-height 0.35s ease}
.seo-a-inner{padding:0 24px 20px;font-size:0.92rem;color:var(--text-soft);line-height:1.65}
.seo-a-inner h3{font-family:var(--font-d);font-size:1.05rem;font-weight:600;color:var(--text);margin:20px 0 8px}
.seo-a-inner h3:first-child{margin-top:0}
.seo-a-inner p{margin-bottom:12px}
.seo-a-inner ul{margin:8px 0 12px 20px;padding:0}
.seo-a-inner ul li{margin-bottom:6px;line-height:1.55}
.seo-a-inner .seo-cta{font-weight:600;color:var(--primary)}

/* ── ANIMATIONS ── */
.fu{opacity:0;transform:translateY(24px);transition:opacity 0.6s ease,transform 0.6s ease}
.fu.vis{opacity:1;transform:translateY(0)}

/* ── RESPONSIVE (landingpage) ── */
@media(max-width:900px){
  .hero-inner{grid-template-columns:1fr;gap:32px}
  .hero-visual{max-width:480px;margin:0 auto}
  .hero-photo{aspect-ratio:16/10;max-height:420px;top:0}
  .hero-trust-card{position:static;max-width:480px;margin:0 auto;width:100%}
  .steps-grid{grid-template-columns:1fr}.steps-grid::before{display:none}
  .why-grid{grid-template-columns:1fr}
  .cond-grid{grid-template-columns:1fr}
  .test-grid{grid-template-columns:1fr}
  .opt-grid-3{grid-template-columns:repeat(3,1fr)}
  .opt-grid-3x3{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:600px){
  .hero{padding:20px 16px 32px}
  .top-bar{padding:10px 16px}
  .top-bar-cta{display:none}
  .top-bar-logo img{height:56px}

  /* Mobile hero reorder: lift hero-content children into hero-inner flex,
     then place the image directly after the H1 so it lands in the first
     viewport without forcing a scroll. */
  .hero-inner{display:flex;flex-direction:column;gap:16px}
  .hero-content{display:contents}
  .hero-badge{order:1;margin-bottom:0;font-size:clamp(0.62rem,2.6vw,0.78rem);padding:5px 11px;white-space:nowrap;max-width:100%;align-self:flex-start}
  .hero h1{order:2;font-size:clamp(1.65rem,6.2vw,2rem);margin-bottom:0;line-height:1.18}
  .hero-visual{order:3;max-width:100%;margin:0}
  .hero-sub{order:4;font-size:1rem;line-height:1.5;margin-bottom:0}
  .hero-pills{order:5;gap:10px;margin-bottom:0}
  .hero-pill{font-size:0.95rem}
  .hero-cta-row{order:6;flex-direction:column;align-items:stretch;gap:10px}
  .btn-p,.btn-s{justify-content:center}

  /* Trust-Card auf Mobile aus — die Pills tragen die gleiche Info kompakter */
  .hero-trust-card{display:none}

  /* Bild: leicht querformatig, niedrige max-height, Fokus oben (Gesicht bleibt sichtbar) */
  .hero-photo{aspect-ratio:5/4;max-height:280px;object-position:center top;top:0}

  .proof-bar-inner{gap:20px}
  .opt-grid-3{grid-template-columns:1fr}
  .opt-grid-3x3{grid-template-columns:repeat(2,1fr)}
  .form-step{padding:32px 20px}
  .form-nav{padding:16px 20px 24px}
  .field-row{grid-template-columns:1fr}
  .mob-sticky{display:block}
  .final-cta{padding-bottom:100px}
  .comp-h,.comp-row{grid-template-columns:0.85fr 1.15fr}
  .comp-cell{padding:12px 12px;font-size:0.8rem;line-height:1.35;hyphens:auto;-webkit-hyphens:auto}
  .comp-col{padding:14px 12px;font-size:0.8rem}
  .progress-steps{padding:0 8px}
  .progress-dot{width:28px;height:28px;font-size:0.7rem}
}

/* ── FORM CONSENT CHECKBOXES ── */
.consent-group{margin-top:20px;padding-top:16px;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:12px}
.consent-row{display:flex;gap:10px;align-items:flex-start;font-size:0.82rem;color:var(--text-soft);line-height:1.5;cursor:pointer}
.consent-row input[type=checkbox]{margin-top:2px;flex-shrink:0;width:16px;height:16px;accent-color:var(--primary);cursor:pointer}
.consent-row a{color:var(--primary);font-weight:600;text-decoration:underline}
.consent-row.error{color:#8A1F1F}
.consent-row.error input[type=checkbox]{outline:2px solid #C44;outline-offset:2px}
.consent-required-mark{color:var(--primary);font-weight:600}

/* ── COOKIE BANNER ── */
.cookie-banner{position:fixed;bottom:16px;left:16px;right:16px;max-width:460px;margin-left:auto;background:var(--white);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:0 12px 40px rgba(0,0,0,0.14);z-index:1000;transform:translateY(140%);opacity:0;transition:transform 0.4s cubic-bezier(.2,.8,.2,1),opacity 0.3s;pointer-events:none}
.cookie-banner.active{transform:translateY(0);opacity:1;pointer-events:auto}
.cookie-banner-inner{padding:22px 22px 20px;max-height:min(78vh,620px);overflow-y:auto}
.cookie-banner-title{font-family:var(--font-d);font-size:1.05rem;font-weight:600;color:var(--text);margin-bottom:6px}
.cookie-banner-text{font-size:0.85rem;color:var(--text-soft);line-height:1.5;margin-bottom:16px}
.cookie-banner-text a{color:var(--primary);font-weight:600;text-decoration:underline}
.cookie-banner-actions{display:flex;flex-wrap:wrap;gap:8px;align-items:center}
.cookie-cat + .cookie-banner-actions{margin-top:24px}
.cookie-btn-primary{background:var(--primary);color:var(--white);border:none;padding:10px 18px;border-radius:50px;font-family:var(--font-b);font-weight:600;font-size:0.85rem;cursor:pointer;transition:background 0.2s}
.cookie-btn-primary:hover{background:var(--primary-dark)}
.cookie-btn-ghost{background:transparent;color:var(--text);border:1px solid var(--border);padding:10px 18px;border-radius:50px;font-family:var(--font-b);font-weight:600;font-size:0.85rem;cursor:pointer;transition:background 0.2s}
.cookie-btn-ghost:hover{background:var(--bg)}
.cookie-btn-text{background:transparent;color:var(--text-soft);border:none;padding:10px 8px;font-family:var(--font-b);font-weight:600;font-size:0.85rem;cursor:pointer;text-decoration:underline}
.cookie-btn-text:hover{color:var(--primary)}
.cookie-cat{padding:14px 0;border-bottom:1px solid var(--border)}
.cookie-cat:last-of-type{border-bottom:none;margin-bottom:14px}
.cookie-cat-head{display:flex;justify-content:space-between;gap:16px;align-items:flex-start}
.cookie-cat-text{flex:1;min-width:0}
.cookie-cat-name{font-weight:600;font-size:0.9rem;color:var(--text);margin-bottom:2px}
.cookie-cat-desc{font-size:0.78rem;color:var(--text-soft);line-height:1.45}
.cookie-switch{position:relative;display:inline-block;width:40px;height:22px;flex-shrink:0;cursor:pointer}
.cookie-switch input{opacity:0;width:0;height:0}
.cookie-switch span{position:absolute;inset:0;background:#CCC;border-radius:22px;transition:background 0.2s}
.cookie-switch span::before{content:'';position:absolute;top:3px;left:3px;width:16px;height:16px;background:white;border-radius:50%;transition:transform 0.2s}
.cookie-switch input:checked+span{background:var(--primary)}
.cookie-switch input:checked+span::before{transform:translateX(18px)}
.cookie-switch.disabled{opacity:0.55;cursor:not-allowed}
.cookie-link{background:none;border:none;color:inherit;font:inherit;padding:0;cursor:pointer;text-decoration:underline}
.cookie-link:hover{color:var(--white)}
@media(max-width:480px){
  .cookie-banner{left:8px;right:8px;bottom:8px;max-width:none}
  .cookie-banner-inner{padding:20px}
}

/* ══════════════════════════════════════════════════
   LEGAL PAGES (Impressum, Datenschutz)
   ══════════════════════════════════════════════════ */
.article{max-width:760px;margin:0 auto;padding:48px 24px 80px;line-height:1.65}
.article h1{font-size:clamp(1.8rem,3vw,2.2rem);font-weight:600;letter-spacing:-0.01em;margin-bottom:14px;color:var(--text)}
.article .lead{color:var(--text-soft);margin-bottom:28px}
.article h2{font-size:1.3rem;font-weight:600;margin-top:48px;margin-bottom:12px;color:var(--text);scroll-margin-top:72px}
.article h3{font-size:1.05rem;font-weight:600;margin-top:24px;margin-bottom:6px;color:var(--text)}
.article h4{font-size:0.95rem;font-weight:600;margin-top:16px;margin-bottom:4px;color:var(--text-soft);text-transform:uppercase;letter-spacing:0.04em}
.article p{margin-bottom:12px;color:var(--text-soft)}
.article strong{color:var(--text);font-weight:600}
.article ul{margin:8px 0 12px 20px;color:var(--text-soft)}
.article li{margin-bottom:4px}
.article a{color:var(--primary);text-decoration:underline;word-break:break-word}
.article a:hover{color:var(--primary-dark)}
.article hr{border:none;border-top:1px solid var(--border);margin:40px 0}
.article address{font-style:normal;display:block;color:var(--text-soft);margin:4px 0 12px;padding-left:14px;border-left:3px solid var(--primary-light)}

.toc{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-md);padding:18px 22px;margin:28px 0 8px}
.toc-t{font-size:0.78rem;font-weight:600;text-transform:uppercase;letter-spacing:0.1em;color:var(--text-muted);margin-bottom:10px}
.toc ol{margin-left:20px;color:var(--text-soft);font-size:0.92rem}
.toc li{margin-bottom:3px}
.toc a{color:var(--text);text-decoration:none}
.toc a:hover{color:var(--primary);text-decoration:underline}

.note{background:var(--primary-light);border-radius:var(--r-md);padding:14px 18px;font-size:0.9rem;color:var(--text);margin:12px 0}

@media(max-width:600px){
  .article{padding:32px 20px 64px}
  .top-bar-back span{display:none}
}
