@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('/fonts/inter-400.woff2') format('woff2');
}
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url('/fonts/inter-500.woff2') format('woff2');
}
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url('/fonts/inter-600.woff2') format('woff2');
}
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url('/fonts/inter-700.woff2') format('woff2');
}
@font-face {
  font-family: 'Barlow';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('/fonts/barlow-400.woff2') format('woff2');
}
@font-face {
  font-family: 'Barlow';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url('/fonts/barlow-500.woff2') format('woff2');
}
@font-face {
  font-family: 'Barlow';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url('/fonts/barlow-700.woff2') format('woff2');
}
@font-face {
  font-family: 'Barlow';
  font-style: normal;
  font-weight: 800;
  font-display: swap;
  src: url('/fonts/barlow-800.woff2') format('woff2');
}
* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}
html {
  scroll-behavior: smooth;
  /* Welle 1: globaler Schutz gegen horizontalen Overflow auf Mobile (clip ist
     sticky-sicher, anders als hidden — bricht .ratgeber-/.rechner-sidebar nicht). */
  overflow-x: clip;
}
/* Offset für fixe Navigation bei Anker-Sprüngen */
section[id],
div[id] {
  scroll-margin-top: 80px;
}

:root {
  --green: #b7d900;
  --green-dark: #9fbf00;
  --schiefer: #1c2b36;
  --schiefer-light: #243847;
  --bernstein: #e8a838;
  --sand: #f4f1ea;
  --nacht: #0a0a0a;
  --charcoal: #2d2d2d;
  --muted: #9a9a9a;
  --white: #ffffff;
  --g300: #d1d5db;
  --g400: #9ca3af;
  --g500: #6b7280;
  --g200: #e5e7eb;
}

body {
  font-family: 'Inter', sans-serif;
  background: var(--schiefer);
  font-size: 16px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  /* Welle 1: zusammen mit html overflow-x:clip — klammert horizontalen
     Overflow auf Body-Ebene (verhindert, dass fixe nav/.mobile-bottom-bar
     über die Viewport-Breite hinauswachsen). clip ist sticky-sicher. */
  overflow-x: clip;
}
h1,
h2,
h3,
h4 {
  font-family: 'Barlow', Arial, sans-serif;
  font-weight: 800;
  line-height: 1.15;
}

img {
  max-width: 100%;
  height: auto;
}

/* ══ INLINE SVG ICON SYSTEM ══ */
.ico {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.ico svg {
  display: block;
}
.ico-sm svg {
  width: 16px;
  height: 16px;
}
.ico-md svg {
  width: 20px;
  height: 20px;
}
.ico-lg svg {
  width: 28px;
  height: 28px;
}
.ico-xl svg {
  width: 48px;
  height: 48px;
}

/* ══ NAVIGATION ══ */
nav {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1000;
  background: rgba(28, 43, 54, 0.97);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid rgba(255, 255, 255, 0.06);
  transition: all 0.3s;
}
nav.scrolled {
  background: rgba(10, 10, 10, 0.98);
  box-shadow: 0 2px 20px rgba(0, 0, 0, 0.3);
}
.nav-inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 24px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  height: 64px;
}
.nav-logo {
  height: 44px;
  width: auto;
}
.nav-links {
  display: flex;
  gap: 16px;
  align-items: center;
}
.nav-links a {
  color: var(--g300);
  text-decoration: none;
  font-size: 13px;
  font-weight: 500;
  transition: color 0.2s;
  white-space: nowrap;
}
.nav-links a:hover {
  color: var(--white);
}
.nav-cta {
  background: var(--green) !important;
  color: var(--nacht) !important;
  padding: 8px 20px !important;
  border-radius: 6px;
  font-weight: 700 !important;
  font-size: 13px !important;
  transition: background 0.2s !important;
  position: relative;
  overflow: hidden;
}
.nav-cta::after {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 50%;
  height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.35), transparent);
  animation: btnShimmer 2.5s ease-in-out infinite;
}
.nav-cta:hover {
  background: var(--green-dark) !important;
}
.nav-cta-call {
  color: var(--g300) !important;
  font-weight: 600 !important;
  font-size: 13px !important;
  display: inline-flex !important;
  align-items: center;
  gap: 6px;
  border: 1px solid rgba(255, 255, 255, 0.2);
  padding: 7px 16px !important;
  border-radius: 6px;
  transition:
    border-color 0.2s,
    color 0.2s;
}
.nav-cta-call:hover {
  border-color: var(--green);
  color: var(--white) !important;
}

.hamburger {
  display: none;
  cursor: pointer;
  padding: 8px;
}
.hamburger span {
  display: block;
  width: 22px;
  height: 2px;
  background: var(--white);
  margin: 5px 0;
  transition: 0.3s;
}
.mobile-menu {
  display: none;
}
.mobile-phone-cta {
  display: none;
}
.mobile-bottom-bar {
  display: none;
}

@media (max-width: 960px) {
  .nav-links {
    display: none;
  }
  .hamburger {
    display: block;
  }
  .mobile-phone-cta {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background: rgba(183, 217, 0, 0.15);
    color: var(--green);
    margin-right: 8px;
    text-decoration: none;
  }
  .mobile-menu.open {
    display: flex;
    flex-direction: column;
    position: fixed;
    top: 64px;
    left: 0;
    right: 0;
    background: var(--nacht);
    padding: 20px 24px;
    gap: 16px;
    border-bottom: 1px solid var(--charcoal);
    z-index: 999;
  }
  .mobile-menu a {
    color: var(--g300);
    text-decoration: none;
    font-size: 16px;
    padding: 8px 0;
  }
  /* Sticky Bottom Bar mit Anrufen + Beratung */
  .mobile-bottom-bar {
    display: flex;
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    z-index: 1000;
    background: rgba(10, 10, 10, 0.97);
    backdrop-filter: blur(12px);
    border-top: 1px solid rgba(183, 217, 0, 0.15);
    padding: 10px 16px;
    gap: 10px;
    padding-bottom: max(10px, env(safe-area-inset-bottom));
  }
  .mobile-bottom-bar a {
    flex: 1;
    /* Welle 1: Buttons dürfen schrumpfen statt zu überlaufen — sonst sprengt der
       Text die Leiste (~90 px Overflow) und schiebt die fixe Nav mit (Header-Clipping). */
    min-width: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 14px 12px;
    border-radius: 10px;
    text-decoration: none;
    font-weight: 700;
    font-size: 14px;
    font-family: 'Inter', sans-serif;
    min-height: 48px;
  }
  .mob-bar-call {
    background: transparent;
    border: 1.5px solid rgba(183, 217, 0, 0.4);
    color: var(--green);
  }
  .mob-bar-cta {
    background: var(--green);
    color: var(--nacht);
    position: relative;
    overflow: hidden;
  }
  .mob-bar-cta::after {
    content: '';
    position: absolute;
    top: 0;
    left: -100%;
    width: 50%;
    height: 100%;
    background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.35), transparent);
    animation: btnShimmer 2.5s ease-in-out infinite;
  }
  /* Platz für Bottom Bar — skaliert mit Notch-Sicherheitszone (statt fixem 76px) */
  body {
    padding-bottom: calc(74px + max(10px, env(safe-area-inset-bottom)));
  }
  /* Funnel-Seiten (Rechner) haben eigene Navigation → redundanten fixen Banner ausblenden */
  body.page-funnel .mobile-bottom-bar {
    display: none;
  }
  body.page-funnel {
    padding-bottom: 0;
  }
}

/* ══ HERO ══ */
.hero {
  background: var(--schiefer);
  display: flex;
  align-items: center;
  padding: 96px 24px 64px;
  position: relative;
  overflow: hidden;
}
.hero::before {
  content: '';
  position: absolute;
  inset: 0;
  /* Theme-bewusster Lesbarkeits-Schleier ueber dem Video: links (Textspalte)
     deckend in der Schiefer-/Hintergrundfarbe, nach rechts transparent.
     var(--schiefer) kippt pro Theme -> dunkel im Dark-, hell im Light-Mode. */
  background: linear-gradient(to right, var(--schiefer) 0%, transparent 58%);
  opacity: 0.8;
  z-index: 1;
  pointer-events: none;
}
.hero::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 80px;
  background: linear-gradient(transparent, var(--schiefer));
  pointer-events: none;
  z-index: 0;
}
/* Hero-Hintergrund-Video (Mockup): gedaempft hinter dem Inhalt.
   object-position 28% zieht den Bildfokus auf die Waermepumpe (oben im
   Hochformat-Clip), damit sie auch auf breiten Monitoren im Bild bleibt
   und nicht nur das Lavendelband zu sehen ist. */
.hero-bg-video {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: 50% 28%;
  z-index: 0;
  opacity: 0.45;
  pointer-events: none;
}
.hero-inner {
  max-width: 1100px;
  margin: 0 auto;
  width: 100%;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 60px;
  align-items: center;
  position: relative;
  z-index: 1;
}
.hero-badge,
.section-tag {
  display: inline-flex;
  align-items: center;
  background: rgba(183, 217, 0, 0.1);
  border: 1px solid rgba(183, 217, 0, 0.3);
  padding: 6px 14px;
  border-radius: 20px;
}
.hero-badge {
  gap: 6px;
  font-size: 13px;
  color: var(--green);
  font-weight: 600;
  margin-bottom: 20px;
}
.hero h1 {
  font-size: clamp(36px, 5vw, 56px);
  color: var(--white);
  margin-bottom: 8px;
}
.hero h1 .accent {
  color: var(--green);
}
.hero-sub {
  font-size: 18px;
  color: var(--g300);
  margin-bottom: 28px;
  max-width: 480px;
}
.hero-ctas {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  margin-bottom: 32px;
}
.hero-ctas .btn-primary,
.hero-ctas .btn-ghost {
  flex: 1 1 200px;
  box-sizing: border-box;
  min-height: 52px;
  padding: 14px 28px;
  font-size: 16px;
}
.hero-ctas .btn-primary {
  border: 1px solid transparent;
}
/* Lade-Animation Rechner (foerderSatzKfw / frZuschuss): pulsierende Punkte statt statischem "..." */
.calc-dots {
  display: inline-flex;
  gap: 0.28em;
  align-items: center;
  justify-content: center;
  line-height: 1;
}
.calc-dots i {
  width: 0.2em;
  height: 0.2em;
  min-width: 7px;
  min-height: 7px;
  border-radius: 50%;
  background: currentColor;
  opacity: 0.3;
  animation: calcDots 1s infinite ease-in-out;
}
.calc-dots i:nth-child(2) {
  animation-delay: 0.18s;
}
.calc-dots i:nth-child(3) {
  animation-delay: 0.36s;
}
@keyframes calcDots {
  0%,
  100% {
    opacity: 0.25;
    transform: translateY(0);
  }
  40% {
    opacity: 1;
    transform: translateY(-0.22em);
  }
}
@keyframes btnShimmer {
  0% {
    left: -100%;
    opacity: 0;
  }
  10% {
    opacity: 1;
  }
  35% {
    left: 150%;
    opacity: 1;
  }
  36%,
  100% {
    left: 150%;
    opacity: 0;
  }
}
.btn-primary {
  background: var(--green);
  color: var(--nacht);
  padding: 14px 32px;
  border-radius: 8px;
  font-family: 'Barlow', sans-serif;
  font-weight: 700;
  font-size: 16px;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  transition: all 0.2s;
  border: none;
  cursor: pointer;
  position: relative;
  overflow: hidden;
}
.btn-primary::after {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 50%;
  height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.35), transparent);
  animation: btnShimmer 2.5s ease-in-out infinite;
}
.btn-primary:hover {
  background: var(--green-dark);
  transform: translateY(-1px);
  box-shadow: 0 4px 16px rgba(183, 217, 0, 0.3);
}
.btn-ghost {
  border: 1px solid var(--g400);
  color: var(--g300);
  padding: 13px 28px;
  border-radius: 8px;
  font-size: 15px;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  transition: all 0.2s;
  background: transparent;
  cursor: pointer;
}
.btn-ghost:hover {
  border-color: var(--white);
  color: var(--white);
}
.hero-trust {
  display: flex;
  gap: 24px;
  flex-wrap: wrap;
}
.trust-item {
  display: flex;
  align-items: center;
  gap: 6px;
  color: var(--g400);
  font-size: 13px;
}
.trust-item .check {
  color: var(--green);
  font-weight: 700;
}

/* ══ HERO CALCULATOR BOX ══ */
.hero-calc {
  background: var(--schiefer);
  border: 1px solid rgba(183, 217, 0, 0.15);
  border-radius: 16px;
  padding: 0;
  overflow: hidden;
  transition: all 0.3s ease;
  position: relative;
  z-index: 2;
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.3);
}
.hero-calc:hover {
  border-color: rgba(183, 217, 0, 0.22);
  box-shadow: 0 0 30px 8px rgba(183, 217, 0, 0.06);
}
.hc-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 18px 24px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.04);
}
.hc-row:last-child {
  border-bottom: none;
}
.hc-label {
  font-family: 'Barlow', sans-serif;
  font-weight: 700;
  font-size: 15px;
  color: var(--white);
}
.hc-label-sub {
  color: var(--g400);
  font-size: 12px;
  margin-top: 2px;
}
.hc-value {
  font-family: 'Barlow', sans-serif;
  font-weight: 800;
  font-size: 22px;
  color: var(--white);
  text-align: right;
  flex-shrink: 0;
}
.hc-value.discount {
  color: var(--green);
}
.hc-value .unit {
  font-size: 14px;
  font-weight: 700;
  color: var(--g300);
}
/* Eigenanteil-Highlight */
.hc-result {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 20px 24px;
  background: rgba(183, 217, 0, 0.08);
  border-top: 1px solid rgba(183, 217, 0, 0.2);
}
.hc-result-label {
  font-family: 'Barlow', sans-serif;
  font-weight: 700;
  font-size: 16px;
  color: var(--white);
}
.hc-result-value {
  font-family: 'Barlow', sans-serif;
  font-weight: 800;
  font-size: 26px;
  color: var(--green);
}
.hc-result-value .unit {
  font-size: 15px;
  font-weight: 600;
}
/* Fördervorschuss-Highlight (Conversion-Treiber) */
.hc-fv-highlight {
  padding: 16px 24px;
  background: linear-gradient(135deg, rgba(232, 168, 56, 0.15), rgba(232, 168, 56, 0.06));
  border-top: 2px solid var(--bernstein);
}
.hc-fv-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: var(--bernstein);
  font-family: 'Barlow', sans-serif;
  font-weight: 700;
  font-size: 13px;
  letter-spacing: 0.5px;
  text-transform: uppercase;
  margin-bottom: 6px;
}
.hc-fv-badge svg {
  flex-shrink: 0;
  color: var(--bernstein);
}
.hc-fv-text {
  font-size: 15px;
  color: var(--g300);
  line-height: 1.5;
}
.hc-fv-text strong {
  color: var(--white);
  font-weight: 700;
  font-size: 16px;
}
/* Fußnote */
.hc-footnote {
  padding: 12px 24px 16px;
  font-size: 12px;
  color: var(--g500);
  line-height: 1.5;
}
/* Trust-Badges — siehe oben bei .hero-trust */

/* Tablet: Calculator unter den Text, aber noch sichtbar */
@media (max-width: 960px) {
  .hero-inner {
    grid-template-columns: 1fr;
    gap: 32px;
  }
  .hero-calc {
    max-width: 520px;
  }
}
@media (max-width: 768px) {
  .hero {
    padding: 88px 20px 48px;
  }
  .hero::before {
    /* Mobil steht der Text oben -> Schleier von oben statt von links. */
    background: linear-gradient(to bottom, var(--schiefer) 0%, transparent 72%);
    opacity: 0.82;
  }
  .hero h1 {
    font-size: 32px;
  }
  .hero-sub {
    font-size: 16px;
    margin-bottom: 20px;
  }
  .hero-ctas {
    margin-bottom: 20px;
  }
  .hero-trust {
    gap: 12px;
  }
  .trust-item {
    font-size: 12px;
  }
  /* Calculator kompakt auf Mobile */
  .hero-calc {
    border-radius: 12px;
    max-width: 100%;
  }
  .hc-row {
    padding: 14px 18px;
  }
  .hc-label {
    font-size: 13px;
  }
  .hc-label-sub {
    font-size: 12px;
  }
  .hc-value {
    font-size: 18px;
  }
  .hc-value .unit {
    font-size: 12px;
  }
  .hc-result {
    padding: 16px 18px;
  }
  .hc-result-label {
    font-size: 14px;
  }
  .hc-result-value {
    font-size: 22px;
  }
  .hc-fv-hint {
    padding: 12px 18px;
    font-size: 12px;
  }
  .hc-footnote {
    padding: 10px 18px 14px;
    font-size: 12px;
  }
}

