/* =========================================================
   RGN Marketing — Agentur-Landingpage
   Performance-LP für lokale Dienstleister (TikTok + Google Ads)
   Design: Anthrazit (Logo) + Emerald-Green (Wachstum/Leads)
   ========================================================= */

/* ---------- Inter LOKAL gehostet (DSGVO-konform, kein CDN) ---------- */
@font-face{ font-family:'Inter'; font-style:normal; font-weight:400; font-display:swap; src:url('../fonts/inter-latin-400.woff2') format('woff2'); }
@font-face{ font-family:'Inter'; font-style:normal; font-weight:500; font-display:swap; src:url('../fonts/inter-latin-500.woff2') format('woff2'); }
@font-face{ font-family:'Inter'; font-style:normal; font-weight:600; font-display:swap; src:url('../fonts/inter-latin-600.woff2') format('woff2'); }
@font-face{ font-family:'Inter'; font-style:normal; font-weight:700; font-display:swap; src:url('../fonts/inter-latin-700.woff2') format('woff2'); }
@font-face{ font-family:'Inter'; font-style:normal; font-weight:800; font-display:swap; src:url('../fonts/inter-latin-800.woff2') format('woff2'); }
@font-face{ font-family:'Inter'; font-style:normal; font-weight:900; font-display:swap; src:url('../fonts/inter-latin-900.woff2') format('woff2'); }

:root{
  /* Brand — Anthrazit */
  --ink:        #14161B;
  --ink-2:      #1A1D24;
  --ink-3:      #23272F;
  --ink-soft:   #2E333D;
  --line-dark:  rgba(255,255,255,.10);

  /* Hell */
  --paper:      #FFFFFF;
  --paper-2:    #F4F7F6;
  --paper-3:    #EAF0EE;
  --line:       #E4E9E8;

  /* Text */
  --text:       #15181D;
  --text-soft:  #495159;
  --text-mute:  #717C85;
  --on-dark:        #EEF2F1;
  --on-dark-soft:   #A7B2B5;
  --on-dark-mute:   #76828A;

  /* Accent — Performance Green */
  /* „Accent" = Schwarz-Weiß (B&W-Theme). Variablennamen bleiben --green* aus Kompatibilität. */
  --green:        #14161B;
  --green-2:      #2C313B;
  --green-dk:     #14161B;
  --green-ink:    #FFFFFF;
  --green-soft:   #EEF0F1;
  --green-tint:   #EEF0F1;
  --green-line:   #DCE0E2;
  --green-glow:   rgba(0,0,0,.16);

  /* Trust-Gold (sparsam, für Partner/Zertifikat-Akzente) */
  --gold:       #E8B14C;
  --star:       #FFB400;

  --radius:     16px;
  --radius-lg:  22px;
  --radius-sm:  11px;
  --shadow-sm:  0 2px 10px rgba(16,24,32,.05);
  --shadow:     0 16px 44px rgba(16,24,32,.10);
  --shadow-lg:  0 34px 80px rgba(16,24,32,.18);
  --shadow-green: 0 14px 30px -8px var(--green-glow);
  --container:  1180px;
  --ease:       cubic-bezier(.22,.61,.36,1);
}

