/* ============================================================
   S.T.A Kanal- & Rohrreinigung – zentrales Stylesheet
   Farbpalette aus dem Firmenlogo gesampelt:
   Stahlblau #385880 · Hellblau #A8C8E0 · Anthrazit #404850 · Rot #B81020
   ============================================================ */

@font-face {
  font-family: "Inter";
  src: url("../fonts/inter-latin-wght-normal.woff2") format("woff2-variations");
  font-weight: 100 900;
  font-style: normal;
  font-display: swap;
}

:root {
  --marine: #1e3450;
  --marine-tief: #152741;
  --blau: #385880;
  --blau-hover: #2c4768;
  --himmel: #a8c8e0;
  --eis: #eef4fa;
  --linie: #d9e4ef;
  --rot: #b81020;
  --rot-hover: #940c19;
  --tinte: #28313b;
  --grau: #5c6874;
  --weiss: #ffffff;
  --radius: 14px;
  --radius-s: 10px;
  --schatten: 0 10px 30px rgba(30, 52, 80, 0.12);
  --schatten-s: 0 4px 14px rgba(30, 52, 80, 0.1);
  --schrift: "Inter", system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  --leiste-h: 62px;
}

* { box-sizing: border-box; }

html {
  scroll-behavior: smooth;
  -webkit-text-size-adjust: 100%;
}

body {
  margin: 0;
  font-family: var(--schrift);
  font-size: 1rem;
  line-height: 1.65;
  color: var(--tinte);
  background: var(--weiss);
  padding-bottom: calc(var(--leiste-h) + env(safe-area-inset-bottom));
}

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

a { color: var(--blau); }
a:hover { color: var(--blau-hover); }

h1, h2, h3, h4 {
  line-height: 1.22;
  color: var(--marine);
  font-weight: 800;
  letter-spacing: -0.015em;
  margin: 0 0 0.5em;
}
h1 { font-size: clamp(1.85rem, 4.2vw, 2.75rem); }
h2 { font-size: clamp(1.45rem, 3vw, 2.05rem); }
h3 { font-size: 1.12rem; }

.wrap { max-width: 1200px; margin-inline: auto; padding-inline: 20px; }
.wrap-eng { max-width: 840px; }