/* ══ USP STRIP (Glow-Box-Design) ══ */
.usp-strip {
  background: var(--nacht);
  padding: 28px 24px;
  border-top: 1px solid rgba(255, 255, 255, 0.04);
  border-bottom: 1px solid rgba(255, 255, 255, 0.04);
}
.usp-strip-inner {
  max-width: 1100px;
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 12px 16px;
}
.usp-item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 0;
  background: none;
  border: none;
  border-radius: 0;
  flex: 0 1 auto;
}
.usp-item:hover {
  background: none;
  box-shadow: none;
}
.usp-icon {
  width: 40px;
  height: 40px;
  border-radius: 10px;
  background: rgba(183, 217, 0, 0.1);
  color: var(--green);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.usp-icon svg {
  width: 20px;
  height: 20px;
}
.usp-text h2 {
  font-family: 'Inter', sans-serif;
  font-size: 13px;
  font-weight: 600;
  color: var(--g300);
  line-height: 1.3;
  margin-bottom: 0;
}
.usp-text p {
  display: none;
}
@media (max-width: 900px) {
  .usp-strip-inner {
    justify-content: center;
    gap: 12px 28px;
  }
}
@media (max-width: 600px) {
  .usp-strip {
    padding: 16px 20px;
  }
  .usp-strip-inner {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px 16px;
    justify-content: unset;
  }
  .usp-item {
    gap: 10px;
  }
  .usp-icon {
    width: 32px;
    height: 32px;
    border-radius: 8px;
  }
  .usp-icon svg {
    width: 16px;
    height: 16px;
  }
  .usp-text h2 {
    font-size: 12px;
  }
  /* 5. Item (ungerade) zentriert → volle Breite */
  .usp-item:last-child {
    grid-column: 1 / -1;
    justify-self: center;
  }
}

/* ══ REFERENZEN ══ */
.referenzen {
  background: var(--schiefer);
}
.referenzen .section-title {
  color: var(--white);
}
.referenzen .section-lead {
  color: var(--g400);
}
.ref-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
.ref-card {
  background: rgba(255, 255, 255, 0.03);
  border-radius: 12px;
  padding: 28px;
  border: 1px solid rgba(183, 217, 0, 0.08);
  transition:
    transform 0.2s,
    box-shadow 0.2s;
}
.ref-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 8px 24px rgba(183, 217, 0, 0.06);
  border-color: rgba(183, 217, 0, 0.18);
}
.ref-stars {
  color: var(--bernstein);
  font-size: 16px;
  letter-spacing: 2px;
  margin-bottom: 12px;
}
.ref-text {
  font-size: 14px;
  color: var(--g400);
  line-height: 1.6;
  margin-bottom: 16px;
  font-style: italic;
}
.ref-author {
  font-weight: 700;
  color: var(--white);
  font-size: 14px;
}
.ref-meta {
  font-size: 12px;
  color: var(--g400);
  margin-top: 2px;
}
.ref-wp {
  display: inline-block;
  margin-top: 8px;
  font-size: 12px;
  font-weight: 600;
  color: var(--green);
  background: rgba(183, 217, 0, 0.1);
  padding: 3px 10px;
  border-radius: 20px;
}
@media (max-width: 768px) {
  .ref-grid {
    grid-template-columns: 1fr;
  }
}

/* ══ SECTIONS ══ */
section {
  padding: 100px 24px;
}
.section-inner {
  max-width: 1100px;
  margin: 0 auto;
}
.section-tag {
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--green);
  margin-bottom: 12px;
}
.section-title {
  font-size: clamp(28px, 4vw, 42px);
  margin-bottom: 16px;
}
.section-lead {
  font-size: 17px;
  color: var(--g500);
  max-width: 640px;
  margin-bottom: 48px;
}

/* ══ FÖRDERVORSCHUSS BANNER ══ */
/* ══ FÖRDERVORSCHUSS LEADMAGNET ══ */
.fv-banner {
  background: var(--schiefer);
  padding: 88px 24px 80px;
  position: relative;
  overflow: visible;
  border-top: 1px solid rgba(183, 217, 0, 0.08);
}
.fv-banner::before {
  content: '';
  position: absolute;
  top: -40%;
  right: -10%;
  width: 900px;
  height: 900px;
  background: radial-gradient(
    circle,
    rgba(183, 217, 0, 0.06) 0%,
    rgba(183, 217, 0, 0.02) 30%,
    transparent 55%
  );
  pointer-events: none;
}
.fv-inner {
  max-width: 1100px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 260px;
  gap: 48px;
  align-items: center;
}
.fv-tag {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  background: rgba(183, 217, 0, 0.15);
  color: var(--green);
  padding: 10px 22px;
  border-radius: 100px;
  font-family: 'Barlow', sans-serif;
  font-weight: 800;
  font-size: 15px;
  text-transform: uppercase;
  letter-spacing: 1px;
  margin-bottom: 24px;
  border: 1px solid rgba(183, 217, 0, 0.25);
}
.fv-tag::before {
  content: '';
  width: 8px;
  height: 8px;
  background: var(--green);
  border-radius: 50%;
  animation: fvTagPulse 2s ease-in-out infinite;
}
@keyframes fvTagPulse {
  0%,
  100% {
    opacity: 1;
    transform: scale(1);
  }
  50% {
    opacity: 0.4;
    transform: scale(0.7);
  }
}
.fv-content h2 {
  color: var(--white);
  font-size: clamp(28px, 4vw, 44px);
  margin-bottom: 8px;
  line-height: 1.15;
}
.fv-content h2 span {
  color: var(--green);
}
.fv-subtitle {
  color: var(--g300);
  font-size: clamp(16px, 2vw, 20px);
  line-height: 1.5;
  margin-bottom: 28px;
  max-width: 560px;
}
.fv-points {
  display: flex;
  gap: 24px;
  margin-bottom: 32px;
  flex-wrap: wrap;
}
.fv-point {
  display: flex;
  align-items: center;
  gap: 10px;
  color: var(--g300);
  font-size: 14px;
  font-weight: 500;
}
.fv-point-icon {
  width: 36px;
  height: 36px;
  border-radius: 8px;
  background: rgba(183, 217, 0, 0.1);
  color: var(--green);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 16px;
  flex-shrink: 0;
}
.fv-cta-row {
  display: flex;
  gap: 16px;
  align-items: center;
  flex-wrap: wrap;
}
.fv-cta-row .btn-primary {
  font-size: 17px;
  padding: 16px 36px;
}
.fv-trust {
  color: var(--g400);
  font-size: 13px;
  font-weight: 500;
}

/* Badge / Kontingent */
.fv-badge-box {
  background: linear-gradient(135deg, rgba(232, 168, 56, 0.15), rgba(232, 168, 56, 0.05));
  border: 1px solid rgba(232, 168, 56, 0.25);
  border-radius: 16px;
  padding: 32px 28px;
  text-align: center;
  position: relative;
  animation: fvBadgeGlow 3s ease-in-out infinite;
}
@keyframes fvBadgeGlow {
  0%,
  100% {
    box-shadow: 0 0 0 0 rgba(232, 168, 56, 0);
  }
  50% {
    box-shadow: 0 0 40px 8px rgba(232, 168, 56, 0.12);
  }
}
.fv-badge-box .fv-count {
  font-family: 'Barlow', sans-serif;
  font-weight: 800;
  font-size: 72px;
  color: var(--bernstein);
  line-height: 1;
}
.fv-badge-box .fv-label {
  color: var(--white);
  font-family: 'Barlow', sans-serif;
  font-weight: 700;
  font-size: 15px;
  margin-top: 8px;
  letter-spacing: 0.3px;
}
.fv-badge-box .fv-sublabel {
  color: var(--g400);
  font-size: 12px;
  margin-top: 8px;
}
.fv-badge-divider {
  width: 40px;
  height: 2px;
  background: var(--bernstein);
  margin: 12px auto;
  opacity: 0.4;
}
.fv-badge-note {
  color: var(--g400);
  font-size: 12px;
  line-height: 1.4;
  margin-top: 12px;
}
/* FV Slot-Anzeige (Scarcity) */
.fv-slots {
  display: flex;
  gap: 6px;
  justify-content: center;
  margin-top: 16px;
}
.fv-slot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: rgba(232, 168, 56, 0.15);
  border: 1px solid rgba(232, 168, 56, 0.3);
  transition: all 0.3s;
}
.fv-slot.taken {
  background: var(--bernstein);
  border-color: var(--bernstein);
  box-shadow: 0 0 6px rgba(232, 168, 56, 0.4);
}
.fv-slot-label {
  color: var(--g400);
  font-size: 12px;
  margin-top: 10px;
  text-align: center;
}
.fv-slot-label strong {
  color: var(--bernstein);
  font-weight: 700;
}
.btn-dark {
  background: var(--nacht);
  color: var(--bernstein);
  padding: 14px 32px;
  border-radius: 8px;
  font-family: 'Barlow', sans-serif;
  font-weight: 700;
  font-size: 16px;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  transition: all 0.2s;
  border: none;
  cursor: pointer;
}
.btn-dark:hover {
  background: var(--charcoal);
}
@media (max-width: 960px) {
  .fv-inner {
    grid-template-columns: 1fr;
    gap: 36px;
  }
  .fv-badge-box {
    max-width: 240px;
    margin: 0 auto;
  }
}
@media (max-width: 768px) {
  .fv-banner {
    padding: 56px 20px;
  }
  .fv-badge-box {
    order: -1;
    max-width: 220px;
  }
  .fv-points {
    gap: 16px;
  }
  .fv-cta-row .btn-primary {
    width: 100%;
    justify-content: center;
  }
}

/* ══ PROZESS ══ */
.prozess {
  background: var(--schiefer);
}
.prozess .section-title {
  color: var(--white);
}

/* Kunden-Schritte: 4er-Grid mit Verbindungslinie */
.pz-steps {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  position: relative;
  margin-bottom: 48px;
}
.pz-steps::before {
  content: '';
  position: absolute;
  top: 36px;
  left: 10%;
  right: 10%;
  height: 3px;
  background: linear-gradient(90deg, var(--green), rgba(183, 217, 0, 0.2));
  z-index: 0;
}
.pz-step {
  text-align: center;
  position: relative;
  z-index: 1;
  padding: 0 12px;
}
.pz-step-num {
  width: 72px;
  height: 72px;
  border-radius: 50%;
  margin: 0 auto 16px;
  background: var(--green);
  color: var(--nacht);
  font-family: 'Barlow', sans-serif;
  font-weight: 800;
  font-size: 28px;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 4px 16px rgba(183, 217, 0, 0.25);
  transition:
    transform 0.3s ease,
    box-shadow 0.3s ease;
}
.pz-step:hover .pz-step-num {
  transform: scale(1.1);
  box-shadow: 0 6px 24px rgba(183, 217, 0, 0.35);
}
.pz-step h3 {
  color: var(--white);
  font-size: 17px;
  margin: 0 0 6px;
}
.pz-step p {
  color: var(--g400);
  font-size: 14px;
  line-height: 1.5;
}
.pz-step .pz-time {
  display: inline-block;
  color: var(--green);
  font-size: 12px;
  font-weight: 700;
  margin-top: 8px;
  letter-spacing: 0.5px;
}

/* Expandable Sub-Steps */
.pz-step {
  cursor: pointer;
}
.pz-substeps {
  max-height: 0;
  overflow: hidden;
  opacity: 0;
  transition:
    max-height 0.4s cubic-bezier(0.4, 0, 0.2, 1),
    opacity 0.3s ease,
    margin 0.3s ease;
  margin-top: 0;
}
.pz-step.expanded .pz-substeps {
  max-height: 300px;
  opacity: 1;
  margin-top: 14px;
}
.pz-step:hover .pz-substeps,
.pz-step:focus-within .pz-substeps {
  max-height: 300px;
  opacity: 1;
  margin-top: 14px;
}
.pz-sub {
  display: flex;
  align-items: center;
  gap: 8px;
  color: var(--g300);
  font-size: 13px;
  line-height: 1.6;
  padding: 3px 0;
  text-align: left;
}
.pz-sub::before {
  content: '✓';
  color: var(--green);
  font-size: 12px;
  font-weight: 700;
  flex-shrink: 0;
}
.pz-expand-hint {
  display: inline-block;
  color: var(--g400);
  font-size: 12px;
  margin-top: 10px;
  transition: color 0.2s;
}
.pz-step:hover .pz-expand-hint {
  color: var(--green);
}
.pz-step.expanded .pz-expand-hint {
  color: var(--green);
}
.fvq-toggle-icon.open {
  transform: rotate(180deg);
}

@media (max-width: 768px) {
  .pz-steps {
    grid-template-columns: repeat(2, 1fr);
    gap: 32px;
  }
  .pz-steps::before {
    display: none;
  }
}
@media (max-width: 480px) {
  .pz-steps {
    grid-template-columns: 1fr;
  }
  .pz-images {
    grid-template-columns: 1fr !important;
  }
}

/* ══ WIZARD (Dimensionierungsrechner) ══ */
.wizard-section {
  background: var(--schiefer);
  position: relative;
  overflow: hidden;
}
.wizard-section::before {
  content: '';
  position: absolute;
  top: 0;
  right: 0;
  width: 400px;
  height: 400px;
  background: radial-gradient(circle, rgba(183, 217, 0, 0.06) 0%, transparent 70%);
  pointer-events: none;
}
.wizard-section .section-title {
  color: var(--white);
}
.wizard-section .section-lead {
  color: var(--g300);
}

.wizard-container {
  background: rgba(0, 0, 0, 0.3);
  border-radius: 16px;
  padding: 40px;
  border: 1px solid rgba(183, 217, 0, 0.15);
  position: relative;
  max-width: 760px;
  margin: 0 auto;
}
/* Beim Schritt-Wechsel die Kachel-Oberkante klar unter der fixen Nav anlegen (GF 22.06.).
   ID-Selektor, damit er die globale div[id]-Regel (80px) sicher überschreibt. */
#wizCard {
  scroll-margin-top: 96px;
}
.wizard-progress {
  display: flex;
  gap: 4px;
  margin-bottom: 32px;
}
.wizard-progress-bar {
  flex: 1;
  height: 4px;
  background: rgba(255, 255, 255, 0.1);
  border-radius: 2px;
  transition: background 0.3s;
}
.wizard-progress-bar.active {
  background: var(--green);
}
.wizard-progress-bar.done {
  background: var(--green);
  opacity: 0.5;
}

.wizard-step {
  display: none;
  animation: fadeIn 0.3s;
}
.wizard-step.active {
  display: flex;
  flex-direction: column;
}
@keyframes fadeIn {
  from {
    opacity: 0;
    transform: translateY(10px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* Desktop/Tablet: Mindesthöhe je Schritt, damit der Wizard zwischen Fragen nicht springt */
@media (min-width: 769px) {
  .wizard-step {
    min-height: 340px;
  }
}

.wizard-question {
  color: var(--white);
  font-size: 22px;
  font-weight: 700;
  margin-bottom: 8px;
}
.wizard-hint {
  color: var(--g400);
  font-size: 14px;
  margin-bottom: 24px;
}

.wizard-options {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.wizard-option {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 16px;
  background: var(--color-surface-secondary);
  border: 2px solid var(--color-border-subtle);
  border-radius: 14px;
  padding: 20px;
  cursor: pointer;
  transition:
    border-color 0.18s,
    background 0.18s,
    box-shadow 0.18s,
    transform 0.12s;
  text-align: left;
}

.wizard-option .opt-body {
  flex: 1;
  display: flex;
  flex-direction: column;
  min-width: 0;
}
#wzHeizung .opt-bonus {
  margin-top: 2px;
  padding-top: 0;
}
.wizard-option:hover {
  border-color: var(--green);
  transform: translateY(-2px);
  box-shadow: 0 8px 24px var(--color-shadow);
}
.wizard-option.selected {
  border-color: var(--green);
  background: rgba(183, 217, 0, 0.12);
  box-shadow: 0 0 0 3px rgba(183, 217, 0, 0.28);
}
.wizard-option .opt-icon {
  width: 56px;
  height: 56px;
  border-radius: 14px;
  background: var(--color-surface-tertiary);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  transition: background 0.2s;
}
.wizard-option .opt-icon svg {
  width: 32px;
  height: 32px;
  stroke: var(--color-text-secondary);
  stroke-width: 1.2;
  fill: none;
  transition: stroke 0.2s;
}
.wizard-option:hover .opt-icon,
.wizard-option.selected .opt-icon {
  background: rgba(183, 217, 0, 0.18);
}
.wizard-option:hover .opt-icon svg {
  stroke: var(--color-text-primary);
}
.wizard-option.selected .opt-icon svg {
  stroke: var(--color-text-primary);
}
.wizard-option .opt-title {
  color: var(--color-text-primary);
  font-family: 'Barlow', sans-serif;
  font-weight: 700;
  font-size: 16px;
  margin-bottom: 4px;
}
.wizard-option .opt-sub {
  color: var(--color-text-secondary);
  font-size: 13px;
}
.wizard-option .opt-check {
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: var(--green);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  opacity: 0;
  transition: opacity 0.15s;
}
.wizard-option .opt-check svg {
  width: 12px;
  height: 12px;
  color: var(--color-accent-primary-text);
  stroke: var(--color-accent-primary-text);
}
.wizard-option.selected .opt-check {
  opacity: 1;
}
#wzRhEnd,
#wzRhMitte {
  display: block;
  background: rgba(255, 255, 255, 0.05);
  border: 2px solid rgba(255, 255, 255, 0.12);
  border-radius: 10px;
  padding: 20px;
  text-align: center;
  box-shadow: none;
  transform: none;
}
#wzRhEnd:hover,
#wzRhMitte:hover {
  border-color: rgba(183, 217, 0, 0.4);
  background: rgba(183, 217, 0, 0.05);
  box-shadow: none;
  transform: none;
}
#wzRhEnd.selected,
#wzRhMitte.selected {
  border-color: var(--green);
  background: rgba(183, 217, 0, 0.1);
  box-shadow: none;
}
#wzRhEnd .opt-icon,
#wzRhMitte .opt-icon {
  width: auto;
  height: auto;
  margin-bottom: 10px;
  border-radius: 0;
  background: transparent;
  display: block;
}
#wzRhEnd .opt-icon svg,
#wzRhMitte .opt-icon svg {
  width: 44px;
  height: 44px;
  stroke: var(--g300);
}
#wzRhEnd:hover .opt-icon,
#wzRhMitte:hover .opt-icon,
#wzRhEnd.selected .opt-icon,
#wzRhMitte.selected .opt-icon {
  background: transparent;
}
#wzRhEnd:hover .opt-icon svg,
#wzRhMitte:hover .opt-icon svg,
#wzRhEnd.selected .opt-icon svg,
#wzRhMitte.selected .opt-icon svg {
  stroke: var(--green);
}

/* AE-D: Personenzahl als kompakte Auswahl-Karten (Step 8, Warmwasser = Ja).
   Gleiches .wizard-option-Muster wie #wzRhEnd, nur mehrspaltiges Zahlen-Raster.
   Festes 3-Spalten-Grid (kein auto-fit -> kein Ueberpacken bei voller Breite). */
