/* ============================================================
   SHK Website – Stylesheet
   Design: Bild-Karten mit Overlay, Akkordeon mit Bild, Referenz-Stil
   ============================================================ */

:root {
  --blau:          #1a3a5c;
  --blau-hell:     #2a5c8a;
  --blau-sehr-hell:#e8f0f7;
  --blau-akzent:   #2563a8;
  --orange:        #e8610a;
  --orange-hover:  #c9520a;
  --orange-dunkel: #b84d08;
  --dunkel:        #1a1a1a;
  --grau-dunkel:   #333333;
  --grau-mittel:   #666666;
  --grau-hell:     #f4f4f4;
  --weiss:         #ffffff;
  --schatten:      0 2px 12px rgba(0,0,0,0.10);
  --schatten-stark:0 4px 24px rgba(0,0,0,0.18);
  --radius:        6px;
  --radius-gross:  12px;
  --max-breite:    1280px;
  --uebergang:     0.22s ease;
}

/* ---- Reset ---- */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; font-size: 16px; }
body { font-family: 'Segoe UI', system-ui, -apple-system, sans-serif; color: var(--grau-dunkel); background: var(--weiss); line-height: 1.65; }
img { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; }
ul { list-style: none; }

/* ---- Typografie ---- */
h1 { font-size: clamp(1.6rem, 3.5vw, 2.6rem); line-height: 1.2; font-weight: 700; }
h2 { font-size: clamp(1.3rem, 2.8vw, 1.9rem); font-weight: 700; }
h3 { font-size: clamp(1rem, 2vw, 1.3rem); font-weight: 600; }
h4 { font-size: 1.05rem; font-weight: 600; }
p  { margin-bottom: 1rem; }
p:last-child { margin-bottom: 0; }

/* ---- Layout ---- */
.container { max-width: var(--max-breite); margin: 0 auto; padding: 0 1.5rem; }
.section    { padding: 3.5rem 0; }
.section--grau { background: var(--grau-hell); }
.section--blau { background: var(--blau); color: var(--weiss); }
.text-center { text-align: center; }

/* ---- Buttons ---- */
.btn {
  display: inline-flex; align-items: center; gap: .5rem;
  padding: .75rem 1.6rem; border-radius: var(--radius);
  font-weight: 600; font-size: .95rem; cursor: pointer;
  border: 2px solid transparent; transition: all var(--uebergang);
  text-decoration: none !important; white-space: nowrap;
}
.btn--orange  { background: var(--orange);  color: var(--weiss); border-color: var(--orange); }
.btn--orange:hover  { background: var(--orange-hover); border-color: var(--orange-hover); transform: translateY(-1px); }
.btn--blau    { background: var(--blau);    color: var(--weiss); border-color: var(--blau); }
.btn--blau:hover    { background: var(--blau-hell); border-color: var(--blau-hell); }
.btn--weiss   { background: transparent; color: var(--weiss); border-color: var(--weiss); font-size: .85rem; padding: .55rem 1.25rem; }
.btn--weiss:hover   { background: var(--weiss); color: var(--dunkel); }
.btn--outline { background: transparent; color: var(--weiss); border-color: var(--weiss); }
.btn--outline:hover { background: var(--weiss); color: var(--blau); }
.btn--gross   { font-size: 1.05rem; padding: .95rem 2rem; }

/* ================================================================
   NAVIGATION
================================================================ */
.nav {
  background: var(--weiss);
  border-bottom: 3px solid var(--orange);
  position: sticky; top: 0; z-index: 1000;
  box-shadow: 0 2px 8px rgba(0,0,0,0.08);
}
.nav__inner {
  display: flex; align-items: center; justify-content: space-between;
  padding: .7rem 1.5rem; max-width: var(--max-breite); margin: 0 auto; gap: 1rem;
}
.nav__logo { display: flex; align-items: center; gap: .75rem; }
.nav__logo img { height: 52px; width: auto; }
.nav__logo-text { color: var(--blau); font-size: 1.15rem; font-weight: 800; letter-spacing: -.02em; }
.nav__links { display: flex; gap: .1rem; align-items: center; }
.nav__link {
  color: var(--grau-dunkel); padding: .45rem .8rem; border-radius: var(--radius);
  font-size: .88rem; font-weight: 600; text-transform: uppercase; letter-spacing: .04em;
  transition: color var(--uebergang), background var(--uebergang);
}
.nav__link:hover, .nav__link--aktiv { color: var(--orange); text-decoration: none; }