.skip {
  position: absolute; left: -9999px; top: 0;
  background: var(--marine); color: #fff; padding: 10px 18px; z-index: 200;
  border-radius: 0 0 var(--radius-s) 0;
}
.skip:focus { left: 0; color: #fff; }

/* ---------- Icons ---------- */
.icon { display: inline-flex; flex: none; }
.icon svg { width: 1.25em; height: 1.25em; }
.icon-s svg { width: 1em; height: 1em; }
.icon-g {
  width: 52px; height: 52px; border-radius: 14px;
  background: var(--eis); color: var(--blau);
  display: inline-flex; align-items: center; justify-content: center;
}
.icon-g svg { width: 26px; height: 26px; }

/* ---------- Buttons ---------- */
.btn {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 0.78em 1.35em;
  border-radius: var(--radius-s);
  font-weight: 650; text-decoration: none; line-height: 1.25;
  border: 2px solid transparent;
  transition: transform 0.15s ease, box-shadow 0.15s ease, background 0.15s ease;
}
.btn:hover { transform: translateY(-1px); }
.btn-gross { padding: 0.95em 1.6em; font-size: 1.05rem; }
.btn-rot {
  background: var(--rot); color: #fff !important;
  box-shadow: 0 8px 20px rgba(184, 16, 32, 0.3);
}
.btn-rot:hover { background: var(--rot-hover); }
.btn-blau { background: var(--blau); color: #fff !important; box-shadow: var(--schatten-s); }
.btn-blau:hover { background: var(--blau-hover); }
.btn-hell { background: #fff; color: var(--marine) !important; box-shadow: var(--schatten-s); }
.btn-hell:hover { background: var(--eis); }

/* ---------- Topbar ---------- */
.topbar {
  background: var(--marine-tief); color: rgba(255, 255, 255, 0.88);
  font-size: 0.86rem;
}
.topbar-innen {
  display: flex; justify-content: space-between; align-items: center;
  gap: 16px; min-height: 38px; flex-wrap: wrap;
}
.topbar p { margin: 0; display: flex; align-items: center; gap: 7px; }
.topbar-tel { display: flex; gap: 22px; }
.topbar a { color: #fff; text-decoration: none; display: inline-flex; align-items: center; gap: 7px; font-weight: 600; }
.topbar a:hover { color: var(--himmel); }
.topbar-notruf { color: #ffb3ba !important; }
.topbar-notruf:hover { color: #ffd6da !important; }

/* ---------- Header ---------- */
.kopfleiste {
  position: sticky; top: 0; z-index: 100;
  background: #fff;
  border-bottom: 1px solid var(--linie);
}
.kopfleiste.gescrollt { box-shadow: 0 6px 24px rgba(30, 52, 80, 0.12); }
.kopf-innen {
  display: flex; align-items: center; gap: 26px;
  min-height: 82px;
}
.logo { flex: none; display: flex; }
.logo img { width: auto; height: 52px; }

.hauptnav { margin-left: auto; }
.hauptnav > ul {
  list-style: none; margin: 0; padding: 0;
  display: flex; align-items: center; gap: 2px;
}
.hauptnav li { position: relative; }
.hauptnav a {
  display: block; padding: 10px 11px;
  color: var(--tinte); text-decoration: none; font-weight: 600; font-size: 0.95rem;
  border-radius: 8px; white-space: nowrap;
}
.hauptnav a:hover, .hauptnav a.aktiv, .hauptnav li.aktiv > a { color: var(--blau); background: var(--eis); }
.nav-notdienst > a { color: var(--rot); }
.nav-notdienst > a:hover { color: var(--rot-hover); background: #fbeaec; }

.sub-toggle {
  border: 0; background: none; padding: 4px; margin-left: -8px;
  color: var(--grau); cursor: pointer; vertical-align: middle;
  border-radius: 6px; display: inline-flex;
}
.sub-toggle svg { width: 15px; height: 15px; transition: transform 0.2s; }
.hat-sub { display: flex; align-items: center; }

.submenu {
  list-style: none; margin: 0; padding: 10px;
  position: absolute; top: 100%; left: 0;
  background: #fff; border: 1px solid var(--linie); border-radius: var(--radius-s);
  box-shadow: var(--schatten); min-width: 265px; z-index: 90;
  opacity: 0; visibility: hidden; transform: translateY(8px);
  transition: opacity 0.18s ease, transform 0.18s ease, visibility 0.18s;
}
.submenu:has(li:nth-child(10)) { min-width: 540px; display: grid; grid-template-columns: 1fr 1fr; }
.hat-sub:hover > .submenu,
.hat-sub:focus-within > .submenu,
.hat-sub.offen > .submenu { opacity: 1; visibility: visible; transform: translateY(0); }
.hat-sub:hover .sub-toggle svg,
.hat-sub.offen .sub-toggle svg { transform: rotate(180deg); }
.submenu a { padding: 9px 12px; font-weight: 550; font-size: 0.94rem; border-radius: 7px; white-space: normal; }
.sub-uebersicht a { color: var(--blau); font-weight: 700; display: flex; align-items: center; gap: 6px; }
.sub-uebersicht svg { width: 14px; height: 14px; }

.kopf-notruf { flex: none; padding: 0.62em 1.1em; }
.kopf-notruf span { display: flex; flex-direction: column; line-height: 1.15; }
.kopf-notruf small { font-weight: 550; font-size: 0.72rem; opacity: 0.9; }

.burger {
  display: none;
  flex: none; border: 0; background: none; cursor: pointer;
  width: 46px; height: 46px; border-radius: 10px;
  flex-direction: column; align-items: center; justify-content: center; gap: 5px;
}
.burger:hover { background: var(--eis); }
.burger span {
  width: 24px; height: 2.6px; border-radius: 2px;
  background: var(--marine); transition: transform 0.25s, opacity 0.2s;
}
.burger[aria-expanded="true"] span:nth-child(1) { transform: translateY(7.6px) rotate(45deg); }
.burger[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
.burger[aria-expanded="true"] span:nth-child(3) { transform: translateY(-7.6px) rotate(-45deg); }

/* ---------- Seitenkopf (Unterseiten, zentriert, mit Bild-Hero) ---------- */
.seitenkopf {
  position: relative; overflow: hidden;
  background:
    radial-gradient(900px 380px at 85% -10%, rgba(168, 200, 224, 0.28), transparent 60%),
    linear-gradient(130deg, var(--marine-tief), var(--blau));
  color: #fff;
  text-align: center;
  padding: 52px 0 96px;
}
.seitenkopf-bild { padding: 72px 0 110px; }
.seitenkopf-overlay {
  position: absolute; inset: 0;
  background:
    radial-gradient(720px 340px at 50% 30%, rgba(11, 23, 40, 0.25), transparent 70%),
    linear-gradient(180deg, rgba(11, 23, 40, 0.88), rgba(21, 39, 65, 0.82));
}
.seitenkopf-inhalt { position: relative; z-index: 1; }
.seitenkopf h1 { color: #fff; max-width: 24ch; margin-inline: auto; margin-bottom: 0.35em; }
.kopf-unter { font-size: 1.12rem; max-width: 62ch; margin-inline: auto; color: rgba(255, 255, 255, 0.88); }
.brotkrumen {
  font-size: 0.86rem; margin-bottom: 20px;
  display: flex; flex-wrap: wrap; gap: 8px; align-items: center; justify-content: center;
  color: rgba(255, 255, 255, 0.66);
}
.brotkrumen a { color: rgba(255, 255, 255, 0.82); text-decoration: none; }
.brotkrumen a:hover { color: #fff; text-decoration: underline; }
.brotkrumen .trenn { opacity: 0.5; }
.kopf-cta { display: flex; flex-wrap: wrap; align-items: center; justify-content: center; gap: 20px; margin-top: 26px; }
.kopf-tel {
  color: #fff; text-decoration: none; font-weight: 700; font-size: 1.05rem;
  display: inline-flex; align-items: center; gap: 9px;
}
.kopf-tel:hover { color: var(--himmel); }

/* Wellen-Übergang unter den Heros */
.welle {
  position: absolute; left: 0; right: 0; bottom: -1px;
  width: 100%; height: 58px; z-index: 1;
  color: #fff; display: block;
}

/* ---------- Voll-Hero (Startseite, Full-Width-Bild) ---------- */
.hero-voll {
  position: relative; overflow: hidden;
  padding: 92px 0 128px;
}
.hero-voll-bg, .banner-bg {
  position: absolute; inset: 0;
  width: 100%; height: 100%; object-fit: cover;
}
.hero-voll-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(102deg, rgba(11, 23, 40, 0.95) 8%, rgba(21, 39, 65, 0.86) 46%, rgba(30, 52, 80, 0.52) 100%);
}
.hero-voll-inhalt { position: relative; z-index: 1; max-width: 840px; margin-inline: auto; text-align: center; }
.hero-voll .hero-cta { justify-content: center; }
.hero-voll .hero-haken { justify-content: center; }
.hero-voll .hero-adresse { justify-content: center; }
.hero-voll .hero-lead { margin-inline: auto; }
.hero-voll h1 { color: #fff; font-size: clamp(2.1rem, 5vw, 3.3rem); margin-inline: auto; margin-bottom: 0.35em; }
.hero-voll h1 .hell { color: var(--himmel); }
.hero-voll .hero-lead { color: rgba(255, 255, 255, 0.9); font-size: 1.18rem; }
.hero-voll .hero-haken { color: #fff; }
.hero-voll .hero-haken .icon { color: #6fd39a; }
.hero-adresse {
  display: flex; align-items: center; gap: 9px;
  margin: 26px 0 0; font-size: 0.95rem; font-weight: 600;
  color: rgba(255, 255, 255, 0.85);
}
.hero-adresse .icon { color: var(--himmel); }

/* Zahlenband (überlappt den Hero) */
.zahlen-band { position: relative; z-index: 2; margin-top: -58px; padding: 0; }
.zahlen-grid {
  background: #fff; border-radius: var(--radius);
  box-shadow: var(--schatten);
  display: grid; grid-template-columns: repeat(4, 1fr);
  padding: 30px 10px;
}
.zahl { text-align: center; padding: 6px 18px; border-left: 1px solid var(--linie); }
.zahl:first-child { border-left: 0; }
.zahl strong { display: block; font-size: 1.9rem; font-weight: 800; color: var(--blau); letter-spacing: -0.02em; }
.zahl span { font-size: 0.88rem; color: var(--grau); line-height: 1.4; display: block; margin-top: 4px; }

/* ---------- Full-Width-Banner ---------- */
.banner { position: relative; overflow: hidden; padding: 98px 0; }
.banner-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(100deg, rgba(11, 23, 40, 0.93) 0%, rgba(21, 39, 65, 0.8) 48%, rgba(30, 52, 80, 0.45) 100%);
}
.banner .wrap { position: relative; z-index: 1; }
.banner-inhalt { max-width: 740px; margin-inline: auto; text-align: center; }
.banner h2 { color: #fff; font-size: clamp(1.6rem, 3.4vw, 2.3rem); margin-inline: auto; }
.banner-text { color: rgba(255, 255, 255, 0.88); font-size: 1.08rem; margin: 0 auto 28px; }
.banner .cta-buttons { margin-top: 26px; justify-content: center; }
.kicker-hell { color: var(--himmel); }
.banner-link { color: var(--himmel); font-weight: 700; text-decoration: none; }
.banner-link:hover { color: #fff; text-decoration: underline; }

/* ---------- Vergleichstabelle ---------- */
.wrap-mittel { max-width: 980px; }
.vergleich-karte {
  background: #fff; border-radius: var(--radius);
  box-shadow: var(--schatten); overflow: hidden; overflow-x: auto;
  margin-top: 38px;
}
.vergleich { width: 100%; border-collapse: collapse; font-size: 0.97rem; min-width: 640px; }
.vergleich th {
  text-align: left; padding: 18px 22px;
  background: var(--marine); color: #fff; font-size: 0.92rem;
}
.vergleich th:first-child { width: 32%; }
.vergleich td { padding: 15px 22px; border-top: 1px solid var(--linie); vertical-align: top; }
.vergleich td:first-child { font-weight: 700; color: var(--marine); }
.vergleich tr:nth-child(even) td { background: #f8fbfe; }
.v-icon {
  display: inline-flex; width: 22px; height: 22px; border-radius: 50%;
  background: #e3f4ea; color: #1fa055;
  align-items: center; justify-content: center;
  margin-right: 9px; vertical-align: -5px; flex: none;
}
.v-icon svg { width: 13px; height: 13px; stroke-width: 3; }
.v-x { background: #fdeaea; color: #c4321f; font-weight: 800; font-size: 0.8rem; }
.v-ja { color: var(--tinte); }
.v-nein { color: var(--grau); }
.vergleich-fuss { text-align: center; color: var(--grau); font-size: 0.92rem; margin: 20px 0 0; }

/* ---------- Stadtteil-Chips ---------- */
.stadtteil-chips {
  list-style: none; margin: 20px 0 0; padding: 0;
  display: flex; flex-wrap: wrap; gap: 10px;
}
.stadtteil-chips li {
  background: #fff; border: 1px solid var(--linie);
  border-radius: 100px; padding: 8px 17px;
  font-size: 0.92rem; font-weight: 600; color: var(--marine);
  margin: 0;
}
.sek-eis .stadtteil-chips li { border-color: transparent; box-shadow: var(--schatten-s); }

/* ---------- Scroll-Reveal (JS fügt .reveal hinzu) ---------- */
.reveal { opacity: 0; transform: translateY(26px); transition: opacity 0.65s ease, transform 0.65s ease; }
.reveal.sichtbar { opacity: 1; transform: none; }

/* ---------- Hero (Startseite) ---------- */
.hero {
  background:
    radial-gradient(1000px 500px at 90% -20%, rgba(168, 200, 224, 0.35), transparent 60%),
    linear-gradient(180deg, var(--eis), #fff 85%);
  padding: 54px 0 64px;
  overflow: hidden;
}
.hero-innen {
  display: grid; grid-template-columns: 1.05fr 0.95fr;
  gap: 48px; align-items: center;
}
.hero-status {
  display: inline-flex; align-items: center; gap: 9px;
  background: #fff; border: 1px solid var(--linie); border-radius: 100px;
  padding: 7px 15px; font-size: 0.88rem; font-weight: 650; color: var(--marine);
  box-shadow: var(--schatten-s); margin-bottom: 20px;
}
.puls {
  width: 9px; height: 9px; border-radius: 50%; background: #1fa055;
  box-shadow: 0 0 0 0 rgba(31, 160, 85, 0.5);
  animation: puls 1.8s infinite;
}
@keyframes puls {
  70% { box-shadow: 0 0 0 9px rgba(31, 160, 85, 0); }
  100% { box-shadow: 0 0 0 0 rgba(31, 160, 85, 0); }
}
.hero h1 { margin-bottom: 0.4em; }
.hero-lead { font-size: 1.14rem; color: var(--grau); max-width: 56ch; margin: 0 0 26px; }
.hero-cta { display: flex; flex-wrap: wrap; gap: 14px; margin-bottom: 26px; }
.hero-haken {
  list-style: none; margin: 0; padding: 0;
  display: flex; flex-wrap: wrap; gap: 10px 26px;
  font-size: 0.94rem; font-weight: 600; color: var(--marine);
}
.hero-haken li { display: flex; align-items: center; gap: 8px; }
.hero-haken .icon { color: #1fa055; }
.hero-haken .icon svg { width: 1.05em; height: 1.05em; stroke-width: 3; }

.hero-bild { position: relative; }
.hero-bild img {
  border-radius: var(--radius);
  box-shadow: var(--schatten);
  aspect-ratio: 4 / 3; object-fit: cover; width: 100%;
}
.hero-badge {
  position: absolute; left: 18px; bottom: 18px;
  background: #fff; border-radius: var(--radius-s);
  box-shadow: var(--schatten); padding: 12px 16px;
  display: flex; align-items: center; gap: 12px;
}
.hero-badge .icon-g { width: 42px; height: 42px; background: #fbeaec; color: var(--rot); }
.hero-badge .icon-g svg { width: 21px; height: 21px; }
.hero-badge strong { display: block; color: var(--marine); font-size: 0.95rem; line-height: 1.3; }
.hero-badge small { color: var(--grau); font-size: 0.82rem; }

/* ---------- Sektionen ---------- */
.sek { padding: 62px 0; }
.sek-eis { background: var(--eis); }
.sek-titel { text-align: center; max-width: 26ch; margin-inline: auto; }
.sek-intro {
  text-align: center; color: var(--grau);
  max-width: 66ch; margin: -6px auto 40px; font-size: 1.05rem;
}
.sek-titel + .karten-grid, .sek-titel + .galerie, .sek-titel + .schritte,
.sek-titel + .orte-grid, .sek-titel + .vorteile-grid, .sek-titel + .verwandt-grid { margin-top: 40px; }
.sek-mehr { text-align: center; margin: 36px 0 0; }

/* Fließtext */
.fliesstext p { margin: 0 0 1.1em; }
.fliesstext p:last-child { margin-bottom: 0; }
.fliesstext h2 { margin-top: 1.4em; }
.fliesstext h2:first-child { margin-top: 0; }
.fliesstext h3 { margin-top: 1.5em; }
.fliesstext ul, .fliesstext ol { margin: 0 0 1.2em; padding-left: 1.3em; }
.fliesstext li { margin-bottom: 0.45em; }
.fliesstext li::marker { color: var(--blau); }
.liste-haken { list-style: none; padding-left: 0 !important; }
.liste-haken li {
  padding-left: 30px; position: relative;
}
.liste-haken li::before {
  content: ""; position: absolute; left: 0; top: 0.32em;
  width: 17px; height: 17px; border-radius: 50%;
  background: var(--blau);
  -webkit-mask: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="none" stroke="black" stroke-width="3.4" stroke-linecap="round" stroke-linejoin="round"><path d="M20 6 9 17l-5-5"/></svg>') center / 100% no-repeat;
  mask: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="none" stroke="black" stroke-width="3.4" stroke-linecap="round" stroke-linejoin="round"><path d="M20 6 9 17l-5-5"/></svg>') center / 100% no-repeat;
}
.fliesstext table {
  width: 100%; border-collapse: collapse; margin: 1.4em 0;
  font-size: 0.95rem;
}
.fliesstext th, .fliesstext td {
  text-align: left; padding: 11px 14px;
  border: 1px solid var(--linie);
}
.fliesstext th { background: var(--eis); color: var(--marine); }
.fliesstext tr:nth-child(even) td { background: #f7fafd; }
.hinweis-box {
  background: var(--eis); border-left: 4px solid var(--blau);
  border-radius: 0 var(--radius-s) var(--radius-s) 0;
  padding: 18px 22px; margin: 1.4em 0;
}
.hinweis-box.rot { border-color: var(--rot); background: #fdf1f2; }

/* Kicker */
.kicker {
  text-transform: uppercase; letter-spacing: 0.09em;
  font-size: 0.82rem; font-weight: 750; color: var(--blau);
  margin: 0 0 10px;
}

/* Vorteile */
.vorteile-grid {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(230px, 1fr));
  gap: 22px;
}
.vorteil {
  background: #fff; border: 1px solid var(--linie); border-radius: var(--radius);
  padding: 26px 24px;
}
.sek-eis .vorteil { border-color: transparent; box-shadow: var(--schatten-s); }
.vorteil h3 { margin: 16px 0 6px; }
.vorteil p { margin: 0; color: var(--grau); font-size: 0.95rem; }

/* Leistungskarten */
.karten-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(255px, 1fr));
  gap: 24px;
}
.karte {
  background: #fff; border: 1px solid var(--linie); border-radius: var(--radius);
  overflow: hidden; text-decoration: none; color: inherit;
  display: flex; flex-direction: column;
  transition: transform 0.18s ease, box-shadow 0.18s ease;
}
.karte:hover { transform: translateY(-4px); box-shadow: var(--schatten); color: inherit; }
.karte-bild img { aspect-ratio: 3 / 2; object-fit: cover; width: 100%; }
.karte-text { padding: 20px 22px 22px; display: flex; flex-direction: column; flex: 1; }
.karte-text h3 { margin-bottom: 6px; }
.karte-text p { margin: 0 0 14px; color: var(--grau); font-size: 0.94rem; flex: 1; }
.karte-mehr {
  color: var(--blau); font-weight: 700; font-size: 0.92rem;
  display: inline-flex; align-items: center; gap: 7px;
}
.karte-mehr svg { width: 15px; height: 15px; transition: transform 0.18s; }
.karte:hover .karte-mehr svg, .verwandt-karte:hover .karte-mehr svg { transform: translateX(4px); }

/* Medien + Text */
.medien-split {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 52px; align-items: center;
}
.medien-links .medien-bildteil { order: -1; }
.medien-bildteil { margin: 0; }
.medien-bild {
  border-radius: var(--radius); box-shadow: var(--schatten);
  aspect-ratio: 4 / 3; object-fit: cover; width: 100%;
}

/* Galerie (zentriert – auch unvollständige Reihen) */
.galerie {
  display: flex; flex-wrap: wrap; justify-content: center;
  gap: 24px;
}
.galerie .gal-bild { flex: 0 1 350px; min-width: 265px; }
.gal-bild { margin: 0; background: #fff; border-radius: var(--radius); overflow: hidden; border: 1px solid var(--linie); }
.sek-eis .gal-bild { border-color: transparent; box-shadow: var(--schatten-s); }
.gal-bild img { aspect-ratio: 4 / 3; object-fit: cover; width: 100%; }
.gal-bild figcaption { padding: 13px 17px; font-size: 0.88rem; color: var(--grau); }

/* Schritte */
.schritte {
  list-style: none; margin: 0; padding: 0;
  display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 26px; counter-reset: schritt;
}
.schritte li {
  background: #fff; border: 1px solid var(--linie); border-radius: var(--radius);
  padding: 26px 24px; position: relative;
}
.sek-eis .schritte li { border-color: transparent; box-shadow: var(--schatten-s); }
.schritt-nr {
  width: 44px; height: 44px; border-radius: 12px;
  background: var(--blau); color: #fff;
  display: flex; align-items: center; justify-content: center;
  font-weight: 800; font-size: 1.15rem; margin-bottom: 16px;
}
.schritte h3 { margin-bottom: 6px; }
.schritte p { margin: 0; color: var(--grau); font-size: 0.95rem; }

/* FAQ */
.faq {
  background: #fff; border: 1px solid var(--linie); border-radius: var(--radius-s);
  margin-bottom: 12px; overflow: hidden;
}
.sek-eis .faq { border-color: transparent; box-shadow: var(--schatten-s); }
.faq summary {
  list-style: none; cursor: pointer;
  padding: 18px 54px 18px 22px;
  font-weight: 700; color: var(--marine); position: relative;
}
.faq summary::-webkit-details-marker { display: none; }
.faq summary:hover { color: var(--blau); }
.faq-plus { position: absolute; right: 20px; top: 50%; width: 18px; height: 18px; transform: translateY(-50%); }
.faq-plus::before, .faq-plus::after {
  content: ""; position: absolute; background: var(--blau); border-radius: 2px;
  transition: transform 0.2s;
}
.faq-plus::before { left: 8px; top: 0; width: 2.5px; height: 18px; }
.faq-plus::after { left: 0; top: 8px; width: 18px; height: 2.5px; }
.faq[open] .faq-plus::before { transform: rotate(90deg); }
.faq-antwort { padding: 0 22px 20px; color: var(--grau); }

/* Orte */
.orte-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: 16px;
}
.ort-karte {
  display: flex; align-items: flex-start; gap: 13px;
  background: #fff; border: 1px solid var(--linie); border-radius: var(--radius-s);
  padding: 17px 19px; text-decoration: none; color: inherit;
  transition: transform 0.15s, box-shadow 0.15s;
}
.sek-eis .ort-karte { border-color: transparent; box-shadow: var(--schatten-s); }
.ort-karte:hover { transform: translateY(-3px); box-shadow: var(--schatten); color: inherit; }
.ort-karte .icon { color: var(--blau); margin-top: 2px; }
.ort-karte strong { display: block; color: var(--marine); }
.ort-karte small { color: var(--grau); font-size: 0.86rem; line-height: 1.45; display: block; }

/* Karte (SVG) */
.gebiet-split { display: grid; grid-template-columns: 1fr 1fr; gap: 50px; align-items: center; }
.gebiet-karte svg { width: 100%; height: auto; }
.karte-ort { cursor: pointer; }
.karte-ort circle { transition: r 0.15s; }
.karte-ort:hover circle.punkt { r: 9; }
.karte-ort text { font-family: var(--schrift); }

/* Verwandt */
.verwandt-grid {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
  gap: 22px;
}
.verwandt-karte {
  background: #fff; border: 1px solid var(--linie); border-radius: var(--radius);
  padding: 24px; text-decoration: none; color: inherit;
  transition: transform 0.15s, box-shadow 0.15s;
  display: flex; flex-direction: column;
}
.sek-eis .verwandt-karte { border-color: transparent; box-shadow: var(--schatten-s); }
.verwandt-karte:hover { transform: translateY(-3px); box-shadow: var(--schatten); color: inherit; }
.verwandt-karte h3 { margin-bottom: 5px; }
.verwandt-karte p { margin: 0 0 14px; color: var(--grau); font-size: 0.93rem; flex: 1; }

/* CTA-Sektionen */
.sek-cta-mitte {
  background: linear-gradient(120deg, var(--blau), var(--marine));
  padding: 46px 0;
}
.cta-mitte {
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 24px; text-align: center;
}
.cta-mitte h2 { color: #fff; margin-bottom: 0.2em; }
.cta-mitte p { color: rgba(255, 255, 255, 0.85); margin: 0 auto; max-width: 62ch; }
.cta-mitte .cta-buttons { justify-content: center; }
.cta-buttons { display: flex; flex-wrap: wrap; gap: 14px; }

.cta-banner {
  position: relative; overflow: hidden;
  background: linear-gradient(120deg, var(--marine-tief), var(--marine) 55%, var(--blau));
  padding: 76px 0;
}
.cta-banner-innen {
  position: relative; z-index: 1;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 30px; text-align: center;
}
.cta-banner h2 { color: #fff; margin-bottom: 0.35em; }
.cta-banner p { color: rgba(255, 255, 255, 0.82); margin: 0 auto; max-width: 58ch; }
.cta-banner .cta-buttons { justify-content: center; }

/* ---------- Formular ---------- */
.formular { display: grid; grid-template-columns: 1fr 1fr; gap: 18px 20px; }
.formular .feld-voll { grid-column: 1 / -1; }
.formular label { font-weight: 650; font-size: 0.92rem; color: var(--marine); display: block; margin-bottom: 7px; }
.formular input, .formular select, .formular textarea {
  width: 100%; padding: 13px 15px;
  border: 1.5px solid var(--linie); border-radius: var(--radius-s);
  font: inherit; color: var(--tinte); background: #fff;
}
.formular input:focus, .formular select:focus, .formular textarea:focus {
  outline: 3px solid rgba(56, 88, 128, 0.25); border-color: var(--blau);
}
.formular textarea { min-height: 150px; resize: vertical; }
.formular .hp-feld { position: absolute; left: -9999px; width: 1px; height: 1px; overflow: hidden; }
.formular button { cursor: pointer; border: 2px solid transparent; font: inherit; }
.form-hinweis { font-size: 0.86rem; color: var(--grau); margin: 4px 0 0; grid-column: 1 / -1; }
.form-fehler {
  background: #fdf1f2; border: 1.5px solid #f0c3c8; border-radius: var(--radius-s);
  color: #8f0c19; font-weight: 600; padding: 14px 18px; margin: 0 0 20px;
}

.kontakt-split { display: grid; grid-template-columns: 0.9fr 1.1fr; gap: 54px; align-items: start; }
.kontakt-kasten {
  background: var(--eis); border-radius: var(--radius);
  padding: 30px 30px 26px; margin-bottom: 22px;
}
.kontakt-kasten h3 { display: flex; align-items: center; gap: 10px; margin-bottom: 10px; }
.kontakt-kasten h3 .icon { color: var(--blau); }
.kontakt-kasten p { margin: 0 0 8px; }
.kontakt-kasten a.tel-gross {
  font-size: 1.45rem; font-weight: 800; text-decoration: none; color: var(--marine);
  display: inline-block; margin: 4px 0 6px;
}
.kontakt-kasten a.tel-gross:hover { color: var(--blau); }
.kontakt-kasten.rot { background: #fdf1f2; }
.kontakt-kasten.rot h3 .icon { color: var(--rot); }
.kontakt-kasten.rot a.tel-gross { color: var(--rot); }
.kontakt-kasten small { color: var(--grau); }

/* ---------- Blog ---------- */
.blog-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 26px; }
.blog-karte {
  background: #fff; border: 1px solid var(--linie); border-radius: var(--radius);
  overflow: hidden; text-decoration: none; color: inherit; display: flex; flex-direction: column;
  transition: transform 0.18s, box-shadow 0.18s;
}
.blog-karte:hover { transform: translateY(-4px); box-shadow: var(--schatten); color: inherit; }
.blog-karte img { aspect-ratio: 16 / 9; object-fit: cover; width: 100%; }
.blog-karte-text { padding: 22px 24px 24px; display: flex; flex-direction: column; flex: 1; }
.blog-meta { font-size: 0.84rem; color: var(--grau); margin: 0 0 8px; }
.blog-karte h3 { margin-bottom: 8px; }
.blog-karte p { color: var(--grau); font-size: 0.95rem; margin: 0 0 14px; flex: 1; }

.artikel { max-width: 780px; margin-inline: auto; }
.artikel-kopfbild img { border-radius: var(--radius); box-shadow: var(--schatten); aspect-ratio: 16/9; object-fit: cover; width: 100%; margin-bottom: 34px; }
.artikel .blog-meta { margin-bottom: 22px; }

/* ---------- Footer ---------- */
.fuss { background: var(--marine-tief); color: rgba(255, 255, 255, 0.82); margin-top: 0; }
.fuss a { color: rgba(255, 255, 255, 0.82); text-decoration: none; }
.fuss a:hover { color: #fff; text-decoration: underline; }
.fuss-spalten {
  display: grid; grid-template-columns: 1.5fr 1fr 1fr 1fr;
  gap: 44px; padding-top: 58px; padding-bottom: 46px;
}
.fuss-logo { font-size: 1.5rem; font-weight: 800; color: #fff; margin: 0 0 4px; letter-spacing: 0.01em; }
.fuss-logo span { display: block; font-size: 0.82rem; font-weight: 650; color: var(--himmel); letter-spacing: 0.14em; text-transform: uppercase; }
.fuss-claim { font-size: 0.94rem; margin: 14px 0 20px; max-width: 34ch; }
.fuss address { font-style: normal; font-size: 0.94rem; }
.fuss address p { margin: 0 0 12px; }
.fuss-kontakt { font-size: 0.97rem; line-height: 2.05; margin: 14px 0 0; }
.fuss-kontakt a { display: inline-flex; align-items: center; gap: 9px; font-weight: 600; }
.fuss-titel {
  color: #fff; font-weight: 750; margin: 6px 0 16px;
  font-size: 0.86rem; letter-spacing: 0.1em; text-transform: uppercase;
}
.fuss nav ul { list-style: none; margin: 0; padding: 0; }
.fuss nav li { margin-bottom: 9px; font-size: 0.94rem; }
.fuss-unten { background: rgba(0, 0, 0, 0.25); border-top: 1px solid rgba(255, 255, 255, 0.09); }
.fuss-unten-innen {
  display: flex; justify-content: space-between; gap: 14px; flex-wrap: wrap;
  padding-top: 18px; padding-bottom: 18px; font-size: 0.88rem;
}
.fuss-unten p { margin: 0; }

/* ---------- Mobile Sticky-Leiste ---------- */
.mobil-leiste {
  position: fixed; left: 0; right: 0; bottom: 0; z-index: 120;
  display: grid; grid-template-columns: 1fr 1fr;
  height: calc(var(--leiste-h) + env(safe-area-inset-bottom));
  padding-bottom: env(safe-area-inset-bottom);
  box-shadow: 0 -6px 24px rgba(30, 52, 80, 0.25);
}
.mobil-leiste a {
  display: flex; align-items: center; justify-content: center; gap: 9px;
  color: #fff; text-decoration: none; font-weight: 750; font-size: 1rem;
}
.mobil-buero { background: var(--blau); }
.mobil-notruf { background: var(--rot); }

/* ---------- 404 ---------- */
.fehler-code { font-size: 5rem; font-weight: 900; color: var(--himmel); margin: 0; line-height: 1; }

/* ============================================================
   Responsiv
   ============================================================ */
@media (max-width: 1230px) {
  .kopf-notruf { display: none; }
}

@media (max-width: 1080px) {
  .burger { display: flex; }
  .hauptnav {
    display: none;
    position: fixed; left: 0; right: 0;
    top: var(--nav-oben, 82px); bottom: 0;
    background: #fff; overflow-y: auto; z-index: 110;
    padding: 10px 20px calc(var(--leiste-h) + 40px);
    border-top: 1px solid var(--linie);
  }
  body.nav-offen .hauptnav { display: block; }
  body.nav-offen { overflow: hidden; }
  .hauptnav > ul { flex-direction: column; align-items: stretch; gap: 0; }
  .hauptnav li { border-bottom: 1px solid var(--linie); }
  .hauptnav a { padding: 15px 8px; font-size: 1.05rem; white-space: normal; }
  .hat-sub { flex-wrap: wrap; }
  .hat-sub > a { flex: 1; }
  .sub-toggle { padding: 12px; margin: 0; }
  .sub-toggle svg { width: 20px; height: 20px; }
  .submenu {
    position: static; opacity: 1; visibility: hidden; transform: none;
    box-shadow: none; border: 0; border-radius: 0;
    min-width: 0; width: 100%; padding: 0 0 8px 14px;
    display: none;
  }
  .submenu:has(li:nth-child(10)) { min-width: 0; display: none; grid-template-columns: 1fr; }
  .hat-sub.offen > .submenu { display: block; visibility: visible; }
  .hat-sub:hover > .submenu:not(.offen) { }
  .hat-sub:focus-within > .submenu { visibility: visible; }
  .hat-sub.offen > .submenu { display: block; }
}

@media (max-width: 900px) {
  .topbar { display: none; }
  .medien-split, .gebiet-split, .kontakt-split { grid-template-columns: 1fr; gap: 34px; }
  .medien-links .medien-bildteil { order: 0; }
  .fuss-spalten { grid-template-columns: 1fr 1fr; gap: 36px; }
}

@media (max-width: 900px) and (min-width: 561px) {
  .zahlen-grid { grid-template-columns: repeat(2, 1fr); gap: 18px 0; }
  .zahl:nth-child(3) { border-left: 0; }
}

@media (max-width: 780px) {
  .hero-innen { grid-template-columns: 1fr; gap: 34px; }
  .hero { padding: 40px 0 50px; }
  .hero-voll { padding: 60px 0 104px; }
  .banner { padding: 64px 0; }
  .sek { padding: 48px 0; }
  .seitenkopf { padding: 34px 0 40px; }
  .formular { grid-template-columns: 1fr; }
  .cta-banner { padding: 52px 0; }
}

@media (max-width: 560px) {
  .zahlen-band { margin-top: -44px; }
  .zahlen-grid { grid-template-columns: 1fr 1fr; padding: 20px 6px; gap: 14px 0; }
  .zahl { border-left: 0; padding: 4px 10px; }
  .zahl strong { font-size: 1.5rem; }
}

@media (max-width: 560px) {
  .fuss-spalten { grid-template-columns: 1fr; gap: 30px; }
  .logo img { height: 42px; }
  .kopf-innen { min-height: 68px; }
  .hero-cta .btn { width: 100%; justify-content: center; }
  .cta-buttons { width: 100%; }
  .cta-buttons .btn { width: 100%; justify-content: center; }
}

@media (min-width: 1081px) {
  body { padding-bottom: 0; }
  .mobil-leiste { display: none; }
}

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { animation: none !important; transition: none !important; }
}