.wz-person-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
}
.wizard-option.wz-person {
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 2px;
  padding: 16px 12px;
  text-align: center;
}
.wizard-option.wz-person .opt-title {
  font-size: 24px;
  margin-bottom: 0;
}
.wizard-option.wz-person .opt-sub {
  font-size: 12px;
}

.wizard-slider-group {
  max-width: 100%;
}
.wizard-slider-group label {
  display: flex;
  justify-content: space-between;
  color: var(--white);
  font-weight: 600;
  font-size: 15px;
  margin-bottom: 12px;
}
.wizard-slider-group label .ws-val {
  color: var(--green);
  font-weight: 800;
  font-size: 18px;
}
.wizard-slider-group input[type='range'] {
  -webkit-appearance: none;
  width: 100%;
  height: 6px;
  background: rgba(255, 255, 255, 0.15);
  border-radius: 3px;
  outline: none;
}
.wizard-slider-group input[type='range']::-webkit-slider-thumb {
  -webkit-appearance: none;
  width: 24px;
  height: 24px;
  background: var(--green);
  border-radius: 50%;
  cursor: pointer;
  border: 3px solid var(--schiefer);
}

.wizard-nav {
  /* Symmetrie (GF 22.06.): 1 Button = volle Breite, 2 = gleich geteilt. */
  display: grid;
  grid-template-columns: 1fr 1fr;
  align-items: stretch;
  gap: 12px;
  /* Buttons an den unteren Rand des Schritts verankern (Höhen-Ruhe), min. 24px Abstand */
  margin-top: auto;
  padding-top: 24px;
}
.wizard-nav:has(> :only-child) {
  grid-template-columns: 1fr;
}
.wizard-btn-back {
  display: flex;
  align-items: center;
  justify-content: center;
  background: transparent;
  border: 1px solid var(--g400);
  color: var(--g300);
  min-height: 54px;
  padding: 14px 28px;
  border-radius: 10px;
  font-size: 15px;
  font-weight: 700;
  cursor: pointer;
  transition: 0.2s;
}
.wizard-btn-back:hover {
  border-color: var(--white);
  color: var(--white);
  transform: translateY(-1px);
}
.wizard-btn-next {
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--green);
  color: var(--nacht);
  min-height: 54px;
  padding: 14px 32px;
  border-radius: 10px;
  font-family: 'Barlow', sans-serif;
  font-weight: 700;
  font-size: 16px;
  border: none;
  cursor: pointer;
  transition: 0.2s;
  /* etwas mehr Tiefe (GF 22.06.) */
  box-shadow: 0 4px 18px rgba(183, 217, 0, 0.3);
}
.wizard-btn-next:hover {
  background: var(--green-dark);
  transform: translateY(-1px);
  box-shadow: 0 6px 22px rgba(183, 217, 0, 0.42);
}

.wizard-result {
  display: none;
  text-align: center;
  padding: 20px 0;
}
.wizard-result.active {
  display: block;
  animation: fadeIn 0.4s;
}
.wizard-result-cards {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  margin: 32px 0;
}
.wr-card {
  background: rgba(0, 0, 0, 0.3);
  border-radius: 12px;
  padding: 24px;
  border: 1px solid rgba(255, 255, 255, 0.1);
}
.wr-card.recommended {
  border-color: var(--green);
  background: rgba(183, 217, 0, 0.08);
}
.wr-card .wr-badge {
  display: inline-block;
  background: var(--green);
  color: var(--nacht);
  padding: 4px 12px;
  border-radius: 4px;
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  margin-bottom: 12px;
}
.wr-card h4 {
  color: var(--white);
  font-size: 20px;
  margin-bottom: 4px;
}
.wr-card .wr-kw {
  color: var(--g400);
  font-size: 13px;
  margin-bottom: 16px;
}
.wr-card .wr-price {
  color: var(--green);
  font-family: 'Barlow', sans-serif;
  font-weight: 800;
  font-size: 28px;
}
.wr-card .wr-sub {
  color: var(--g400);
  font-size: 12px;
  margin-top: 4px;
}
.wr-card .wr-detail {
  color: var(--g300);
  font-size: 13px;
  margin-top: 16px;
  padding-top: 16px;
  border-top: 1px solid rgba(255, 255, 255, 0.1);
  text-align: left;
  line-height: 1.7;
}
@media (max-width: 768px) {
  .wizard-container {
    max-width: none;
    padding: 24px;
  }
}

@media (max-width: 768px) {
  .wizard-result-cards {
    grid-template-columns: 1fr;
  }
}

/* ══ FÖRDERRECHNER (eigenständige Sektion) ══ */
.foerder-section {
  background: var(--schiefer);
}
.foerder-section .section-title {
  color: var(--white);
}
.foerder-section .section-lead {
  color: var(--g300);
}
.foerder-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 480px), 1fr));
  gap: 40px;
  background: rgba(255, 255, 255, 0.03);
  border-radius: 16px;
  padding: 40px;
  border: 1px solid rgba(183, 217, 0, 0.1);
}
.foerder-grid > * {
  min-width: 0;
}
.foerder-inputs-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
}
.fi-group {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.fi-group label {
  color: var(--g300);
  font-weight: 600;
  font-size: 13px;
}
.fi-group select {
  width: 100%;
  min-width: 0;
  padding: 10px 12px;
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(255, 255, 255, 0.15);
  border-radius: 6px;
  color: var(--white);
  font-size: 14px;
}
.fi-group select:focus {
  outline: none;
  border-color: var(--green);
}

.foerder-result {
  background: rgba(183, 217, 0, 0.05);
  border: 1px solid rgba(183, 217, 0, 0.2);
  border-radius: 12px;
  padding: 28px;
  display: flex;
  flex-direction: column;
  align-self: stretch;
}
.foerder-result .fr-satz {
  font-family: 'Barlow', sans-serif;
  font-weight: 800;
  font-size: 64px;
  color: var(--green);
  line-height: 1;
}
.foerder-result .fr-label {
  color: var(--g400);
  font-size: 14px;
  margin-bottom: 20px;
}
.foerder-result .fr-row {
  display: flex;
  justify-content: space-between;
  padding: 8px 0;
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
  color: var(--g300);
  font-size: 14px;
}
.foerder-result .fr-row:last-of-type {
  border-bottom: none;
}
.foerder-result .fr-row .fr-val {
  color: var(--white);
  font-weight: 700;
}
.breakdown-item {
  display: flex;
  justify-content: space-between;
  color: var(--g300);
  font-size: 13px;
  padding: 4px 0;
}
.breakdown-item .pct {
  color: var(--green);
  font-weight: 700;
}
/* Segmented Control Toggle */
.seg-toggle {
  display: inline-flex;
  border-radius: 10px;
  border: 2px solid rgba(183, 217, 0, 0.35);
  background: rgba(0, 0, 0, 0.3);
  flex-shrink: 0;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.3);
}
.seg-toggle button {
  flex: 1;
  padding: 8px 10px;
  font-size: 13px;
  font-weight: 700;
  border: none;
  cursor: pointer;
  transition: all 0.2s;
  color: var(--g300);
  background: transparent;
  font-family: 'Inter', sans-serif;
  white-space: nowrap;
  text-align: center;
  border-radius: 8px;
  margin: 2px;
}
.seg-toggle button.active {
  background: rgba(183, 217, 0, 0.2);
  color: var(--green);
  box-shadow: 0 1px 4px rgba(183, 217, 0, 0.15);
}
.seg-toggle button:hover:not(.active) {
  color: var(--white);
  background: rgba(255, 255, 255, 0.05);
}

@media (max-width: 768px) {
  .foerder-grid {
    grid-template-columns: 1fr;
    padding: 20px;
    gap: 24px;
  }
  .foerder-inputs-grid {
    grid-template-columns: 1fr;
  }
  .fi-group label[style*='space-between'] {
    flex-wrap: wrap;
    gap: 8px;
  }
  /* Größere Touch-Targets für Selects auf Mobile */
  .fi-group select {
    padding: 14px 16px;
    font-size: 16px;
    border-radius: 10px;
    -webkit-appearance: none;
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%239A9A9A' stroke-width='2.5'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 14px center;
    padding-right: 40px;
    min-height: 48px;
  }
  .fi-group label {
    font-size: 14px;
    margin-bottom: 2px;
  }
  .foerder-result .fr-satz {
    font-size: 48px;
  }
}
@media (max-width: 480px) {
  .seg-toggle button {
    font-size: 13px;
    padding: 6px 12px;
  }
  .foerder-grid {
    padding: 14px;
  }
  .fi-group select {
    padding: 12px 14px;
    font-size: 16px;
  }
}

/* ══ AMORTISATIONS + HEIZKOSTENVERGLEICH ══ */
.compare-section {
  background: var(--schiefer);
  border-top: 1px solid rgba(255, 255, 255, 0.04);
}
.compare-section .section-title {
  color: var(--white);
}
.compare-section .section-lead {
  color: var(--g300);
}
.compare-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 40px;
}
.compare-card {
  background: rgba(255, 255, 255, 0.04);
  border-radius: 12px;
  padding: 32px;
  border: 1px solid rgba(183, 217, 0, 0.08);
}
.compare-card h3 {
  color: var(--white);
  font-size: 20px;
  margin-bottom: 20px;
}
.cc-input-group {
  margin-bottom: 16px;
}
.cc-input-group label {
  display: block;
  color: var(--g400);
  font-weight: 600;
  font-size: 13px;
  margin-bottom: 6px;
}
.cc-input-group select,
.cc-input-group input[type='number'] {
  width: 100%;
  padding: 10px 12px;
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 6px;
  font-size: 14px;
  color: var(--white);
  background: var(--charcoal);
}
.cc-input-group select:focus,
.cc-input-group input:focus {
  outline: none;
  border-color: var(--green);
}
.cc-input-group input[type='range'] {
  width: 100%;
  cursor: pointer;
}
.cc-result {
  background: rgba(0, 0, 0, 0.2);
  border-radius: 8px;
  padding: 20px;
  margin-top: 20px;
}
.cc-result-row {
  display: flex;
  justify-content: space-between;
  padding: 8px 0;
  font-size: 14px;
}
.cc-result-row .cc-label {
  color: var(--g400);
}
.cc-result-row .cc-val {
  color: var(--white);
  font-weight: 700;
}
.cc-highlight {
  background: rgba(183, 217, 0, 0.1);
  border: 1px solid rgba(183, 217, 0, 0.25);
  border-radius: 8px;
  padding: 16px;
  margin-top: 16px;
  text-align: center;
}
.cc-highlight .cc-hl-label {
  color: var(--green);
  font-weight: 700;
  font-size: 13px;
  text-transform: uppercase;
}
.cc-highlight .cc-hl-val {
  color: var(--green);
  font-size: 28px;
  font-weight: 800;
  margin-top: 4px;
}
.cc-bar-container {
  margin-top: 16px;
}
.cc-bar-row {
  margin-bottom: 12px;
}
.cc-bar-label {
  display: flex;
  justify-content: space-between;
  font-size: 13px;
  margin-bottom: 4px;
}
.cc-bar-label span:first-child {
  color: var(--g400);
}
.cc-bar-label span:last-child {
  color: var(--white);
  font-weight: 700;
}
.cc-bar {
  height: 8px;
  background: rgba(255, 255, 255, 0.08);
  border-radius: 4px;
  overflow: hidden;
}
.cc-bar-fill {
  height: 100%;
  border-radius: 4px;
  transition: width 0.4s;
}
.cc-bar-fill.alt {
  background: var(--bernstein);
}
.cc-bar-fill.wp {
  background: var(--green);
}

@media (max-width: 768px) {
  .compare-grid {
    grid-template-columns: 1fr;
  }
}

/* ══ QUICKSTART / SELF-SERVICE SECTION ══ */
.quickstart-section {
  background: var(--nacht);
}
.qs-intro {
  text-align: center;
  margin-bottom: 40px;
}
.qs-intro h3 {
  color: var(--white);
  font-size: 28px;
  margin-bottom: 12px;
  font-family: 'Barlow', sans-serif;
  font-weight: 800;
}
.qs-intro p {
  color: var(--g300);
  font-size: 16px;
  max-width: 600px;
  margin: 0 auto 24px;
}
.qs-reward {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  background: rgba(183, 217, 0, 0.08);
  border: 1px solid rgba(183, 217, 0, 0.2);
  border-radius: 10px;
  padding: 12px 20px;
}
.qs-reward span {
  color: var(--green);
  font-size: 14px;
  font-weight: 600;
}

/* Self-Service Form */
.qs-form {
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 16px;
  padding: 40px;
  max-width: 720px;
  margin: 0 auto;
}
.qs-form-steps {
  display: flex;
  gap: 4px;
  margin-bottom: 32px;
}
.qs-form-step-bar {
  flex: 1;
  height: 4px;
  background: rgba(255, 255, 255, 0.1);
  border-radius: 2px;
  transition: background 0.3s;
}
.qs-form-step-bar.active {
  background: var(--green);
}
.qs-form-step-bar.done {
  background: var(--green);
  opacity: 0.5;
}
.qs-form-panel {
  display: none;
  animation: fadeIn 0.3s;
}
.qs-form-panel.active {
  display: block;
}
.qs-form-label {
  color: var(--white);
  font-size: 18px;
  font-weight: 700;
  margin-bottom: 6px;
  font-family: 'Barlow', sans-serif;
}
.qs-form-hint {
  color: var(--g400);
  font-size: 14px;
  margin-bottom: 20px;
}
.qs-options {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: 10px;
  margin-bottom: 16px;
}
.qs-option {
  background: rgba(255, 255, 255, 0.05);
  border: 2px solid rgba(255, 255, 255, 0.1);
  border-radius: 10px;
  padding: 16px;
  cursor: pointer;
  transition: all 0.2s;
  text-align: center;
  color: var(--g300);
  font-size: 14px;
}
.qs-option:hover {
  border-color: rgba(183, 217, 0, 0.4);
  background: rgba(183, 217, 0, 0.05);
}
.qs-option.selected {
  border-color: var(--green);
  background: rgba(183, 217, 0, 0.1);
  color: var(--white);
}
.qs-option .qs-opt-icon {
  font-size: 24px;
  margin-bottom: 6px;
}
.qs-input {
  width: 100%;
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 8px;
  padding: 14px 16px;
  color: var(--white);
  font-size: 15px;
  font-family: 'Inter', sans-serif;
  margin-bottom: 12px;
  outline: none;
  transition: border-color 0.2s;
}
.qs-input:focus {
  border-color: var(--green);
}
.qs-input::placeholder {
  color: var(--g500);
}
.qs-input-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}
.qs-upload-area {
  border: 2px dashed rgba(255, 255, 255, 0.12);
  border-radius: 12px;
  padding: 32px;
  text-align: center;
  cursor: pointer;
  transition: all 0.2s;
}
.qs-upload-area:hover {
  border-color: rgba(183, 217, 0, 0.4);
  background: rgba(183, 217, 0, 0.03);
}
.qs-upload-area svg {
  margin-bottom: 8px;
}
.qs-upload-area p {
  color: var(--g300);
  font-size: 14px;
  margin: 0;
}
.qs-upload-area .qs-upload-small {
  color: var(--g500);
  font-size: 12px;
  margin-top: 6px;
}
.qs-upload-examples {
  display: flex;
  gap: 12px;
  margin-top: 16px;
  flex-wrap: wrap;
}
.qs-upload-ex {
  display: flex;
  align-items: center;
  gap: 6px;
  color: var(--g400);
  font-size: 12px;
}
.qs-upload-ex::before {
  content: '📷';
  font-size: 14px;
}
.qs-nav {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: 24px;
}
.qs-nav-back {
  color: var(--g400);
  font-size: 14px;
  cursor: pointer;
  background: none;
  border: none;
  font-family: 'Inter', sans-serif;
  transition: color 0.2s;
}
.qs-nav-back:hover {
  color: var(--white);
}
.qs-nav-next {
  background: var(--green);
  color: var(--nacht);
  border: none;
  border-radius: 8px;
  padding: 14px 28px;
  font-weight: 700;
  font-size: 15px;
  cursor: pointer;
  font-family: 'Inter', sans-serif;
  transition: all 0.2s;
}
.qs-nav-next:hover {
  filter: brightness(1.1);
  transform: translateY(-1px);
}
.qs-success {
  text-align: center;
  padding: 40px 20px;
  display: none;
}
.qs-success.active {
  display: block;
}
.qs-success-icon {
  font-size: 48px;
  margin-bottom: 16px;
}
.qs-success h3 {
  color: var(--white);
  font-size: 24px;
  margin-bottom: 12px;
  font-family: 'Barlow', sans-serif;
  font-weight: 800;
}
.qs-success p {
  color: var(--g300);
  font-size: 16px;
}
@media (max-width: 768px) {
  .qs-form {
    padding: 24px;
  }
  .qs-input-row {
    grid-template-columns: 1fr;
  }
  .qs-options {
    grid-template-columns: repeat(2, 1fr);
  }
}

/* ══ PREISANKER TEASER — Zoom-Karten + Detail-Panel ══ */
.preisanker-section {
  background: var(--schiefer);
  border-top: 1px solid rgba(255, 255, 255, 0.04);
}