/* Dropdown */
.nav__dropdown { position: relative; align-self: stretch; display: flex; align-items: center; }
.nav__dropdown-menu {
  display: none; position: absolute; top: 100%; left: 0;
  background: var(--weiss); border-radius: var(--radius);
  box-shadow: var(--schatten-stark); min-width: 240px; z-index: 200;
  border-top: 3px solid var(--orange);
  padding: 8px 0 .5rem;
}
.nav__dropdown-menu.sichtbar { display: block; }
.nav__dropdown-item {
  display: flex; align-items: center; gap: .6rem;
  padding: .6rem 1.25rem; color: var(--grau-dunkel); font-size: .88rem;
  transition: background var(--uebergang);
}
.nav__dropdown-item:hover { background: var(--grau-hell); color: var(--orange); text-decoration: none; }
.nav__dropdown-item .item-icon { font-size: 1rem; }

/* Hamburger */
.nav__hamburger {
  display: none; flex-direction: column; gap: 5px;
  background: none; border: none; cursor: pointer; padding: .75rem;
}
.nav__hamburger span { display: block; width: 26px; height: 2px; background: var(--blau); border-radius: 2px; transition: transform var(--uebergang); }

/* Notdienst-Chip in Nav */
.nav__notdienst {
  display: flex; align-items: center; gap: .5rem;
  background: var(--orange); color: var(--weiss);
  padding: .45rem 1rem; border-radius: 50px;
  font-size: .82rem; font-weight: 700; white-space: nowrap;
  text-decoration: none !important;
}
.nav__notdienst:hover { background: var(--orange-hover); }

/* ================================================================
   HERO – Bildslider
================================================================ */
.hero-slider {
  position: relative; overflow: hidden;
  height: min(560px, 55vw); background: var(--blau);
}
.hero-slider__track {
  display: flex; height: 100%;
  transition: transform .7s cubic-bezier(.4,0,.2,1);
}
.hero-slider__slide {
  min-width: 100vw; width: 100vw; height: 100%;
  position: relative; flex-shrink: 0;
}
.hero-slider__slide img {
  width: 100%; height: 100%; object-fit: cover;
}
.hero-slider__slide::after {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(to right, rgba(0,0,0,.55) 0%, rgba(0,0,0,.1) 70%);
}
.hero-slider__text {
  position: absolute; left: 8%; top: 50%; transform: translateY(-50%);
  z-index: 10; color: var(--weiss); max-width: 560px;
}
.hero-slider__badge {
  display: inline-block; background: var(--orange); color: var(--weiss);
  font-size: .75rem; font-weight: 700; text-transform: uppercase; letter-spacing: .1em;
  padding: .3rem .9rem; border-radius: 50px; margin-bottom: .9rem;
}
.hero-slider__titel { font-size: clamp(1.5rem,3.5vw,2.8rem); margin-bottom: .75rem; text-shadow: 0 2px 8px rgba(0,0,0,.3); }
.hero-slider__sub   { font-size: 1.05rem; opacity: .9; margin-bottom: 1.5rem; }
.hero-slider__ctas  { display: flex; gap: .9rem; flex-wrap: wrap; }

/* Slider-Pfeile */
.slider-pfeil {
  position: absolute; top: 50%; transform: translateY(-50%);
  background: rgba(255,255,255,.18); border: none; color: #fff;
  width: 44px; height: 44px; border-radius: 50%; font-size: 1.2rem;
  cursor: pointer; z-index: 20; backdrop-filter: blur(4px);
  transition: background var(--uebergang);
}
.slider-pfeil:hover { background: rgba(255,255,255,.35); }
.slider-pfeil--links  { left: 1.5rem; }
.slider-pfeil--rechts { right: 1.5rem; }

/* Slider-Dots */
.slider-dots {
  position: absolute; bottom: 1rem; left: 50%; transform: translateX(-50%);
  display: flex; gap: .5rem; z-index: 20;
}
.slider-dot {
  width: 8px; height: 8px; border-radius: 50%; background: rgba(255,255,255,.5);
  border: none; cursor: pointer; transition: background var(--uebergang);
}
.slider-dot--aktiv { background: var(--orange); }

/* ================================================================
   INTRO-TEXT UNTER HERO
================================================================ */
.intro {
  padding: 2.5rem 0 1rem;
  border-bottom: 1px solid #e5e5e5;
}
.intro h1 { color: var(--blau); margin-bottom: 1rem; }
.intro p   { color: var(--grau-mittel); max-width: 820px; }

/* ================================================================
   LEISTUNGS-KARTEN (Bild + Overlay)
================================================================ */
.karten-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem;
}

.leistung-karte {
  position: relative; overflow: hidden;
  border-radius: var(--radius-gross);
  aspect-ratio: 4/3;
  background: #111;
  box-shadow: var(--schatten);
  transition: transform var(--uebergang), box-shadow var(--uebergang);
}
.leistung-karte:hover { transform: translateY(-4px); box-shadow: var(--schatten-stark); }