/* ---------- Reset / Base ---------- */
*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  color:var(--text);
  background:var(--paper);
  line-height:1.6;
  font-size:17px;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img,svg{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
ul{ list-style:none; }
button{ font-family:inherit; cursor:pointer; border:none; background:none; }
h1,h2,h3{ line-height:1.12; letter-spacing:-.02em; font-weight:800; color:var(--text); }
strong{ font-weight:700; }
section[id]{ scroll-margin-top:88px; }

.container{ width:100%; max-width:var(--container); margin:0 auto; padding:0 22px; }
.desktop-only{ display:flex; }
.mobile-only{ display:none; }
.center{ text-align:center; margin-top:38px; }

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:9px;
  padding:14px 24px; border-radius:var(--radius-sm);
  font-weight:800; font-size:15.5px; letter-spacing:-.01em;
  transition:transform .18s var(--ease), box-shadow .25s var(--ease), background .2s;
  white-space:nowrap; line-height:1;
}
.btn i{ font-size:18px; }
.btn-primary{ background:var(--green); color:var(--green-ink); box-shadow:var(--shadow-green); }
.btn-primary:hover{ background:var(--green-2); transform:translateY(-2px); box-shadow:0 18px 36px -8px var(--green-glow); }
.btn-ghost{ background:rgba(255,255,255,.06); color:var(--on-dark); border:1.5px solid rgba(255,255,255,.22); }
.btn-ghost:hover{ background:rgba(255,255,255,.12); transform:translateY(-2px); }
.btn-outline-light{ background:transparent; color:#fff; border:1.5px solid rgba(255,255,255,.55); }
.btn-outline-light:hover{ background:#fff; color:var(--ink); transform:translateY(-2px); }
.btn-lg{ padding:17px 30px; font-size:16.5px; }
.btn-sm{ padding:11px 16px; font-size:14px; }
.btn-block{ width:100%; }

/* ---------- Header ---------- */
.site-header{
  position:sticky; top:0; z-index:90;
  background:rgba(255,255,255,.86);
  backdrop-filter:saturate(180%) blur(14px);
  border-bottom:1px solid var(--line);
  transition:box-shadow .3s, background .3s;
}
.site-header.scrolled{ box-shadow:0 6px 24px rgba(16,24,32,.07); }
.header-inner{ display:flex; align-items:center; justify-content:space-between; height:72px; gap:24px; }

/* USP-/Trust-Leiste direkt unter dem Header (weiß, schwarze Checks) */
.usp-bar{ background:#fff; border-bottom:1px solid var(--line); }
.usp-bar-inner{ display:flex; align-items:center; justify-content:center; flex-wrap:wrap; gap:10px 26px; min-height:46px; padding:8px 0; }
.usp-item{ display:inline-flex; align-items:center; gap:8px; font-size:14px; font-weight:700; letter-spacing:-.01em; color:var(--ink); }
.usp-item i{ font-size:18px; color:var(--ink); flex-shrink:0; }
.usp-sep{ width:1px; height:16px; background:var(--line); }
.usp-desktop-only{ display:none; }
@media(min-width:761px){ .usp-desktop-only{ display:inline-flex; } }
@media (max-width:480px){
  .usp-bar-inner{ gap:8px 16px; }
  .usp-item{ font-size:12.5px; }
  .usp-item i{ font-size:16px; }
}
.logo{ color:var(--ink); flex-shrink:0; }
.logo-img{ height:50px; width:auto; display:block; }
/* Logo automatisch weiß färben auf dunklen Flächen (Footer/Quiz). Funktioniert mit einem einfarbigen Logo auf transparentem Hintergrund. */
.logo-on-dark{ filter:brightness(0) invert(1); }
.main-nav{ gap:30px; margin-right:auto; margin-left:42px; }
.main-nav a{ font-size:15px; font-weight:600; color:var(--text-soft); transition:color .2s; position:relative; }
.main-nav a:hover{ color:var(--green-dk); }
.header-actions{ align-items:center; gap:16px; }
.header-actions .icon-btn + .icon-btn{ margin-left:-8px; }
.phone-link{ display:inline-flex; align-items:center; gap:7px; font-weight:700; font-size:15px; color:var(--text); }
.phone-link i{ color:var(--green-dk); font-size:18px; }
.phone-link:hover{ color:var(--green-dk); }
.icon-btn{
  width:44px; height:44px; border-radius:11px; display:inline-flex; align-items:center; justify-content:center;
  font-size:20px; background:var(--paper-2); color:var(--text); border:1px solid var(--line);
}
.icon-btn-phone{ color:var(--green-dk); }
.icon-btn-wa{ color:#25D366; }

/* ---------- Eyebrows / Section heads ---------- */
.eyebrow{
  display:inline-block; font-size:13px; font-weight:800; letter-spacing:.14em; text-transform:uppercase;
  color:var(--green-dk); margin-bottom:14px;
}
.eyebrow-light{ color:var(--green); }
.section{ padding:clamp(62px,8.5vw,116px) 0; position:relative; }
.section-alt{ background:var(--paper-2); }
.section-tight{ padding:clamp(20px,4vw,46px) 0; }
.section-title{ font-size:clamp(1.85rem,3.6vw,2.85rem); max-width:18ch; }
.section > .container > .eyebrow,
.section > .container > .section-title,
.section > .container > .section-sub{ }
.section-sub{ font-size:clamp(1rem,1.4vw,1.18rem); color:var(--text-soft); max-width:62ch; margin-top:16px; }
.section-title + .section-sub{ margin-top:18px; }

/* =========================================================
   HERO
   ========================================================= */
.hero{
  position:relative; background:var(--ink); color:var(--on-dark);
  padding:clamp(56px,8vw,104px) 0 clamp(64px,8vw,110px);
  overflow:hidden;
}
.hero-bg{
  position:absolute; inset:0; z-index:0; pointer-events:none;
  background:
    radial-gradient(680px 420px at 88% 8%, rgba(19,198,103,.18), transparent 60%),
    radial-gradient(560px 480px at 8% 92%, rgba(19,198,103,.10), transparent 60%),
    linear-gradient(180deg,#15181E 0%, #111319 100%);
}
.hero-bg::after{
  content:""; position:absolute; inset:0;
  background-image:radial-gradient(rgba(255,255,255,.05) 1px, transparent 1px);
  background-size:30px 30px; opacity:.6; mask-image:linear-gradient(180deg,#000,transparent 80%);
}
.hero-grid{
  position:relative; z-index:1;
  display:grid; grid-template-columns:1.08fr .92fr; gap:54px; align-items:center;
}
.badge{
  display:inline-flex; align-items:center; gap:9px;
  background:rgba(19,198,103,.12); border:1px solid rgba(19,198,103,.3);
  color:#9af0c2; font-weight:700; font-size:13.5px; padding:8px 15px; border-radius:100px; margin-bottom:24px;
}
.badge-dot{ width:8px; height:8px; border-radius:50%; background:var(--green); box-shadow:0 0 0 4px rgba(19,198,103,.25); }
.hero h1{
  color:#fff; font-size:clamp(1.95rem,3vw,2.45rem); font-weight:900; letter-spacing:-.022em;
  line-height:1.14;
}
.rotator-wrap{ display:inline-flex; align-items:baseline; color:var(--green); white-space:nowrap; }
.rotator-bracket{ font-weight:700; opacity:.55; }
.rotator{ display:inline-block; min-width:1ch; transition:opacity .35s, transform .35s; font-weight:900; padding:0 .12em; }
.rotator.swap{ opacity:0; transform:translateY(8px); }
.hero-sub{ color:var(--on-dark-soft); font-size:clamp(0.97rem,1.15vw,1.06rem); margin-top:20px; max-width:46ch; }
.hero-usps{ display:flex; flex-direction:column; gap:15px; margin:26px 0 32px; }
.hero-usps li{ display:flex; align-items:center; gap:13px; font-size:17px; font-weight:600; color:var(--on-dark); }
.hero-usps i{ color:var(--green); font-size:23px; flex-shrink:0; }
.hero-cta{ display:flex; gap:14px; flex-wrap:wrap; }
.hero-trust{
  display:flex; align-items:center; gap:16px; flex-wrap:wrap; margin-top:30px;
  font-size:14px; color:var(--on-dark-soft);
}
.hero-trust strong{ color:#fff; }
.ht-stars{ display:inline-flex; align-items:center; gap:3px; }
.ht-stars i{ color:var(--star); font-size:15px; }
.ht-stars strong{ margin-left:5px; }
.ht-div{ width:1px; height:18px; background:var(--line-dark); }
.hero-trust .ti-brand-google{ color:#fff; }

/* Hero Dashboard Mock */
.hero-visual{ position:relative; }
.dash-card{
  background:linear-gradient(180deg,#fff,#fbfdfc); border-radius:var(--radius-lg);
  box-shadow:0 40px 90px rgba(0,0,0,.45); padding:20px; color:var(--text);
  border:1px solid rgba(255,255,255,.6);
  transform:perspective(1400px) rotateY(-9deg) rotateX(3deg);
  transform-origin:center;
}
.dash-head{ display:flex; align-items:center; gap:10px; padding-bottom:14px; border-bottom:1px solid var(--line); }
.dash-dots{ display:flex; gap:5px; }
.dash-dots span{ width:9px; height:9px; border-radius:50%; background:#E0E5E4; }
.dash-dots span:first-child{ background:#FF6058; }
.dash-dots span:nth-child(2){ background:#FFBE2F; }
.dash-dots span:nth-child(3){ background:#28C940; }
.dash-title{ font-size:12.5px; font-weight:700; color:var(--text-soft); margin-left:4px; }
.dash-live{ margin-left:auto; display:inline-flex; align-items:center; gap:5px; font-size:11px; font-weight:800; color:var(--green-dk); text-transform:uppercase; letter-spacing:.04em; }
.live-dot{ width:7px; height:7px; border-radius:50%; background:var(--green); animation:pulse 1.8s infinite; }
@keyframes pulse{ 0%,100%{ box-shadow:0 0 0 0 var(--green-glow);} 50%{ box-shadow:0 0 0 6px transparent; } }
.dash-kpis{ display:grid; grid-template-columns:1fr 1fr; gap:12px; margin:16px 0; }
.kpi{ background:var(--paper-2); border:1px solid var(--line); border-radius:13px; padding:13px 15px; }
.kpi-label{ font-size:11.5px; font-weight:700; color:var(--text-mute); text-transform:uppercase; letter-spacing:.04em; }
.kpi-num{ display:block; font-size:30px; font-weight:900; letter-spacing:-.03em; margin:3px 0 4px; color:var(--ink); }
.kpi-trend{ font-size:12px; font-weight:800; display:inline-flex; align-items:center; gap:3px; }
.kpi-trend.up{ color:var(--green-dk); }
.kpi-trend.down{ color:#1f8fde; }
.dash-chart{ display:flex; align-items:flex-end; gap:8px; height:84px; padding:6px 4px 0; }
.dash-chart .bar{ flex:1; height:var(--h); background:var(--paper-3); border-radius:6px 6px 3px 3px; transform-origin:bottom; animation:growbar .9s var(--ease) both; }
.dash-chart .bar-on{ background:linear-gradient(180deg,var(--green),var(--green-dk)); box-shadow:0 4px 12px -2px var(--green-glow); }
@keyframes growbar{ from{ transform:scaleY(.05); opacity:.4; } to{ transform:scaleY(1); opacity:1; } }
.dash-feed{ margin-top:14px; display:flex; flex-direction:column; gap:8px; }
.feed-item{ display:flex; align-items:center; gap:10px; background:#fff; border:1px solid var(--line); border-radius:11px; padding:10px 12px; box-shadow:var(--shadow-sm); animation:slidein .6s var(--ease) both; }
.feed-item:nth-child(2){ animation-delay:.25s; }
.feed-item:nth-child(3){ animation-delay:.5s; }
@keyframes slidein{ from{ opacity:0; transform:translateX(14px); } to{ opacity:1; transform:translateX(0); } }
.feed-ic{ width:32px; height:32px; border-radius:9px; background:var(--green-tint); color:var(--green-dk); display:flex; align-items:center; justify-content:center; font-size:17px; flex-shrink:0; }
.feed-ic-wa{ background:#e7fbef; color:#1faf54; }
.feed-txt{ font-size:12.5px; color:var(--text-soft); }
.feed-txt strong{ color:var(--ink); }
.feed-time{ margin-left:auto; font-size:11px; color:var(--text-mute); white-space:nowrap; }
.dash-badge{
  position:absolute; left:-18px; bottom:24px;
  background:#fff; color:var(--ink); font-weight:800; font-size:13px;
  padding:10px 15px; border-radius:12px; box-shadow:var(--shadow-lg);
  display:inline-flex; align-items:center; gap:8px;
}
.dash-badge i{ color:var(--green); font-size:19px; }
.dash-badge-partner{ left:-16px; bottom:-26px; padding:11px 16px; gap:12px; }
.dash-badge-partner .g-logo{ width:28px; height:28px; flex-shrink:0; }
.db-text{ display:flex; flex-direction:column; line-height:1.18; text-align:left; }
.db-text strong{ font-size:14.5px; font-weight:800; color:var(--ink); }
.db-text span{ font-size:11px; font-weight:600; color:var(--text-mute); }
.db-text strong, .db-text span{ white-space:nowrap; }

/* =========================================================
   LOGOBAR
   ========================================================= */
.logobar{ background:var(--paper); border-bottom:1px solid var(--line); padding:26px 0; }
.logobar-label{ text-align:center; font-size:13px; font-weight:700; color:var(--text-mute); letter-spacing:.02em; margin-bottom:16px; }
.logobar-items{ display:flex; flex-wrap:wrap; justify-content:center; gap:14px 32px; }
.logobar-items span{ display:inline-flex; align-items:center; gap:8px; font-size:15px; font-weight:700; color:var(--text-soft); }
.logobar-items i{ font-size:19px; color:var(--green-dk); }

/* =========================================================
   PROBLEM
   ========================================================= */
#problem .section-title{ max-width:20ch; }
.problem-scene{ font-size:clamp(1.05rem,1.55vw,1.28rem); color:var(--text); font-weight:500; max-width:60ch; }
.pain-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:20px; margin-top:42px; }
.card{ background:var(--paper); border:1px solid var(--line); border-radius:var(--radius); box-shadow:var(--shadow-sm); }
.pain-card{ padding:26px 24px; transition:transform .2s var(--ease), box-shadow .25s; }
.pain-card:hover{ transform:translateY(-4px); box-shadow:var(--shadow); }
.pain-ic{ width:52px; height:52px; border-radius:13px; background:#FFF1F0; color:#E5544B; display:flex; align-items:center; justify-content:center; font-size:26px; margin-bottom:16px; }
.pain-card h3{ font-size:18px; margin-bottom:8px; }
.pain-card p{ font-size:14.5px; color:var(--text-soft); }
.problem-bridge{
  margin:40px auto 0; max-width:44ch; text-align:center;
  font-size:clamp(1.25rem,2.2vw,1.7rem); font-weight:800; letter-spacing:-.02em; color:var(--text); line-height:1.3;
}
.problem-bridge::before{ content:"„"; color:var(--green-dk); }
.problem-bridge::after{ content:"“"; color:var(--green-dk); }

/* =========================================================
   LÖSUNG
   ========================================================= */
.solution-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; margin-top:46px; }
.sol-card{ padding:32px 28px; transition:transform .2s var(--ease), box-shadow .25s; }
.sol-card:hover{ transform:translateY(-5px); box-shadow:var(--shadow); }
.sol-ic{
  width:60px; height:60px; border-radius:15px; display:flex; align-items:center; justify-content:center;
  background:linear-gradient(150deg,var(--green-tint),#dff7e8); color:var(--green-dk); font-size:30px; margin-bottom:20px;
}
.sol-card h3{ font-size:20px; margin-bottom:11px; }
.sol-card p{ font-size:15px; color:var(--text-soft); }

/* =========================================================
   ERGEBNISSE / CASE STUDIES
   ========================================================= */
.ph-note{ display:inline-block; margin-top:8px; font-size:12.5px; font-weight:700; color:var(--gold); }
.case-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; margin-top:46px; align-items:stretch; }
.case-card{ padding:26px 24px 24px; display:flex; flex-direction:column; transition:transform .2s var(--ease), box-shadow .25s; }
.case-card:hover{ transform:translateY(-5px); box-shadow:var(--shadow); }
.case-card-featured{ background:var(--ink); border-color:var(--ink-3); color:var(--on-dark); box-shadow:var(--shadow-lg); }
.case-head{ display:flex; align-items:center; justify-content:space-between; margin-bottom:20px; }
.case-tag{ display:inline-flex; align-items:center; gap:7px; font-size:13px; font-weight:800; color:var(--green-dk); background:var(--green-tint); padding:6px 12px; border-radius:100px; }
.case-card-featured .case-tag{ background:rgba(19,198,103,.16); color:#9af0c2; }
.case-loc{ display:inline-flex; align-items:center; gap:4px; font-size:13px; font-weight:600; color:var(--text-mute); }
.case-loc i{ font-size:14px; }
.case-card-featured .case-loc{ color:var(--on-dark-soft); }
.case-result{ display:flex; align-items:baseline; gap:10px; flex-wrap:wrap; margin-bottom:18px; }
.case-from{ font-size:34px; font-weight:800; color:var(--text-mute); text-decoration:line-through; text-decoration-color:#cdd5d3; }
.case-arrow{ font-size:22px; color:var(--green-dk); }
.case-to{ font-size:52px; font-weight:900; letter-spacing:-.04em; color:var(--green-dk); line-height:1; }
.case-card-featured .case-to{ color:var(--green); }
.case-to-solo{ font-size:58px; }
.case-unit{ font-size:14px; font-weight:600; color:var(--text-soft); line-height:1.25; flex-basis:100%; }
.case-card-featured .case-unit{ color:var(--on-dark-soft); }
.case-pre{ font-size:19px; font-weight:700; color:var(--text-mute); }
.case-to-suffix{ font-size:23px; font-weight:800; letter-spacing:-.01em; color:var(--green-dk); }
.case-card-featured .case-to-suffix{ color:var(--green); }
.case-bars{ display:flex; align-items:flex-end; gap:18px; height:84px; margin:auto 0 16px; padding-top:8px; }
.cb{ flex:1; display:flex; flex-direction:column; align-items:center; justify-content:flex-end; gap:7px; height:100%; }
.cb span{ width:100%; max-width:60px; height:var(--h); border-radius:7px 7px 0 0; }
.cb-before span{ background:#E1E7E5; }
.cb-after span{ background:linear-gradient(180deg,var(--green),var(--green-dk)); box-shadow:0 6px 16px -4px var(--green-glow); }
.cb label{ font-size:11.5px; font-weight:700; color:var(--text-mute); text-transform:uppercase; letter-spacing:.03em; }
.case-roas{ display:flex; align-items:baseline; gap:10px; margin:auto 0 16px; padding:14px 0; border-top:1px solid var(--line-dark); border-bottom:1px solid var(--line-dark); }
.roas-num{ font-size:38px; font-weight:900; color:var(--green); letter-spacing:-.03em; }
.roas-label{ font-size:13px; font-weight:600; color:var(--on-dark-soft); }
.case-meta{ display:flex; flex-direction:column; gap:9px; margin-top:auto; padding-top:6px; }
.case-meta li{ display:flex; align-items:center; gap:9px; font-size:14px; font-weight:600; color:var(--text-soft); }
.case-meta i{ color:var(--green-dk); font-size:18px; }
.case-card-featured .case-meta li{ color:var(--on-dark); }
.case-card-featured .case-meta i{ color:var(--green); }

/* Statband */
.statband{
  display:grid; grid-template-columns:repeat(4,1fr); gap:18px; margin-top:30px;
  background:linear-gradient(135deg,var(--green-dk),#0a6e37); border-radius:var(--radius-lg); padding:34px 28px;
  box-shadow:var(--shadow-green);
}
.stat{ text-align:center; color:#fff; position:relative; }
.stat:not(:last-child)::after{ content:""; position:absolute; right:-9px; top:50%; transform:translateY(-50%); height:42px; width:1px; background:rgba(255,255,255,.2); }
.stat-num{ display:block; font-size:clamp(1.9rem,3.2vw,2.6rem); font-weight:900; letter-spacing:-.03em; }
.stat-label{ font-size:13.5px; font-weight:600; color:rgba(255,255,255,.82); }

/* =========================================================
   CTA-BAND
   ========================================================= */
.cta-band{
  background:var(--ink); border-radius:var(--radius-lg); padding:clamp(28px,4vw,46px);
  display:flex; align-items:center; justify-content:space-between; gap:30px; flex-wrap:wrap;
  position:relative; overflow:hidden; box-shadow:var(--shadow);
}
.cta-band::before{ content:""; position:absolute; right:-60px; top:-60px; width:260px; height:260px; border-radius:50%; background:radial-gradient(circle,var(--green-glow),transparent 70%); }
.cta-band > div{ position:relative; z-index:1; }
.cta-band h2{ color:#fff; font-size:clamp(1.4rem,2.4vw,1.95rem); }
.cta-band p{ color:var(--on-dark-soft); margin-top:8px; max-width:50ch; font-size:15.5px; }
.cta-band-actions{ display:flex; gap:13px; flex-wrap:wrap; position:relative; z-index:1; }

/* Ansprechpartner im CTA-Band (Desktop) */
.cta-band-ap{
  display:flex; align-items:center; gap:14px;
  background:rgba(255,255,255,.07); border:1px solid rgba(255,255,255,.12);
  border-radius:14px; padding:14px 18px;
  position:relative; z-index:1; flex-shrink:0;
}
.cta-ap-photo{
  width:56px; height:56px; border-radius:50%; object-fit:cover; object-position:top center;
  flex-shrink:0; border:2px solid rgba(255,255,255,.18);
}
.cta-ap-info{ display:flex; flex-direction:column; gap:3px; }
.cta-ap-name{ color:#fff; font-size:14px; font-weight:700; line-height:1.2; }
.cta-ap-role{ color:var(--on-dark-soft); font-size:12px; margin-bottom:4px; }
.cta-ap-link{
  color:rgba(255,255,255,.75); font-size:12px; text-decoration:none;
  display:flex; align-items:center; gap:5px; transition:color .15s;
}
.cta-ap-link:hover{ color:#fff; }
.cta-ap-link i{ font-size:13px; }

/* Ansprechpartner-Sektion (nur Mobil) */
.ap-mobile-section{ display:none; }
.ap-card{
  display:flex; align-items:center; gap:20px;
  background:#fff; border:1px solid var(--line); border-radius:16px;
  padding:20px 24px; box-shadow:0 2px 12px rgba(0,0,0,.05);
}
.ap-photo{
  width:80px; height:80px; border-radius:50%; object-fit:cover; object-position:top center;
  flex-shrink:0; border:2px solid var(--line);
}
.ap-info{ display:flex; flex-direction:column; gap:4px; }
.ap-name{ font-size:16px; font-weight:700; color:var(--ink); }
.ap-role{ font-size:13px; color:var(--muted); }
.ap-links{ display:flex; flex-direction:column; gap:5px; margin-top:6px; }
.ap-link{
  font-size:13px; font-weight:600; color:var(--ink); text-decoration:none;
  display:flex; align-items:center; gap:6px;
}
.ap-link:hover{ color:var(--green); }
.ap-link i{ font-size:15px; }

/* =========================================================
   VERGLEICH
   ========================================================= */
.compare-grid{ display:grid; grid-template-columns:1fr 1fr; gap:22px; margin-top:46px; }
.compare-card{ padding:30px 28px; }
.compare-good{ border:2px solid var(--green); box-shadow:0 20px 50px -16px var(--green-glow); position:relative; }
.compare-good::before{
  content:"Empfohlen"; position:absolute; top:-13px; left:28px;
  background:var(--green); color:var(--green-ink); font-size:12px; font-weight:800; padding:5px 13px; border-radius:100px; letter-spacing:.02em;
}
.compare-bad{ background:var(--paper-2); }
.compare-head{ display:flex; align-items:center; gap:12px; min-height:54px; margin-bottom:20px; padding-bottom:18px; border-bottom:1px solid var(--line); }
.compare-logo{ color:var(--ink); }
.compare-logo img{ height:52px; width:auto; }
.compare-head .ti-building-store{ font-size:30px; color:var(--text-mute); }
.compare-rating{ margin-left:auto; display:inline-flex; align-items:center; gap:6px; flex-shrink:0; }
.compare-rating .cr-stars{ color:#FFB400; font-size:13px; letter-spacing:1px; }
.compare-rating strong{ font-size:13.5px; font-weight:800; color:var(--text); }
.compare-rating .g-ico{ width:16px; height:16px; }
.compare-bad h3{ font-size:19px; color:var(--text-soft); }
.compare-list{ display:flex; flex-direction:column; gap:13px; }
.compare-list li{ display:flex; align-items:flex-start; gap:11px; font-size:15px; font-weight:500; }
.compare-good .compare-list li{ color:var(--text); }
.compare-good .compare-list i{ color:var(--green-dk); font-size:21px; flex-shrink:0; }
.compare-bad .compare-list li{ color:var(--text-mute); }
.compare-bad .compare-list i{ color:#C0524A; font-size:21px; flex-shrink:0; }

/* =========================================================
   STEPS
   ========================================================= */
.section-steps{ background:var(--paper-2); }
.steps-grid{ display:flex; align-items:stretch; justify-content:center; gap:8px; margin-top:50px; }
.step-card{
  flex:1; max-width:340px; background:var(--paper); border:1px solid var(--line); border-radius:var(--radius);
  padding:34px 26px 30px; text-align:center; position:relative; box-shadow:var(--shadow-sm);
}
.step-num{
  position:absolute; top:-18px; left:50%; transform:translateX(-50%);
  width:38px; height:38px; border-radius:50%; background:var(--ink); color:#fff;
  font-weight:800; font-size:17px; display:flex; align-items:center; justify-content:center; box-shadow:var(--shadow);
}
.step-icon{ display:flex; justify-content:center; margin:14px 0 16px; }
.step-title{ font-size:19px; margin-bottom:10px; }
.step-text{ font-size:14.5px; color:var(--text-soft); }
.step-connector{ display:flex; align-items:center; color:var(--green-dk); font-size:26px; flex-shrink:0; }
.steps-cta{ text-align:center; margin-top:44px; }
.steps-cta-sub{ margin-top:14px; font-size:14px; color:var(--text-mute); display:inline-flex; align-items:center; gap:7px; }
.steps-cta-sub i{ color:var(--green-dk); font-size:17px; }

/* =========================================================
   BEWERTUNGEN / MARQUEE
   ========================================================= */
/* Echtes Google-„G" (per <use href="#ico-google">) */
.g-ico{ width:1em; height:1em; display:inline-block; vertical-align:-.14em; flex-shrink:0; }
.reviews-badge{ display:inline-flex; align-items:center; gap:14px; background:var(--paper); border:1px solid var(--line); border-radius:14px; padding:13px 20px; box-shadow:var(--shadow-sm); margin-top:10px; }
.g-ico-lg{ width:34px; height:34px; }
.rb-info{ display:flex; flex-direction:column; text-align:left; }
.rb-score{ display:inline-flex; align-items:center; gap:9px; }
.rb-score strong{ font-size:23px; font-weight:800; letter-spacing:-.02em; }
.rb-stars{ color:var(--star); font-size:16px; letter-spacing:1.5px; }
.rb-link{ font-size:12.5px; color:var(--text-mute); text-decoration:underline; margin-top:2px; }
.rb-link:hover{ color:var(--green-dk); }
.marquee-wrap{ overflow:hidden; margin-top:42px; -webkit-mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent); mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent); }
.marquee{ display:flex; gap:20px; width:max-content; animation:marquee 64s linear infinite; }
.marquee:hover{ animation-play-state:paused; }
@keyframes marquee{ from{ transform:translateX(0); } to{ transform:translateX(-50%); } }
.review-card{ width:360px; padding:24px; flex-shrink:0; display:flex; flex-direction:column; }
.review-head{ display:flex; align-items:flex-start; gap:12px; margin-bottom:14px; }
.avatar{ width:46px; height:46px; border-radius:50%; background:var(--green-dk); color:#fff; font-weight:800; font-size:15px; display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.review-who{ flex:1; min-width:0; }
.review-head strong{ display:block; font-size:15.5px; line-height:1.25; }
.review-meta{ display:flex; align-items:center; gap:5px; font-size:12.5px; color:var(--text-mute); font-weight:600; margin-top:3px; }
.review-meta .g-ico{ width:14px; height:14px; }
.review-stars{ color:var(--star); font-size:13px; letter-spacing:1px; align-self:flex-start; white-space:nowrap; margin-top:2px; }
.review-card p{ font-size:14.5px; color:var(--text-soft); }

/* =========================================================
   ÜBER RGN
   ========================================================= */
.section-about{ background:var(--ink); color:var(--on-dark); overflow:hidden; }
.about-grid{ display:grid; grid-template-columns:.92fr 1.08fr; gap:54px; align-items:center; }
.about-media{ position:relative; }
.about-photo{ aspect-ratio:4/3; border-radius:var(--radius-lg); overflow:hidden; box-shadow:var(--shadow-lg); }
.ph-img{
  background:repeating-linear-gradient(135deg,#1d2128,#1d2128 12px,#20242c 12px,#20242c 24px);
  border:1.5px dashed rgba(255,255,255,.18); display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:10px; color:var(--on-dark-mute); text-align:center; font-size:13px; font-weight:600;
}
.ph-img i{ font-size:40px; opacity:.6; }
.about-photo-badge{
  position:absolute; bottom:18px; left:-14px; background:var(--green); color:var(--green-ink);
  font-weight:800; font-size:14px; padding:10px 16px; border-radius:12px; box-shadow:var(--shadow-lg);
  display:inline-flex; align-items:center; gap:7px;
}
.about-text h2{ color:#fff; font-size:clamp(1.8rem,3.2vw,2.6rem); margin-top:6px; }
.about-text p{ color:var(--on-dark-soft); margin-top:18px; font-size:16px; max-width:54ch; }
.about-points{ display:grid; grid-template-columns:1fr 1fr; gap:14px; margin:28px 0 30px; }
.about-points li{ display:flex; align-items:center; gap:11px; font-size:15px; font-weight:600; color:var(--on-dark); }
.about-points i{ color:var(--green); font-size:22px; flex-shrink:0; }

/* =========================================================
   WAS SIE BEKOMMEN
   ========================================================= */
.deliver-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-top:46px; }
.deliver-item{ display:flex; gap:15px; padding:22px 22px; align-items:flex-start; transition:transform .2s var(--ease), box-shadow .25s; }
.deliver-item:hover{ transform:translateY(-3px); box-shadow:var(--shadow); }
.deliver-item > i{ font-size:26px; color:var(--green-dk); background:var(--green-tint); width:48px; height:48px; border-radius:12px; display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.deliver-item strong{ display:block; font-size:16px; margin-bottom:4px; }
.deliver-item span{ font-size:14px; color:var(--text-soft); }
.offer-reassure{ display:flex; flex-wrap:wrap; justify-content:center; gap:14px 30px; margin-top:38px; }
.offer-reassure span{ display:inline-flex; align-items:center; gap:9px; font-size:15px; font-weight:700; color:var(--text); }
.offer-reassure i{ color:var(--green-dk); font-size:20px; }

/* =========================================================
   KONTAKT / QUIZ
   ========================================================= */
.contact-grid{ display:grid; grid-template-columns:1fr 1.05fr; gap:34px; margin-top:46px; align-items:start; }
.contact-left h3{ font-size:22px; margin-bottom:10px; }
.contact-left > p{ color:var(--text-soft); font-size:15.5px; margin-bottom:22px; }
.contact-options{ display:flex; flex-direction:column; gap:12px; }
.contact-option{ display:flex; align-items:center; gap:14px; background:var(--paper); border:1px solid var(--line); border-radius:13px; padding:14px 16px; transition:transform .18s var(--ease), border-color .2s, box-shadow .2s; }
.contact-option:hover{ transform:translateX(4px); border-color:var(--green-line); box-shadow:var(--shadow-sm); }
.co-icon{ width:46px; height:46px; border-radius:11px; display:flex; align-items:center; justify-content:center; font-size:21px; flex-shrink:0; }
.co-icon-phone{ background:var(--green-tint); color:var(--green-dk); }
.co-icon-wa{ background:#e7fbef; color:#1faf54; }
.co-icon-mail{ background:#eef3fb; color:#3677c9; }
.co-label{ display:block; font-size:12px; font-weight:700; color:var(--text-mute); text-transform:uppercase; letter-spacing:.04em; }
.co-value{ display:block; font-size:16px; font-weight:700; }
.contact-person{ display:flex; align-items:center; gap:14px; margin-top:22px; padding:16px; background:var(--paper-2); border:1px solid var(--line); border-radius:14px; }
.cp-avatar{ width:54px; height:54px; border-radius:50%; flex-shrink:0; font-size:24px; aspect-ratio:auto; }
.contact-person strong{ display:block; font-size:15px; }
.contact-person span{ font-size:13px; color:var(--text-soft); }
.contact-person em{ color:var(--green-dk); font-style:normal; font-weight:700; }
.contact-trust{ display:flex; flex-direction:column; gap:9px; margin-top:20px; }
.contact-trust li{ display:flex; align-items:center; gap:9px; font-size:14px; font-weight:600; color:var(--text-soft); }
.contact-trust i{ color:var(--green-dk); font-size:18px; }

/* Quiz */
.quiz{ background:var(--ink); border:1px solid var(--ink-3); border-radius:var(--radius-lg); padding:30px 28px; color:var(--on-dark); box-shadow:var(--shadow-lg); }
.quiz-logo-wrap{ display:flex; justify-content:center; margin-bottom:20px; color:#fff; }
.quiz-logo{ height:54px; width:auto; display:block; }
.quiz-progress-head{ display:flex; justify-content:space-between; font-size:13px; font-weight:700; color:var(--on-dark-soft); margin-bottom:8px; }
.quiz-bar{ height:7px; background:rgba(255,255,255,.1); border-radius:100px; overflow:hidden; margin-bottom:24px; }
#q-bar{ height:100%; width:20%; background:linear-gradient(90deg,var(--green),var(--green-2)); border-radius:100px; transition:width .4s var(--ease); }
.q-title{ font-size:21px; font-weight:800; color:#fff; text-align:center; margin-bottom:20px; letter-spacing:-.02em; }
.q-grid{ display:grid; grid-template-columns:1fr; gap:11px; }
.q-grid-2{ grid-template-columns:1fr 1fr; }
.q-opt{
  display:flex; align-items:center; gap:11px; background:rgba(255,255,255,.05); border:1.5px solid rgba(255,255,255,.13);
  border-radius:12px; padding:15px 16px; font-size:15px; font-weight:600; color:#fff; cursor:pointer;
  transition:border-color .18s, background .18s, transform .18s;
}
.q-opt:hover{ border-color:var(--green); background:rgba(19,198,103,.12); transform:translateY(-2px); }
.q-opt i{ font-size:21px; color:var(--green); }
.q-back{ display:inline-flex; align-items:center; gap:6px; margin-top:16px; font-size:13.5px; font-weight:700; color:var(--on-dark-soft); cursor:pointer; }
.q-back:hover{ color:#fff; }
.q-field{
  width:100%; background:rgba(255,255,255,.06); border:1.5px solid rgba(255,255,255,.16); border-radius:11px;
  padding:14px 15px; font-size:15px; color:#fff; transition:border-color .2s;
}
.q-field::placeholder{ color:var(--on-dark-mute); }
.q-field:focus{ outline:none; border-color:var(--green); }
.q-field.is-invalid{ border-color:#FF7A70; box-shadow:0 0 0 3px rgba(255,122,112,.18); }
.q-err{ display:flex; align-items:center; gap:6px; margin-top:-5px; font-size:12.5px; font-weight:600; color:#FF8079; }
.q-err[hidden]{ display:none; }
.q-err i{ font-size:15px; flex-shrink:0; }
.form-consent{ display:flex; align-items:flex-start; gap:9px; font-size:12.5px; color:var(--on-dark-soft); line-height:1.45; cursor:pointer; }
.form-consent input{ margin-top:2px; accent-color:var(--green); width:16px; height:16px; flex-shrink:0; }
.form-consent a{ color:var(--green); text-decoration:underline; }
.quiz-done{ text-align:center; padding:24px 10px; }
.quiz-done > i{ font-size:58px; color:var(--green); }
.quiz-done strong{ display:block; font-size:23px; color:#fff; margin:12px 0 8px; }
.quiz-done p{ color:var(--on-dark-soft); font-size:15px; max-width:34ch; margin:0 auto; }
.quiz-done-urgent{ margin-top:24px; padding-top:20px; border-top:1px solid var(--line-dark); }
.quiz-done-urgent-label{ display:block; font-size:13px; font-weight:600; color:var(--on-dark-soft); margin-bottom:12px; }
.quiz-done-urgent-btns{ display:flex; justify-content:center; gap:12px; }
.quiz-urgent-btn{ width:50px; height:50px; border-radius:13px; background:rgba(19,198,103,.14); color:var(--green); display:flex; align-items:center; justify-content:center; font-size:23px; transition:transform .18s, background .18s; }
.quiz-urgent-btn:hover{ transform:translateY(-3px); background:rgba(19,198,103,.24); }
.quiz-urgent-wa{ background:rgba(37,211,102,.14); color:#25D366; }

/* =========================================================
   FAQ
   ========================================================= */
.faq{ max-width:820px; margin:42px auto 0; display:flex; flex-direction:column; gap:13px; }
.faq details{ background:var(--paper); border:1px solid var(--line); border-radius:13px; padding:4px 22px; transition:box-shadow .2s, border-color .2s; }
.faq details[open]{ box-shadow:var(--shadow-sm); border-color:var(--green-line); }
.faq summary{ display:flex; align-items:center; justify-content:space-between; gap:16px; padding:18px 0; font-weight:700; font-size:16.5px; cursor:pointer; list-style:none; }
.faq summary::-webkit-details-marker{ display:none; }
.faq-plus{ font-size:21px; color:var(--green-dk); transition:transform .25s var(--ease); flex-shrink:0; }
.faq details[open] .faq-plus{ transform:rotate(45deg); }
.faq p{ padding:0 0 20px; color:var(--text-soft); font-size:15px; max-width:64ch; }

/* =========================================================
   FINALE CTA
   ========================================================= */
.section-final-cta{ position:relative; padding:clamp(70px,9vw,124px) 0; color:#fff; overflow:hidden; background:var(--ink); }
.final-cta-bg{
  position:absolute; inset:0; z-index:0;
  background:
    radial-gradient(700px 420px at 50% 0%, rgba(19,198,103,.22), transparent 62%),
    radial-gradient(500px 400px at 85% 100%, rgba(19,198,103,.12), transparent 60%),
    linear-gradient(180deg,#15181E,#101216);
}
.final-cta-bg::after{ content:""; position:absolute; inset:0; background-image:radial-gradient(rgba(255,255,255,.05) 1px,transparent 1px); background-size:32px 32px; opacity:.5; }
.final-cta-overlay{ position:absolute; inset:0; z-index:0; }
.final-cta-inner{ position:relative; z-index:1; text-align:center; }
.final-cta-title{ font-size:clamp(1.9rem,3.8vw,3rem); color:#fff; max-width:18ch; margin:0 auto; font-weight:900; }
.final-cta-sub{ color:var(--on-dark-soft); font-size:clamp(1.02rem,1.5vw,1.2rem); max-width:56ch; margin:20px auto 0; }
.final-cta-actions{ display:flex; gap:14px; justify-content:center; flex-wrap:wrap; margin-top:34px; }
.final-cta-trust{ display:flex; gap:14px 28px; justify-content:center; flex-wrap:wrap; margin-top:30px; }
.final-cta-trust span{ display:inline-flex; align-items:center; gap:8px; font-size:14.5px; font-weight:600; color:var(--on-dark-soft); }
.final-cta-trust i{ color:var(--green); font-size:18px; }

/* =========================================================
   FOOTER
   ========================================================= */
.site-footer{ background:#0E1014; color:var(--on-dark-soft); padding-top:60px; }
.footer-cols{ display:grid; grid-template-columns:1.6fr 1fr 1fr 1.3fr; gap:36px; padding-bottom:46px; }
.footer-logo{ color:#fff; display:inline-block; }
.footer-logo img{ height:56px; width:auto; }
.footer-tag{ margin-top:16px; font-size:14.5px; max-width:38ch; line-height:1.6; }
.footer-badges{ display:flex; gap:18px; margin-top:18px; }
.footer-badges span{ display:inline-flex; align-items:center; gap:7px; font-size:13px; font-weight:700; color:var(--on-dark); }
.footer-badges i{ color:var(--green); font-size:17px; }
.footer-col h3{ color:#fff; font-size:14px; font-weight:800; letter-spacing:.05em; text-transform:uppercase; margin-bottom:16px; }
.footer-col ul{ display:flex; flex-direction:column; gap:11px; }
.footer-col ul a{ font-size:14.5px; color:var(--on-dark-soft); transition:color .2s; }
.footer-col ul a:hover{ color:var(--green); }
.footer-contact-line{ display:flex; align-items:center; gap:10px; font-size:14.5px; margin-bottom:12px; }
.footer-contact-line i{ color:var(--green); font-size:18px; }
.footer-contact-line a:hover{ color:#fff; }
.footer-address{ margin-top:14px; font-size:14px; line-height:1.6; display:flex; gap:9px; }
.footer-address i{ color:var(--green); font-size:18px; flex-shrink:0; margin-top:2px; }
.footer-bottom-wrap{ border-top:1px solid rgba(255,255,255,.08); padding:20px 0; }
.footer-bottom{ display:flex; align-items:center; justify-content:space-between; gap:14px; flex-wrap:wrap; font-size:13px; color:var(--on-dark-mute); }
.footer-bottom a{ transition:color .2s; }
.footer-bottom a:hover{ color:var(--green); }

/* =========================================================
   PROMO POPUP
   ========================================================= */
.promo{ position:fixed; inset:0; z-index:120; display:flex; align-items:center; justify-content:center; padding:18px; }
.promo[hidden]{ display:none !important; }
.promo-backdrop{ position:absolute; inset:0; background:rgba(14,16,20,.62); backdrop-filter:blur(3px); animation:fade .3s; }
@keyframes fade{ from{ opacity:0; } to{ opacity:1; } }
.promo-card{ position:relative; z-index:1; max-width:min(440px,calc(100vw - 32px)); padding:34px 30px 28px; text-align:center; border-radius:var(--radius-lg); box-shadow:var(--shadow-lg); animation:pop .35s var(--ease); }
@keyframes pop{ from{ opacity:0; transform:translateY(16px) scale(.97); } to{ opacity:1; transform:translateY(0) scale(1); } }
.promo-close{ position:absolute; top:14px; right:14px; width:34px; height:34px; border-radius:9px; color:var(--text-mute); font-size:20px; display:flex; align-items:center; justify-content:center; transition:background .2s; }
.promo-close:hover{ background:var(--paper-2); }
.promo-ic{ width:64px; height:64px; border-radius:17px; background:var(--green-tint); color:var(--green-dk); font-size:32px; display:flex; align-items:center; justify-content:center; margin:0 auto 16px; }
.promo-card h3{ font-size:23px; margin-bottom:10px; }
.promo-card > p{ font-size:15px; color:var(--text-soft); margin-bottom:22px; }
.promo-mini{ margin-top:14px; font-size:12.5px; color:var(--text-mute); display:inline-flex; align-items:center; gap:7px; }
.promo-mini i{ color:var(--green-dk); }

/* =========================================================
   COOKIE BANNER
   ========================================================= */
.cookie-wall{ position:fixed; inset:0; z-index:200; }
.cookie-wall[hidden]{ display:none !important; }
.cookie-backdrop{ position:absolute; inset:0; background:rgba(14,16,20,.6); backdrop-filter:blur(3px); }
.cookie-card{
  position:fixed; top:50%; left:50%; transform:translate(-50%,-50%);
  width:min(520px,calc(100vw - 24px)); max-height:calc(100vh - 32px); overflow:auto;
  background:#fff; border-radius:20px; box-shadow:0 24px 64px rgba(0,0,0,.22);
  padding:30px 30px 26px; text-align:center;
}
.cookie-logo{ display:flex; justify-content:center; margin-bottom:16px; color:var(--ink); }
.cookie-logo img{ height:48px; width:auto; }
.cookie-title{ font-size:21px; margin-bottom:10px; }
.cookie-text{ font-size:14.5px; color:var(--text-soft); margin-bottom:14px; text-align:left; }
.cookie-links{ display:flex; gap:8px; justify-content:center; font-size:13px; margin-bottom:20px; }
.cookie-links a{ color:var(--text-mute); text-decoration:underline; }
.cookie-links a:hover{ color:var(--green-dk); }
.cookie-links span{ color:var(--line); }
.cookie-actions{ display:flex; flex-direction:column; gap:11px; }
.cookie-btn-accept{ width:100%; justify-content:center; padding:15px; }
.cookie-actions-row{ display:flex; gap:11px; }
.btn-cookie-reject,.btn-cookie-settings{ flex:1; padding:13px; border-radius:var(--radius-sm); font-weight:700; font-size:14.5px; display:inline-flex; align-items:center; justify-content:center; gap:7px; transition:background .2s, border-color .2s; }
.btn-cookie-reject{ border:1.5px solid var(--green); color:var(--green-dk); background:#fff; }
.btn-cookie-reject:hover{ background:var(--green-tint); }
.btn-cookie-settings{ border:1.5px solid var(--line); color:var(--text-soft); background:#fff; }
.btn-cookie-settings:hover{ border-color:var(--text-mute); }
.cookie-settings-panel{ margin-top:16px; padding-top:18px; border-top:1px solid var(--line); display:flex; flex-direction:column; gap:14px; }
.cookie-settings-panel[hidden]{ display:none !important; }
.cookie-category{ display:flex; align-items:center; justify-content:space-between; gap:14px; text-align:left; }
.cookie-cat-label{ font-size:14.5px; font-weight:700; }
.cookie-cat-text{ font-size:12.5px; color:var(--text-mute); margin-top:3px; }
.cookie-always-on{ font-size:12.5px; font-weight:700; color:var(--green-dk); white-space:nowrap; }
.cookie-toggle-wrap{ position:relative; width:48px; height:27px; flex-shrink:0; cursor:pointer; }
.cookie-toggle-input{ position:absolute; opacity:0; width:0; height:0; }
.cookie-toggle-track{ position:absolute; inset:0; background:#d3dad8; border-radius:100px; transition:background .25s; }
.cookie-toggle-track::after{ content:""; position:absolute; top:3px; left:3px; width:21px; height:21px; background:#fff; border-radius:50%; transition:transform .25s; box-shadow:0 2px 5px rgba(0,0,0,.2); }
.cookie-toggle-input:checked + .cookie-toggle-track{ background:var(--green); }
.cookie-toggle-input:checked + .cookie-toggle-track::after{ transform:translateX(21px); }

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width:1000px){
  .hero-grid{ grid-template-columns:1fr; gap:44px; }
  .hero-visual{ max-width:460px; margin:0 auto; }
  .dash-card{ transform:none; }
  .about-grid{ grid-template-columns:1fr; gap:34px; }
  .about-media{ max-width:380px; margin:0 auto; }
  .pain-grid{ grid-template-columns:1fr 1fr; }
  .solution-grid,.case-grid,.deliver-grid{ grid-template-columns:1fr; }
  .case-grid{ max-width:480px; margin-left:auto; margin-right:auto; }
  .deliver-grid{ grid-template-columns:1fr 1fr; }
  .contact-grid{ grid-template-columns:1fr; }
  .footer-cols{ grid-template-columns:1fr 1fr; gap:30px; }
}
@media (max-width:760px){
  body{ font-size:16px; }
  .desktop-only{ display:none !important; }
  .mobile-only{ display:flex !important; }
  .header-inner{ height:64px; }
  .logo-img{ height:44px; }
  .section-title{ font-size:1.85rem; }
  .section-sub,.problem-scene{ font-size:.95rem; }
  .hero h1{ font-size:2.15rem; }
  .hero-usps{ grid-template-columns:1fr; gap:10px; }
  .rotator-wrap{ display:inline-flex; }
  .steps-grid{ flex-direction:column; align-items:stretch; gap:30px; }
  .step-card{ max-width:none; }
  .step-connector{ transform:rotate(90deg); justify-content:center; }
  .compare-grid{ grid-template-columns:1fr; }
  .pain-grid,.deliver-grid,.about-points,.hero-usps{ grid-template-columns:1fr; }
  .statband{ grid-template-columns:1fr 1fr; gap:24px 18px; }
  .stat:not(:last-child)::after{ display:none; }
  .stat:nth-child(2)::after{ display:block; }
  .cta-band{ flex-direction:column; align-items:flex-start; }
  .cta-band-actions{ width:100%; }
  .cta-band-actions .btn{ flex:1; }
  .cta-band-ap{ display:none; }
  .ap-mobile-section{ display:block; }
  .footer-cols{ grid-template-columns:1fr; gap:30px; }
  .footer-bottom{ flex-direction:column; align-items:flex-start; }
  .btn-lg{ width:100%; }
  .hero-cta,.final-cta-actions,.steps-cta .btn{ width:100%; }
  .hero-cta .btn,.final-cta-actions .btn{ width:100%; }
  .marquee{ animation-duration:48s; }
  .review-card{ width:300px; }
  .logobar-items{ gap:12px 20px; }
  .logobar-items span{ font-size:13.5px; }
  .offer-reassure{ flex-direction:column; align-items:flex-start; gap:12px; }
}
@media (max-width:380px){
  .statband{ grid-template-columns:1fr; }
  .stat:nth-child(2)::after{ display:none; }
  .stat:not(:last-child){ padding-bottom:18px; border-bottom:1px solid rgba(255,255,255,.16); }
}

/* Reduced motion */
@media (prefers-reduced-motion:reduce){
  *{ animation-duration:.001ms !important; animation-iteration-count:1 !important; transition-duration:.05ms !important; }
  .marquee{ animation:none; }
  html{ scroll-behavior:auto; }
}

/* =========================================================
   SCHWARZ-WEISS THEME — Overrides (grün → schwarz/weiß)
   Marken-Logos (Google-G) & Sterne (Gold) bleiben farbig.
   ========================================================= */

/* Primär-Buttons auf DUNKLEN Sektionen: weiß / schwarzer Text */
.hero .btn-primary, .cta-band .btn-primary, .section-about .btn-primary,
.section-final-cta .btn-primary, .quiz .btn-primary, .q-screen .btn-primary{
  background:#fff; color:var(--ink); box-shadow:0 16px 34px -12px rgba(0,0,0,.55);
}
.hero .btn-primary:hover, .cta-band .btn-primary:hover, .section-about .btn-primary:hover,
.section-final-cta .btn-primary:hover, .quiz .btn-primary:hover, .q-screen .btn-primary:hover{
  background:#E9EBED; color:var(--ink);
}

/* Akzente auf DUNKLEN Sektionen → weiß */
.eyebrow-light{ color:#fff; }
.hero-usps i, .about-points i, .final-cta-trust i{ color:#fff; }
.rotator-wrap, .rotator{ color:#fff; }
.badge{ background:rgba(255,255,255,.08); border-color:rgba(255,255,255,.2); color:#fff; }
.badge-dot{ background:#fff; box-shadow:0 0 0 4px rgba(255,255,255,.18); }
.about-photo-badge{ background:#fff; color:var(--ink); }

/* Dunkle Hintergründe: Glows neutral statt grün */
.hero-bg{
  background:
    radial-gradient(680px 420px at 88% 8%, rgba(255,255,255,.07), transparent 60%),
    radial-gradient(560px 480px at 8% 92%, rgba(255,255,255,.04), transparent 60%),
    linear-gradient(180deg,#16181E 0%, #0F1116 100%);
}
.final-cta-bg{
  background:
    radial-gradient(700px 420px at 50% 0%, rgba(255,255,255,.08), transparent 62%),
    radial-gradient(500px 400px at 85% 100%, rgba(255,255,255,.04), transparent 60%),
    linear-gradient(180deg,#16181E,#0E1014);
}
.cta-band::before{ background:radial-gradient(circle, rgba(255,255,255,.06), transparent 70%); }

/* Statband dunkel statt grün */
.statband{ background:linear-gradient(135deg,#1C2027,#0C0E12); box-shadow:0 20px 50px -20px rgba(0,0,0,.55); }

/* Quiz (dunkle Karte): grün → weiß */
#q-bar, .q-bar > div{ background:linear-gradient(90deg,#fff,#c9cdd2); }
.q-opt:hover{ border-color:#fff; background:rgba(255,255,255,.09); }
.q-opt i{ color:#fff; }
.q-field:focus{ border-color:#fff; }
.form-consent input{ accent-color:#fff; }
.form-consent a{ color:#fff; }
.quiz-done > i{ color:#fff; }
.quiz-urgent-btn, .quiz-urgent-wa{ background:rgba(255,255,255,.12); color:#fff; }

/* Featured Case-Card (dunkel): grün → weiß */
.case-card-featured .case-tag{ background:rgba(255,255,255,.14); color:#fff; }
.case-card-featured .case-to, .case-card-featured .roas-num{ color:#fff; }
.case-card-featured .case-meta i{ color:#fff; }

/* Footer (dunkel): grün → weiß */
.footer-badges i, .footer-contact-line i, .footer-address i{ color:#fff; }
.footer-col ul a:hover, .footer-contact-line a:hover, .footer-bottom a:hover{ color:#fff; }

/* Review-Avatare & Mac-Dots & Brand-Tints mono */
.marquee .avatar{ background:#262B33 !important; }
.dash-dots span{ background:#D6DADC !important; }
.kpi-trend.down{ color:#8A929A; }
.feed-ic-wa, .co-icon-wa, .co-icon-mail, .co-icon-phone{ background:var(--green-tint); color:var(--ink); }
.icon-btn-wa{ color:var(--ink); }
.sol-ic{ background:var(--green-tint); color:var(--ink); }
/* Pain-Icons (Problem-Sektion) bleiben rot — Rot = Schmerzpunkt */
.pain-ic{ background:#FFF1F0; color:#E5544B; }
.compare-bad .compare-list i{ color:#AEB4B9; }

/* Hero-USP unterstrichen */
.usp-ul{ text-decoration:underline; text-underline-offset:3px; text-decoration-thickness:2px; }

/* ===== Zertifikats-Siegel ===== */
.certbar{ padding:30px 0; background:var(--paper); border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
.certbar.on-dark{ background:transparent; border:none; padding:8px 0 0; }
.certbar-label{ text-align:center; font-size:12.5px; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:var(--text-mute); margin-bottom:18px; }
.certbar.on-dark .certbar-label{ color:var(--on-dark-soft); }
.cert-row{ display:flex; flex-wrap:wrap; align-items:center; justify-content:center; gap:20px 42px; }
.cert{ height:clamp(58px,6.8vw,96px); width:auto; filter:grayscale(1); opacity:.6; transition:filter .25s, opacity .25s; }
.cert:hover{ filter:none; opacity:1; }
.certbar.on-dark .cert{ filter:grayscale(1) brightness(1.7); opacity:.7; }
.certbar.on-dark .cert:hover{ filter:none; opacity:1; }

/* ===== Gründer-Foto (B&W) ===== */
.about-foto{ display:block; width:100%; height:100%; object-fit:cover; object-position:center; }
.about-photo-badge{ display:flex; flex-direction:column; align-items:flex-start; gap:0; padding:11px 17px; }
.about-photo-badge strong{ font-size:14.5px; font-weight:800; line-height:1.25; }
.about-photo-badge span{ font-size:11.5px; font-weight:600; color:var(--text-soft); }
.cp-avatar{ overflow:hidden; }
.cp-avatar img{ width:100%; height:100%; object-fit:cover; border-radius:50%; filter:grayscale(1); }

/* ===== Trust-Badge am Formular ===== */
.analyse-trust{ display:flex; align-items:center; justify-content:center; flex-wrap:wrap; gap:8px 16px; margin:36px auto 0; padding:15px 26px; background:var(--paper); border:1px solid var(--line); border-radius:100px; box-shadow:var(--shadow-sm); width:max-content; max-width:100%; }
.at-stars{ color:var(--star); font-size:19px; letter-spacing:2px; }
.analyse-trust strong{ font-size:18px; font-weight:800; }
.analyse-trust .g-ico{ width:20px; height:20px; }
.at-label{ font-size:14.5px; font-weight:700; }
.at-sep{ width:1px; height:20px; background:var(--line); }

/* ===== Lead-Modal (CTA öffnet Formular direkt) ===== */
.lead-modal{ position:fixed; inset:0; z-index:140; display:flex; align-items:center; justify-content:center; padding:18px; }
.lead-modal[hidden]{ display:none !important; }
.lead-modal-backdrop{ position:absolute; inset:0; background:rgba(8,9,12,.66); backdrop-filter:blur(4px); animation:fade .3s; }
.lead-modal-card{ position:relative; z-index:1; width:min(520px,calc(100vw - 28px)); max-height:calc(100vh - 30px); overflow:auto; animation:pop .35s var(--ease); }
.lead-modal-card .quiz{ box-shadow:0 40px 90px rgba(0,0,0,.5); }
.lead-modal-close{ position:absolute; top:16px; right:16px; z-index:3; width:38px; height:38px; border-radius:10px; background:rgba(255,255,255,.12); color:#fff; font-size:20px; display:flex; align-items:center; justify-content:center; transition:background .2s; }
.lead-modal-close:hover{ background:rgba(255,255,255,.22); }

/* =========================================================
   MOBILE-FEINSCHLIFF (zusätzliche Wünsche)
   ========================================================= */
@media (max-width:760px){
  /* Statband untereinander (einspaltig) */
  .statband{ grid-template-columns:1fr; gap:0; }
  .stat{ padding:18px 0; }
  .stat:not(:last-child){ border-bottom:1px solid rgba(255,255,255,.16); }
  .stat:not(:last-child)::after, .stat:nth-child(2)::after{ display:none !important; }

  /* Google-Partner-Badge am Dashboard: größer & mittiger */
  .dash-badge-partner{ left:50%; transform:translateX(-50%); bottom:-24px; padding:13px 22px; gap:13px; }
  .dash-badge-partner .g-logo{ width:32px; height:32px; }
  .db-text strong{ font-size:16px; }
  .db-text span{ font-size:12px; }

  /* Hero-Badge (Pill) einzeilig halten */
  .badge{ font-size:11px; padding:7px 13px; white-space:nowrap; letter-spacing:0; }

  /* FAQ-Frage einzeilig: kompakter */
  .faq details{ padding:2px 16px; }
  .faq summary{ font-size:14px; padding:16px 0; gap:10px; }
  .faq-plus{ font-size:19px; }

  /* Zertifikate mobil etwas kleiner */
  .cert{ height:48px; }
  .cert-row{ gap:16px 26px; }
}

/* =========================================================
   FEINSCHLIFF: semantische Farben + größere Logos (nach B&W)
   ========================================================= */
/* Logos größer (Logo-Datei ist quadratisch mit viel Rand) */
.logo-img{ height:60px; }
.quiz-logo{ height:72px; }
.compare-logo img{ height:66px; }
.compare-head{ min-height:66px; }
.footer-logo img{ height:66px; }
.cookie-logo img{ height:56px; }

/* Lösungs-Icons GRÜN (positiv) */
.sol-ic{ background:linear-gradient(150deg,#ECFBF3,#DFF7E8); color:#0B8A44; }

/* Case-Study: nur die „MIT RGN"-Balken grün (suggeriert Erfolg) */
.cb-after span{ background:linear-gradient(180deg,#16D870,#0B8A44); box-shadow:0 6px 16px -4px rgba(19,198,103,.30); }

/* Vergleich: links grüne Haken, rechts rote Kreuze */
.compare-good .compare-list i{ color:#0B8A44; }
.compare-bad .compare-list i{ color:#E5544B; }

/* CTA-Band: Gradient + Punktraster + Form (weniger eintönig) */
.cta-band{
  background:
    radial-gradient(rgba(255,255,255,.045) 1px, transparent 1px) 0 0/26px 26px,
    linear-gradient(120deg,#212630 0%, #14161B 56%, #0C0E12 100%);
}
.cta-band::after{
  content:""; position:absolute; left:-50px; bottom:-60px; width:240px; height:240px; border-radius:50%;
  background:radial-gradient(circle, rgba(255,255,255,.05), transparent 70%); pointer-events:none;
}

/* Steps-CTA: Button oben, Text mittig darunter */
.steps-cta{ display:flex; flex-direction:column; align-items:center; gap:16px; }
.steps-cta-sub{ margin-top:0; }

/* Fotos in FARBE (kein Graustufen-Filter) */
.about-foto, .cp-avatar img{ filter:none; }

@media (max-width:760px){
  .logo-img{ height:50px; }
  .quiz-logo{ height:62px; }
  .compare-logo img{ height:58px; }
  .footer-logo img{ height:58px; }
}

/* =========================================================
   FARB-AKZENTE an psychologisch wichtigen Stellen
   (Layout bleibt B&W, Farbe gezielt: grün=positiv, rot=Problem)
   ========================================================= */
/* Zertifikate FARBIG (jetzt direkt unter der Hero) */
.cert{ filter:none; opacity:1; transition:transform .25s; }
.cert:hover{ filter:none; opacity:1; transform:translateY(-3px); }
.certbar{ border-top:none; }

/* Pulsierender grüner Punkt (Hero-Badge + Dashboard-LIVE) */
@keyframes dotPulse{ 0%{ box-shadow:0 0 0 0 rgba(22,216,112,.5);} 70%{ box-shadow:0 0 0 7px rgba(22,216,112,0);} 100%{ box-shadow:0 0 0 0 rgba(22,216,112,0);} }
.badge-dot{ background:#16D870; box-shadow:0 0 0 0 rgba(22,216,112,.55); animation:dotPulse 2s infinite; }
.live-dot{ background:#16D870; animation:dotPulse 1.8s infinite; }
.dash-live{ color:#0B8A44; }

/* Dashboard: aktive Balken grün, +675% grün, -38% grün (Kosten runter = gut) */
.dash-chart .bar-on{ background:linear-gradient(180deg,#16D870,#0B8A44); box-shadow:0 4px 12px -2px rgba(22,216,112,.35); }
.kpi-trend.up{ color:#0B8A44; }
.kpi-trend.down{ color:#0B8A44; }

/* Final-CTA: Gradient + Lichtformen (cooler Agentur-Look statt stumpf schwarz) */
.final-cta-bg{
  background:
    radial-gradient(820px 540px at 50% -8%, rgba(255,255,255,.11), transparent 60%),
    radial-gradient(620px 520px at 88% 110%, rgba(255,255,255,.06), transparent 62%),
    radial-gradient(540px 440px at 6% 104%, rgba(255,255,255,.05), transparent 62%),
    linear-gradient(160deg,#1E222C 0%, #14161B 46%, #0B0D11 100%);
}

/* Footer-Logo deutlich größer */
.footer-logo img{ height:86px; }

@media (max-width:760px){
  .footer-logo img{ height:74px; }
  /* Hero-Headline mobil: 3 Zeilen statt 4 (Umbruch raus + kleiner) */
  .hero-br{ display:none; }
  .hero h1{ font-size:1.58rem; }
}

/* =========================================================
   LOGOS DEUTLICH GRÖSSER (überall) + Trust-Badge am Formular
   ========================================================= */
.header-inner{ height:84px; }
.logo-img{ height:70px; }
.quiz-logo{ height:96px; }
.compare-logo img{ height:82px; }
.compare-head{ min-height:82px; }
.footer-logo img{ height:112px; }
.cookie-logo img{ height:76px; }
section[id]{ scroll-margin-top:96px; }

/* Trust-Badge direkt im Formular (dunkle Quiz-Karte) */
.quiz-trust{ display:flex; align-items:center; justify-content:center; flex-wrap:wrap; gap:6px 11px; margin-top:18px; padding-top:16px; border-top:1px solid rgba(255,255,255,.1); }
.qt-stars{ color:#FFB400; font-size:15px; letter-spacing:1.5px; }
.quiz-trust strong{ color:#fff; font-size:14px; font-weight:800; }
.quiz-trust .g-ico{ width:16px; height:16px; }
.qt-label{ font-size:12px; color:var(--on-dark-soft); font-weight:600; }
.qt-sep{ width:1px; height:15px; background:rgba(255,255,255,.18); }

@media (max-width:760px){
  .header-inner{ height:72px; }
  .logo-img{ height:58px; }
  .quiz-logo{ height:80px; }
  .compare-logo img{ height:72px; }
  .compare-head{ min-height:72px; }
  .footer-logo img{ height:92px; }

  /* Headline mobil etwas größer */
  .hero h1{ font-size:1.68rem; }

  /* Hero-Trust: zentriert, „Google Partner zertifiziert" mittig unter den beiden */
  .hero-trust{ justify-content:center; gap:8px 14px; }
  .hero-trust .ht-div{ display:none; }

  /* Zertifikate mobil: größer + weniger Abstand (füllt die Breite, 1 Reihe) */
  .certbar .container{ padding:0 2px; }
  .cert{ height:90px; }
  .cert-row{ gap:3px; flex-wrap:nowrap; align-items:center; }
}

/* =========================================================
   MAC-FENSTER-PUNKTE wieder farbig + MOBILE-OVERFLOW-FIX
   ========================================================= */
.dash-dots span:nth-child(1){ background:#FF5F57 !important; }
.dash-dots span:nth-child(2){ background:#FEBC2E !important; }
.dash-dots span:nth-child(3){ background:#28C840 !important; }

@media (max-width:760px){
  /* Grid-Items dürfen schrumpfen (sonst Overflow durch min-content) */
  .contact-grid > *, .contact-left, .contact-right{ min-width:0; }
  .contact-option, .co-text, .co-value{ min-width:0; }
  .co-value{ overflow-wrap:anywhere; }
  /* Quiz-Optionen mobil einspaltig → passt sauber in die Breite */
  .q-grid-2{ grid-template-columns:1fr; }
}

/* =========================================================
   RADIUS-SLIDER (Quiz) + ERFOLGS-SCREEN + FOMO
   ========================================================= */
/* Radius-Slider (dunkle Quiz-Karte) */
.q-radius-wrap{ background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.12); border-radius:12px; padding:15px 16px 13px; }
.q-radius-head{ display:flex; justify-content:space-between; align-items:center; font-size:13px; color:var(--on-dark-soft); font-weight:600; margin-bottom:13px; }
.q-radius-val{ color:#fff; font-size:15px; font-weight:800; }
.q-radius{ -webkit-appearance:none; appearance:none; width:100%; height:6px; border-radius:100px; background:rgba(255,255,255,.2); outline:none; cursor:pointer; }
.q-radius::-webkit-slider-thumb{ -webkit-appearance:none; appearance:none; width:24px; height:24px; border-radius:50%; background:#fff; border:none; cursor:pointer; box-shadow:0 3px 10px rgba(0,0,0,.45); }
.q-radius::-moz-range-thumb{ width:24px; height:24px; border-radius:50%; background:#fff; border:none; cursor:pointer; box-shadow:0 3px 10px rgba(0,0,0,.45); }
.q-radius-scale{ display:flex; justify-content:space-between; font-size:11px; color:var(--on-dark-mute); font-weight:600; margin-top:9px; }

/* Erfolgs-Screen: großer grüner Haken */
.quiz-done > i{ font-size:74px; color:#16D870; animation:pop .45s var(--ease); }
.quiz-urgent-mail{ background:rgba(255,255,255,.12); color:#fff; }

/* FOMO-Bottom-Sheet (Verpasste Anfragen / Konkurrenz-Hype, fährt von unten rein) */
.fomo{ position:fixed; left:0; right:0; bottom:0; z-index:135; transform:translateY(105%); transition:transform .5s var(--ease); }
.fomo[hidden]{ display:none !important; }
.fomo.fomo-in{ transform:translateY(0); }
.fomo-sheet{ position:relative; width:100%; max-width:540px; margin:0 auto; max-height:50vh; overflow:auto; background:#fff; border-radius:24px 24px 0 0; box-shadow:0 -18px 60px rgba(10,14,20,.30); padding:26px 22px calc(24px + env(safe-area-inset-bottom)); }
.fomo-grip{ position:absolute; top:9px; left:50%; transform:translateX(-50%); width:42px; height:5px; border-radius:100px; background:var(--line); }
.fomo-close{ position:absolute; top:13px; right:13px; width:32px; height:32px; border-radius:9px; color:var(--text-mute); font-size:19px; display:flex; align-items:center; justify-content:center; }
.fomo-close:hover{ background:var(--paper-2); }
.fomo-head{ display:flex; flex-direction:column; align-items:center; text-align:center; gap:13px; margin-top:10px; }
.fomo-ic{ width:54px; height:54px; border-radius:15px; background:#FFF1F0; color:#E5544B; display:flex; align-items:center; justify-content:center; font-size:28px; flex-shrink:0; animation:fomoShake 2.8s ease-in-out infinite; }
@keyframes fomoShake{ 0%,86%,100%{ transform:rotate(0); } 89%{ transform:rotate(-10deg); } 92%{ transform:rotate(9deg); } 95%{ transform:rotate(-5deg); } }
.fomo-head-txt strong{ display:block; font-size:16.5px; line-height:1.25; letter-spacing:-.01em; }
.fomo-head-txt > span{ display:block; font-size:13.5px; color:var(--text-soft); line-height:1.5; margin-top:6px; }
.fomo-stats{ display:grid; grid-template-columns:1fr 1fr; gap:12px; margin:18px 0; }
.fomo-stat{ background:var(--paper-2); border:1px solid var(--line); border-radius:13px; padding:13px 12px; text-align:center; }
.fs-num{ display:block; font-size:23px; font-weight:900; letter-spacing:-.02em; color:#0B8A44; }
.fs-label{ display:block; font-size:12px; font-weight:600; color:var(--text-soft); margin-top:2px; line-height:1.2; }
.fomo-actions{ display:flex; gap:10px; }
.fomo-cta{ flex:1; justify-content:center; width:100%; }

/* =========================================================
   FLOATING ACTION BUTTON
   ========================================================= */
.fab-wrap{
  position:fixed; bottom:24px; right:20px; z-index:950;
  display:flex; flex-direction:column; align-items:center; gap:10px;
}
.fab-btn{
  width:56px; height:56px; border-radius:50%;
  background:var(--ink); color:#fff; border:none; cursor:pointer;
  display:flex; align-items:center; justify-content:center;
  font-size:24px; position:relative;
  box-shadow:0 4px 20px rgba(0,0,0,.28);
  transition:transform .2s var(--ease), background .2s;
}
.fab-btn:hover{ background:#2a2d35; transform:scale(1.07); }
.fab-btn.is-open{ background:#3A3F47; }
.fab-btn i{ transition:transform .25s var(--ease); }
.fab-btn.is-open i{ transform:rotate(90deg); }
.fab-badge{
  position:absolute; top:-5px; right:-5px;
  width:20px; height:20px; border-radius:50%;
  background:#e03131; color:#fff;
  font-size:11px; font-weight:800;
  display:flex; align-items:center; justify-content:center;
  border:2px solid #fff;
  animation:fabPulse 1.8s ease-in-out infinite;
}
.fab-badge[hidden]{ display:none; }
@keyframes fabPulse{ 0%,100%{transform:scale(1)} 50%{transform:scale(1.18)} }
.fab-menu{ display:flex; flex-direction:column; align-items:center; gap:10px; animation:fabIn .2s var(--ease) both; }
.fab-menu[hidden]{ display:none; }
@keyframes fabIn{ from{opacity:0;transform:translateY(8px)} to{opacity:1;transform:translateY(0)} }
.fab-item{
  width:48px; height:48px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  font-size:22px; text-decoration:none;
  box-shadow:0 3px 14px rgba(0,0,0,.2);
  transition:transform .18s, box-shadow .18s;
  background:var(--ink); color:#fff;
}
.fab-item:hover{ transform:scale(1.1); box-shadow:0 6px 20px rgba(0,0,0,.25); }
.fab-item-wa{ background:#25D366; }
.fab-item-mail{ background:#fff; color:var(--ink); border:1.5px solid var(--line); }

/* =========================================================
   KI-POTENZIAL-RECHNER (Hero-Visual, ersetzt Dashboard-Mock)
   ========================================================= */
.calc{
  position:relative; overflow:hidden;
  padding:22px 22px 20px;
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow-lg);
  color:var(--text);
  background:
    radial-gradient(120% 80% at 50% -8%, #FBFCFC 0%, #FFFFFF 46%) , #fff;
}
/* Primär-Buttons sitzen auf der WEISSEN Karte → dunkel (nicht die weiße Hero-Variante) */
.hero .calc .btn-primary{ background:var(--ink); color:#fff; box-shadow:0 12px 26px -10px rgba(20,22,27,.5); border:none; }
.hero .calc .btn-primary:hover{ background:#262b34; color:#fff; transform:translateY(-2px); box-shadow:0 16px 30px -10px rgba(20,22,27,.6); }
.calc::before{ /* dezenter Akzent-Rahmen oben */
  content:""; position:absolute; left:0; right:0; top:0; height:3px;
  background:linear-gradient(90deg,#0B8A44,#16D870,#0B8A44); opacity:.9;
}
.calc-head{ display:flex; align-items:center; justify-content:space-between; gap:10px; margin-bottom:14px; }
.calc-badge{
  display:inline-flex; align-items:center; gap:7px;
  background:var(--ink); color:#fff; font-weight:800; font-size:12px; letter-spacing:.01em;
  padding:7px 13px; border-radius:100px;
}
.calc-badge i{ color:#16D870; font-size:15px; }
.calc-badge-done{ background:#ECFBF3; color:#0B8A44; }
.calc-badge-done i{ color:#0B8A44; }
.calc-pct{ font-size:12px; font-weight:700; color:var(--text-mute); }
.calc-bar{ height:5px; border-radius:100px; background:var(--paper-3); overflow:hidden; margin-bottom:18px; }
.calc-bar[hidden]{ display:none; }
.calc-bar-fill{ height:100%; width:33%; border-radius:100px; background:linear-gradient(90deg,var(--ink),#3A4150); transition:width .45s var(--ease); }
.calc-screen{ min-height:330px; }

/* ---- Intro / Hook ---- */
.calc-intro{ text-align:center; padding:14px 6px 8px; animation:calcFade .4s var(--ease) both; }
.calc-intro-ic{
  width:74px; height:74px; margin:6px auto 18px; border-radius:20px;
  display:flex; align-items:center; justify-content:center; font-size:34px; color:#fff;
  background:linear-gradient(150deg,#16D870,#0B8A44);
  box-shadow:0 14px 30px -8px rgba(11,138,68,.55); animation:calcGlow 2.6s ease-in-out infinite;
}
.calc-intro-h{ font-size:1.42rem; font-weight:900; letter-spacing:-.022em; line-height:1.18; color:var(--text); max-width:18ch; margin:0 auto; }
.calc-intro-p{ font-size:14px; line-height:1.6; color:var(--text-soft); margin:13px auto 22px; max-width:34ch; }
.calc-start{ width:100%; justify-content:center; }
.calc-intro-feat{ display:flex; justify-content:center; gap:18px; margin-top:16px; flex-wrap:wrap; }
.calc-intro-feat span{ display:inline-flex; align-items:center; gap:6px; font-size:12.5px; font-weight:700; color:var(--text-mute); }
.calc-intro-feat i{ color:#0B8A44; font-size:15px; }

/* ---- Steps ---- */
.calc-step{ animation:calcFade .35s var(--ease) both; }
.calc-q{ font-size:1.12rem; font-weight:900; letter-spacing:-.018em; line-height:1.25; color:var(--text); }
.calc-hint{ font-size:13px; color:var(--text-mute); margin:7px 0 18px; line-height:1.45; }
.calc-opts{ display:grid; grid-template-columns:1fr 1fr; gap:10px; }
.calc-opt{
  display:flex; flex-direction:column; align-items:flex-start; gap:9px;
  background:var(--paper-2); border:1.5px solid var(--line); border-radius:13px;
  padding:14px 14px; text-align:left; cursor:pointer; min-width:0;
  transition:border-color .18s, background .18s, transform .15s, box-shadow .2s;
}
.calc-opt i{ font-size:23px; color:var(--ink); }
.calc-opt span{ font-size:13.5px; font-weight:700; line-height:1.2; }
.calc-opt:hover{ border-color:var(--ink); background:#fff; transform:translateY(-2px); box-shadow:var(--shadow-sm); }
.calc-opt.is-active{ border-color:var(--ink); background:#fff; box-shadow:0 0 0 3px rgba(20,22,27,.08); }

.calc-field{ display:block; margin-bottom:18px; }
.calc-field > span{ display:block; font-size:13px; font-weight:700; color:var(--text-soft); margin-bottom:7px; }
.calc-input{
  width:100%; font:inherit; font-size:16px; font-weight:600; color:var(--text);
  background:var(--paper-2); border:1.5px solid var(--line); border-radius:12px; padding:13px 15px;
  transition:border-color .18s, box-shadow .18s; outline:none;
}
.calc-input:focus{ border-color:var(--ink); box-shadow:0 0 0 3px rgba(20,22,27,.08); background:#fff; }
.calc-input.is-invalid{ border-color:#E5544B; box-shadow:0 0 0 3px rgba(229,84,75,.14); background:#fff; }
.calc-err{ display:flex; align-items:center; gap:6px; margin:-11px 0 16px; font-size:12.5px; font-weight:600; color:#E5544B; }
.calc-err[hidden]{ display:none; }
.calc-err i{ font-size:15px; flex-shrink:0; }

.calc-range-block{ background:var(--paper-2); border:1px solid var(--line); border-radius:13px; padding:15px 16px 14px; }
.calc-range-top{ display:flex; justify-content:space-between; align-items:center; font-size:13px; color:var(--text-soft); font-weight:700; margin-bottom:13px; }
.calc-range-val{ color:var(--ink); font-size:15px; font-weight:900; }
.calc-budget-val{ text-align:center; font-size:2.5rem; font-weight:900; letter-spacing:-.03em; color:var(--text); margin:6px 0 16px; }
.calc-budget-val small{ font-size:.95rem; font-weight:700; color:var(--text-mute); margin-left:6px; letter-spacing:0; }
.calc-range{ -webkit-appearance:none; appearance:none; width:100%; height:6px; border-radius:100px; background:var(--paper-3); outline:none; cursor:pointer; }
.calc-range::-webkit-slider-thumb{ -webkit-appearance:none; appearance:none; width:26px; height:26px; border-radius:50%; background:var(--ink); border:3px solid #fff; cursor:pointer; box-shadow:0 3px 10px rgba(0,0,0,.28); }
.calc-range::-moz-range-thumb{ width:23px; height:23px; border-radius:50%; background:var(--ink); border:3px solid #fff; cursor:pointer; box-shadow:0 3px 10px rgba(0,0,0,.28); }
.calc-range-budget{ margin-top:2px; }
.calc-range-scale{ display:flex; justify-content:space-between; font-size:11.5px; color:var(--text-mute); font-weight:600; margin-top:10px; }

.calc-nav{ display:flex; align-items:center; gap:12px; margin-top:22px; }
.calc-nav .calc-next{ flex:1; justify-content:center; }
.calc-nav-solo{ justify-content:flex-start; }
.calc-back{ display:inline-flex; align-items:center; gap:6px; font-size:13.5px; font-weight:700; color:var(--text-mute); padding:8px 4px; cursor:pointer; transition:color .18s; }
.calc-back:hover{ color:var(--ink); }

/* ---- Loading ---- */
.calc-load{ text-align:center; padding:18px 6px; animation:calcFade .3s var(--ease) both; }
.calc-load-ring{ position:relative; width:108px; height:108px; margin:6px auto 18px; }
.calc-load-ring svg{ width:100%; height:100%; transform:rotate(-90deg); }
.calc-load-ring circle{ fill:none; stroke-width:7; stroke-linecap:round; }
.calc-load-ring .clr-bg{ stroke:var(--paper-3); }
.calc-load-ring .clr-fg{ stroke:#0B8A44; }
.calc-load-pct{ position:absolute; inset:0; display:flex; align-items:center; justify-content:center; font-size:1.5rem; font-weight:900; letter-spacing:-.02em; color:var(--text); }
.calc-load-title{ font-size:1.02rem; font-weight:800; color:var(--text); margin-bottom:18px; }
.calc-load-steps{ display:flex; flex-direction:column; gap:11px; text-align:left; max-width:300px; margin:0 auto; }
.calc-load-step{ display:flex; align-items:center; gap:11px; font-size:13.5px; font-weight:600; color:var(--text-mute); opacity:.5; transition:opacity .3s, color .3s; }
.calc-load-step i{ font-size:19px; flex-shrink:0; }
.calc-load-step .cls-done{ display:none; color:#0B8A44; }
.calc-load-step .cls-spin{ color:var(--text-mute); }
.calc-load-step.is-active{ opacity:1; color:var(--text-soft); }
.calc-load-step.is-active .cls-spin{ color:var(--ink); animation:calcSpin .8s linear infinite; }
.calc-load-step.is-done{ opacity:1; color:var(--text); }
.calc-load-step.is-done .cls-spin{ display:none; }
.calc-load-step.is-done .cls-done{ display:inline-block; animation:calcPop .35s var(--ease); }

/* ---- Result ---- */
.calc-result{ animation:calcFade .4s var(--ease) both; }
.calc-res-badge{
  display:inline-flex; align-items:center; gap:7px; font-size:12px; font-weight:800;
  color:#0B8A44; background:#ECFBF3; border:1px solid #CDEFDD; border-radius:100px; padding:6px 12px; margin-bottom:16px;
}
.calc-res-badge i{ font-size:15px; }

/* Gauge rot → grün */
.calc-gauge{ margin-bottom:18px; }
.calc-gauge-head{ margin-bottom:26px; }
.calc-gauge-head > span{ font-size:12.5px; font-weight:700; color:var(--text-soft); text-transform:uppercase; letter-spacing:.04em; }
.calc-gauge-verdict{ display:flex; align-items:center; justify-content:center; gap:7px; font-size:1.08rem; font-weight:900; letter-spacing:-.015em; color:#0B8A44; margin-top:15px; }
.calc-gauge-verdict i{ font-size:19px; }
.calc-gauge-track{
  position:relative; height:12px; border-radius:100px;
  background:linear-gradient(90deg,#E5544B 0%,#F5A623 40%,#16D870 68%);
  box-shadow:inset 0 1px 3px rgba(0,0,0,.12);
}
.calc-gauge-marker{
  position:absolute; top:50%; width:22px; height:22px; border-radius:50%;
  background:#fff; border:4px solid var(--ink); transform:translate(-50%,-50%);
  box-shadow:0 3px 10px rgba(0,0,0,.3); transition:left 1.1s var(--ease);
}
.calc-gauge-bubble{
  position:absolute; bottom:calc(100% + 9px); left:50%; transform:translateX(-50%);
  background:var(--ink); color:#fff; font-size:12px; font-weight:900; line-height:1;
  padding:5px 9px; border-radius:8px; white-space:nowrap;
}
.calc-gauge-bubble::after{ content:""; position:absolute; top:100%; left:50%; transform:translateX(-50%); border:5px solid transparent; border-top-color:var(--ink); }
.calc-gauge-scale{ display:flex; justify-content:space-between; font-size:10.5px; font-weight:700; color:var(--text-mute); margin-top:11px; text-transform:uppercase; letter-spacing:.02em; }

/* Hauptmetrik */
.calc-metric{ text-align:center; background:var(--ink); border-radius:16px; padding:18px 16px; margin-bottom:14px; }
.calc-metric-num{ font-size:3rem; font-weight:900; letter-spacing:-.04em; color:#fff; line-height:1; display:flex; align-items:center; justify-content:center; gap:4px; }
.calc-metric-num .cm-dash{ color:#fff; font-weight:800; }
.calc-metric-lbl{ font-size:13px; font-weight:700; color:var(--on-dark-soft); margin-top:9px; text-transform:uppercase; letter-spacing:.03em; }

/* Stat-Kacheln */
.calc-stats{ display:grid; grid-template-columns:1fr 1fr 1fr; gap:9px; margin-bottom:16px; }
.calc-stat{ background:var(--paper-2); border:1px solid var(--line); border-radius:12px; padding:13px 8px; text-align:center; min-width:0; }
.calc-stat .cs-num{ display:block; font-size:1.02rem; font-weight:900; letter-spacing:-.02em; color:var(--text); white-space:nowrap; }
.calc-stat .cs-lbl{ display:block; font-size:10.5px; font-weight:700; color:var(--text-mute); margin-top:4px; line-height:1.25; }

/* KI-Einschätzung */
.calc-ai{ display:flex; gap:11px; background:var(--paper-2); border:1px solid var(--line); border-left:3px solid #0B8A44; border-radius:12px; padding:14px 15px; margin:16px 0 0; }
.calc-ai > i{ color:#0B8A44; font-size:19px; flex-shrink:0; margin-top:1px; }
.calc-ai p{ font-size:13px; line-height:1.55; color:var(--text-soft); }
.calc-ai strong{ color:var(--text); font-weight:800; }

/* Trust-Badge im Rechner (weiße Karte) — sichtbar bis zum Ergebnis */
.calc-trust{ display:flex; align-items:center; justify-content:center; flex-wrap:wrap; gap:6px 11px; margin-top:18px; padding-top:16px; border-top:1px solid var(--line); }
.calc-trust[hidden]{ display:none; }
.calc-trust .qt-stars{ color:#FFB400; font-size:15px; letter-spacing:1.5px; }
.calc-trust strong{ color:var(--text); font-size:14px; font-weight:800; }
.calc-trust .g-ico{ width:16px; height:16px; }
.calc-trust .qt-label{ font-size:12px; color:var(--text-mute); font-weight:600; }
.calc-trust .qt-sep{ width:1px; height:15px; background:var(--line); }

/* Secure-CTA */
.calc-secure{ border-top:1px solid var(--line); padding-top:20px; }
.calc-secure-h{ font-size:1.14rem; font-weight:900; letter-spacing:-.018em; line-height:1.25; text-align:center; color:var(--text); margin-bottom:15px; }
.calc-cta{ width:100%; justify-content:center; }
.calc-result > .calc-cta{ margin-top:18px; }
.calc-bullets{ display:grid; grid-template-columns:1fr; gap:13px; margin-top:6px; }
.calc-bullets span{ display:flex; align-items:center; gap:11px; font-size:14.5px; font-weight:600; color:var(--text-soft); min-width:0; }
.calc-bullets i{ color:#0B8A44; font-size:20px; flex-shrink:0; }

/* Direkt-Kontakt */
.calc-contact{ margin-top:20px; }
.calc-contact-lbl{ display:block; text-align:center; font-size:12px; font-weight:700; color:var(--text-mute); margin-bottom:11px; }
.calc-dbtns{ display:grid; grid-template-columns:1fr 1fr 1fr; gap:9px; }
.calc-dbtn{
  display:flex; align-items:center; justify-content:center; gap:5px;
  font-size:12.5px; font-weight:800; padding:12px 8px; border-radius:11px;
  border:1.5px solid var(--line); background:var(--paper-2); color:var(--text);
  transition:transform .16s var(--ease), border-color .18s, background .18s; min-width:0;
}
.calc-dbtn i{ font-size:16px; }
.calc-dbtn:hover{ transform:translateY(-2px); }
.calc-dbtn.cd-tel:hover{ border-color:var(--ink); }
.calc-dbtn.cd-wa{ color:#0B8A44; }
.calc-dbtn.cd-wa:hover{ background:#ECFBF3; border-color:#9FE0BE; }
.calc-dbtn.cd-mail:hover{ border-color:var(--ink); }

.calc-restart{ display:flex; align-items:center; justify-content:center; gap:7px; width:100%; margin-top:16px; font-size:13px; font-weight:700; color:var(--text-mute); padding:9px; cursor:pointer; transition:color .18s; }
.calc-restart:hover{ color:var(--ink); }
.calc-restart i{ font-size:16px; }
.calc-disc{ display:flex; gap:9px; align-items:flex-start; text-align:left; font-size:11.5px; line-height:1.55; color:var(--text-mute); background:var(--paper-2); border:1px solid var(--line); border-radius:11px; padding:11px 13px; margin-top:16px; }
.calc-disc i{ font-size:16px; color:var(--text-soft); flex-shrink:0; margin-top:1px; }
.calc-disc strong{ color:var(--text-soft); font-weight:800; }

/* Animationen */
@keyframes calcFade{ from{ opacity:0; transform:translateY(10px); } to{ opacity:1; transform:none; } }
@keyframes calcSpin{ to{ transform:rotate(360deg); } }
@keyframes calcGlow{ 0%,100%{ box-shadow:0 14px 30px -8px rgba(11,138,68,.55); } 50%{ box-shadow:0 16px 40px -6px rgba(22,216,112,.7); } }
@keyframes calcPop{ 0%{ transform:scale(.4); opacity:0; } 60%{ transform:scale(1.15); } 100%{ transform:scale(1); opacity:1; } }

/* Calc mobil */
@media (max-width:760px){
  .calc{ padding:18px 16px 18px; }
  .calc-screen{ min-height:300px; }
  .calc-intro-h{ font-size:1.3rem; }
  .calc-metric-num{ font-size:2.6rem; }
  .calc-budget-val{ font-size:2.2rem; }
  .calc-head{ justify-content:center; }
}
@media (max-width:380px){
  .calc-stats{ gap:7px; }
  .calc-stat{ padding:11px 5px; }
  .calc-stat .cs-num{ font-size:.92rem; }
  .calc-dbtn{ font-size:12px; padding:11px 5px; gap:5px; }
  .calc-dbtn i{ font-size:16px; }
  .calc-bullets{ grid-template-columns:1fr; }
}

/* =========================================================
   LOGOS: eng zugeschnittene Dateien (dark-tight/white-tight, ~1,53:1)
   → Wortmarke füllt die Höhe, deshalb deutlich größer als die alten
     quadratischen Logos mit viel Rand. Finaler Override (gewinnt per Quell-Reihenfolge).
   ========================================================= */
.logo-img{ height:52px; }
.quiz-logo{ height:66px; }
.compare-logo img{ height:60px; }
.compare-head{ min-height:60px; }
.footer-logo img{ height:84px; }
.cookie-logo img{ height:54px; }

@media (max-width:760px){
  .logo-img{ height:44px; }
  .quiz-logo{ height:56px; }
  .compare-logo img{ height:52px; }
  .compare-head{ min-height:52px; }
  .footer-logo img{ height:70px; }
  .cookie-logo img{ height:48px; }
}

/* =========================================================
   RECHTSSEITEN (Impressum / Datenschutz / Cookie-Richtlinie)
   ========================================================= */
.legal-topbar{ position:sticky; top:0; z-index:50; background:#fff; border-bottom:1px solid var(--line); }
.legal-topbar .container{ display:flex; align-items:center; justify-content:space-between; height:76px; }
.legal-topbar .logo-img{ height:46px; }
.legal-back{ display:inline-flex; align-items:center; gap:7px; font-size:14px; font-weight:700; color:var(--text-soft); transition:color .18s; }
.legal-back:hover{ color:var(--ink); }
.legal-hero{ background:var(--ink); color:#fff; padding:52px 0 44px; }
.legal-hero .eyebrow{ color:var(--on-dark-soft); }
.legal-hero h1{ color:#fff; font-size:clamp(1.9rem,4vw,2.6rem); font-weight:900; letter-spacing:-.022em; line-height:1.12; margin-top:6px; }
.legal-hero p{ color:var(--on-dark-soft); margin-top:12px; font-size:15px; max-width:60ch; }
.legal-wrap{ max-width:840px; margin:0 auto; padding:50px 20px 84px; }
.legal-content h2{ font-size:1.32rem; font-weight:800; letter-spacing:-.01em; margin:38px 0 12px; color:var(--text); }
.legal-content > h2:first-child{ margin-top:0; }
.legal-content h3{ font-size:1.04rem; font-weight:800; margin:24px 0 8px; color:var(--text); }
.legal-content p, .legal-content li{ font-size:15px; line-height:1.72; color:var(--text-soft); }
.legal-content p{ margin-bottom:14px; }
.legal-content ul{ margin:0 0 16px 22px; }
.legal-content li{ margin-bottom:7px; }
.legal-content a{ color:var(--ink); text-decoration:underline; text-underline-offset:2px; }
.legal-content a:hover{ opacity:.7; }
.legal-content strong{ color:var(--text); font-weight:700; }
.legal-box{ background:var(--paper-2); border:1px solid var(--line); border-left:3px solid var(--ink); border-radius:12px; padding:16px 20px; margin:20px 0; }
.legal-box p:last-child{ margin-bottom:0; }
.legal-note{ background:#FFF8E8; border:1px solid #F2D89B; border-radius:12px; padding:16px 20px; margin:20px 0; }
.legal-note p{ color:#7A5B12; margin-bottom:0; }
.legal-updated{ font-size:13.5px; color:var(--text-mute); margin-top:44px; padding-top:20px; border-top:1px solid var(--line); }
@media (max-width:760px){
  .legal-topbar .container{ height:64px; }
  .legal-topbar .logo-img{ height:38px; }
  .legal-wrap{ padding:36px 18px 64px; }
  .legal-content h2{ font-size:1.18rem; }
}