.manufacturer-tabs {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
  margin: 0 0 22px;
}
.manufacturer-tab {
  text-align: left;
  border: 2px solid rgba(255, 255, 255, 0.08);
  border-radius: 14px;
  padding: 20px;
  background: rgba(255, 255, 255, 0.04);
  cursor: pointer;
  transition:
    transform 0.2s ease,
    border-color 0.2s ease,
    box-shadow 0.2s ease,
    background 0.2s ease;
  font-family: 'Inter', sans-serif;
}
.manufacturer-tab:hover,
.manufacturer-tab:focus-visible {
  transform: translateY(-2px);
  border-color: rgba(183, 217, 0, 0.6);
  box-shadow: 0 8px 24px rgba(183, 217, 0, 0.14);
  outline: none;
}
.manufacturer-tab.active {
  border-color: var(--green);
  background: linear-gradient(135deg, rgba(183, 217, 0, 0.12), rgba(255, 255, 255, 0.05));
}
.manufacturer-name {
  display: block;
  color: var(--white);
  font-family: 'Barlow', sans-serif;
  font-weight: 800;
  font-size: 20px;
  margin-bottom: 6px;
}
.manufacturer-price {
  display: block;
  color: var(--green);
  font-size: 14px;
  font-weight: 700;
}
.vaillant-panel {
  margin-bottom: 16px;
}
.vaillant-panel-inner {
  background: rgba(255, 255, 255, 0.04);
  border: 2px solid rgba(255, 255, 255, 0.08);
  border-radius: 16px;
  padding: 28px;
}
.vaillant-panel h3 {
  color: var(--white);
  font-size: 24px;
  margin-bottom: 10px;
}
.vaillant-panel p {
  color: var(--g300);
  max-width: 760px;
  margin-bottom: 20px;
}
[data-theme='light'] .manufacturer-tab,
[data-theme='light'] .vaillant-panel-inner {
  background: var(--color-surface-secondary);
  border-color: var(--color-border-subtle);
  box-shadow: 0 8px 28px var(--color-shadow);
}
[data-theme='light'] .manufacturer-tab.active {
  border-color: var(--green);
  background: linear-gradient(135deg, rgba(183, 217, 0, 0.24), var(--color-surface-secondary));
}
[data-theme='light'] .manufacturer-name,
[data-theme='light'] .vaillant-panel h3 {
  color: var(--color-text-primary);
}
[data-theme='light'] .vaillant-panel p {
  color: var(--color-text-secondary);
}
@media (max-width: 640px) {
  .manufacturer-tabs {
    grid-template-columns: 1fr;
  }
}

/* Karten-Reihe */
.pa-cards {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 12px;
  margin-bottom: 0;
  transition: margin-bottom 0.4s ease;
}
.pa-cards.has-selection {
  margin-bottom: 16px;
}

/* Scroll-Reveal */
@keyframes paCardReveal {
  from {
    opacity: 0;
    transform: translateY(24px) scale(0.92);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

/* Karte */
.pa-card {
  background: rgba(255, 255, 255, 0.04);
  border-radius: 14px;
  padding: 22px 14px;
  text-align: center;
  border: 2px solid rgba(255, 255, 255, 0.08);
  cursor: pointer;
  transition:
    transform 0.4s cubic-bezier(0.34, 1.56, 0.64, 1),
    border-color 0.3s,
    box-shadow 0.4s,
    opacity 0.3s,
    filter 0.3s;
  opacity: 0;
  transform: translateY(24px) scale(0.92);
  will-change: transform, opacity;
}
.pa-card.pa-visible {
  animation: paCardReveal 0.5s ease forwards;
}
.pa-card.pa-visible:nth-child(1) {
  animation-delay: 0.05s;
}
.pa-card.pa-visible:nth-child(2) {
  animation-delay: 0.12s;
}
.pa-card.pa-visible:nth-child(3) {
  animation-delay: 0.19s;
}
.pa-card.pa-visible:nth-child(4) {
  animation-delay: 0.26s;
}
.pa-card.pa-visible:nth-child(5) {
  animation-delay: 0.33s;
}

.pa-card h2,
.pa-card h3 {
  color: var(--white);
  font-size: 16px;
  margin: 0 0 2px;
}
.pa-card .pa-modell {
  color: var(--green);
  font-size: 12px;
  font-weight: 700;
}
.pa-card .pa-kw {
  color: var(--g300);
  font-size: 12px;
  margin: 4px 0 8px;
}
.pa-card .pa-price-compact {
  font-family: 'Barlow', sans-serif;
  font-weight: 800;
  font-size: 22px;
  color: var(--green);
}
.pa-card .pa-label {
  color: var(--g400);
  font-size: 12px;
  margin-top: 2px;
}

/* Default-Highlight (vor Auswahl) */
.pa-card.pa-default-highlight {
  border-color: rgba(183, 217, 0, 0.5);
  background: linear-gradient(135deg, rgba(183, 217, 0, 0.08), rgba(255, 255, 255, 0.03));
  box-shadow: 0 4px 16px rgba(183, 217, 0, 0.12);
  transform: scale(1.03) translateY(-2px);
}
.pa-card.pa-default-highlight .pa-price-compact {
  font-size: 26px;
}

/* Preisanker Header — Titel + CTA nebeneinander auf Desktop */
.pa-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  margin-bottom: 28px;
  flex-wrap: wrap;
}
.pa-header-left {
  flex: 1;
  min-width: 280px;
}
.pa-header-cta {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  gap: 14px;
  background: var(--green);
  border: none;
  border-radius: 12px;
  padding: 16px 28px;
  text-decoration: none;
  transition: all 0.2s;
  white-space: nowrap;
  box-shadow: 0 4px 16px rgba(183, 217, 0, 0.25);
}
.pa-header-cta:hover {
  filter: brightness(1.1);
  transform: translateY(-2px);
  box-shadow: 0 6px 24px rgba(183, 217, 0, 0.35);
}
.pa-header-cta .pa-cta-icon {
  color: var(--nacht);
  flex-shrink: 0;
}
.pa-header-cta .pa-cta-icon svg {
  stroke: var(--nacht);
}
.pa-header-cta .pa-cta-text {
  font-size: 15px;
  font-weight: 700;
  color: var(--nacht);
  font-family: 'Barlow', sans-serif;
}
.pa-header-cta .pa-cta-sub {
  font-size: 12px;
  color: rgba(10, 10, 10, 0.7);
  font-weight: 500;
  font-family: 'Inter', sans-serif;
}
.pa-header-cta svg:last-child {
  stroke: var(--nacht);
}

/* Hover: leichter Zoom */
.pa-card:hover {
  transform: scale(1.06) translateY(-4px);
  border-color: var(--green);
  box-shadow: 0 8px 24px rgba(183, 217, 0, 0.15);
}

/* Aktiv: voll rein-gezoomt */
.pa-card.zoomed {
  transform: scale(1.1) translateY(-6px);
  border-color: var(--green);
  box-shadow: 0 12px 36px rgba(183, 217, 0, 0.25);
  background: linear-gradient(135deg, rgba(183, 217, 0, 0.12), rgba(255, 255, 255, 0.06));
  z-index: 2;
  position: relative;
}

/* Andere: raus-gezoomt, leicht unscharf */
.pa-card.dimmed {
  transform: scale(0.88);
  opacity: 0.45;
  filter: blur(1px);
}
.pa-card.dimmed:hover {
  transform: scale(0.95);
  opacity: 0.7;
  filter: blur(0);
}

/* ── Detail-Panel (unterhalb der Karten) ── */
.pa-detail {
  max-height: 0;
  overflow: hidden;
  opacity: 0;
  transition:
    max-height 0.5s cubic-bezier(0.4, 0, 0.2, 1),
    opacity 0.4s ease,
    margin 0.4s ease;
  margin-top: 0;
}
.pa-detail.open {
  max-height: 1600px;
  opacity: 1;
  margin-top: 16px;
}
.pa-detail-inner {
  background: var(--schiefer);
  border-radius: 16px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: 1fr auto;
  gap: 0;
  padding: 0;
  overflow: hidden;
}
.pa-detail-left {
  display: flex;
  flex-direction: column;
  gap: 0;
  position: relative;
  grid-column: 1;
  grid-row: 1;
}
/* Pfeil zum aktiven Card */
.pa-detail-arrow {
  position: absolute;
  top: -10px;
  width: 20px;
  height: 20px;
  background: var(--schiefer);
  transform: rotate(45deg);
  transition: left 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}
.pa-detail {
  position: relative;
}

/* Links: Bild — full bleed, fluchtet mit Karten-Außenkante */
.pa-detail-img {
  position: relative;
  overflow: hidden;
  height: 340px;
}
.pa-detail-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center center;
  transition: transform 0.4s ease;
  mask-image:
    linear-gradient(to bottom, black 70%, transparent 100%),
    linear-gradient(to right, black 75%, transparent 100%);
  mask-composite: intersect;
  -webkit-mask-image:
    linear-gradient(to bottom, black 70%, transparent 100%),
    linear-gradient(to right, black 75%, transparent 100%);
  -webkit-mask-composite: source-in;
}
.pa-detail.open .pa-detail-img img {
  animation: paImgZoom 0.5s ease 0.2s forwards;
  transform: scale(0.95);
  opacity: 0;
}
@keyframes paImgZoom {
  from {
    transform: scale(0.95);
    opacity: 0;
  }
  to {
    transform: scale(1);
    opacity: 1;
  }
}

/* Rechts: Specs-Tabelle — rechts bündig mit Panel-Außenkante */
.pa-detail-right {
  padding: 20px 0 12px 20px;
  display: flex;
  flex-direction: column;
  grid-column: 2;
  grid-row: 1;
}
.pa-specs {
  width: 100%;
  font-size: 12px;
  border-collapse: collapse;
}
.pa-specs td {
  padding: 3px 0;
  border-bottom: 1px solid rgba(255, 255, 255, 0.06);
}
.pa-specs td:first-child {
  color: var(--g400);
  white-space: nowrap;
  font-size: 12px;
}
.pa-specs td:last-child {
  color: var(--white);
  font-weight: 600;
  text-align: right;
}
.pa-specs-title {
  color: var(--white);
  font-size: 17px;
  font-weight: 700;
  margin: 0 0 2px;
  font-family: 'Barlow', sans-serif;
}
.pa-specs-sub {
  color: var(--green);
  font-size: 12px;
  font-weight: 600;
  margin-bottom: 10px;
}

/* CTAs in Grid-Zeile 2 — gleiche Höhe, bündig mit Spalten-Außenkanten */
.pa-bottom-cta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 20px;
  min-height: 64px;
  border-radius: 0;
  text-decoration: none;
  transition: all 0.2s ease;
  box-sizing: border-box;
  align-self: end;
}
.pa-bottom-cta--beratung {
  background: var(--green);
  color: var(--nacht);
  position: relative;
  overflow: hidden;
  grid-column: 1;
  grid-row: 2;
  margin: 0;
}
.pa-bottom-cta--beratung::after {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 50%;
  height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.35), transparent);
  animation: btnShimmer 2.5s ease-in-out infinite;
}
.pa-bottom-cta--wizard {
  background: var(--green);
  color: var(--nacht);
  grid-column: 2;
  grid-row: 2;
  margin: 0;
  position: relative;
  overflow: hidden;
}
.pa-bottom-cta--wizard::after {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 50%;
  height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.35), transparent);
  animation: btnShimmer 2.5s ease-in-out infinite;
  animation-delay: 1.25s;
}
.pa-bottom-cta:hover {
  background: var(--green-dark);
  transform: translateY(-1px);
  box-shadow: 0 4px 16px rgba(183, 217, 0, 0.3);
}

/* Links unterm Bild: Preis + Info — linksbündig mit Bild (kein Padding links) */
.pa-detail-cta {
  display: flex;
  flex-direction: column;
  gap: 8px;
  text-align: left;
  padding: 8px 0 12px 0;
}
.pa-detail-cta .pa-big-price {
  font-family: 'Barlow', sans-serif;
  font-weight: 800;
  font-size: 34px;
  color: var(--green);
  line-height: 1.1;
}
.pa-detail-cta .pa-price-sub {
  color: var(--g400);
  font-size: 12px;
}
.pa-detail-cta .pa-proklima-badge {
  background: rgba(232, 168, 56, 0.12);
  color: var(--bernstein);
  font-size: 13px;
  font-weight: 600;
  padding: 8px 12px;
  border-radius: 8px;
}
.pa-detail-cta .pa-info {
  color: var(--g400);
  font-size: 12px;
  line-height: 1.5;
}

.preisanker-disclaimer {
  text-align: center;
  color: var(--g400);
  font-size: 12px;
  max-width: 700px;
  margin: 16px auto 20px;
  line-height: 1.5;
}

/* Fördervorschuss-Banner */
@keyframes paFvPulse {
  0%,
  100% {
    box-shadow: 0 0 0 0 rgba(183, 217, 0, 0.2);
  }
  50% {
    box-shadow: 0 0 20px 4px rgba(183, 217, 0, 0.1);
  }
}
.preisanker-fv {
  background: rgba(0, 0, 0, 0.25);
  border: 1px solid rgba(183, 217, 0, 0.15);
  border-radius: 12px;
  padding: 20px 28px;
  text-align: center;
  color: var(--white);
  margin-top: 20px;
  animation: paFvPulse 3s ease-in-out infinite;
  transition: transform 0.3s ease;
}
.preisanker-fv:hover {
  transform: scale(1.01);
}
.preisanker-fv strong {
  color: var(--green);
}

/* Responsive */
@media (max-width: 900px) {
  .pa-cards {
    grid-template-columns: repeat(3, 1fr);
  }
  .pa-detail-inner {
    grid-template-columns: 1fr;
    grid-template-rows: auto auto auto auto;
  }
  .pa-detail-left {
    grid-column: 1;
    grid-row: 1;
    flex-direction: column;
    gap: 0;
    align-items: stretch;
  }
  .pa-detail-right {
    grid-column: 1;
    grid-row: 2;
    padding: 16px 0 12px 0;
  }
  .pa-detail-cta {
    padding: 8px 0 12px 0;
  }
  .pa-bottom-cta--beratung {
    grid-column: 1;
    grid-row: 3;
    margin: 0;
  }
  .pa-bottom-cta--wizard {
    grid-column: 1;
    grid-row: 4;
    margin: 0;
    border-top: 1px solid rgba(10, 10, 10, 0.3);
  }
  /* Bild: Seitenverhältnis statt feste Höhe → WP bleibt sichtbar */
  .pa-detail-img {
    height: auto;
    aspect-ratio: 16/9;
  }
  /* Bild: Im Einzelspalten-Modus kein Rechts-Fade (nur unten) */
  .pa-detail-img img {
    mask-image: linear-gradient(to bottom, black 80%, transparent 100%);
    -webkit-mask-image: linear-gradient(to bottom, black 80%, transparent 100%);
    mask-composite: unset;
    -webkit-mask-composite: unset;
    object-position: center 60%;
  }
  /* Schriftgrößen für 50+ Zielgruppe */
  .pa-specs {
    font-size: 14px;
  }
  .pa-specs td {
    padding: 6px 0;
  }
  .pa-specs td:first-child {
    font-size: 13px;
  }
  .pa-specs-title {
    font-size: 20px;
  }
  .pa-specs-sub {
    font-size: 14px;
  }
  .pa-detail-cta .pa-big-price {
    font-size: 38px;
  }
  .pa-detail-cta .pa-price-sub {
    font-size: 14px;
  }
  .pa-detail-cta .pa-proklima-badge {
    font-size: 15px;
    padding: 10px 14px;
  }
  .pa-detail-cta .pa-info {
    font-size: 14px;
  }
}
@media (max-width: 768px) {
  .pa-header {
    flex-direction: column;
    align-items: stretch;
    gap: 16px;
  }
  .pa-header-left {
    text-align: center;
  }
  .pa-header-cta {
    justify-content: center;
  }
  .pa-card.pa-default-highlight {
    transform: scale(1.02);
  }
  .pa-card.pa-default-highlight .pa-price-compact {
    font-size: 22px;
  }
  .pa-detail-left {
    flex-direction: column;
    align-items: stretch;
  }
  .pa-detail-cta {
    text-align: left;
    padding-left: 0;
  }
  /* Größere CTA-Buttons für Touch */
  .pa-bottom-cta {
    padding: 18px 20px;
    min-height: 72px;
  }
}
@media (max-width: 600px) {
  /* Horizontale Scroll-Karten auf Mobile */
  .pa-cards {
    display: flex;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    gap: 10px;
    padding-bottom: 8px;
    grid-template-columns: unset;
  }
  .pa-cards::-webkit-scrollbar {
    height: 4px;
  }
  .pa-cards::-webkit-scrollbar-thumb {
    background: rgba(183, 217, 0, 0.3);
    border-radius: 2px;
  }
  .pa-card {
    flex: 0 0 42%;
    min-width: 140px;
    scroll-snap-align: start;
    padding: 16px 12px;
  }
  .pa-card .pa-price-compact {
    font-size: 19px;
  }
  .pa-card h2,
  .pa-card h3 {
    font-size: 14px;
  }
  .pa-card .pa-modell {
    font-size: 12px;
  }
  .pa-card .pa-kw {
    font-size: 12px;
    margin: 2px 0 6px;
  }
  .pa-card .pa-label {
    font-size: 12px;
  }
  .pa-detail-inner {
    grid-template-columns: 1fr;
    grid-template-rows: auto auto auto auto;
  }
  .pa-detail-left {
    grid-column: 1;
    grid-row: 1;
  }
  .pa-detail-right {
    grid-column: 1;
    grid-row: 2;
  }
  .pa-bottom-cta--beratung {
    grid-column: 1;
    grid-row: 3;
  }
  .pa-bottom-cta--wizard {
    grid-column: 1;
    grid-row: 4;
  }
  .pa-detail-img {
    aspect-ratio: 4/3;
  }
  .pa-card.zoomed {
    transform: scale(1.04) translateY(-3px);
  }
  .pa-card.dimmed {
    transform: scale(0.92);
    filter: none;
    opacity: 0.6;
  }
  .pa-card.pa-default-highlight {
    transform: scale(1.02);
  }
  .pa-card.pa-default-highlight .pa-price-compact {
    font-size: 21px;
  }
  /* Größere Schrift für 50+ auf kleinen Screens */
  .pa-specs {
    font-size: 15px;
  }
  .pa-specs td:first-child {
    font-size: 14px;
  }
  .pa-detail-cta .pa-big-price {
    font-size: 36px;
  }
}