.leistung-karte__bild {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform .5s ease;
}
.leistung-karte:hover .leistung-karte__bild { transform: scale(1.05); }

/* Dunkles Overlay unten */
.leistung-karte__overlay {
  position: absolute; inset: 0;
  background: linear-gradient(to top, rgba(5,5,15,.95) 0%, rgba(5,5,15,.85) 35%, rgba(5,5,15,.4) 65%, transparent 100%);
  display: flex; flex-direction: column; justify-content: flex-end;
  padding: 1.5rem 1.5rem 1.25rem;
  transition: background var(--uebergang);
}

.leistung-karte__kategorie {
  font-size: .72rem; font-weight: 700; letter-spacing: .12em;
  color: rgba(255,255,255,.65); text-transform: uppercase; margin-bottom: .35rem;
}
.leistung-karte__icon { font-size: 1.6rem; margin-bottom: .4rem; }
.leistung-karte__titel {
  font-size: 1.25rem; font-weight: 800; color: var(--orange);
  text-transform: uppercase; letter-spacing: .04em; margin-bottom: .5rem;
}
.leistung-karte__text {
  font-size: .85rem; color: rgba(255,255,255,.85); line-height: 1.5;
  display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical;
  overflow: hidden; margin-bottom: .9rem;
}
.leistung-karte__link {
  display: inline-flex; align-items: center; gap: .4rem;
  background: transparent; border: 1.5px solid rgba(255,255,255,.7);
  color: var(--weiss); font-size: .78rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: .08em;
  padding: .45rem 1rem; border-radius: var(--radius);
  transition: all var(--uebergang); width: fit-content;
  text-decoration: none !important;
}
.leistung-karte__link:hover { background: var(--orange); border-color: var(--orange); }

/* ================================================================
   KLEINE KARTEN
================================================================ */
.karten-grid--klein {
  grid-template-columns: repeat(3, 1fr);
  gap: 1rem;
}
.leistung-karte--klein { aspect-ratio: 3/2; }
.leistung-karte--klein .leistung-karte__titel { font-size: 1rem; }
.leistung-karte--klein .leistung-karte__text  { -webkit-line-clamp: 2; }

/* ================================================================
   STATS-LEISTE
================================================================ */
.stats {
  background: var(--blau); color: var(--weiss); padding: 2rem 0;
  border-top: 4px solid var(--orange);
}
.stats__grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 1rem; text-align: center; }
.stat__zahl  { font-size: 2.4rem; font-weight: 800; color: var(--orange); line-height: 1; }
.stat__label { font-size: .88rem; opacity: .82; margin-top: .35rem; }

/* ================================================================
   SEKTION-HEADER
================================================================ */
.section-header { margin-bottom: 2.5rem; }
.section-header--center { text-align: center; }
.section-header__vorspann {
  display: block; color: var(--orange); font-size: .78rem;
  font-weight: 700; text-transform: uppercase; letter-spacing: .12em; margin-bottom: .4rem;
}
.section-header__titel { color: var(--blau); margin-bottom: .6rem; }
.section-header__text  { color: var(--grau-mittel); max-width: 640px; }

