/* =========================================================================
   Förde Teppichreinigung — globales Stylesheet
   Farben aus Logo: Navy (Haupt/Struktur) · Rot (CTA-Akzent) · Stahl/Silber
   ========================================================================= */

:root{
  --navy:#0C2747;
  --navy-800:#102f56;
  --navy-700:#16406f;
  --rot:#C01622;
  --rot-dark:#9c0f1a;
  --stahl:#C9D2DC;
  --stahl-light:#eef2f6;
  --tint:#f5f8fb;
  --ink:#16222e;
  --muted:#5a6b7a;
  --line:#e2e8ee;
  --white:#ffffff;
  --shadow-sm:0 1px 3px rgba(12,39,71,.08), 0 1px 2px rgba(12,39,71,.06);
  --shadow-md:0 8px 24px rgba(12,39,71,.10);
  --shadow-lg:0 20px 50px rgba(12,39,71,.18);
  --radius:14px;
  --radius-sm:10px;
  --maxw:1200px;
  --font:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,"Helvetica Neue",sans-serif;
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;font-family:var(--font);color:var(--ink);background:var(--white);
  line-height:1.6;font-size:17px;-webkit-font-smoothing:antialiased;overflow-x:hidden;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--rot);text-decoration:none}
a:hover{text-decoration:underline}
h1,h2,h3,h4{line-height:1.15;color:var(--navy);margin:0 0 .5em;font-weight:800;letter-spacing:-.02em}
h1{font-size:clamp(2rem,5vw,3.25rem)}
h2{font-size:clamp(1.6rem,3.4vw,2.4rem)}
h3{font-size:1.2rem}
p{margin:0 0 1rem}
.container{max-width:var(--maxw);margin:0 auto;padding:0 20px}
.section{padding:72px 0}
.section--tint{background:var(--tint)}
.section--navy{background:var(--navy);color:#dce6f0}
.section--navy h2,.section--navy h3{color:#fff}
.eyebrow{display:inline-block;font-size:.8rem;font-weight:700;letter-spacing:.14em;
  text-transform:uppercase;color:var(--rot);margin-bottom:.6rem}
.section--navy .eyebrow{color:var(--stahl)}
.lead{font-size:1.12rem;color:var(--muted);max-width:62ch}
.section--navy .lead{color:#b9c8d8}
.center{text-align:center}
.center .lead{margin-left:auto;margin-right:auto}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5em;
  font-weight:700;font-size:1rem;line-height:1;padding:15px 26px;border-radius:var(--radius-sm);
  border:2px solid transparent;cursor:pointer;transition:transform .12s ease,background .15s ease,box-shadow .15s ease;
  text-decoration:none;white-space:nowrap}
.btn:hover{text-decoration:none;transform:translateY(-1px)}
.btn--primary{background:var(--rot);color:#fff;box-shadow:0 6px 16px rgba(192,22,34,.28)}
.btn--primary:hover{background:var(--rot-dark);color:#fff}
.btn--ghost{background:transparent;color:var(--navy);border-color:var(--stahl)}
.btn--ghost:hover{border-color:var(--navy);background:var(--stahl-light)}
.btn--light{background:#fff;color:var(--navy)}
.btn--light:hover{background:var(--stahl-light);color:var(--navy)}
.btn--lg{padding:18px 34px;font-size:1.08rem}
.btn--block{width:100%}

/* ---------- Header / Nav ---------- */
.site-header{position:sticky;top:0;z-index:60;background:rgba(255,255,255,.96);
  backdrop-filter:saturate(150%) blur(8px);border-bottom:1px solid var(--line);transition:top .25s ease}
.nav{display:flex;align-items:center;gap:20px;height:72px}
.nav__logo{display:flex;align-items:center;gap:10px;flex-shrink:0}
.nav__logo img{height:46px;width:auto}
.nav__logo b{font-size:1.02rem;color:var(--navy);letter-spacing:-.01em;line-height:1.05}
.nav__logo span{display:block;font-size:.66rem;font-weight:600;letter-spacing:.18em;
  text-transform:uppercase;color:var(--muted)}
.nav__links{display:flex;align-items:center;gap:18px;margin-left:auto}
.nav__links a{color:var(--navy);font-weight:600;font-size:.97rem;letter-spacing:-.01em}
.nav__links a:hover{color:var(--rot);text-decoration:none}
.nav__phone{display:flex;align-items:center;gap:7px;color:var(--navy);font-weight:800;
  font-size:1.02rem;white-space:nowrap}
.nav__phone:hover{color:var(--rot);text-decoration:none}
.nav__phone svg{flex-shrink:0}
.nav__cta{flex-shrink:0}
.nav__toggle{display:none;background:none;border:0;cursor:pointer;padding:8px;margin-left:auto}
.nav__toggle span{display:block;width:26px;height:2.5px;background:var(--navy);border-radius:2px;
  margin:5px 0;transition:.25s}
.nav.open .nav__toggle span:nth-child(1){transform:translateY(7.5px) rotate(45deg)}
.nav.open .nav__toggle span:nth-child(2){opacity:0}
.nav.open .nav__toggle span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}

/* ---------- Hero ---------- */
.hero{position:relative;background:linear-gradient(135deg,#0a2240 0%,#0C2747 55%,#071a32 100%);
  color:#fff;overflow:hidden}
.hero__grid{display:grid;grid-template-columns:1.1fr .9fr;gap:48px;align-items:center;
  padding:64px 0 72px}
.hero__grid>*{min-width:0}
.hero h1{color:#fff;margin-bottom:.4em}
.hero__sub{font-size:1.15rem;color:#cdd9e6;max-width:48ch;margin-bottom:1.5rem}
.hero__trust{display:flex;flex-wrap:wrap;gap:8px 18px;margin:0 0 28px;padding:0;list-style:none}
.hero__trust li{display:flex;align-items:center;gap:8px;font-weight:600;font-size:.95rem;color:#e7eef6}
.hero__trust svg{flex-shrink:0;color:var(--stahl)}
.hero__cta-row{display:flex;flex-wrap:wrap;gap:14px;align-items:center}
.hero__phone-note{font-size:.92rem;color:#aebfd1}
.hero__phone-note a{color:#fff;font-weight:700}
/* Hero-Bild nur ab >1200px (Speed: mobil reiner Gradient) */
@media(min-width:1201px){
  .hero::before{content:"";position:absolute;inset:0;
    background:linear-gradient(115deg,rgba(8,28,52,.94) 0%,rgba(10,34,64,.78) 42%,rgba(10,34,64,.45) 100%),
      url('/bilder/hero-teppichreinigung-kiel.jpg') center/cover no-repeat;}
  .hero .container{position:relative;z-index:2}
}

/* ---------- Karte / Form-Box ---------- */
.formcard{background:#fff;color:var(--ink);border-radius:var(--radius);box-shadow:var(--shadow-lg);
  padding:26px;border:1px solid rgba(255,255,255,.5)}
.formcard h2{font-size:1.4rem;margin-bottom:.25em}
.formcard p.sub{color:var(--muted);font-size:.95rem;margin-bottom:1rem}

/* ---------- Platzhalter (GHL/Consent) ---------- */
.placeholder{border:2px dashed var(--stahl);border-radius:var(--radius-sm);background:var(--stahl-light);
  padding:28px 22px;text-align:center;color:var(--muted)}
.placeholder strong{display:block;color:var(--navy);margin-bottom:.35rem;font-size:1.02rem}
.placeholder small{font-size:.82rem;opacity:.85}
.consent-gate{position:relative}
.consent-gate__box{border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--tint);
  padding:30px 22px;text-align:center}
.consent-gate__box strong{display:block;color:var(--navy);margin-bottom:.4rem}
.consent-gate__box p{font-size:.9rem;color:var(--muted);margin-bottom:1rem}
.section--navy .consent-gate__box{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.15)}
.section--navy .consent-gate__box strong{color:#fff}
.section--navy .consent-gate__box p{color:#b9c8d8}

/* ---------- Leistungs-Grid ---------- */
.grid{display:grid;gap:24px}
.grid--3{grid-template-columns:repeat(3,1fr)}
.grid--2{grid-template-columns:repeat(2,1fr)}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;
  box-shadow:var(--shadow-sm);transition:transform .15s ease,box-shadow .15s ease;display:flex;flex-direction:column}
.card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}
.card__img{aspect-ratio:16/11;width:100%;object-fit:cover;background:var(--stahl-light)}
.card__body{padding:22px;display:flex;flex-direction:column;flex:1}
.card__body h3{margin-bottom:.4rem}
.card__body p{color:var(--muted);font-size:.96rem;flex:1}
.card__link{margin-top:14px;font-weight:700;color:var(--rot);display:inline-flex;align-items:center;gap:6px}
.card__link:hover{gap:10px;text-decoration:none}

/* ---------- Über uns (Split) ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:center}
.split__media img{border-radius:var(--radius);box-shadow:var(--shadow-md);width:100%;aspect-ratio:4/3;object-fit:cover}
.featurelist{list-style:none;padding:0;margin:1rem 0 1.5rem}
.featurelist li{display:flex;gap:12px;align-items:flex-start;margin-bottom:12px}
.featurelist svg{flex-shrink:0;color:var(--rot);margin-top:3px}
.featurelist b{color:var(--navy)}

/* ---------- Galerie ---------- */
.gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.gallery img{border-radius:var(--radius-sm);aspect-ratio:1;object-fit:cover;box-shadow:var(--shadow-sm)}
.gallery a:nth-child(1){grid-column:span 2;grid-row:span 2}
.gallery a:nth-child(1) img{aspect-ratio:1}

/* ---------- Einsatzgebiete ---------- */
.cities{display:flex;flex-wrap:wrap;gap:10px;margin-top:18px}
.cities a{background:#fff;border:1px solid var(--line);border-radius:50px;padding:9px 18px;
  font-weight:600;color:var(--navy);font-size:.95rem}
.cities a:hover{border-color:var(--rot);color:var(--rot);text-decoration:none}
.section--navy .cities a{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.18);color:#fff}
.section--navy .cities a:hover{background:var(--rot);border-color:var(--rot)}

/* ---------- Warum wir ---------- */
.why{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.why__item{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:26px}
.why__icon{width:48px;height:48px;border-radius:12px;background:var(--stahl-light);
  display:flex;align-items:center;justify-content:center;color:var(--rot);margin-bottom:14px}
.why__item h3{margin-bottom:.4rem}
.why__item p{color:var(--muted);font-size:.96rem;margin:0}

/* ---------- Abschluss-CTA ---------- */
.cta-final{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center}
.cta-final h2{color:#fff}

/* ---------- Footer ---------- */
.site-footer{background:#08203b;color:#a9bdd2;font-size:.95rem;padding:56px 0 30px}
.footer__grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:36px;margin-bottom:36px}
.site-footer h4{color:#fff;font-size:.85rem;letter-spacing:.12em;text-transform:uppercase;margin-bottom:16px}
.site-footer a{color:#a9bdd2}
.site-footer a:hover{color:#fff;text-decoration:none}
.footer__brand b{color:#fff;font-size:1.1rem;display:block;margin-bottom:6px}
.footer__list{list-style:none;padding:0;margin:0}
.footer__list li{margin-bottom:9px}
.footer__nap{font-style:normal;line-height:1.8}
.footer__social{display:flex;gap:12px;margin-top:14px}
.footer__social a{width:38px;height:38px;border-radius:9px;background:rgba(255,255,255,.08);
  display:flex;align-items:center;justify-content:center;color:#fff}
.footer__social a:hover{background:var(--rot)}
.footer__bottom{border-top:1px solid rgba(255,255,255,.12);padding-top:22px;
  display:flex;flex-wrap:wrap;gap:8px 22px;align-items:center;justify-content:space-between;font-size:.88rem}
.footer__legal{display:flex;flex-wrap:wrap;gap:8px 20px}
.footer__legal a, .footer__legal button{color:#a9bdd2;background:none;border:0;cursor:pointer;
  font:inherit;padding:0}
.footer__legal a:hover,.footer__legal button:hover{color:#fff}

/* ---------- Mobile Action Bar (oben, erscheint beim Scrollen) ---------- */
.mobilebar{display:none;position:fixed;top:0;left:0;right:0;z-index:65;
  background:#fff;border-bottom:1px solid var(--line);box-shadow:0 4px 14px rgba(12,39,71,.14);
  padding:8px 12px;gap:10px;transform:translateY(-100%);transition:transform .25s ease}
.mobilebar.show{transform:translateY(0)}
.mobilebar .btn{flex:1;padding:13px 10px;font-size:.98rem}
.mobilebar .btn--call{background:var(--navy);color:#fff}

/* ---------- Chat-Widget ---------- */
/* Chat liegt über ALLEN Seiteninhalten (Header, Formular, Aktionsleiste); nur Cookie-Dialog bleibt darüber */
.chat-fab{position:fixed;right:18px;bottom:18px;z-index:9999;width:58px;height:58px;border-radius:50%;
  background:var(--navy);color:#fff;display:flex;align-items:center;justify-content:center;
  box-shadow:var(--shadow-lg);border:0;cursor:pointer}
.chat-fab:hover{background:var(--navy-700)}
/* Echtes GHL/LeadConnector-Chat-Widget garantiert ganz oben (Custom-Element <chat-widget>) */
chat-widget,#chat-widget,#lc_chat-widget,[id^="lc_chat"],[class*="chat-widget"],
iframe[src*="leadconnector"],iframe[src*="leadconnectorhq"]{z-index:2147483000 !important}

/* ---------- Cookie-Consent ---------- */
.cc-banner{position:fixed;left:16px;right:16px;bottom:16px;z-index:10000;max-width:520px;margin:0 auto;
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-lg);
  padding:22px}
.cc-banner h3{font-size:1.1rem;margin-bottom:.4rem}
.cc-banner p{font-size:.9rem;color:var(--muted);margin-bottom:14px}
.cc-actions{display:flex;flex-wrap:wrap;gap:10px}
.cc-actions .btn{flex:1;min-width:130px;padding:12px 14px;font-size:.92rem}
.cc-link{background:none;border:0;color:var(--rot);font:inherit;cursor:pointer;padding:0;text-decoration:underline}
.cc-overlay{position:fixed;inset:0;z-index:10001;background:rgba(8,28,52,.55);
  display:none;align-items:center;justify-content:center;padding:18px}
.cc-overlay.show{display:flex}
.cc-modal{background:#fff;border-radius:var(--radius);max-width:540px;width:100%;max-height:90vh;
  overflow:auto;padding:28px;box-shadow:var(--shadow-lg)}
.cc-modal h3{margin-bottom:.3rem}
.cc-cat{border:1px solid var(--line);border-radius:var(--radius-sm);padding:16px;margin:14px 0}
.cc-cat__head{display:flex;justify-content:space-between;align-items:center;gap:12px}
.cc-cat__head b{color:var(--navy)}
.cc-cat p{font-size:.86rem;color:var(--muted);margin:.5rem 0 0}
.cc-switch{position:relative;width:46px;height:26px;flex-shrink:0}
.cc-switch input{opacity:0;width:0;height:0}
.cc-slider{position:absolute;inset:0;background:#cdd6df;border-radius:50px;transition:.2s;cursor:pointer}
.cc-slider::before{content:"";position:absolute;height:20px;width:20px;left:3px;top:3px;background:#fff;
  border-radius:50%;transition:.2s}
.cc-switch input:checked + .cc-slider{background:var(--rot)}
.cc-switch input:checked + .cc-slider::before{transform:translateX(20px)}
.cc-switch input:disabled + .cc-slider{background:var(--navy);opacity:.6;cursor:not-allowed}
.cc-modal__actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:18px}
.cc-modal__actions .btn{flex:1;min-width:140px}

/* ---------- FAQ (für Unterseiten) ---------- */
.faq details{border:1px solid var(--line);border-radius:var(--radius-sm);padding:0 20px;margin-bottom:12px;background:#fff}
.faq summary{cursor:pointer;font-weight:700;color:var(--navy);padding:18px 0;list-style:none;
  display:flex;justify-content:space-between;gap:12px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-size:1.4rem;color:var(--rot);line-height:1}
.faq details[open] summary::after{content:"–"}
.faq details[open] summary{border-bottom:1px solid var(--line)}
.faq details p{padding:16px 0;margin:0;color:var(--muted)}

/* ---------- Responsive ---------- */
@media(max-width:980px){
  .hero__grid{grid-template-columns:1fr;gap:34px;padding:48px 0 56px}
  .split,.cta-final{grid-template-columns:1fr;gap:32px}
  .grid--3,.why{grid-template-columns:repeat(2,1fr)}
  .gallery{grid-template-columns:repeat(3,1fr)}
  .footer__grid{grid-template-columns:1fr 1fr}
}
/* Navigation klappt früh auf Hamburger um, damit Telefon + CTA nie abgeschnitten werden */
@media(max-width:900px){
  .nav__links{position:fixed;top:72px;left:0;right:0;background:#fff;flex-direction:column;
    align-items:stretch;gap:0;padding:8px 20px 20px;border-bottom:1px solid var(--line);
    box-shadow:var(--shadow-md);transform:translateY(-130%);transition:transform .28s ease;margin-left:0}
  .nav.open .nav__links{transform:translateY(0)}
  .nav__links a{padding:14px 0;border-bottom:1px solid var(--line);font-size:1.05rem}
  .nav__links .nav__phone{padding:14px 0;border-bottom:1px solid var(--line)}
  .nav__links .nav__cta{margin-top:14px}
  .nav__links .btn{width:100%}
  .nav__toggle{display:block}
}
@media(max-width:760px){
  .section{padding:54px 0}
  .btn{white-space:normal}
  .grid--3,.why,.grid--2{grid-template-columns:1fr}
  .gallery{grid-template-columns:repeat(2,1fr)}
  .gallery a:nth-child(1){grid-column:span 2;grid-row:auto}
  .footer__grid{grid-template-columns:1fr}
  .mobilebar{display:flex}
  body.mbar-shown .site-header{top:60px}
  /* nav__links ist (wegen backdrop-filter) relativ zum Header positioniert -> top = Headerhöhe, bündig ohne Lücke */
  .cc-banner{left:8px;right:8px;bottom:8px}
  /* Offenes Menü: Action-Bar + Header (mit X) fest oben, Menü bündig darunter, über ALLEM (auch Chat).
     Chat bleibt sichtbar (nur das Menü liegt darüber). */
  body.nav-open .mobilebar{transform:translateY(0)}
  body.nav-open .site-header{position:fixed;top:60px;left:0;right:0;z-index:2147483647}
}
@media(max-width:380px){
  .hero__cta-row{flex-direction:column;align-items:stretch}
}

/* =========================================================================
   ERWEITERUNG: Top-Bar · Mega-Menü · Telefon-Button · Mehrstufiges Formular
   · Subpage-Heros · Prosa · Breadcrumbs   (Header-Redesign nach Vorlage)
   ========================================================================= */
:root{ --blau:#1c6fc9; --blau-dark:#155aa6; }

/* ---- Top-Utility-Bar ---- */
.topbar{background:var(--navy);color:#cdd9e6;font-size:.88rem}
.topbar .container{display:flex;align-items:center;justify-content:space-between;min-height:42px;gap:14px}
.topbar__rating{display:inline-flex;align-items:center;gap:8px;color:#fff;font-weight:600}
.topbar__rating:hover{color:#fff;text-decoration:none}
.topbar__stars{color:#f5a623;letter-spacing:1px}
.topbar__right{display:inline-flex;align-items:center;gap:18px}
.topbar__phone{display:inline-flex;align-items:center;gap:7px;color:#fff;font-weight:700}
.topbar__phone:hover{color:#fff;text-decoration:underline}
.topbar__call{display:inline-flex;align-items:center;gap:7px;background:var(--blau);color:#fff;
  font-weight:700;padding:6px 14px;border-radius:8px;font-size:.86rem;white-space:nowrap}
.topbar__call:hover{background:var(--blau-dark);color:#fff;text-decoration:none}
.topbar__badge{display:inline-flex;align-items:center;gap:6px;color:#cdd9e6}
.topbar__badge svg{color:var(--stahl)}
@media(max-width:760px){
  .topbar .container{justify-content:center}
  .topbar__badge{display:none}
  .topbar__right{gap:0}
}

/* ---- Telefon-Button (blau wie Logo): nur im Mobile-Menü, Desktop nutzt Top-Bar ---- */
.nav__call{display:none;align-items:center;gap:8px;background:var(--blau);color:#fff;
  font-weight:700;padding:11px 16px;border-radius:var(--radius-sm);white-space:nowrap;font-size:.95rem}
.nav__call:hover{background:var(--blau-dark);color:#fff;text-decoration:none}

/* ---- Mega-Menü / Dropdown ---- */
.nav-item{position:relative;display:flex;align-items:center}
.nav-item>a, .nav-item>.menu-trigger{display:inline-flex;align-items:center;gap:5px;color:var(--navy);
  font-weight:600;font-size:.97rem;background:none;border:0;cursor:pointer;font-family:inherit;padding:0}
.nav-item>a:hover, .nav-item>.menu-trigger:hover{color:var(--rot)}
.nav-item .caret{width:11px;height:11px;transition:transform .2s}
.nav-item.open>.menu-trigger .caret{transform:rotate(180deg)}
.mega{position:absolute;top:calc(100% + 14px);left:0;background:#fff;border:1px solid var(--line);
  border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:22px;z-index:70;
  opacity:0;visibility:hidden;transform:translateY(8px);transition:.18s;min-width:260px}
.mega::before{content:"";position:absolute;top:-14px;left:0;right:0;height:14px} /* Hover-Brücke */
.nav-item:hover .mega{opacity:1;visibility:visible;transform:translateY(0)}
.mega--right{left:auto;right:0}
.mega--wide{width:560px}
.mega__title{font-size:.74rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;
  color:var(--blau);margin:0 0 12px}
.mega__list{list-style:none;margin:0;padding:0;display:grid;gap:2px}
.mega--cols .mega__list{grid-template-columns:1fr 1fr 1fr;gap:2px 10px}
.mega__list a{display:block;padding:9px 12px;border-radius:8px;color:var(--ink);font-weight:600;font-size:.95rem}
.mega__list a:hover{background:var(--tint);color:var(--rot);text-decoration:none}
.mega__all{display:block;margin-top:8px;padding:9px 12px;font-weight:700;color:var(--blau)}
.mega__all:hover{text-decoration:none;color:var(--rot)}

/* ---- Mega-Menü im Mobile-Panel = Accordion ---- */
@media(max-width:900px){
  .nav-item{display:block}
  .nav-item>a, .nav-item>.menu-trigger{width:100%;justify-content:space-between;padding:14px 0;
    border-bottom:1px solid var(--line);font-size:1.05rem}
  .mega{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;border:0;
    padding:4px 0 10px;min-width:0;width:auto !important;display:none}
  .mega::before{display:none}
  .nav-item.open .mega{display:block}
  .nav-item:hover .mega{opacity:1} /* kein Hover-Auto auf Mobile */
  .mega--cols .mega__list{grid-template-columns:1fr 1fr}
  .mega__list a{padding:11px 12px}
  .nav__call{display:flex;width:100%;justify-content:center;margin-top:10px}
}

/* ---- Mehrstufiges Formular ---- */
.msform__head{display:flex;align-items:center;gap:12px;margin-bottom:6px}
.msform__head img{width:46px;height:46px;border-radius:50%;object-fit:cover;flex-shrink:0}
.msform__head small{color:var(--muted);font-size:.8rem;display:block}
.msform__head b{color:var(--navy)}
.msform__progress{display:flex;align-items:center;justify-content:center;gap:6px;margin:14px 0 20px}
.msform__progress span{width:30px;height:30px;border-radius:50%;background:var(--stahl-light);
  color:var(--muted);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.88rem;flex-shrink:0}
.msform__progress span.active{background:var(--rot);color:#fff}
.msform__progress span.done{background:var(--navy);color:#fff}
.msform__progress i{height:2px;width:22px;background:var(--line);flex-shrink:0}
.msform__step{display:none}
.msform__step.active{display:block;animation:fadeIn .25s ease}
@keyframes fadeIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.msform__step h3{font-size:1.08rem;margin-bottom:14px}
.field{width:100%;padding:14px 16px;border:1px solid var(--line);border-radius:var(--radius-sm);
  font:inherit;font-size:1rem;margin-bottom:12px;background:#fff;color:var(--ink)}
.field:focus{outline:none;border-color:var(--blau);box-shadow:0 0 0 3px rgba(28,111,201,.15)}
textarea.field{min-height:100px;resize:vertical}
.options{display:grid;gap:10px;margin-bottom:6px}
.opt{display:flex;align-items:center;gap:12px;border:1px solid var(--line);border-radius:var(--radius-sm);
  padding:14px 16px;cursor:pointer;transition:.12s;font-weight:600;color:var(--navy)}
.opt:hover{border-color:var(--blau);background:var(--tint)}
.opt input{accent-color:var(--rot);width:18px;height:18px;flex-shrink:0}
.opt.selected{border-color:var(--rot);background:rgba(192,22,34,.05)}
.msform__nav{display:flex;gap:10px;margin-top:8px}
.msform__nav .btn{flex:1}
.msform__back{flex:0 0 auto !important;min-width:54px}
.consent-check{display:flex;gap:10px;align-items:flex-start;font-size:.86rem;color:var(--muted);margin:6px 0 14px}
.consent-check input{margin-top:3px;accent-color:var(--rot);flex-shrink:0}
.consent-check a{color:var(--rot)}
.msform__success{display:none;text-align:center;padding:24px 8px}
.msform__success.show{display:block}
.msform__success .ok{width:60px;height:60px;border-radius:50%;background:#1f9d55;color:#fff;
  display:flex;align-items:center;justify-content:center;margin:0 auto 16px}
.msform__error{display:none;background:#fdecee;color:var(--rot-dark);border:1px solid #f5c2c7;
  border-radius:var(--radius-sm);padding:12px 14px;font-size:.9rem;margin-bottom:12px}
.msform__error.show{display:block}

/* ---- Subpage-Hero (Text-Hero für Leistungs-Seiten) ---- */
.subhero{background:linear-gradient(135deg,#0a2240 0%,#0C2747 60%,#071a32 100%);color:#fff;position:relative}
.subhero--img{background:var(--navy)}
@media(min-width:1201px){
  .subhero--img::before{content:"";position:absolute;inset:0;z-index:0;
    background:linear-gradient(115deg,rgba(8,28,52,.94),rgba(10,34,64,.6)),var(--subhero-img) center/cover no-repeat}
}
.subhero .container{position:relative;z-index:2}
.subhero__grid{display:grid;grid-template-columns:1.1fr .9fr;gap:46px;align-items:start;padding:48px 0 56px}
.subhero__grid>*{min-width:0}
.subhero h1{color:#fff}
.subhero p{color:#cdd9e6;max-width:54ch}
.subhero__list{list-style:none;padding:0;margin:18px 0 0;display:grid;gap:9px}
.subhero__list li{display:flex;gap:10px;align-items:flex-start;color:#e7eef6;font-weight:600}
.subhero__list svg{color:var(--stahl);flex-shrink:0;margin-top:3px}
@media(max-width:980px){ .subhero__grid{grid-template-columns:1fr;gap:30px;padding:38px 0 44px} }

/* ---- Breadcrumbs ---- */
.crumbs{font-size:.85rem;color:#aebfd1;margin-bottom:14px}
.crumbs a{color:#dce6f0}
.crumbs span{opacity:.6;margin:0 6px}

/* ---- Prosa-Inhalt (Leistungs-/Stadt-Seiten) ---- */
.prose{max-width:760px}
.prose h2{margin-top:0}
.prose h3{margin-top:1.6em}
.prose ul{padding-left:0;list-style:none;margin:1rem 0}
.prose ul li{position:relative;padding-left:30px;margin-bottom:11px}
.prose ul li::before{content:"";position:absolute;left:0;top:7px;width:16px;height:16px;
  background:var(--rot);-webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23000' d='M9 16.2l-3.5-3.5L4 14.2l5 5 11-11-1.4-1.4z'/%3E%3C/svg%3E") center/contain no-repeat;
  mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23000' d='M9 16.2l-3.5-3.5L4 14.2l5 5 11-11-1.4-1.4z'/%3E%3C/svg%3E") center/contain no-repeat}
.steps{counter-reset:s;list-style:none;padding:0;margin:1.2rem 0;display:grid;gap:14px}
.steps li{position:relative;padding:16px 18px 16px 60px;background:#fff;border:1px solid var(--line);border-radius:var(--radius);counter-increment:s}
.steps li::before{content:counter(s);position:absolute;left:16px;top:16px;width:30px;height:30px;border-radius:50%;
  background:var(--navy);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.9rem}
.steps li b{color:var(--navy)}
.content-split{display:grid;grid-template-columns:1.5fr 1fr;gap:40px;align-items:start}
.content-split .sticky{position:sticky;top:96px}
@media(max-width:980px){ .content-split{grid-template-columns:1fr;gap:28px} .content-split .sticky{position:static} }

/* ---- Galerie-Seite Grid ---- */
.gallery-page{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.gallery-page img{border-radius:var(--radius-sm);aspect-ratio:4/3;object-fit:cover;box-shadow:var(--shadow-sm);width:100%}
@media(max-width:760px){ .gallery-page{grid-template-columns:1fr 1fr;gap:10px} }

/* ---- Städte-Grid (Übersichtsseite) ---- */
.citygrid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.citygrid a{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:18px 16px;
  font-weight:700;color:var(--navy);display:flex;align-items:center;justify-content:space-between;gap:8px}
.citygrid a:hover{border-color:var(--rot);color:var(--rot);text-decoration:none;box-shadow:var(--shadow-sm)}
.citygrid a svg{color:var(--blau)}
@media(max-width:900px){ .citygrid{grid-template-columns:1fr 1fr} }
@media(max-width:480px){ .citygrid{grid-template-columns:1fr} }

/* =========================================================================
   FIXES & CONTENT-MEDIA (SEO-Ausbau)
   ========================================================================= */
/* Desktop-CTA im Header: Schrift weiß erzwingen (Rot-Hintergrund) */
.nav__links a.btn--primary, .nav__links a.btn--primary:hover{color:#fff}

/* Inhaltsbilder auf Leistungs-/Stadt-Seiten */
.media{border-radius:var(--radius);box-shadow:var(--shadow-md);width:100%;margin:1.4rem 0;
  aspect-ratio:16/10;object-fit:cover}
.media--tall{aspect-ratio:4/3}
.imgrow{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin:1.4rem 0}
.imrow img{border-radius:var(--radius-sm);box-shadow:var(--shadow-sm);width:100%;aspect-ratio:4/3;object-fit:cover;margin:0}
.imrow{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin:1.4rem 0}
.citypics{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:8px}
.citypics img{border-radius:var(--radius-sm);box-shadow:var(--shadow-sm);width:100%;aspect-ratio:4/3;object-fit:cover;margin:0}
@media(max-width:760px){ .citypics{grid-template-columns:1fr 1fr;gap:10px} .imrow{grid-template-columns:1fr} }
.kw{color:var(--navy);font-weight:700}

/* Mobile: Chat-Button bleibt unten rechts (Action-Buttons sind nach oben gewandert) */
@media(max-width:760px){
  .chat-fab{right:14px;bottom:16px;width:52px;height:52px}
}
/* Echtes GHL-Chat-Widget (nach Consent) auf Mobile über die Sticky-Bar heben */
@media(max-width:760px){
  [id*="lc_chat"], [class*="chat-widget"], chat-widget, #chat-widget-container{ margin-bottom:76px !important; }
}

/* =========================================================================
   VORHER / NACHHER – interaktiver Vergleichs-Slider
   ========================================================================= */
.ba-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.ba-grid figure{margin:0}
.ba-grid figcaption{text-align:center;font-weight:700;color:var(--navy);margin-top:14px}
.ba{position:relative;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-md);
  aspect-ratio:4/3;--p:50%;user-select:none;-webkit-user-select:none;touch-action:none;background:var(--stahl-light);cursor:ew-resize}
.ba__img{position:absolute;inset:0}
.ba__img img{width:100%;height:100%;object-fit:cover;display:block;pointer-events:none}
.ba__after{z-index:1}
.ba__before{z-index:2;clip-path:inset(0 calc(100% - var(--p)) 0 0)}
.ba__label{position:absolute;top:12px;z-index:3;background:rgba(12,39,71,.82);color:#fff;
  font-size:.76rem;font-weight:700;letter-spacing:.03em;padding:5px 12px;border-radius:50px;pointer-events:none}
.ba__label--before{left:12px}
.ba__label--after{right:12px}
.ba__handle{position:absolute;top:0;bottom:0;left:var(--p);width:3px;background:var(--blau);
  z-index:4;transform:translateX(-1.5px);pointer-events:none}
.ba__handle span{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:44px;height:44px;border-radius:50%;background:var(--blau);color:#fff;display:flex;
  align-items:center;justify-content:center;font-weight:800;font-size:1.15rem;box-shadow:0 4px 14px rgba(12,39,71,.35);
  border:3px solid #fff}
.ba__range{position:absolute;inset:0;width:100%;height:100%;margin:0;padding:0;opacity:0;
  cursor:ew-resize;z-index:5;-webkit-appearance:none;appearance:none;background:transparent;pointer-events:none}
.ba__range::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:48px;height:100%;cursor:ew-resize}
.ba__range::-moz-range-thumb{width:48px;height:240px;border:0;background:transparent;cursor:ew-resize}
@media(max-width:880px){ .ba-grid{grid-template-columns:1fr;max-width:520px;margin:0 auto} }