@media (prefers-reduced-motion: reduce) {
  .pa-card,
  .pa-detail,
  .pa-detail-img img {
    animation: none !important;
    opacity: 1 !important;
    transform: none !important;
    transition: none !important;
  }
  .preisanker-fv {
    animation: none;
  }
  .btn-primary::after {
    animation: none;
    display: none;
  }
}

/* ══ HERO FRIENDS ══ */
.hero-friends {
  background: var(--schiefer);
  border-top: 1px solid rgba(255, 255, 255, 0.04);
}
.hero-friends .section-title {
  color: var(--white);
}
.hf-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 60px;
}
.hf-col h3 {
  color: var(--white);
  font-size: 24px;
  margin-bottom: 20px;
}
.hf-col p {
  color: var(--g400);
  margin-bottom: 16px;
  line-height: 1.7;
}
.hf-steps {
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.hf-step {
  display: flex;
  gap: 16px;
}
.hf-step-num {
  width: 32px;
  height: 32px;
  background: var(--green);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: 'Barlow', sans-serif;
  font-weight: 800;
  color: var(--nacht);
  flex-shrink: 0;
}
.hf-step-text {
  color: var(--g400);
  font-size: 14px;
}
@media (max-width: 768px) {
  .hf-grid {
    grid-template-columns: 1fr;
    gap: 40px;
  }
}

/* ══ BLOG ══ */
.blog-section {
  background: var(--schiefer);
  border-top: 1px solid rgba(255, 255, 255, 0.04);
}
.blog-section .section-title {
  color: var(--white);
}
.blog-section .section-lead {
  color: var(--g300);
}
.blog-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
.blog-card {
  border-radius: 12px;
  overflow: hidden;
  border: 1px solid rgba(183, 217, 0, 0.08);
  background: rgba(255, 255, 255, 0.03);
  transition: all 0.2s;
  cursor: pointer;
}
.blog-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 8px 32px rgba(183, 217, 0, 0.06);
  border-color: rgba(183, 217, 0, 0.18);
}
.blog-card-img {
  height: 180px;
  background: rgba(0, 0, 0, 0.2);
  display: flex;
  align-items: center;
  justify-content: center;
}
.blog-card-img .blog-icon {
  font-size: 48px;
  opacity: 0.3;
  color: var(--green);
}
.blog-card-body {
  padding: 24px;
}
.blog-card-tag {
  color: var(--green);
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1px;
  margin-bottom: 8px;
}
.blog-card h3 {
  color: var(--white);
  font-size: 18px;
  margin-bottom: 8px;
  font-weight: 700;
}
.blog-card p {
  color: var(--g400);
  font-size: 14px;
  line-height: 1.6;
}
.blog-card .blog-link {
  color: var(--green);
  font-size: 13px;
  font-weight: 700;
  margin-top: 12px;
  display: inline-block;
  text-decoration: none;
}
@media (max-width: 768px) {
  .blog-grid {
    grid-template-columns: 1fr;
  }
}

/* Ratgeber hub: cluster layout, varied card motifs and sticky guidance rail. */
.ratgeber-hub {
  padding-top: 112px;
}
.ratgeber-hub .section-inner {
  max-width: 1180px;
}
.ratgeber-intro {
  max-width: 780px;
  margin-bottom: 36px;
}
.ratgeber-hub .section-lead {
  margin-bottom: 22px;
}
.ratgeber-topic-row {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}
.ratgeber-topic-row a {
  display: inline-flex;
  align-items: center;
  min-height: 38px;
  padding: 8px 14px;
  border: 1px solid rgba(183, 217, 0, 0.22);
  border-radius: 8px;
  color: var(--g200);
  background: rgba(255, 255, 255, 0.04);
  text-decoration: none;
  font-size: 14px;
  font-weight: 700;
}
.ratgeber-topic-row a:hover {
  color: var(--nacht);
  background: var(--green);
  border-color: var(--green);
}
.ratgeber-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 318px;
  gap: 34px;
  align-items: start;
}
.ratgeber-main {
  display: grid;
  gap: 34px;
  min-width: 0;
}
.ratgeber-cluster {
  display: grid;
  gap: 16px;
}
.ratgeber-cluster-head {
  max-width: 720px;
}
.ratgeber-cluster-head h2 {
  color: var(--white);
  font-size: clamp(23px, 2.5vw, 31px);
  margin-bottom: 0;
}
.ratgeber-hub .blog-grid {
  grid-template-columns: 1fr;
  gap: 18px;
}
.ratgeber-hub .blog-card {
  position: relative;
  display: grid;
  grid-template-columns: minmax(230px, 0.52fr) minmax(0, 1fr);
  min-height: 226px;
  border-radius: 10px;
  cursor: pointer;
}
.ratgeber-hub .blog-card:hover {
  transform: translateY(-3px);
}
.ratgeber-hub .blog-card-featured {
  grid-template-columns: minmax(230px, 0.52fr) minmax(0, 1fr);
  min-height: 226px;
  background: rgba(255, 255, 255, 0.04);
}
.blog-card-art {
  min-height: 100%;
  background:
    radial-gradient(circle at 28% 18%, rgba(232, 168, 56, 0.22), transparent 34%),
    linear-gradient(135deg, rgba(255, 255, 255, 0.08), rgba(10, 10, 10, 0.12));
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 18px;
}
.blog-card-art svg {
  width: 100%;
  max-width: 220px;
  height: auto;
  display: block;
}
.blog-card-photo {
  background-size: cover;
  background-position: center;
  padding: 0;
}
.guide-visual {
  position: relative;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  color: var(--white);
  background: #20323e;
}
.guide-visual::after {
  display: none;
}
.blog-card-art .guide-icon,
.blog-card-art .guide-icon-img {
  position: relative;
  z-index: 1;
  display: block;
  width: 148px;
  height: 148px;
  max-width: calc(100% - 36px);
  object-fit: contain;
}
.blog-card-art .guide-icon {
  aspect-ratio: 1;
}
.guide-brand-logo {
  position: relative;
  z-index: 1;
  display: block;
  width: min(78%, 188px);
  max-height: 82px;
  object-fit: contain;
}
.guide-card-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 14px;
}
.guide-card-meta span {
  display: inline-flex;
  align-items: center;
  min-height: 26px;
  padding: 5px 9px;
  border: 1px solid rgba(255, 255, 255, 0.15);
  border-radius: 6px;
  color: var(--g200);
  background: rgba(255, 255, 255, 0.06);
  font-size: 11px;
  font-weight: 800;
}
.guide-logo-row img {
  position: relative;
  z-index: 1;
  display: block;
  width: 100%;
  max-width: 128px;
  max-height: 42px;
  object-fit: contain;
}
.guide-logo-row {
  position: relative;
  z-index: 1;
  display: grid;
  width: min(78%, 188px);
  gap: 14px;
  align-items: center;
  justify-items: center;
}
.guide-logo-row-large img {
  max-width: 154px;
  max-height: 52px;
}
.ratgeber-hub .blog-card-body {
  display: flex;
  flex-direction: column;
  min-width: 0;
  padding: 20px;
}
.ratgeber-hub .blog-card h2 {
  color: var(--white);
  font-size: clamp(23px, 2.4vw, 30px);
  margin-bottom: 8px;
  font-weight: 800;
}
.ratgeber-hub .blog-card-featured h2 {
  font-size: clamp(23px, 2.4vw, 30px);
}
.ratgeber-hub .blog-card p {
  margin-bottom: 0;
}
.ratgeber-hub .blog-card .blog-link {
  margin-top: auto;
  padding-top: 16px;
}
.ratgeber-hub .blog-card .blog-link::after {
  content: '';
  position: absolute;
  inset: 0;
  z-index: 2;
}
.ratgeber-hub .blog-card:focus-within {
  outline: 3px solid var(--green);
  outline-offset: 4px;
}
.ratgeber-sidebar {
  position: sticky;
  top: 88px;
  display: grid;
  gap: 14px;
}
.ratgeber-side-panel {
  border: 1px solid rgba(183, 217, 0, 0.12);
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.04);
  padding: 20px;
}
.ratgeber-side-panel h2 {
  color: var(--white);
  font-size: 20px;
  margin-bottom: 10px;
}
.ratgeber-side-panel p {
  color: var(--g300);
  font-size: 14px;
  line-height: 1.55;
  margin-bottom: 18px;
}
.ratgeber-lead-source {
  background:
    linear-gradient(155deg, rgba(183, 217, 0, 0.13), rgba(255, 255, 255, 0.035) 48%),
    rgba(255, 255, 255, 0.04);
}
.ratgeber-lead-source .btn-primary {
  width: 100%;
  padding-left: 18px;
  padding-right: 18px;
  text-align: center;
}
.side-panel-tag {
  color: var(--green);
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 1.4px;
  text-transform: uppercase;
  margin-bottom: 10px;
}
.ratgeber-side-nav,
.ratgeber-next {
  display: grid;
}
.ratgeber-side-nav a,
.ratgeber-next a {
  color: var(--g200);
  border-top: 1px solid rgba(255, 255, 255, 0.08);
  padding: 12px 0;
  text-decoration: none;
  font-size: 14px;
  font-weight: 700;
}
.ratgeber-side-nav a:hover,
.ratgeber-next a:hover {
  color: var(--green);
}