/* ================================================================
   AKKORDEON
================================================================ */
.akkordeon { border: 1px solid #d8dfe8; border-radius: var(--radius-gross); overflow: hidden; margin-bottom: 1rem; }

.akkordeon__header {
  display: flex; justify-content: space-between; align-items: center;
  padding: 1.1rem 1.5rem; background: var(--blau); cursor: pointer;
  transition: background var(--uebergang); gap: 1rem; border: none; width: 100%; text-align: left;
}
.akkordeon__header:hover { background: var(--blau-hell); }
.akkordeon.offen .akkordeon__header { background: var(--blau-hell); }

.akkordeon__header-titel {
  font-size: 1.05rem; font-weight: 600; color: var(--weiss); margin: 0;
}
.akkordeon__pfeil {
  color: var(--orange); font-size: 1.3rem; font-weight: 800;
  flex-shrink: 0; transition: transform var(--uebergang); line-height: 1;
}

.akkordeon__body {
  display: none; padding: 2rem 1.75rem;
  background: var(--weiss); border-top: 2px solid var(--orange);
}
.akkordeon.offen .akkordeon__body { display: block; }

.akkordeon__inhalt {
  display: grid; grid-template-columns: 1fr 1fr; gap: 2rem; align-items: start;
}
.akkordeon__inhalt--nur-text { grid-template-columns: 1fr; }
.akkordeon__text p { color: var(--grau-mittel); font-size: .95rem; }
.akkordeon__text p a { color: var(--blau-akzent); }
.akkordeon__bild img {
  width: 100%; border-radius: var(--radius);
  box-shadow: var(--schatten); object-fit: cover;
  max-height: 280px;
}

.akkordeon__meta { margin-top: 1.25rem; display: flex; flex-direction: column; gap: .6rem; }
.akkordeon__meta-zeile { display: flex; gap: .5rem; font-size: .88rem; color: var(--grau-mittel); }
.akkordeon__meta-zeile strong { color: var(--blau); min-width: 110px; }

.vorteile-liste { margin: .75rem 0; }
.vorteile-liste li, .nachteile-liste li { font-size: .9rem; color: var(--grau-mittel); padding: .25rem 0; }
.vorteile-liste li::before { content: "✓ "; color: #27ae60; font-weight: 700; }
.nachteile-liste li::before { content: "→ "; color: var(--grau-mittel); }

.foerder-box {
  background: var(--blau-sehr-hell); border-left: 4px solid var(--orange);
  border-radius: 0 var(--radius) var(--radius) 0;
  padding: .9rem 1.25rem; font-size: .9rem; margin-top: 1rem;
}
.foerder-box strong { color: var(--blau); }

/* ================================================================
   ABLAUF-SCHRITTE
================================================================ */
.ablauf-liste { display: grid; grid-template-columns: repeat(auto-fit,minmax(210px,1fr)); gap: 1.25rem; }
.ablauf-schritt {
  background: var(--weiss); border-radius: var(--radius-gross);
  padding: 1.5rem; box-shadow: var(--schatten); position: relative;
  border-top: 3px solid var(--orange);
}
.ablauf-schritt__nummer {
  display: inline-flex; align-items: center; justify-content: center;
  width: 40px; height: 40px; background: var(--orange); color: var(--weiss);
  border-radius: 50%; font-weight: 800; font-size: 1.05rem; margin-bottom: .9rem;
}
.ablauf-schritt__titel { color: var(--blau); margin-bottom: .45rem; font-size: 1rem; }
.ablauf-schritt__text  { font-size: .88rem; color: var(--grau-mittel); }

/* ================================================================
   FEATURES
================================================================ */
.features-grid { display: grid; grid-template-columns: repeat(auto-fit,minmax(240px,1fr)); gap: 1.5rem; }
.feature       { display: flex; gap: 1rem; align-items: flex-start; }
.feature__icon { font-size: 1.7rem; flex-shrink: 0; margin-top: .1rem; }
.feature__titel { font-weight: 600; color: var(--blau); margin-bottom: .2rem; }
.feature__text  { font-size: .88rem; color: var(--grau-mittel); }

/* ================================================================
   ZERTIFIKATE
================================================================ */
.zertifikate { display: flex; gap: 1rem; flex-wrap: wrap; align-items: center; justify-content: center; }
.zertifikat-badge {
  background: var(--weiss); border: 2px solid #d0d8e4;
  border-radius: var(--radius); padding: .5rem 1.1rem;
  font-size: .82rem; font-weight: 700; color: var(--blau);
}

/* ================================================================
   BEWERTUNGS-BOX
================================================================ */
.bewertung-box {
  background: var(--weiss); border-radius: var(--radius-gross);
  padding: 1.25rem 1.75rem; box-shadow: var(--schatten);
  display: inline-flex; align-items: center; gap: 1.25rem;
}
.bewertung-box__sterne { color: #f5a623; font-size: 1.4rem; letter-spacing: 2px; }
.bewertung-box__zahl   { font-size: 2rem; font-weight: 800; color: var(--blau); }
.bewertung-box__label  { font-size: .82rem; color: var(--grau-mittel); }

/* ================================================================
   CTA-BANNER
================================================================ */
.cta-banner {
  background: linear-gradient(135deg,var(--blau) 0%,var(--blau-hell) 100%);
  color: var(--weiss); padding: 3rem 0;
}
.cta-banner__inner {
  display: flex; align-items: center; justify-content: space-between;
  gap: 2rem; flex-wrap: wrap;
}
.cta-banner__titel { font-size: clamp(1.2rem,2.8vw,1.7rem); margin-bottom: .4rem; }
.cta-banner__text  { opacity: .85; }
.cta-banner__buttons { display: flex; gap: 1rem; flex-wrap: wrap; flex-shrink: 0; }

/* ================================================================
   NOTDIENST-BANNER
================================================================ */
.notdienst-banner { background: var(--orange); color: var(--weiss); padding: 1.75rem 0; text-align: center; }
.notdienst-banner__nummer { font-size: clamp(1.8rem,4vw,2.6rem); font-weight: 800; display: block; margin: .4rem 0; }
.notdienst-banner__nummer a { color: inherit; }
.telefon-gross {
  display: inline-flex; align-items: center; gap: .75rem;
  background: var(--orange); color: var(--weiss); padding: 1rem 2rem;
  border-radius: 50px; font-size: 1.4rem; font-weight: 800;
  box-shadow: 0 4px 20px rgba(232,97,10,.4); transition: transform var(--uebergang);
  text-decoration: none !important;
}
.telefon-gross:hover { transform: scale(1.03); }

/* ================================================================
   LEISTUNGS-HERO (Unterseite)
================================================================ */
.leistung-hero {
  background: var(--blau); color: var(--weiss); padding: 3rem 0 2.5rem;
  position: relative; overflow: hidden;
}
.leistung-hero::before {
  content: ''; position: absolute; right: 0; top: 0; bottom: 0; width: 40%;
  background: rgba(255,255,255,.04);
  clip-path: polygon(15% 0, 100% 0, 100% 100%, 0% 100%);
}
.leistung-hero__breadcrumb { font-size: .82rem; opacity: .65; margin-bottom: .9rem; }
.leistung-hero__breadcrumb a { color: inherit; }
.leistung-hero__breadcrumb a:hover { opacity: 1; }
.leistung-hero__icon { font-size: 2.8rem; margin-bottom: .6rem; display: block; }
.leistung-hero__titel { margin-bottom: .6rem; }
.leistung-hero__untertitel { opacity: .85; font-size: 1.05rem; max-width: 600px; }

/* Hero mit Bild (Leistungsseite) */
.leistung-hero--bild {
  min-height: min(520px, 55vw); display: flex; align-items: flex-end;
  background-size: cover; background-position: center top;
}
.leistung-hero--bild::after {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(to right, rgba(10,20,40,.85) 0%, rgba(10,20,40,.4) 100%);
  z-index: 0;
}
.leistung-hero--bild .container { position: relative; z-index: 1; padding-bottom: 2.5rem; }

/* ================================================================
   FAQ
================================================================ */
.faq-liste { max-width: 800px; margin: 0 auto; }
.faq-item  { border-bottom: 1px solid #e0e0e0; }
.faq-item__frage {
  padding: 1.1rem 0; cursor: pointer; font-weight: 600; color: var(--blau);
  display: flex; justify-content: space-between; align-items: center; gap: 1rem;
}
.faq-item__pfeil { color: var(--orange); transition: transform var(--uebergang); flex-shrink: 0; }
.faq-item.offen .faq-item__pfeil { transform: rotate(180deg); }
.faq-item__antwort { display: none; padding-bottom: 1.1rem; color: var(--grau-mittel); font-size: .95rem; }
.faq-item.offen .faq-item__antwort { display: block; }

/* ================================================================
   REFERENZ-KARTEN
================================================================ */
.referenzen-grid { display: grid; grid-template-columns: repeat(auto-fit,minmax(290px,1fr)); gap: 1.5rem; }
.referenz-card   { background: var(--weiss); border-radius: var(--radius-gross); box-shadow: var(--schatten); overflow: hidden; }
.referenz-card__bild { height: 190px; background: var(--grau-hell); display: flex; align-items: center; justify-content: center; font-size: 3rem; overflow: hidden; }
.referenz-card__bild img { width: 100%; height: 100%; object-fit: cover; }
.referenz-card__inhalt { padding: 1.4rem; }
.referenz-card__zitat { font-style: italic; color: var(--grau-mittel); font-size: .9rem; border-left: 3px solid var(--orange); padding-left: .9rem; margin-top: .6rem; }
.referenz-card__author { font-size: .8rem; color: var(--grau-mittel); margin-top: .4rem; }

/* ================================================================
   TEAM
================================================================ */
.team-grid { display: grid; grid-template-columns: repeat(auto-fit,minmax(180px,1fr)); gap: 1.5rem; }
.team-card { text-align: center; }
.team-card__foto { width: 110px; height: 110px; border-radius: 50%; background: var(--blau-sehr-hell); margin: 0 auto 1rem; display: flex; align-items: center; justify-content: center; font-size: 2.2rem; overflow: hidden; }
.team-card__foto img { width: 100%; height: 100%; object-fit: cover; }
.team-card__name { font-weight: 700; color: var(--blau); }
.team-card__rolle { font-size: .82rem; color: var(--grau-mittel); }

/* ================================================================
   STELLEN
================================================================ */
.stellen-grid { display: grid; grid-template-columns: repeat(auto-fit,minmax(290px,1fr)); gap: 1.5rem; }
.stelle-card  { background: var(--weiss); border-radius: var(--radius-gross); box-shadow: var(--schatten); padding: 1.75rem; border-left: 4px solid var(--orange); }
.stelle-card__art { display: inline-block; background: var(--blau-sehr-hell); color: var(--blau); font-size: .75rem; font-weight: 700; padding: .2rem .7rem; border-radius: 50px; margin-bottom: .6rem; }
.stelle-card__titel { color: var(--blau); margin-bottom: .5rem; }

/* ================================================================
   KONTAKT
================================================================ */
.kontakt-grid { display: grid; grid-template-columns: 1.5fr 1fr; gap: 2.5rem; align-items: flex-start; }
.kontakt-info__item { display: flex; gap: .9rem; align-items: flex-start; margin-bottom: 1.4rem; }
.kontakt-info__icon { font-size: 1.4rem; flex-shrink: 0; }
.kontakt-info__label { font-size: .75rem; text-transform: uppercase; letter-spacing: .05em; color: var(--grau-mittel); }
.kontakt-info__wert  { font-weight: 600; color: var(--blau); font-size: 1.02rem; }
.kontakt-info__wert a { color: inherit; }

/* Formular */
.form-karte { background: var(--weiss); border-radius: var(--radius-gross); box-shadow: var(--schatten-stark); padding: 2.25rem; }
.form-gruppe { margin-bottom: 1.15rem; }
.form-gruppe label { display: block; margin-bottom: .3rem; font-size: .88rem; font-weight: 600; }
.form-gruppe input, .form-gruppe select, .form-gruppe textarea {
  width: 100%; padding: .7rem 1rem; border: 2px solid #dde3ec;
  border-radius: var(--radius); font-size: .95rem; font-family: inherit;
  transition: border-color var(--uebergang); background: var(--weiss);
}
.form-gruppe input:focus, .form-gruppe select:focus, .form-gruppe textarea:focus { outline: none; border-color: var(--blau); }
.form-gruppe textarea { resize: vertical; min-height: 120px; }
.form-gruppe--checkbox { display: flex; align-items: flex-start; gap: .7rem; font-size: .85rem; }
.form-gruppe--checkbox input { width: auto; margin-top: .15rem; flex-shrink: 0; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }

/* ================================================================
   KALKULATOR
================================================================ */
.kalkulator { background: var(--weiss); border-radius: var(--radius-gross); box-shadow: var(--schatten-stark); padding: 2.25rem; max-width: 700px; margin: 0 auto; }
.kalkulator__ergebnis { background: var(--blau-sehr-hell); border-radius: var(--radius); padding: 1.4rem; margin-top: 1.4rem; display: none; }
.kalkulator__ergebnis.sichtbar { display: block; }
.kalkulator__preis { font-size: 1.9rem; font-weight: 800; color: var(--blau); }
.kalkulator-formular { display: flex; flex-direction: column; gap: 1.1rem; }
.kalk-karte { background: var(--weiss); border: 2px solid var(--blau); border-radius: var(--radius-gross); padding: 1.5rem; }
.kalk-karte--grau { border-color: var(--grau-mittel); }
.kalk-karte__titel { color: var(--blau); font-size: 1rem; margin-bottom: 1rem; }
.kalk-karte--grau .kalk-karte__titel { color: var(--grau-mittel); }
.kalk-karte__zeile { display: flex; justify-content: space-between; padding: .4rem 0; border-bottom: 1px solid var(--grau-hell); font-size: .9rem; }
.kalk-karte__zeile--gesamt { border-top: 2px solid var(--blau); border-bottom: none; padding-top: .75rem; margin-top: .25rem; font-weight: 700; }

/* ================================================================
   FOOTER
================================================================ */
.footer { background: #111827; color: rgba(255,255,255,.8); padding: 3.5rem 0 0; }
.footer__grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 2.5rem; margin-bottom: 2.5rem; }
.footer__logo { display: flex; align-items: center; gap: .75rem; margin-bottom: 1rem; }
.footer__logo img { height: 40px; width: auto; }
.footer__logo-text { color: var(--weiss); font-size: 1.1rem; font-weight: 700; }
.footer__beschreibung { font-size: .88rem; opacity: .65; max-width: 260px; }
.footer__titel { color: var(--weiss); font-size: .82rem; font-weight: 700; text-transform: uppercase; letter-spacing: .08em; margin-bottom: .9rem; }
.footer__liste li { margin-bottom: .45rem; }
.footer__liste a { color: inherit; font-size: .88rem; transition: color var(--uebergang); }
.footer__liste a:hover { color: var(--weiss); text-decoration: none; }
.footer__kontakt-item { display: flex; align-items: flex-start; gap: .55rem; font-size: .88rem; margin-bottom: .55rem; }
.footer__kontakt-item a { color: inherit; }
.footer__zertifikate { display: flex; gap: .6rem; flex-wrap: wrap; margin-top: .9rem; }
.footer__zertifikat { background: rgba(255,255,255,.1); border-radius: var(--radius); padding: .25rem .65rem; font-size: .72rem; color: rgba(255,255,255,.75); }
.footer__bottom { border-top: 1px solid rgba(255,255,255,.1); padding: 1.1rem 0; display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 1rem; font-size: .82rem; opacity: .55; }
.footer__bottom a { color: inherit; }
.footer__bottom a:hover { opacity: 1; }
.footer__orange-bar { height: 4px; background: var(--orange); }

/* ================================================================
   RECHTLICHES
================================================================ */
.rechtliches { max-width: 820px; margin: 0 auto; }
.rechtliches h2 { color: var(--blau); margin: 2rem 0 .6rem; font-size: 1.25rem; }
.rechtliches h3 { color: var(--blau); margin: 1.4rem 0 .4rem; font-size: 1.05rem; }
.rechtliches p, .rechtliches li { color: var(--grau-mittel); font-size: .93rem; }
.rechtliches ul { list-style: disc; padding-left: 1.4rem; margin-bottom: .9rem; }

/* ================================================================
   STICKY NOTDIENST-BUTTON (Mobile)
================================================================ */
.sticky-notdienst {
  display: none; position: fixed; bottom: 1rem; left: 50%; transform: translateX(-50%);
  z-index: 999; background: var(--orange); color: var(--weiss);
  padding: .8rem 1.75rem; border-radius: 50px; font-weight: 700; font-size: .95rem;
  box-shadow: 0 4px 18px rgba(0,0,0,.25); text-decoration: none !important; white-space: nowrap;
  align-items: center; gap: .5rem;
}

/* ================================================================
   FÖRDER-WARNUNG
================================================================ */
.foerder-warnung {
  background: var(--orange); color: var(--weiss); padding: 1.25rem 0;
}
.foerder-warnung__inner { display: flex; gap: 1rem; align-items: center; flex-wrap: wrap; }

/* ================================================================
   LEGAL PAGES
================================================================ */
.legal-text { max-width: 780px; }
.legal-text h2 { color: var(--blau); margin: 2rem 0 .5rem; font-size: 1.15rem; }
.legal-text p { color: var(--grau-mittel); margin-bottom: .75rem; line-height: 1.7; }
.legal-text a { color: var(--blau); }

/* ================================================================
   KONTAKT KARTEN
================================================================ */
.kontakt-sidebar { position: sticky; top: 5rem; }
.kontakt-karten-liste { display: flex; flex-direction: column; gap: .6rem; }
.kontakt-karte { display: flex; gap: .75rem; align-items: flex-start; padding: .85rem 1rem; background: var(--grau-hell); border-radius: var(--radius); }
.kontakt-karte__icon { font-size: 1.2rem; flex-shrink: 0; line-height: 1.5; }
.kontakt-karte strong { display: block; margin-bottom: .1rem; color: var(--blau); font-size: .88rem; }
.kontakt-karte p { margin: 0; font-size: .9rem; }
.kontakt-karte a { color: var(--blau-dunkel); font-weight: 600; }
.kontakt-karte__meta { font-size: .78rem !important; color: var(--grau-mittel); margin-top: .1rem !important; }

/* ================================================================
   VERTRAUEN CHIPS
================================================================ */
.vertrauen-chip { display: inline-block; background: var(--blau-sehr-hell); color: var(--blau); border-radius: 20px; padding: .35rem .9rem; font-size: .82rem; font-weight: 600; }
.vertrauen-chip--gross { font-size: .9rem; padding: .5rem 1.1rem; }

/* ================================================================
   TEAM KARTEN
================================================================ */
.team-karte { background: var(--weiss); border-radius: var(--radius-gross); overflow: hidden; box-shadow: var(--schatten); }
.team-karte__foto { width: 100%; height: 220px; object-fit: cover; }
.team-karte__info { padding: 1.25rem 1.5rem; }
.team-karte__name { font-size: 1.05rem; font-weight: 700; color: var(--blau); margin-bottom: .15rem; }
.team-karte__rolle { font-size: .82rem; color: var(--orange); font-weight: 600; text-transform: uppercase; margin-bottom: .5rem; }
.team-karte__text { color: var(--grau-mittel); font-size: .88rem; }

/* ================================================================
   INFO KARTEN
================================================================ */
.info-karte { background: var(--weiss); border-radius: var(--radius-gross); padding: 1.75rem; box-shadow: var(--schatten); }
.info-karte h3 { color: var(--blau); margin-bottom: .5rem; }
.info-karte p { color: var(--grau-mittel); font-size: .9rem; }

/* ================================================================
   BEWERTUNGS KARTEN
================================================================ */
.bewertungs-karte { background: var(--weiss); border-radius: var(--radius-gross); padding: 1.75rem; box-shadow: var(--schatten); border-top: 3px solid var(--orange); }
.bewertungs-karte__sterne { color: var(--orange); font-size: 1.2rem; margin-bottom: .75rem; }
.bewertungs-karte__text { color: var(--grau-mittel); font-style: italic; margin-bottom: .75rem; line-height: 1.6; }
.bewertungs-karte__name { font-size: .82rem; font-weight: 600; color: var(--blau); }

/* ================================================================
   ANIMATIONEN
================================================================ */
@keyframes einblenden { from { opacity:0; transform:translateY(18px); } to { opacity:1; transform:translateY(0); } }
.einblenden { animation: einblenden .45s ease forwards; }

/* ================================================================
   RESPONSIVE
================================================================ */
@media (max-width: 1024px) {
  .karten-grid { grid-template-columns: repeat(2,1fr); }
  .stats__grid  { grid-template-columns: repeat(2,1fr); }
  .footer__grid { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 768px) {
  /* --- Navigation --- */
  .nav__links { display: none; }
  .nav__links.offen {
    display: flex; flex-direction: column;
    position: absolute; top: 100%; left: 0; right: 0;
    background: var(--weiss); padding: 1rem; gap: .2rem;
    box-shadow: var(--schatten-stark); border-top: 3px solid var(--orange);
  }
  .nav__dropdown-menu { position: static; box-shadow: none; background: var(--grau-hell); margin: .2rem 0; }
  .nav__hamburger { display: flex; padding: .75rem; }
  .nav__inner { position: relative; flex-wrap: wrap; }
  .nav__notdienst { display: none; }

  /* --- Hero Slider --- */
  .hero-slider { height: min(420px, 75vw); }
  .hero-slider__text { left: 5%; max-width: 90%; }
  .hero-slider__sub { font-size: .9rem; margin-bottom: 1rem; }
  .hero-slider__ctas { gap: .6rem; }
  .hero-slider__ctas .btn--gross { font-size: .88rem; padding: .65rem 1.25rem; }
  .slider-pfeil { width: 36px; height: 36px; font-size: 1rem; }
  .slider-pfeil--links { left: .75rem; }
  .slider-pfeil--rechts { right: .75rem; }

  /* --- Leistungs-Hero mit Bild --- */
  .leistung-hero--bild { min-height: 320px; align-items: flex-end; }

  /* --- Section --- */
  .section { padding: 2.75rem 0; }

  /* --- Karten-Grids --- */
  .karten-grid { grid-template-columns: 1fr; }
  .karten-grid--klein { grid-template-columns: repeat(2,1fr); }
  /* Text auf Mobile nicht abschneiden */
  .leistung-karte__text { -webkit-line-clamp: unset; overflow: visible; display: block; }
  .leistung-karte { aspect-ratio: auto; min-height: 280px; }

  /* --- Akkordeon --- */
  .akkordeon__inhalt { grid-template-columns: 1fr; }
  .akkordeon__bild { order: -1; }
  .akkordeon__body { padding: 1.5rem 1.25rem; }

  /* --- Stats, Kontakt, Form --- */
  .stats__grid { grid-template-columns: repeat(2,1fr); }
  .kontakt-grid { grid-template-columns: 1fr; }
  .kontakt-sidebar { position: static; }
  .form-row { grid-template-columns: 1fr; }

  /* iOS Safari: verhindert Auto-Zoom */
  .form-gruppe input,
  .form-gruppe select,
  .form-gruppe textarea { font-size: 1rem; }

  /* --- CTA-Banner --- */
  .cta-banner__inner { flex-direction: column; text-align: center; }
  .cta-banner__buttons { flex-direction: column; width: 100%; }
  .cta-banner__buttons .btn { width: 100%; justify-content: center; }

  /* --- Footer --- */
  .footer__grid { grid-template-columns: 1fr; }

  /* --- Sticky Notdienst --- */
  .sticky-notdienst { display: flex; }
}

@media (max-width: 480px) {
  /* --- Hero Slider --- */
  .hero-slider { height: 380px; }
  .hero-slider__sub { display: none; }
  .hero-slider__ctas { flex-direction: column; align-items: flex-start; gap: .5rem; }
  .hero-slider__badge { font-size: .7rem; margin-bottom: .5rem; }
  .hero-slider__titel { margin-bottom: .5rem; }

  /* --- Leistungs-Hero mit Bild --- */
  .leistung-hero--bild { min-height: 280px; }
  .leistung-hero__icon { font-size: 2rem; }

  /* --- Kleine Karten einspaltig --- */
  .karten-grid--klein { grid-template-columns: 1fr; }

  /* --- Akkordeon Padding --- */
  .akkordeon__header { padding: .9rem 1rem; }
  .akkordeon__body { padding: 1.25rem 1rem; }

  /* --- Section Padding --- */
  .section { padding: 2rem 0; }
  .section-header { margin-bottom: 1.75rem; }

  /* --- Buttons kompakter --- */
  .btn--gross { font-size: .95rem; padding: .85rem 1.5rem; }

  /* --- Stats --- */
  .stat__zahl { font-size: 2rem; }
}