@media (max-width: 1020px) {
  .ratgeber-layout {
    grid-template-columns: 1fr;
  }
  .ratgeber-sidebar {
    position: static;
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 820px) {
  .ratgeber-hub {
    padding-top: 92px;
  }
  .ratgeber-hub .blog-grid,
  .ratgeber-sidebar {
    grid-template-columns: 1fr;
  }
  .ratgeber-hub .blog-card,
  .ratgeber-hub .blog-card-featured {
    grid-template-columns: minmax(0, 1fr);
  }
  .blog-card-art {
    min-height: 178px;
  }
  .blog-card-art .guide-icon,
  .blog-card-art .guide-icon-img {
    width: 132px;
    height: 132px;
  }
  .ratgeber-hub .blog-card-body {
    padding: 20px;
  }
}

@media (max-width: 520px) {
  .ratgeber-hub {
    padding-left: 18px;
    padding-right: 18px;
  }
  .ratgeber-topic-row a {
    flex: 1 1 100%;
    justify-content: center;
  }
  .blog-card-art {
    min-height: 154px;
  }
  .blog-card-art .guide-icon,
  .blog-card-art .guide-icon-img {
    width: 118px;
    height: 118px;
  }
  .ratgeber-hub .blog-card h2 {
    font-size: 18px;
  }
  .ratgeber-hub .blog-card-featured h2 {
    font-size: 26px;
  }
}

[data-theme='light'] .ratgeber-topic-row a {
  color: var(--color-text-primary);
  background: var(--color-surface-secondary);
  border-color: rgba(28, 43, 54, 0.16);
}
[data-theme='light'] .ratgeber-topic-row a:hover {
  color: var(--color-accent-primary-text);
  background: var(--green);
  border-color: var(--green);
}
[data-theme='light'] .ratgeber-hub .blog-card-featured {
  background: var(--color-surface-secondary) !important;
}
[data-theme='light'] .blog-card-art {
  background: #f4f6ef;
}
[data-theme='light'] .guide-visual {
  color: var(--color-text-primary);
  background: #f4f6ef;
}
[data-theme='light'] .guide-visual::after {
  border-color: rgba(28, 43, 54, 0.08);
}
[data-theme='light'] .guide-card-meta span {
  color: var(--color-text-primary);
  background: rgba(28, 43, 54, 0.05);
  border-color: rgba(28, 43, 54, 0.12);
}
[data-theme='dark'] .guide-icon,
[data-theme='dark'] .guide-icon-img {
  filter: invert(1) brightness(1.18);
}
[data-theme='light'] .guide-brand-logo,
[data-theme='light'] .guide-logo-row img {
  box-shadow: none;
}
[data-theme='light'] .guide-logo-kfw,
[data-theme='light'] .guide-logo-proklima {
  filter: none;
}
[data-theme='dark'] .guide-logo-kfw {
  filter: brightness(0) invert(1);
}
[data-theme='dark'] .guide-logo-proklima {
  filter: none;
}
[data-theme='light'] .ratgeber-side-panel {
  background: var(--color-surface-secondary);
  border-color: var(--color-border-subtle);
  box-shadow: 0 10px 30px rgba(28, 43, 54, 0.07);
}
[data-theme='light'] .ratgeber-lead-source {
  background:
    linear-gradient(155deg, rgba(183, 217, 0, 0.18), rgba(255, 255, 255, 0.8) 52%),
    var(--color-surface-secondary);
}
[data-theme='light'] .ratgeber-side-nav a,
[data-theme='light'] .ratgeber-next a {
  color: var(--color-text-primary);
  border-top-color: var(--color-border-subtle);
}
[data-theme='light'] .ratgeber-side-panel p {
  color: var(--color-text-secondary);
}

/* ══ FAQ ══ */
.faq {
  background: var(--schiefer);
  border-top: 1px solid rgba(255, 255, 255, 0.04);
}
.faq .section-title {
  color: var(--white);
}
.faq-item {
  border-bottom: 1px solid rgba(255, 255, 255, 0.06);
  padding: 24px 0;
}
.faq-item:last-child {
  border-bottom: none;
}
.faq-question {
  display: flex;
  justify-content: space-between;
  align-items: center;
  cursor: pointer;
  user-select: none;
}
.faq-q-text {
  color: var(--white);
  font-weight: 600;
  font-size: 16px;
}
.faq-toggle {
  color: var(--green);
  font-weight: 700;
  font-size: 20px;
  transition: transform 0.2s;
}
.faq-item.open .faq-toggle {
  transform: rotate(45deg);
}
.faq-answer {
  display: none;
  color: var(--g400);
  margin-top: 16px;
  line-height: 1.7;
  font-size: 15px;
}
.faq-item.open .faq-answer {
  display: block;
  animation: slideDown 0.3s;
}
@keyframes slideDown {
  from {
    opacity: 0;
    transform: translateY(-10px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* ══ CONTACT FORM ══ */
.contact {
  background: var(--schiefer);
  border-top: 1px solid rgba(255, 255, 255, 0.04);
}
.contact .section-title {
  color: var(--white);
}
.contact .section-lead {
  color: var(--g300);
}
.contact-form {
  max-width: 600px;
  background: rgba(0, 0, 0, 0.3);
  border-radius: 12px;
  padding: 32px;
  border: 1px solid rgba(255, 255, 255, 0.1);
}
.form-group {
  margin-bottom: 20px;
}
.form-group label {
  display: block;
  color: var(--white);
  font-weight: 600;
  font-size: 14px;
  margin-bottom: 8px;
}
.form-group input,
.form-group textarea,
.form-group select {
  width: 100%;
  padding: 12px;
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(255, 255, 255, 0.15);
  border-radius: 6px;
  color: var(--white);
  font-size: 14px;
  font-family: 'Inter', sans-serif;
}
.form-group input::placeholder,
.form-group textarea::placeholder {
  color: var(--g400);
}
.form-group input:focus,
.form-group textarea:focus,
.form-group select:focus {
  outline: none;
  border-color: var(--green);
  background: rgba(255, 255, 255, 0.1);
}
.form-group textarea {
  resize: vertical;
  min-height: 100px;
}
.form-checkbox {
  display: flex;
  gap: 12px;
  align-items: flex-start;
  margin-bottom: 24px;
}
.form-checkbox input {
  width: 18px;
  height: 18px;
  margin-top: 2px;
  cursor: pointer;
}
.form-checkbox label {
  color: var(--g300);
  font-size: 13px;
  cursor: pointer;
  margin: 0;
}
.form-submit {
  width: 100%;
  padding: 14px;
  background: var(--green);
  color: var(--nacht);
  border: none;
  border-radius: 6px;
  font-family: 'Barlow', sans-serif;
  font-weight: 700;
  font-size: 15px;
  cursor: pointer;
  transition: all 0.2s;
}
.form-submit:hover {
  background: var(--green-dark);
}
.form-success {
  display: none;
  background: rgba(183, 217, 0, 0.1);
  border: 1px solid var(--green);
  border-radius: 8px;
  padding: 24px;
  text-align: center;
  color: var(--white);
}
.form-success.show {
  display: block;
}
.form-success h2,
.form-success h4 {
  color: var(--green);
  font-size: 18px;
  margin-bottom: 8px;
}

/* Contact-Layout: desktop image follows the form column height without distortion. */
.contact-layout {
  align-items: stretch !important;
}
.contact-image {
  display: flex;
  min-height: 0;
  height: 100%;
}
.contact-image img {
  flex: 1 1 auto;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center center;
}

/* Contact-Layout responsive */
@media (max-width: 768px) {
  .contact-layout {
    grid-template-columns: 1fr !important;
  }
  .contact-image {
    max-height: 280px;
  }
  .contact-image img {
    height: 280px;
    max-height: 280px;
    object-fit: cover;
  }
}

/* ══ TRUST STREIFEN (hell) ══ */
.trust-strip {
  padding: 36px 24px;
  border-top: 3px solid var(--green);
}
[data-theme='light'] .trust-strip {
  background: var(--color-surface-primary);
  border-bottom: 1px solid var(--color-border-subtle);
}
[data-theme='dark'] .trust-strip {
  background: var(--color-surface-secondary);
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}
.trust-strip-inner {
  max-width: 1100px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 24px;
}
.trust-strip-label {
  font-family: 'Inter', sans-serif;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-text-secondary);
}
.trust-logos {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: 12px 24px;
}
.trust-logo-badge {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 20px;
  background: #f9fafb;
  border: 1.5px solid #e5e7eb;
  border-radius: 10px;
  font-family: 'Inter', sans-serif;
  font-size: 13px;
  font-weight: 600;
  color: #1c2b36;
  white-space: nowrap;
  transition:
    border-color 0.2s,
    box-shadow 0.2s;
}
.trust-logo-badge:hover {
  border-color: var(--green);
  box-shadow: 0 2px 8px rgba(183, 217, 0, 0.15);
}
.trust-logo-badge .badge-icon {
  width: 32px;
  height: 32px;
  border-radius: 6px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 16px;
  font-weight: 800;
  flex-shrink: 0;
}
.badge-wolf {
  background: #1c2b36;
  color: #b7d900;
  font-family: 'Barlow', sans-serif;
  font-size: 12px;
  letter-spacing: 0.05em;
}
.badge-vaillant {
  background: #cc0033;
  color: #ffffff;
  font-family: 'Barlow', sans-serif;
  font-size: 12px;
  letter-spacing: 0.03em;
}
.badge-shk {
  background: rgba(183, 217, 0, 0.15);
  color: #1c2b36;
}
.badge-hero {
  background: rgba(183, 217, 0, 0.15);
  color: #1c2b36;
}
.badge-kfw {
  background: #006ab3;
  color: #ffffff;
  font-family: 'Barlow', sans-serif;
  font-size: 12px;
  letter-spacing: 0.05em;
}
.badge-proklima {
  background: #2e7d32;
  color: #ffffff;
  font-family: 'Barlow', sans-serif;
  font-size: 12px;
  letter-spacing: 0.03em;
}
.trust-strip-sub {
  font-size: 12px;
  color: #9a9a9a;
  font-family: 'Inter', sans-serif;
  text-align: center;
}
@media (max-width: 600px) {
  .trust-logos {
    gap: 10px;
  }
  .trust-logo-badge {
    font-size: 12px;
    padding: 10px 14px;
  }
}

/* ══ CONTACT HELL ══ */
.contact {
  background: #f4f1ea !important;
  border-top: none !important;
}
.contact .section-tag {
  color: var(--schiefer) !important;
  background: rgba(28, 43, 54, 0.08);
  border-color: rgba(28, 43, 54, 0.15) !important;
}
.contact .section-title {
  color: var(--schiefer) !important;
}
.contact .section-lead {
  color: #4b5563 !important;
}
.contact-form {
  background: #ffffff !important;
  border: 1.5px solid #e5e7eb !important;
  box-shadow: 0 4px 24px rgba(28, 43, 54, 0.08) !important;
}
.contact-form .form-group label {
  color: var(--schiefer) !important;
}
.contact-form .form-group input,
.contact-form .form-group textarea,
.contact-form .form-group select {
  background: #f9fafb !important;
  border: 1.5px solid #d1d5db !important;
  color: var(--schiefer) !important;
}
.contact-form .form-group input::placeholder,
.contact-form .form-group textarea::placeholder {
  color: #9ca3af !important;
}
.contact-form .form-group input:focus,
.contact-form .form-group textarea:focus,
.contact-form .form-group select:focus {
  border-color: var(--green) !important;
  background: #ffffff !important;
  outline: none;
  box-shadow: 0 0 0 3px rgba(183, 217, 0, 0.18) !important;
}
.contact-form .form-checkbox label {
  color: #4b5563 !important;
}
.contact-form .form-success {
  background: rgba(183, 217, 0, 0.12) !important;
  border-color: var(--green) !important;
}
.contact-form .form-success h2,
.contact-form .form-success h4 {
  color: var(--schiefer) !important;
}
.contact-form .form-success p {
  color: #4b5563 !important;
}
.contact .contact-image {
  box-shadow: 0 8px 32px rgba(28, 43, 54, 0.12);
}

/* ══ FOOTER ══ */
footer {
  background: var(--nacht);
  border-top: 1px solid rgba(255, 255, 255, 0.1);
  padding: 60px 24px 40px;
}
.footer-inner {
  max-width: 1100px;
  margin: 0 auto;
}
.footer-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 40px;
  margin-bottom: 40px;
}
.footer-col h2 {
  color: var(--white);
  font-size: 14px;
  font-weight: 700;
  margin-bottom: 16px;
  text-transform: uppercase;
}
.footer-col a,
.footer-col p {
  color: var(--g400);
  font-size: 13px;
  margin-bottom: 8px;
  text-decoration: none;
  transition: color 0.2s;
}
.footer-col a:hover {
  color: var(--green);
}
.footer-bottom {
  border-top: 1px solid rgba(255, 255, 255, 0.1);
  padding-top: 32px;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.footer-tagline {
  color: var(--g400);
  font-size: 13px;
}
.footer-legal {
  display: flex;
  gap: 24px;
}
.footer-legal a {
  color: var(--g400);
  font-size: 12px;
  text-decoration: none;
  transition: color 0.2s;
}
.footer-legal a:hover {
  color: var(--green);
}
@media (max-width: 768px) {
  .footer-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 32px;
  }
  .footer-bottom {
    flex-direction: column;
    gap: 20px;
  }
}

@keyframes slideUp {
  from {
    opacity: 0;
    transform: translateY(30px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
.fade-up {
  animation: slideUp 0.6s ease-out;
}

/* Iteration 3 GF-Sichtrunde: shared visual fixes without new component vocabulary. */
.logo-light {
  display: none;
}
[data-theme='light'] .logo-dark {
  display: none !important;
}
[data-theme='light'] .logo-light {
  display: inline-block !important;
}

.hc-fv-highlight {
  background: #e8a838 !important;
  border-color: #e8a838 !important;
  color: #1c2b36 !important;
  box-shadow: 0 14px 32px rgba(232, 168, 56, 0.24);
}

/* Abnahme 27.06.: Light-Mode zeigte einen 1px weissen Sliver links/rechts der
   Amber-Box (border-radius+overflow:hidden+weisser Card-BG scheint an der Clip-Kante
   durch). Amber 1px ueber die Kante ziehen — overflow:hidden der .hero-calc kappt es
   sauber. Dark-Mode unsichtbar (dunkler Card-BG), daher nur light-scoped. */
[data-theme='light'] .hc-fv-highlight {
  margin-inline: -1px;
}
.hc-fv-badge,
.hc-fv-badge svg,
.hc-fv-text,
.hc-fv-text strong {
  color: #1c2b36 !important;
}

.home-teaser-section {
  background: var(--nacht);
  border-top: 1px solid rgba(255, 255, 255, 0.06);
}
.home-teaser-section.home-teaser-alt {
  background: var(--schiefer);
}
.home-teaser-section.home-teaser-fv {
  background: linear-gradient(135deg, rgba(232, 168, 56, 0.18), rgba(28, 43, 54, 0.96));
}
.home-teaser-inner {
  max-width: 860px;
}
.home-teaser-inner .btn-primary {
  margin-top: 10px;
}
[data-theme='light'] .home-teaser-section,
[data-theme='light'] .home-teaser-section.home-teaser-alt {
  background: var(--color-surface-primary) !important;
}
[data-theme='light'] .home-teaser-section.home-teaser-fv {
  background: var(--color-surface-primary) !important;
}
[data-theme='light'] .hero h1 .accent,
[data-theme='light'] .trust-headline em {
  color: var(--color-text-primary) !important;
}
.partner-logo {
  /* Einheitliche Höhe statt starrer 96×32-Box: die 4 Hersteller-/Förder-SVGs
     haben sehr unterschiedliche Seitenverhältnisse; object-fit in einer festen
     Box ließ sie optisch verschieden hoch wirken. Höhe fix + Breite auto =
     gleiche Sichthöhe (dieselbe Methode wie .wiz-brand-logo im Rechner). */
  height: 24px;
  width: auto;
  max-width: 88px;
  object-fit: contain;
  display: block;
  flex-shrink: 0;
}

/* Preise: tables and detail panel alignment. */
.pa-specs td:last-child {
  padding-right: 16px;
}
.pa-detail-cta {
  padding-left: 16px;
}
.pa-card.dimmed {
  opacity: 0.72;
  background: rgba(28, 43, 54, 0.52);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}
[data-theme='light'] .pa-card.dimmed {
  background: color-mix(in srgb, var(--color-surface-secondary) 48%, transparent) !important;
  border-color: var(--color-border-subtle) !important;
}

/* Förderung light: input fields stay white inside unified light cards.
   AE-2-Politur: kraeftigerer Rahmen + dezenter Schatten, damit die weissen Felder
   sich vom hellen Panel abheben (weiss-auf-weiss ging unter). */
[data-theme='light'] .foerder-section input,
[data-theme='light'] .foerder-section select,
[data-theme='light'] .foerder-section textarea {
  background: var(--color-surface-secondary) !important;
  border: 1px solid rgba(28, 43, 54, 0.4) !important;
  box-shadow: 0 2px 5px rgba(28, 43, 54, 0.1) !important;
  color: var(--color-text-primary) !important;
}

/* Dimensionierung: shared grid width and light card surface. */
.wizard-section .section-inner {
  max-width: 1120px;
  margin-left: auto;
  margin-right: auto;
}

/* Kontakt: dark theme must cover the complete page, not only the title bar. */
[data-theme='dark'] .contact {
  background: var(--nacht) !important;
  border-top: 1px solid rgba(255, 255, 255, 0.06) !important;
}
[data-theme='dark'] .contact .section-title,
[data-theme='dark'] .contact-form .form-success h2,
[data-theme='dark'] .contact-form .form-success h4 {
  color: var(--white) !important;
}
[data-theme='dark'] .contact .section-lead,
[data-theme='dark'] .contact-form .form-checkbox label,
[data-theme='dark'] .contact-form .form-success p {
  color: var(--g300) !important;
}
[data-theme='dark'] .contact-form {
  background: rgba(255, 255, 255, 0.06) !important;
  border-color: rgba(255, 255, 255, 0.14) !important;
  box-shadow: none !important;
}
[data-theme='dark'] .contact-form .form-group label {
  color: var(--white) !important;
}
[data-theme='dark'] .contact-form .form-group input,
[data-theme='dark'] .contact-form .form-group textarea,
[data-theme='dark'] .contact-form .form-group select {
  background: rgba(255, 255, 255, 0.08) !important;
  border-color: rgba(255, 255, 255, 0.15) !important;
  color: var(--white) !important;
}

/* Ratgeber FAQ breathing room. */
.faq-question,
.faq-answer {
  padding-left: 20px;
  padding-right: 20px;
}

/* Iteration 3b: exact dark-mode axe rest node. */
[data-theme='dark'] .contact .section-tag {
  color: #d1d5db !important;
  background: rgba(255, 255, 255, 0.08);
  border-color: rgba(255, 255, 255, 0.15) !important;
}

/* Iteration 6 Design: Light-mode refinement, translated from dark-mode design language. */
[data-theme='light'] .pa-card,
[data-theme='light'] .blog-card,
[data-theme='light'] .foerder-grid,
[data-theme='light'] .foerder-result,
[data-theme='light'] .wizard-container,
[data-theme='light'] .contact-form,
[data-theme='light'] .qs-form,
[data-theme='light'] .hero-calc {
  border: 1px solid rgba(28, 43, 54, 0.06) !important;
  box-shadow:
    0 1px 3px rgba(28, 43, 54, 0.05),
    0 10px 30px rgba(28, 43, 54, 0.07) !important;
}

[data-theme='light'] .wizard-slider-group input[type='range'],
[data-theme='light'] .cc-input-group input[type='range'] {
  -webkit-appearance: none;
  appearance: none;
  height: 5px;
  background: transparent;
  accent-color: var(--color-accent-primary);
}
[data-theme='light'] .wizard-slider-group input[type='range']::-webkit-slider-runnable-track,
[data-theme='light'] .cc-input-group input[type='range']::-webkit-slider-runnable-track {
  height: 5px;
  background: color-mix(in srgb, var(--color-text-secondary) 88%, var(--color-surface-secondary));
  border-radius: 999px;
}
[data-theme='light'] .wizard-slider-group input[type='range']::-moz-range-track,
[data-theme='light'] .cc-input-group input[type='range']::-moz-range-track {
  height: 5px;
  background: color-mix(in srgb, var(--color-text-secondary) 88%, var(--color-surface-secondary));
  border-radius: 999px;
}
[data-theme='light'] .wizard-slider-group input[type='range']::-webkit-slider-thumb,
[data-theme='light'] .cc-input-group input[type='range']::-webkit-slider-thumb {
  -webkit-appearance: none;
  width: 20px;
  height: 20px;
  margin-top: -7.5px;
  background: var(--color-surface-secondary);
  border: 1px solid var(--color-text-secondary);
  border-radius: 50%;
  box-shadow:
    0 2px 8px rgba(28, 43, 54, 0.16),
    0 0 0 5px rgba(183, 217, 0, 0.16);
  cursor: pointer;
}
[data-theme='light'] .wizard-slider-group input[type='range']::-moz-range-thumb,
[data-theme='light'] .cc-input-group input[type='range']::-moz-range-thumb {
  width: 20px;
  height: 20px;
  background: var(--color-surface-secondary);
  border: 1px solid var(--color-text-secondary);
  border-radius: 50%;
  box-shadow:
    0 2px 8px rgba(28, 43, 54, 0.16),
    0 0 0 5px rgba(183, 217, 0, 0.16);
  cursor: pointer;
}
[data-theme='light'] .wizard-slider-group input[type='range']:focus-visible,
[data-theme='light'] .cc-input-group input[type='range']:focus-visible {
  outline: 2px solid var(--color-text-primary);
  outline-offset: 5px;
}

[data-theme='light'] .btn-ghost,
[data-theme='light'] .wizard-btn-back {
  background: transparent;
  border: 1px solid rgba(28, 43, 54, 0.52);
  color: var(--color-text-primary);
  box-shadow: none;
}
[data-theme='light'] .btn-ghost:hover,
[data-theme='light'] .wizard-btn-back:hover {
  background: rgba(28, 43, 54, 0.04);
  border-color: var(--color-text-primary);
  color: var(--color-text-primary);
}
[data-theme='light'] .btn-ghost:active,
[data-theme='light'] .wizard-btn-back:active {
  background: rgba(28, 43, 54, 0.07);
}
[data-theme='light'] .btn-ghost:focus-visible,
[data-theme='light'] .wizard-btn-back:focus-visible {
  outline: 2px solid var(--color-text-primary);
  outline-offset: 3px;
}

[data-theme='light'] #effektivSatzBox,
[data-theme='light'] .wr-card,
[data-theme='light'] .cc-result {
  background: #f6f3ec !important;
  border: 1px solid rgba(28, 43, 54, 0.06) !important;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.72),
    0 8px 22px rgba(28, 43, 54, 0.06);
}

/* ── AE-2-Politur ③: Foerderrechner-Ergebnispanel — Panel = Sand, Effektiv-Box = Weiss (GF-ratifiziert 2026-06-22/23).
   SCOPED auf .foerder-section, damit die mit dem Dimensionierungsrechner GETEILTE .foerder-result
   (.wiz-brand-panel/.wiz-selected, js/site.js) unberuehrt bleibt. Theme-sicher (Dark = dunkle Entsprechung). ── */
/* Dark: warme Sand-Entsprechung statt Gruen-Tint */
.foerder-section .foerder-result {
  background: rgba(240, 233, 218, 0.05) !important;
}
/* Dark: hellere "weisse" Box, hebt sich vom Panel ab */
.foerder-section #effektivSatzBox {
  background: rgba(255, 255, 255, 0.1) !important;
}
[data-theme='light'] .foerder-section .foerder-result {
  background: var(--sand) !important; /* Light: Sand #f4f1ea */
}
[data-theme='light'] .foerder-section #effektivSatzBox {
  background: #ffffff !important; /* Light: Weiss */
}
[data-theme='light'] .hc-result {
  background: rgba(183, 217, 0, 0.07) !important;
  border: 0 !important;
  border-top: 2px solid var(--color-accent-primary) !important;
  box-shadow: 0 8px 22px rgba(28, 43, 54, 0.06);
}
[data-theme='light'] .wr-card.recommended {
  background: rgba(183, 217, 0, 0.07) !important;
  border: 1px solid rgba(28, 43, 54, 0.06) !important;
  box-shadow:
    inset 0 2px 0 var(--color-accent-primary),
    0 10px 28px rgba(28, 43, 54, 0.08);
}

html[data-theme='light'] .foerder-result .fr-satz,
html[data-theme='light'] .hc-result-value,
html[data-theme='light'] .hc-value,
html[data-theme='light'] .manufacturer-price,
html[data-theme='light'] .pa-detail-cta .pa-big-price {
  color: var(--color-text-primary) !important;
}

[data-theme='light'] #foerderBreakdown .breakdown-item {
  border-bottom: 1px solid rgba(28, 43, 54, 0.1);
  padding-top: 7px;
  padding-bottom: 7px;
}
[data-theme='light'] #foerderBreakdown .breakdown-item:last-child {
  border-bottom: 0;
}
[data-theme='light'] #foerderBreakdown .breakdown-item[style*='border-top'] {
  border-top-color: rgba(28, 43, 54, 0.45) !important;
}

[data-theme='light'] .seg-toggle {
  background: rgba(28, 43, 54, 0.04) !important;
  border: 1px solid rgba(28, 43, 54, 0.08);
  box-shadow: inset 0 1px 2px rgba(28, 43, 54, 0.04);
}
[data-theme='light'] .wizard-option:not(#wzRhEnd):not(#wzRhMitte) {
  background-color: var(--color-surface-secondary) !important;
}
/* AE-D: Slider-Wert (.ws-val) ist im Dark lime (--green), auf hellem Karton aber nur ~1,6:1.
   Im Light den etablierten Akzent-auf-Hell-Satz nutzen (#4f6000 = 6,99:1), wie .fr-satz/.hc-result-value.
   Geteilt ueber alle verbleibenden Slider (Flaeche, Verbrauch) - gleiche, korrekte Behandlung. */
[data-theme='light'] .wizard-slider-group label .ws-val {
  color: var(--color-accent-on-light);
}
[data-theme='light'] .seg-toggle button {
  color: var(--color-text-secondary) !important;
}
[data-theme='light'] .seg-toggle button.active {
  background: var(--color-surface-secondary) !important;
  color: var(--color-text-primary) !important;
  box-shadow:
    0 1px 3px rgba(28, 43, 54, 0.08),
    0 6px 18px rgba(28, 43, 54, 0.08);
}
[data-theme='light'] .cc-input-group select,
[data-theme='light'] .cc-input-group input[type='number'],
[data-theme='light'] .contact-form .form-group input,
[data-theme='light'] .contact-form .form-group textarea,
[data-theme='light'] .contact-form .form-group select {
  background: rgba(255, 255, 255, 0.92) !important;
  border: 1px solid rgba(28, 43, 54, 0.18) !important;
  color: var(--color-text-primary) !important;
  box-shadow: inset 0 1px 2px rgba(28, 43, 54, 0.04);
}
[data-theme='light'] .cc-input-group select:focus,
[data-theme='light'] .cc-input-group input:focus,
[data-theme='light'] .contact-form .form-group input:focus,
[data-theme='light'] .contact-form .form-group textarea:focus,
[data-theme='light'] .contact-form .form-group select:focus {
  border-color: var(--color-text-primary) !important;
  box-shadow:
    0 0 0 3px rgba(183, 217, 0, 0.28),
    inset 0 1px 2px rgba(28, 43, 54, 0.04) !important;
}

html[data-theme='light'] .hero-badge,
html[data-theme='light'] .section-tag {
  background: rgba(183, 217, 0, 0.16) !important;
  border: 1px solid rgba(28, 43, 54, 0.08) !important;
  color: #4f6000 !important;
  box-shadow: 0 4px 14px rgba(28, 43, 54, 0.06);
}

/* Home feature uplift */
.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}
.fv-content h2 .accent,
.fv-content h2 span.accent,
.fv-tag {
  color: var(--bernstein);
}
.fv-tag {
  background: rgba(232, 168, 56, 0.14);
  border-color: rgba(232, 168, 56, 0.28);
}
.fv-tag::before {
  background: var(--bernstein);
}
.fv-sub {
  color: var(--g300);
  font-size: clamp(16px, 2vw, 20px);
  line-height: 1.5;
  margin-bottom: 28px;
  max-width: 640px;
}
.home-feature {
  background: var(--nacht);
  border-top: 1px solid rgba(255, 255, 255, 0.06);
  position: relative;
  overflow: hidden;
}
.home-feature::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 80% 0%, rgba(183, 217, 0, 0.05), transparent 55%);
  pointer-events: none;
}
.home-feature-alt {
  background: var(--schiefer);
}
.home-feature-inner {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: clamp(28px, 5vw, 64px);
  align-items: center;
}
.home-feature-inner.media-right .home-feature-media {
  order: 2;
}
.home-feature-media {
  position: relative;
  border-radius: 16px;
  overflow: hidden;
  aspect-ratio: 4 / 3;
  box-shadow: 0 10px 28px rgba(0, 0, 0, 0.18);
}
.home-feature-media::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(28, 43, 54, 0.55), transparent 55%);
  pointer-events: none;
}
.home-feature-media picture,
.home-feature-media img {
  display: block;
  width: 100%;
  height: 100%;
}
.home-feature-media img {
  object-fit: cover;
  transition: transform 0.35s ease;
}
.home-feature:hover .home-feature-media img {
  transform: scale(1.025);
}
.home-feature-body {
  border-radius: 16px;
  padding: clamp(24px, 4vw, 44px);
}
.home-feature-amber .section-tag {
  color: var(--bernstein);
  background: rgba(232, 168, 56, 0.14);
  border-color: rgba(232, 168, 56, 0.28);
}
.entry-plz {
  display: flex;
  flex-wrap: wrap;
  align-items: stretch;
  gap: 12px;
  margin: 26px 0 14px;
}
.entry-plz input {
  /* min-width/basis sichert Platz für 5 Ziffern + Placeholder "Deine PLZ";
     ohne dies kollabiert das Feld im Flex-Row-Layout auf ~34px (Placeholder
     und Eingabe abgeschnitten) */
  min-width: 14ch;
  /* max-width deckelt das Wachstum: ohne Deckel füllt das Feld die ganze
     Restbreite der Feature-Spalte (mal ~300px, mal länger) und wirkt
     überdimensioniert; 220px = so breit wie der Button daneben. */
  flex: 1 1 160px;
  max-width: 220px;
  border: 1px solid rgba(255, 255, 255, 0.18);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.08);
  color: var(--white);
  padding: 15px 16px;
  font:
    700 16px 'Barlow',
    sans-serif;
}
.entry-plz input::placeholder {
  color: var(--g400);
}
.entry-plz input:focus-visible,
.home-feature-link:focus-visible {
  outline: 3px solid rgba(183, 217, 0, 0.55);
  outline-offset: 3px;
}
.entry-plz .btn-primary {
  border: 0;
  flex: 0 0 auto;
  min-width: 220px;
  justify-content: center;
  padding-inline: 24px;
  white-space: nowrap;
}

.home-feature .btn-primary,
.fv-banner .btn-primary {
  min-width: 220px;
  justify-content: center;
  padding-inline: 24px;
  white-space: nowrap;
}

.entry-plz-feedback {
  flex-basis: 100%;
  margin-top: -4px;
  color: var(--g300);
  font-weight: 700;
  line-height: 1.45;
}
.entry-plz-feedback.is-ok {
  color: var(--green);
}
.entry-plz-feedback.is-warn {
  color: var(--bernstein);
}
.entry-plz-feedback.is-neutral {
  color: var(--g300);
}
.home-feature-link {
  color: var(--green);
  font-weight: 700;
  text-decoration: none;
}
.home-feature-link:hover {
  text-decoration: underline;
}
.foerder-result .fr-row.fr-total {
  border-top: 2px solid rgba(183, 217, 0, 0.65);
  border-bottom: 0;
  padding-top: 14px;
  margin-top: 10px;
}
[data-theme='light'] .fv-banner {
  background: linear-gradient(135deg, #fff8e7, #ffffff);
  border-top-color: rgba(232, 168, 56, 0.28);
}
[data-theme='light'] .fv-content h2 {
  color: var(--color-text-primary);
}
[data-theme='light'] .fv-sub,
[data-theme='light'] .fv-badge-note,
[data-theme='light'] .fv-slot-label {
  color: var(--color-text-secondary);
}
[data-theme='light'] .fv-badge-box {
  background: linear-gradient(135deg, rgba(232, 168, 56, 0.18), rgba(255, 255, 255, 0.88));
  box-shadow: 0 18px 42px rgba(121, 84, 22, 0.16);
}
[data-theme='light'] .home-feature,
[data-theme='light'] .home-feature-alt {
  background: linear-gradient(135deg, #ffffff, #f5f7f8) !important;
  border-top-color: rgba(28, 43, 54, 0.08);
}
[data-theme='light'] .home-feature-body {
  background: transparent;
}
[data-theme='light'] .home-feature-media {
  box-shadow: 0 10px 28px rgba(28, 43, 54, 0.14);
}
[data-theme='light'] .entry-plz input {
  background: #ffffff;
  border-color: rgba(28, 43, 54, 0.24);
  color: var(--color-text-primary);
}
[data-theme='light'] .entry-plz input::placeholder {
  color: #5d6872;
}
[data-theme='light'] .home-feature-link {
  color: #3f5f00;
}
@media (max-width: 860px) {
  .home-feature {
    padding-left: 20px;
    padding-right: 20px;
  }
  .home-feature-body {
    padding-left: 0;
    padding-right: 0;
  }
  .home-feature-inner,
  .home-feature-inner.media-right {
    grid-template-columns: 1fr;
  }
  .home-feature-inner.media-right .home-feature-media {
    order: 0;
  }
  .home-feature-media {
    min-height: 260px;
  }
  /* Trust-Leiste mobil linksbündig wie Hero/Features (vermeidet den
     center↔links-Sprung beim Scrollen); Desktop bleibt zentriert. */
  .trust-strip-inner {
    align-items: flex-start;
  }
  .trust-logos {
    justify-content: flex-start;
  }
  .trust-strip-sub {
    text-align: left;
  }
}
@media (max-width: 560px) {
  .entry-plz {
    flex-direction: column;
  }
  /* Welle 1: Im Column-Layout macht das Basis-flex:1 1 160px die 160px zur HÖHE,
     und flex-grow lässt das Feld mit der Spaltenhöhe mitwachsen (auf iPhones
     unnatürlich hoch). Höhe deckeln ≈ Button, kein vertikales Strecken mehr. */
  .entry-plz input {
    flex: 0 0 auto;
    width: 100%;
    max-width: none;
    min-height: 48px;
    height: auto;
  }
  .entry-plz .btn-primary {
    width: 100%;
    justify-content: center;
  }
}

.detail-final-cta {
  padding: 56px 20px 72px;
  background: var(--section-bg, transparent);
}
.detail-final-cta .section-inner {
  border: 1px solid rgba(183, 217, 0, 0.28);
  border-radius: 24px;
  padding: 34px 28px;
  text-align: center;
  background: linear-gradient(135deg, rgba(183, 217, 0, 0.12), rgba(255, 255, 255, 0.04));
}
.detail-final-cta h2 {
  color: var(--white);
  margin: 0 0 10px;
}
.detail-final-cta p {
  color: var(--g300);
  margin: 0 auto 22px;
  max-width: 620px;
}
.detail-final-cta .btn-primary {
  min-width: 220px;
  justify-content: center;
  white-space: nowrap;
}
[data-theme='light'] .detail-final-cta .section-inner {
  background: linear-gradient(135deg, #ffffff, #f5f7f8);
  border-color: rgba(28, 43, 54, 0.12);
}
[data-theme='light'] .detail-final-cta h2 {
  color: var(--color-text-primary);
}
[data-theme='light'] .detail-final-cta p {
  color: var(--color-text-secondary);
}

@media (prefers-reduced-motion: reduce) {
  .fv-tag::before,
  .fv-badge-box,
  .home-feature-media img {
    animation: none !important;
    transition: none !important;
    transform: none !important;
  }
}

/* ===== Dimensionierungs-Rechner: Ergebnis im Foerderrechner-Design (C22, 2026-06-19) ===== */
.wiz-result-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}
@media (max-width: 560px) {
  .wiz-result-grid {
    grid-template-columns: 1fr;
  }
}
.wiz-brand-panel {
  padding: 20px;
  cursor: pointer;
  transition:
    border-color 0.15s ease,
    box-shadow 0.15s ease;
}
.wiz-brand-panel:hover {
  border-color: var(--green);
}
.foerder-result.wiz-selected {
  border: 2px solid var(--green) !important;
}
[data-theme='light'] .foerder-result.wiz-selected {
  border: 2px solid var(--green) !important;
}
.wiz-brand-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 8px;
  min-height: 24px;
  margin-bottom: 14px;
}
.wiz-brand-logo {
  display: inline-flex;
  align-items: center;
  color: var(--color-text-primary);
}
.wiz-brand-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  background: var(--green);
  color: var(--color-accent-primary-text);
  border-radius: 999px;
  padding: 3px 11px;
  font-family: 'Barlow', sans-serif;
  font-weight: 800;
  font-size: 12px;
  white-space: nowrap;
}
.wiz-brand-satz {
  text-align: center;
  margin-bottom: 14px;
}
.wiz-result-shell {
  display: block;
  padding: 24px;
}
@media (max-width: 560px) {
  .wiz-result-shell {
    padding: 16px;
  }
}

/* Sprint F3/F6/DIN/iPhone Feintuning */
.wizard-btn-next.is-disabled,
.wizard-btn-next:disabled {
  opacity: 0.4;
  cursor: not-allowed;
  transform: none;
  box-shadow: none;
}
.wizard-btn-next.is-disabled:hover,
.wizard-btn-next:disabled:hover {
  background: var(--green);
  transform: none;
  box-shadow: none;
}
.wizard-btn-back.is-disabled,
.wizard-btn-back:disabled {
  opacity: 0.4;
  cursor: not-allowed;
  pointer-events: none;
}

.foerder-toggle-slot,
.foerder-reserved-note,
.foerder-reserved-effective,
#heizungsalterGroup {
  display: block;
  visibility: hidden;
  opacity: 0;
  max-height: 0;
  overflow: hidden;
  pointer-events: none;
  transition: opacity 0.18s ease;
}
.foerder-toggle-slot.is-visible,
.foerder-reserved-note.is-visible,
.foerder-reserved-effective.is-visible,
#heizungsalterGroup.is-visible,
#heizungsalterGroup:not([aria-hidden='true']) {
  visibility: visible;
  opacity: 1;
  max-height: none;
  overflow: visible;
  pointer-events: auto;
}
.foerder-toggle-slot {
  min-height: 92px;
}
.foerder-toggle-slot:not(.is-visible) {
  margin: 0 !important;
  min-height: 0;
}
.foerder-breakdown-slot {
  margin-top: 24px;
  min-height: 188px;
}
.foerder-reserved-note {
  margin-top: 20px;
  min-height: 88px;
  padding: 16px 20px;
  background: rgba(232, 168, 56, 0.1);
  border: 1px solid rgba(232, 168, 56, 0.3);
  border-radius: 10px;
}
.foerder-reserved-effective {
  min-height: 70px;
  background: rgba(255, 255, 255, 0.05);
  border-radius: 8px;
  padding: 10px 14px;
  margin-bottom: 16px;
}
.wiz-din-note {
  margin-top: 18px;
  padding: 16px 18px;
  border: 1px solid rgba(183, 217, 0, 0.22);
  border-radius: 12px;
  background: rgba(183, 217, 0, 0.06);
  color: var(--g300);
  font-size: 13px;
  line-height: 1.6;
  text-align: left;
}
.wiz-din-note strong {
  display: block;
  color: var(--white);
  margin-bottom: 8px;
}
.wiz-din-note p {
  margin: 0;
}
[data-theme='light'] .wiz-din-note {
  background: rgba(183, 217, 0, 0.12);
  border-color: rgba(28, 43, 54, 0.12);
  color: var(--color-text-secondary);
}
[data-theme='light'] .wiz-din-note strong {
  color: var(--color-text-primary);
}

@media (max-width: 768px) {
  nav,
  .mobile-bottom-bar {
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
  }
  nav {
    background: rgba(28, 43, 54, 0.99);
  }
  .mobile-bottom-bar {
    background: rgba(10, 10, 10, 0.99);
  }
  .wizard-section::before,
  .fv-banner::before {
    width: 180px;
    height: 180px;
    opacity: 0.35;
  }
  .wizard-section::before {
    right: -70px;
  }
  .fv-banner::before {
    top: -90px;
    right: -90px;
  }
}

.foerder-reserved-note:not(.is-visible),
.foerder-reserved-effective:not(.is-visible) {
  max-height: none;
  overflow: hidden;
}

/* Rechner-Hub */
.rechner-hub {
  padding-top: 112px;
  background: var(--schiefer);
}
.rechner-hub .section-inner {
  max-width: 1180px;
}
.rechner-intro {
  max-width: 780px;
  margin-bottom: 36px;
}
.rechner-hub .section-lead {
  color: var(--g200);
}
.rechner-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 318px;
  gap: 34px;
  align-items: start;
}
.rechner-main {
  display: grid;
  gap: 18px;
  min-width: 0;
}
.rechner-tool-card {
  position: relative;
  display: grid;
  grid-template-columns: minmax(230px, 0.52fr) minmax(0, 1fr);
  min-height: 226px;
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.04);
  box-shadow: 0 14px 36px rgba(0, 0, 0, 0.18);
  color: inherit;
  text-decoration: none;
  overflow: hidden;
  transition:
    transform 0.2s ease,
    border-color 0.2s ease,
    box-shadow 0.2s ease;
}
.rechner-tool-card:hover {
  transform: translateY(-3px);
  border-color: rgba(183, 217, 0, 0.32);
}
.rechner-tool-card:focus-visible {
  outline: 3px solid var(--green);
  outline-offset: 4px;
}
.rechner-tool-card--primary {
  border-color: rgba(183, 217, 0, 0.34);
  background: rgba(183, 217, 0, 0.07);
}
.rechner-card-art {
  position: relative;
  min-height: 100%;
}
.rechner-dimension-visual {
  color: var(--white);
}
.rechner-wp-unit {
  position: absolute;
  display: block;
  background: currentColor;
  -webkit-mask: url('/funnel-icons/interesse-wp.svg') center / contain no-repeat;
  mask: url('/funnel-icons/interesse-wp.svg') center / contain no-repeat;
}
.rechner-wp-unit-single {
  width: 130px;
  height: 130px;
  left: 50%;
  top: 50%;
  opacity: 1;
  transform: translate(-50%, -50%);
}
.rechner-card-art.guide-visual-funding .guide-icon {
  width: 170px;
  height: 170px;
  max-width: calc(100% - 28px);
}
.rechner-card-art.guide-visual-cost .guide-icon,
.rechner-card-art.guide-visual-cost .guide-icon-img {
  width: 170px;
  height: 170px;
  max-width: calc(100% - 28px);
}
.rechner-price-visual,
.rechner-sound-visual {
  color: var(--white);
}
.rechner-sound-unit {
  position: absolute;
  right: 20%;
  top: 50%;
  display: block;
  width: 80px;
  height: 80px;
  background: currentColor;
  -webkit-mask: url('/funnel-icons/interesse-wp.svg') center / contain no-repeat;
  mask: url('/funnel-icons/interesse-wp.svg') center / contain no-repeat;
  transform: translateY(-50%);
}
.rechner-sound-wave {
  position: absolute;
  display: block;
  border: 4px solid currentColor;
  border-right: 0;
  border-top-left-radius: 999px;
  border-bottom-left-radius: 999px;
  transform: translateY(-50%);
}
.rechner-sound-wave-small {
  right: 48%;
  top: 50%;
  width: 24px;
  height: 36px;
  opacity: 0.96;
}
.rechner-sound-wave-medium {
  right: 58%;
  top: 50%;
  width: 38px;
  height: 58px;
  opacity: 0.72;
}
.rechner-sound-wave-large {
  right: 70%;
  top: 50%;
  width: 54px;
  height: 82px;
  opacity: 0.48;
}
.rechner-card-body {
  display: flex;
  flex-direction: column;
  min-width: 0;
  padding: 20px;
}
.rechner-card-kicker {
  color: var(--green);
  font-size: 13px;
  font-weight: 800;
  letter-spacing: 0.4px;
  text-transform: uppercase;
  margin-bottom: 8px;
}
.rechner-tool-card h2,
.rechner-roadmap h2 {
  color: var(--white);
}
.rechner-tool-card h2 {
  margin: 0 0 8px;
  font-size: clamp(23px, 2.4vw, 30px);
  font-weight: 800;
}
.rechner-tool-card p {
  margin-bottom: 0;
  color: var(--g300);
  font-size: 15px;
  line-height: 1.65;
}
.rechner-card-link {
  margin-top: auto;
  padding-top: 16px;
  color: var(--green);
  font-size: 14px;
  font-weight: 800;
}
.rechner-card-link::after {
  content: ' →';
}
.rechner-sidebar {
  position: sticky;
  top: 88px;
  display: grid;
  gap: 14px;
}
.rechner-roadmap {
  padding: 24px;
  border: 1px solid rgba(255, 255, 255, 0.09);
  border-radius: 10px;
  background: rgba(0, 0, 0, 0.14);
}
.rechner-roadmap h2 {
  margin: 0 0 16px;
  font-size: 22px;
}
.rechner-roadmap-grid {
  display: grid;
  gap: 12px;
}
.rechner-roadmap-card {
  display: grid;
  grid-template-columns: minmax(142px, 0.32fr) minmax(0, 1fr);
  min-height: 132px;
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.04);
}
.rechner-roadmap-art {
  min-height: 132px;
}
.rechner-roadmap-card .guide-icon,
.rechner-roadmap-card .guide-icon-img {
  width: 92px;
  height: 92px;
}
.rechner-roadmap-body {
  display: grid;
  align-content: center;
  gap: 6px;
  min-width: 0;
  padding: 18px;
}
.rechner-roadmap-body h3 {
  margin: 0;
  color: var(--white);
  font-size: 20px;
}
.rechner-roadmap-body p {
  margin: 0;
  color: var(--g400);
  font-size: 14px;
  line-height: 1.5;
}
@media (max-width: 1020px) {
  .rechner-layout {
    grid-template-columns: 1fr;
  }
  .rechner-sidebar {
    position: static;
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}
@media (max-width: 820px) {
  .rechner-hub {
    padding-top: 92px;
  }
  .rechner-sidebar,
  .rechner-roadmap-grid {
    grid-template-columns: 1fr;
  }
  .rechner-tool-card {
    grid-template-columns: minmax(0, 1fr);
  }
  .rechner-card-art {
    min-height: 178px;
  }
  .rechner-roadmap-card {
    grid-template-columns: minmax(0, 1fr);
  }
  .rechner-card-body {
    padding: 20px;
  }
}
@media (max-width: 520px) {
  .rechner-hub {
    padding-left: 18px;
    padding-right: 18px;
  }
  .rechner-card-art {
    min-height: 154px;
  }
  .rechner-wp-unit-single {
    width: 112px;
    height: 112px;
  }
  .rechner-card-art.guide-visual-funding .guide-icon {
    width: 136px;
    height: 136px;
  }
  .rechner-tool-card h2 {
    font-size: 18px;
  }
}
[data-theme='light'] .rechner-hub {
  background: var(--sand);
}
[data-theme='light'] .rechner-tool-card,
[data-theme='light'] .rechner-roadmap,
[data-theme='light'] .rechner-roadmap-card {
  background: var(--surface);
  border-color: rgba(28, 43, 54, 0.12);
  box-shadow: 0 12px 30px rgba(28, 43, 54, 0.08);
}
[data-theme='light'] .rechner-tool-card--primary {
  background: rgba(183, 217, 0, 0.12);
  border-color: rgba(79, 96, 0, 0.28);
}
[data-theme='light'] .rechner-card-kicker {
  color: var(--color-accent-on-light);
}
[data-theme='light'] .rechner-card-link {
  color: var(--color-accent-on-light);
}
[data-theme='light'] .rechner-tool-card h2,
[data-theme='light'] .rechner-roadmap h2,
[data-theme='light'] .rechner-roadmap-body h3 {
  color: var(--nacht);
}
[data-theme='light'] .rechner-tool-card p,
[data-theme='light'] .rechner-roadmap-body p {
  color: var(--g700);
}

/* ===== W4-Konsolidierung: vormals css/_w2.css (Welle 2 — Startseite/Prozess/Kontakt) ===== */
/* ==========================================================================
   _w2.css — Website Runde 2, Welle 2 (Startseite-CTAs, Trust, Bilder, Prozess)
   Scope: index.html (außer <nav>), prozess.html, kontakt.html.
   Konflikt-Vermeidung (Shared-Contracts): neue Styles NUR hier, NICHT in site.css.
   W4 konsolidiert diese Datei später nach site.css.
   Variablen (--green, --schiefer, …) stammen aus tokens.css / site.css.
   ========================================================================== */

/* ── FV-Banner §5-UWG-Disclaimer (kein unbedingtes Versprechen) ─────────── */
/* Sternchen am Claim + Fußnote unterhalb der CTAs; „Voraussetzungen"-Link
   sitzt außerhalb des klickbaren CTA-Labels (a11y/UX, analog W1 anfrage.html). */
.fv-asterisk {
  color: var(--green);
  font-size: 0.55em;
  vertical-align: super;
  font-weight: 800;
  margin-left: 2px;
}
.fv-disclaimer {
  margin-top: 18px;
  max-width: 560px;
  color: var(--g400);
  font-size: 12px;
  line-height: 1.5;
}
.fv-disclaimer-link {
  color: var(--green);
  font-weight: 700;
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 2px;
}
.fv-disclaimer-link:hover {
  color: var(--white);
}
.fv-disclaimer-link:focus-visible {
  outline: 3px solid rgba(183, 217, 0, 0.55);
  outline-offset: 3px;
}
[data-theme='light'] .fv-disclaimer {
  color: var(--color-text-secondary);
}
[data-theme='light'] .fv-disclaimer-link {
  color: #3f5f00;
}
[data-theme='light'] .fv-disclaimer-link:hover {
  color: var(--color-text-primary);
}

/* ── SF2-A2 · Fördervorschuss-Banner: zweiter CTA „Mehr erfahren" ─────────── */
/* site.css kennt `.fv-cta-row .btn-primary` bereits für Mobil (width:100%);
   hier nur das Row-Layout + Angleichen des Ghost-Buttons an den Primary. */
.fv-cta-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 14px;
}
.fv-cta-row .btn-ghost {
  min-height: 52px;
  box-sizing: border-box;
  padding: 14px 26px;
  font-size: 16px;
}
@media (max-width: 768px) {
  .fv-cta-row {
    flex-direction: column;
    align-items: stretch;
  }
  .fv-cta-row .btn-primary,
  .fv-cta-row .btn-ghost {
    width: 100%;
    justify-content: center;
  }
}

/* ── SF2-C1/C2 · Förderungs-Sektion: zwei CTAs nebeneinander ──────────────── */
.home-feature-ctas {
  display: flex;
  flex-wrap: wrap;
  align-items: stretch;
  gap: 12px;
}
/* Das lange Primär-Label („Fördermittel-Rechner starten") passt neben einem
   zweiten Button nicht in die schmale Feature-Textspalte (~430px). Saubere,
   robuste Lösung: zwei volle Breite gestapelte CTAs mit klarer Hierarchie
   (Primär oben, Ghost darunter). min-width:auto hebt site.css min-width:220 auf. */
.home-feature-ctas .btn-primary,
.home-feature-ctas .btn-ghost {
  flex: 1 1 100%;
  min-width: auto;
  justify-content: center;
}
.home-feature-ctas .btn-ghost {
  min-height: 52px;
  box-sizing: border-box;
  padding: 14px 26px;
  font-size: 16px;
}

/* ── SF2-F1 · Prozess: ein Bild statt zwei ────────────────────────────────── */
.pz-figure {
  margin: 0 auto 48px;
  max-width: 800px;
  border-radius: 14px;
  overflow: hidden;
  aspect-ratio: 1600 / 844;
  box-shadow: 0 14px 40px rgba(0, 0, 0, 0.35);
}
.pz-figure img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
[data-theme='light'] .pz-figure {
  box-shadow: 0 12px 32px rgba(28, 43, 54, 0.18);
}

/* ── SF2-F2 · Prozess-Aufklapp-Dynamik (TRIAL) ────────────────────────────── */
/* Ziel: Leistungsumfang sichtbar machen. Karte 1 vorab offen (Desktop),
   dezenter „Mehr"-Puls an zugeklappten Karten, Mobil = Bottom-Sheet.
   Zustände:  .is-open  = Desktop-Inline-Aufklappung (nur ≥769px wirksam)
              .is-sheet = Mobil-Bottom-Sheet (nur ≤768px wirksam)
   Substeps/Checks erben ihr Aussehen aus site.css (.pz-substeps/.pz-sub). */

/* Saubere Oberkante, wenn eine Karte höher (offen) ist als die Nachbarn. */
.pz-steps {
  align-items: start;
}

/* Eyebrow über der Checkliste — verstärkt „das übernehmen wir alles". */
.pz-sub-head {
  margin: 0 0 10px;
  text-align: left;
  color: var(--green);
  font-family: 'Barlow', sans-serif;
  font-weight: 700;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.6px;
}

/* „Details anzeigen" war zu unscheinbar → klar klickbarer Pill-Button. */
.pz-expand-hint {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  margin-top: 14px;
  padding: 8px 16px;
  background: rgba(183, 217, 0, 0.08);
  border: 1px solid rgba(183, 217, 0, 0.28);
  border-radius: 999px;
  color: var(--green);
  font-family: 'Barlow', sans-serif;
  font-weight: 700;
  font-size: 13px;
  line-height: 1;
  cursor: pointer;
  transition:
    background 0.2s ease,
    border-color 0.2s ease,
    box-shadow 0.2s ease;
}
.pz-expand-hint:hover {
  background: rgba(183, 217, 0, 0.16);
  border-color: rgba(183, 217, 0, 0.5);
}
.pz-expand-hint:focus-visible {
  outline: 3px solid rgba(183, 217, 0, 0.55);
  outline-offset: 3px;
}
.pz-hint-chev {
  width: 14px;
  height: 14px;
  flex-shrink: 0;
  transition: transform 0.3s ease;
}
.pz-step.is-open .pz-hint-chev {
  transform: rotate(180deg);
}

/* Dezenter „Mehr"-Puls als Klick-Einladung — nur an zugeklappten Karten. */
@media (prefers-reduced-motion: no-preference) {
  .pz-step:not(.is-open):not(.is-sheet) .pz-expand-hint {
    animation: pzPulse 2.6s ease-in-out infinite;
  }
}
@keyframes pzPulse {
  0%,
  100% {
    box-shadow: 0 0 0 0 rgba(183, 217, 0, 0);
  }
  50% {
    box-shadow: 0 0 0 6px rgba(183, 217, 0, 0.12);
  }
}

/* Sheet-Close + Backdrop sind im neuen Modell (kein Bottom-Sheet) nicht mehr aktiv. */
.pz-sheet-close,
.pz-backdrop {
  display: none;
}

/* Inline-Aufklappung über .is-open — identisches Pattern für Desktop + Mobil
   (GF-Entscheidung 26.06.: kein Bottom-Sheet mehr; Mobile-Karten initial offen,
   zuklappbar via Pille. JS-Init setzt is-open auf Mobile auf alle, auf Desktop
   nur auf die erste Karte). */
.pz-step.is-open .pz-substeps {
  max-height: 500px;
  opacity: 1;
  margin-top: 16px;
}
/* Wenn der User eine explizit geöffnete Karte gerade zugeklappt hat (JS:
   data-just-closed), darf der site.css :hover/:focus-within-Preview die Karte
   NICHT sofort wieder aufpoppen lassen. Marker fällt bei mouseleave weg. */
.pz-step[data-just-closed]:hover .pz-substeps,
.pz-step[data-just-closed]:focus-within .pz-substeps {
  max-height: 0;
  opacity: 0;
  margin-top: 0;
}

@media (max-width: 768px) {
  /* Doppel-Tap-Zoom auf iOS verhindern, damit der Tap unmittelbar greift. */
  .pz-step,
  .pz-expand-hint {
    touch-action: manipulation;
  }
  /* Mobil etwas mehr Höhe (5+ Substeps möglich), Pille rückt etwas weiter rauf. */
  .pz-step.is-open .pz-substeps {
    max-height: 600px;
  }
}

[data-theme='light'] .pz-sub-head {
  color: #3f5f00;
}

/* ── SF2-H1 (Nachschliff) · Kontaktformular: Layout + Foto + Pflicht-Felder ── */
/* Vorher: contact-layout grid blieb auch mobil zweispaltig → rechts neben dem
   Foto schwarzer Bereich (User-Eindruck: „da fehlt ein zweites Bild");
   <picture> war inline → Bild füllte Container nicht voll. */
.contact-layout {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: 40px;
  align-items: stretch;
}
.contact-image {
  position: relative;
  overflow: hidden;
  border-radius: 16px;
  min-height: 460px;
}
.contact-image-picture {
  display: block;
  width: 100%;
  height: 100%;
}
.contact-image-picture img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  border-radius: 16px;
}
.contact-image-caption {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  padding: 20px 24px;
  background: linear-gradient(transparent, rgba(28, 43, 54, 0.95));
  border-radius: 0 0 16px 16px;
}
.contact-image-caption-title {
  color: var(--green);
  font-weight: 700;
  font-size: 14px;
}
.contact-image-caption-sub {
  color: var(--g300);
  font-size: 13px;
  margin-top: 4px;
}

/* Form-Rows: Straße/Hausnr (3:1) und PLZ/Ort (1:2) nebeneinander auf Desktop. */
.contact-form .form-row {
  display: grid;
  gap: 14px;
}
.contact-form .form-row-3-1 {
  grid-template-columns: 3fr 1fr;
}
.contact-form .form-row-1-2 {
  grid-template-columns: 1fr 2fr;
}
.contact-form select {
  width: 100%;
  padding: 12px 14px;
  border: 1px solid rgba(255, 255, 255, 0.18);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.06);
  color: var(--white);
  font-family: 'Barlow', sans-serif;
  font-size: 15px;
}
.contact-form select:focus-visible {
  outline: 3px solid rgba(183, 217, 0, 0.55);
  outline-offset: 2px;
}
.form-optional {
  display: inline-block;
  margin-left: 6px;
  color: var(--g400);
  font-weight: 400;
  font-size: 12px;
  letter-spacing: 0.3px;
}
[data-theme='light'] .contact-form select {
  background: #ffffff;
  border-color: rgba(28, 43, 54, 0.24);
  color: var(--color-text-primary);
}
[data-theme='light'] .form-optional {
  color: #5d6872;
}

/* Mobil: Foto oben, Form unten — kein „fehlendes zweites Bild"-Eindruck mehr. */
@media (max-width: 860px) {
  .contact-layout {
    grid-template-columns: 1fr;
    gap: 24px;
  }
  .contact-image {
    aspect-ratio: 4 / 3;
    min-height: 0;
  }
  .contact-form .form-row,
  .contact-form .form-row-3-1,
  .contact-form .form-row-1-2 {
    grid-template-columns: 1fr;
  }
}

/* ===== W4-Konsolidierung: vormals css/_w3.css (Welle 3 — Preise-Anreicherung) ===== */
/* ===== Welle 3 — minimale Stile für die Preise-Anreicherung =====
   Nur preise.html lädt diese Datei (Intro-Orientierung + Marken-Orientierung).
   Die neuen Artikel-Seiten (Fördervorschuss, Dimensionierung) nutzen die native
   Prosa aus ratgeber.css und brauchen kein eigenes CSS. Alles token-basiert, damit
   Light-Mode automatisch mitläuft. Konsolidierung nach site.css erfolgt in Welle 4. */

/* Intro-Orientierung über den Preiskarten */
.w3-intro-list {
  margin: 4px 0 0;
  padding-left: 20px;
  color: var(--g300);
  font-size: 16px;
  line-height: 1.7;
  max-width: 760px;
}
.w3-intro-list li {
  margin: 0 0 10px;
}
.w3-intro-list strong {
  color: var(--white);
}
.w3-purpose {
  margin: 22px 0 0;
  max-width: 760px;
  color: var(--g300);
  font-size: 16px;
  line-height: 1.7;
}

/* Marken-Orientierung Wolf / Vaillant — native, schlichte Karten */
.w3-brands {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(290px, 1fr));
  gap: 18px;
  margin-top: 20px;
}
.w3-brand-card {
  background: var(--schiefer);
  border: 1px solid var(--g600);
  border-radius: 14px;
  padding: 24px 24px 26px;
}
.w3-brand-card h3 {
  font-family: 'Barlow', sans-serif;
  color: var(--white);
  font-size: 21px;
  margin: 0 0 2px;
}
.w3-brand-sub {
  margin: 0 0 14px;
  color: var(--g400);
  font-size: 14px;
}
.w3-brand-card ul {
  margin: 0;
  padding-left: 20px;
}
.w3-brand-card li {
  margin: 0 0 10px;
  color: var(--g300);
  font-size: 15px;
  line-height: 1.6;
}
.w3-brand-card li:last-child {
  margin-bottom: 0;
}
.w3-brand-card strong {
  color: var(--white);
}
.w3-brand-note {
  margin: 18px 0 0;
  max-width: 820px;
  color: var(--g400);
  font-size: 14px;
  line-height: 1.6;
}
