/* ============================================================
   DoPa Hebeanlagen Service — Komponenten (Produktion)
   Geteilte Stildatei fuer alle Seiten in 02_Visual/.
   Benoetigt tokens.css (zuerst einbinden).
   Stand: 2026-06-06
   ============================================================ */

/* --- Basis --- */
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font-sans);color:var(--color-text);line-height:var(--lh-body);background:#fff;-webkit-font-smoothing:antialiased;min-height:100vh;min-height:100dvh;display:flex;flex-direction:column}
.site-main{flex:1 0 auto}
.wrap{max-width:var(--container-max);margin:0 auto;padding:0 var(--container-pad)}
h1,h2,h3,h4{font-family:var(--font-serif);font-weight:var(--fw-regular);line-height:var(--lh-heading);color:var(--color-text)}
a{color:inherit}
img{max-width:100%;display:block}
code{font-family:ui-monospace,Menlo,Consolas,monospace;font-size:.85em;background:var(--color-bg-alt);padding:2px 6px;border-radius:var(--radius-sm)}
.link{color:var(--color-primary);text-decoration:none;background-image:linear-gradient(currentColor,currentColor);background-size:0% 1px;background-position:left bottom;background-repeat:no-repeat;transition:background-size 300ms var(--ease-standard)}
.link:hover{background-size:100% 1px}

/* --- Buttons --- */
.btn{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-sans);font-weight:var(--fw-semibold);font-size:var(--fs-body);line-height:1;border-radius:var(--radius-md);padding:14px 24px;border:1.5px solid transparent;cursor:pointer;text-decoration:none;transition:background-color var(--motion-base) var(--ease-standard),transform var(--motion-fast) var(--ease-standard)}
.btn svg{width:18px;height:18px;fill:none;stroke:currentColor;stroke-width:2}
.btn-primary{background:var(--color-primary);color:#fff}
.btn-primary:hover{background:var(--color-primary-dark)}
.btn-primary:active{transform:scale(.97)}
.btn-secondary{background:transparent;color:var(--color-primary);border-color:var(--color-primary)}
.btn-secondary:hover{background:var(--color-blue-pale)}
.btn-notdienst{background:var(--color-notdienst);color:#fff}
.btn-notdienst:hover{background:#b91c1c}
.btn-outline-notdienst{background:transparent;color:var(--color-notdienst);border-color:var(--color-notdienst)}
.btn-outline-notdienst:hover{background:var(--color-notdienst);color:#fff}
.btn:focus-visible{outline:var(--focus-ring);outline-offset:var(--focus-offset)}

/* --- Header (sticky) --- */
.site-header{position:sticky;top:0;z-index:50}
/* EINE gefrostete Flaeche fuer Header + wellige Unterkante (kinderloses ::before -> clippt Dropdown/Mobil-Menue NICHT). Hellblauer Wellen-Akzent als unterer Background-Layer, durch dieselbe Maske deckungsgleich. */
.site-header::before{content:"";position:absolute;inset:0 0 -22px 0;z-index:-1;pointer-events:none;background:url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%201440%2022'%20preserveAspectRatio='none'%3E%3Cpath%20d='M0,2%20C360,14%201080,14%201440,2%20L1440,8%20C1080,20%20360,20%200,8%20Z'%20fill='%23569BCD'%20fill-opacity='0.6'/%3E%3C/svg%3E") bottom/100% 22px no-repeat,rgba(255,255,255,.92);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transition:filter .25s var(--ease-out);-webkit-mask:linear-gradient(#000,#000) top/100% calc(100% - 22px) no-repeat,url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%201440%2022'%20preserveAspectRatio='none'%3E%3Cpath%20d='M0,0%20H1440%20V8%20C1080,20%20360,20%200,8%20Z'%20fill='%23000'/%3E%3C/svg%3E") bottom/100% 22px no-repeat;mask:linear-gradient(#000,#000) top/100% calc(100% - 22px) no-repeat,url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%201440%2022'%20preserveAspectRatio='none'%3E%3Cpath%20d='M0,0%20H1440%20V8%20C1080,20%20360,20%200,8%20Z'%20fill='%23000'/%3E%3C/svg%3E") bottom/100% 22px no-repeat}
.site-header.scrolled::before{filter:drop-shadow(0 4px 6px rgba(18,27,43,.09))}
.site-header .wrap{display:flex;align-items:center;justify-content:space-between;height:90px;padding-top:16px;gap:24px}
.brand{display:flex;align-items:center;gap:12px;text-decoration:none}
.brand img{height:60px;width:auto;max-width:230px;object-fit:contain}
@media(max-width:520px){.brand img{height:48px}}
.brand .bt{font-family:var(--font-serif);font-size:20px;color:var(--color-navy);line-height:1}
.brand .bs{display:block;font-family:var(--font-sans);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--color-text-muted)}
.nav{display:flex;gap:28px;align-items:center;font-size:16px;font-weight:var(--fw-medium)}
.nav a,.nav .navparent{color:var(--color-text);text-decoration:none;transition:color .2s}
.nav a:hover,.nav a.active{color:var(--color-primary)}
.header-cta{display:flex;align-items:center;gap:16px}
.header-phone{display:none;font-weight:var(--fw-semibold);color:var(--color-navy);text-decoration:none;white-space:nowrap;transition:color .2s}
.header-phone:hover{color:var(--color-primary)}
.header-phone::before{content:"";width:16px;height:16px;flex:none;background-color:currentColor;-webkit-mask:url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%3E%3Cpath%20d='M6.6%2010.8c1.4%202.8%203.8%205.2%206.6%206.6l2.2-2.2c.3-.3.7-.4%201-.2%201.1.4%202.3.6%203.5.6.6%200%201%20.4%201%201V20c0%20.6-.4%201-1%201C10.7%2021%203%2013.3%203%204c0-.6.4-1%201-1h3.6c.6%200%201%20.4%201%201%200%201.2.2%202.4.6%203.5.1.4%200%20.8-.3%201l-2.3%202.3z'/%3E%3C/svg%3E") center/contain no-repeat;mask:url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%3E%3Cpath%20d='M6.6%2010.8c1.4%202.8%203.8%205.2%206.6%206.6l2.2-2.2c.3-.3.7-.4%201-.2%201.1.4%202.3.6%203.5.6.6%200%201%20.4%201%201V20c0%20.6-.4%201-1%201C10.7%2021%203%2013.3%203%204c0-.6.4-1%201-1h3.6c.6%200%201%20.4%201%201%200%201.2.2%202.4.6%203.5.1.4%200%20.8-.3%201l-2.3%202.3z'/%3E%3C/svg%3E") center/contain no-repeat}
@media(min-width:1080px){.header-phone{display:inline-flex;gap:8px;align-items:center}}

/* Mobile-Navigation (Hamburger + Off-canvas Drawer) */
.navtoggle{display:none;flex:none;width:44px;height:44px;border:1px solid var(--color-border);border-radius:var(--radius-md);background:#fff;cursor:pointer;align-items:center;justify-content:center}
.navtoggle span,.navtoggle span::before,.navtoggle span::after{content:"";display:block;width:22px;height:2px;background:var(--color-navy);border-radius:2px;transition:transform .3s var(--ease-out),opacity .3s var(--ease-out)}
.navtoggle span::before{position:relative;top:-7px}
.navtoggle span::after{position:relative;top:5px}
body.nav-open .navtoggle span{background:transparent}
body.nav-open .navtoggle span::before{transform:translateY(7px) rotate(45deg)}
body.nav-open .navtoggle span::after{transform:translateY(-7px) rotate(-45deg)}
.navbackdrop{position:fixed;inset:0;background:rgba(18,27,43,.45);opacity:0;visibility:hidden;transition:opacity .3s var(--ease-out);z-index:60}
body.nav-open .navbackdrop{opacity:1;visibility:visible}
/* Header (mit der Drawer als Kind) ueber die Backdrop heben, sonst liegt der Schleier ueber dem Menue und blockiert Klicks */
body.nav-open .site-header{z-index:120}
@media(max-width:980px){
  .nav{position:fixed;inset:0;width:100%;height:100dvh;flex-direction:column;align-items:center;justify-content:center;gap:6px;background:rgba(255,255,255,.98);backdrop-filter:blur(6px);padding:88px 24px 40px;transform:translateX(100%);transition:transform .32s var(--ease-out);z-index:70;overflow-y:auto}
  body.nav-open .nav{transform:translateX(0)}
  .nav a,.nav .navparent{width:auto;padding:8px 4px;font-family:var(--font-serif);font-size:24px;color:var(--color-navy);border-bottom:0}
  .nav a:hover,.nav a.active{color:var(--color-primary)}
  .navtoggle{display:inline-flex}
  body.nav-open .navtoggle{position:fixed;top:16px;right:16px;z-index:80}
}
/* Navigation: Dropdown "Leistungen" */
.nav .has-sub{position:relative}
.nav .has-sub > a::after,.nav .has-sub > .navparent::after{content:"+";display:inline-flex;align-items:center;justify-content:center;width:16px;margin-left:5px;color:currentColor;font-size:17px;font-weight:600;line-height:1;position:relative;top:-1px;transition:color .2s}
.nav .has-sub:hover > a::after,.nav .has-sub:hover > .navparent::after,.nav .has-sub:focus-within > a::after,.nav .has-sub:focus-within > .navparent::after{content:"\2212"}
.nav .submenu{list-style:none;display:flex;flex-direction:column}
.nav .submenu a{display:flex;align-items:center;gap:12px;text-decoration:none}
.nav .submenu a img{flex:none;width:40px;height:40px;object-fit:contain}
.nav .submenu a b{display:block;font-family:var(--font-sans);font-weight:var(--fw-semibold);font-size:14.5px;color:var(--color-navy);line-height:1.2}
.nav .submenu a small{display:block;font-size:12px;color:var(--color-text-muted);margin-top:2px}
.nav .submenu a:hover b{color:var(--color-primary)}
@media(min-width:981px){
  /* Top-Level-Menuepunkte: blaue Hover-/Aktiv-Pille */
  .nav > a,.nav > .has-sub > .navparent{display:inline-flex;align-items:center;height:36px;padding:0 12px;border-radius:var(--radius-sm);transition:color .2s,background .2s}
  .nav > a:hover,.nav > a.active,.nav > .has-sub:hover > .navparent,.nav > .has-sub:focus-within > .navparent,.nav > .has-sub > .navparent.active{background:var(--color-blue-pale);color:var(--color-primary)}
  .nav .submenu{position:absolute;top:calc(100% + 10px);left:50%;min-width:312px;background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:0 12px 30px rgba(18,27,43,.12);padding:8px;opacity:0;visibility:hidden;transform:translate(-50%,6px);transition:opacity .2s var(--ease-out),transform .2s var(--ease-out)}
  /* Hover-Bridge: ueberbrueckt die 10px-Luecke zwischen Pille und Box, damit der Hover beim Hinuntergehen nicht abreisst */
  .nav .submenu::before{content:"";position:absolute;left:0;right:0;top:-10px;height:10px}
  .nav .has-sub:hover .submenu,.nav .has-sub:focus-within .submenu{opacity:1;visibility:visible;transform:translate(-50%,0)}
  .nav .submenu a{padding:10px 10px;border-radius:var(--radius-sm)}
  .nav .submenu a:hover{background:var(--color-blue-pale)}
}
@media(max-width:980px){
  .nav{gap:2px}
  .nav .submenu{align-items:center;gap:2px;margin:2px 0 6px}
  .nav .submenu a{justify-content:center;padding:6px 4px;color:var(--color-text-muted)}
  .nav .submenu a img{width:26px;height:26px}
  .nav .submenu a b{font-size:17px}
  .nav .submenu a small{display:none}
}

/* --- Hero (Startseite) --- */
.hero{padding:64px 0 72px;background:linear-gradient(180deg,var(--color-blue-pale),#fff)}
.hero .wrap{display:grid;grid-template-columns:1.05fr .95fr;gap:52px;align-items:center}
.kicker{font-family:var(--font-display);font-weight:600;letter-spacing:.16em;text-transform:uppercase;font-size:13px;color:var(--color-primary);margin-bottom:7px}
.hero h1{font-size:clamp(34px,4.6vw,56px);line-height:1.08;color:var(--color-navy);margin-bottom:18px}
.hero .sub{font-size:18px;line-height:1.6;color:var(--color-text);max-width:52ch;margin-bottom:26px}
.hero .ctas{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:22px}
.hero-trust{display:inline-flex;align-items:center;gap:10px;background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-pill);padding:9px 18px;font-weight:var(--fw-semibold);font-size:14px;box-shadow:var(--shadow-subtle)}
.hero-trust .stars{color:var(--color-warn);letter-spacing:1px}
.hero-media{position:relative}
.hero-media img{width:100%;border-radius:var(--radius-lg);box-shadow:0 24px 60px rgba(0,73,125,.22);aspect-ratio:4/3;object-fit:cover}
.hero-badge{position:absolute;left:-14px;bottom:-14px;background:var(--color-navy);color:#fff;border-radius:var(--radius-md);padding:10px 16px;font-size:13px;font-weight:var(--fw-semibold);display:flex;align-items:center;gap:8px;box-shadow:var(--shadow-card)}
.hero-badge .k{background:#fff;color:var(--color-navy);border-radius:var(--radius-sm);padding:2px 7px;font-weight:var(--fw-bold);letter-spacing:.04em}
@media(max-width:860px){.hero .wrap{grid-template-columns:1fr;gap:34px}.hero-media{order:-1}}

/* Hero Scroll-Sequenz (Canvas, beim Scrollen gescrubbt) */
.heroseq{position:relative;height:280vh;background:var(--color-navy)}
.heroseq .sticky{position:sticky;top:0;height:100vh;overflow:hidden;background:var(--color-navy)}
.heroseq canvas{position:absolute;inset:0;width:100%;height:100%;display:block}
.heroseq .overlay{position:absolute;inset:0;z-index:2;background:linear-gradient(90deg,rgba(10,18,30,.74) 0%,rgba(10,18,30,.40) 48%,rgba(10,18,30,.06) 100%)}
.heroseq .content{position:absolute;inset:0;z-index:3;display:flex;align-items:center}
.heroseq .box{max-width:640px;color:#fff}
.heroseq .kicker{color:var(--color-blue-light);margin-bottom:14px}
.heroseq h1{color:#fff;font-size:clamp(32px,5vw,58px);line-height:1.07;margin-bottom:16px}
.heroseq .sub{color:#fff;font-size:clamp(16px,2vw,20px);line-height:1.5;margin-bottom:24px;max-width:48ch}
.heroseq .ctas{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:20px}
.heroseq .hero-trust{background:rgba(255,255,255,.94)}
.btn-outline-light{background:transparent;color:#fff;border-color:rgba(255,255,255,.7)}
.btn-outline-light:hover{background:rgba(255,255,255,.12)}
.heroseq .seqload{position:absolute;z-index:4;left:50%;bottom:20px;transform:translateX(-50%);color:#fff;font-size:13px;background:rgba(0,0,0,.4);padding:6px 12px;border-radius:var(--radius-pill)}
.heroseq .scrollhint{position:absolute;z-index:4;left:50%;bottom:22px;transform:translateX(-50%);color:#fff;font-size:11px;letter-spacing:.18em;text-transform:uppercase;opacity:.8;display:flex;flex-direction:column;align-items:center;gap:5px}
.heroseq .scrollhint .arrow{animation:bob 1.6s ease-in-out infinite}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(5px)}}
@media(max-width:768px){.heroseq{height:230vh}}
@media(prefers-reduced-motion:reduce){.heroseq{height:100vh}.heroseq .sticky{position:relative}.heroseq .scrollhint .arrow{animation:none}}

/* Hero Unterseite + Breadcrumb */
.subhero{position:relative;background:linear-gradient(180deg,var(--color-blue-pale),rgba(230,240,249,0));padding:48px 0 56px}
.breadcrumb{font-size:13px;color:var(--color-text-muted);margin-bottom:14px;display:flex;gap:8px;flex-wrap:wrap}
.breadcrumb a{color:var(--color-text-muted);text-decoration:none}
.breadcrumb a:hover{color:var(--color-primary)}
.breadcrumb .sep{opacity:.5}
.subhero h1{font-size:clamp(30px,4vw,46px);color:var(--color-navy);margin-bottom:10px}
.subhero p{color:var(--color-text-muted);font-size:17px;max-width:62ch}

/* Großes Emblem als Hintergrund-Motiv, rechts unten angeschnitten (sichtbar durch die transparenten bg-morph-Sektionen) */
.subhero .wrap{position:relative;z-index:1}
body::after{content:"";position:fixed;right:-5%;bottom:-12%;width:min(1050px,88vw);aspect-ratio:284/244;background:url("dopa-emblem.svg") center/contain no-repeat;opacity:.05;z-index:-1;pointer-events:none}

/* Klassischer Startseiten-Hero (Standbild statt Scrub) */
.herostage{position:relative;min-height:clamp(560px,72vh,720px);min-height:clamp(560px,72dvh,720px);display:flex;align-items:center;overflow:hidden;background:var(--color-navy)}
.herostage::before{content:"";position:absolute;inset:0;z-index:0;background:url("hero-home.webp") center/cover no-repeat;animation:kenburns 24s ease-in-out infinite alternate}
@media(max-width:768px){.herostage::before{background-image:url("hero-home-mobile.webp");background-position:38% center}.herostage .hero-overlay{background:linear-gradient(0deg,rgba(10,18,30,.86) 0%,rgba(10,18,30,.5) 52%,rgba(10,18,30,.3) 100%)}.herostage .hero-content{justify-content:flex-start}.herostage .box{max-width:none}}
.herostage .hero-overlay{position:absolute;inset:0;z-index:1;background:linear-gradient(90deg,rgba(10,18,30,.08) 0%,rgba(10,18,30,.42) 50%,rgba(10,18,30,.82) 100%)}
.herostage .hero-content{position:relative;z-index:2;display:flex;justify-content:flex-end}
.herostage .box{max-width:640px;color:#fff}
.herostage .kicker{color:#fff;margin-bottom:14px}
.herostage h1{color:#fff;font-size:clamp(32px,5vw,58px);line-height:1.07;margin-bottom:16px}
.herostage .sub{color:#fff;font-size:clamp(16px,2vw,20px);line-height:1.5;margin-bottom:24px;max-width:48ch}
.herostage .ctas{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:20px}
.herostage .hero-trust{background:rgba(255,255,255,.94);color:var(--color-navy)}
.herostage .scrollhint{position:absolute;z-index:3;left:50%;bottom:22px;transform:translateX(-50%);color:#fff;font-size:11px;letter-spacing:.18em;text-transform:uppercase;opacity:.85;display:flex;flex-direction:column;align-items:center;gap:5px}
.herostage .scrollhint .arrow{animation:bob 1.6s ease-in-out infinite}
@keyframes kenburns{0%{transform:scale(1)}100%{transform:scale(1.08)}}
@media(prefers-reduced-motion:reduce){.herostage::before{animation:none}.herostage .scrollhint .arrow{animation:none}}
/* Leistungen lappt in den Hero (Conversion): Karten zuerst -> sie ueberlappen den Foto-Rand, Titel darunter.
   DOM-Reihenfolge bleibt shead->cards->stackwrap (SEO/A11y), nur visuell via order vertauscht. */
.herostage + #leistungen{position:relative;z-index:3;margin-top:clamp(-96px,-6vw,-56px);padding-top:0}
.herostage + #leistungen > .wrap{display:flex;flex-direction:column}
.herostage + #leistungen > .wrap > .cards{order:-1}
.herostage + #leistungen > .wrap > .shead{order:0;margin-top:46px;padding-top:0}
.herostage:has(+ #leistungen) .scrollhint{display:none}
@media(max-width:768px){
  .herostage{min-height:clamp(520px,82vh,640px);min-height:clamp(520px,82dvh,640px)}
  .herostage + #leistungen{margin-top:0;padding-top:56px}
  .herostage + #leistungen > .wrap{display:block}
  .herostage + #leistungen > .wrap > .shead{margin-top:0}
}

/* Scrub als In-Page-Brand-Moment (kürzer, eigene Überschrift) */
.heroseq--story{height:160vh}
.heroseq .seq-h{color:#fff;font-size:clamp(26px,4vw,46px);line-height:1.1;margin-bottom:14px}
@media(max-width:768px){.heroseq--story{height:130vh}}

/* Leistungsseiten: 2-spaltiger Hero mit 3D-Grafik rechts */
.subhero--media{padding-top:52px}
.subhero--media::after{display:none}
.subhero--media .wrap{display:grid;grid-template-columns:1.1fr .9fr;gap:44px;align-items:center}
.subhero--media .hero-copy{position:relative;z-index:1}
.hero-chips{display:flex;flex-wrap:wrap;gap:10px;margin-top:18px}
.hero-chips span{display:inline-flex;align-items:center;gap:6px;background:#fff;border:1px solid #d3dfea;border-radius:var(--radius-pill);padding:7px 13px;font-size:13px;font-weight:var(--fw-medium);color:var(--color-navy)}
.hero-chips .st{color:var(--color-warn);letter-spacing:1px}
.subhero--media .hero-cta{margin-top:22px}
.hero-figure{position:relative;display:flex;align-items:center;justify-content:center;min-height:240px}
.hero-figure::before{content:"";position:absolute;width:300px;height:300px;border-radius:50%;background:radial-gradient(circle,var(--color-blue-pale) 0%,rgba(230,240,249,0) 68%)}
.hero-figure img{position:relative;width:min(300px,82%);height:auto;filter:drop-shadow(0 18px 34px rgba(0,73,125,.20))}
@media(max-width:860px){.subhero--media .wrap{grid-template-columns:1fr;gap:20px}.hero-figure{order:-1;min-height:0}.hero-figure img{width:min(220px,60%)}.hero-figure::before{width:220px;height:220px}}

/* --- Sektions-Rhythmus --- */
.section{padding:96px 0}
.section--alt{background:var(--color-bg-alt)}

/* --- Wellen-Divider (Sektionsuebergang) --- */
/* Liegt FLUSH zwischen zwei <section>. Wrapper-Hintergrund = Farbe der OBEREN
   Sektion; SVG-fill = Farbe der UNTEREN Sektion (Welle "fliesst" nach unten).
   Flach & neutral: geringe Amplitude + nach unten gestufte Hoehe = ruhig. */
.wave{display:block;width:100%;height:56px;line-height:0;font-size:0;margin:0;padding:0;overflow:hidden;pointer-events:none}
.wave-svg{display:block;width:100%;height:100%}
.wave-svg path{fill:currentColor}
@media(max-width:860px){.wave{height:40px}}
@media(max-width:520px){.wave{height:28px}}
@media(max-width:380px){.wave{height:24px}}
.wave--white-gray{background:var(--color-white);color:var(--color-bg-alt)}
.wave--gray-white{background:var(--color-bg-alt);color:var(--color-white)}
.wave--navy-white{background:var(--color-navy);color:var(--color-white)}
.wave--white-navy{background:var(--color-white);color:var(--color-navy)}
/* Wellen-Stil-Varianten (zur Auswahl) — Standard ist die flache Einzelwelle oben */
.wave--duo .w-back{fill:var(--color-blue-light)}
.wave--duo .w-front{fill:currentColor}
.wave--layered .w-1{fill:var(--color-primary-logo);opacity:.16}
.wave--layered .w-2{fill:var(--color-primary-logo);opacity:.34}
.wave--layered .w-front{fill:currentColor}
.wave--line .w-front{fill:currentColor}
.wave--line .w-line{fill:none;stroke:var(--color-blue-light);stroke-width:2;vector-effect:non-scaling-stroke}

/* --- Sektionsuebergaenge ---
   Inhaltsuebergaenge: weicher GSAP-Hintergrund-Morph (weiss<->grau) beim Scrollen,
   aktiviert via body.bg-morph. Fallback ohne JS/reduced-motion: statische Gliederung.
   Hellblaue gelagerte Welle nur an Heroes (Startseite #leistungen, Unterseiten .subhero) + Footern. */
.section,.site-footer{position:relative}
/* Hero-Wellen entfernt (Header hat jetzt eine Welle -> sonst too much). Nur noch die Welle vor dem Footer. */
.site-footer::before{content:"";position:absolute;left:0;right:0;top:0;transform:translateY(-100%);height:48px;background-repeat:no-repeat;background-position:bottom;background-size:100% 100%;pointer-events:none;z-index:1}
.site-footer::before{background-image:url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%201440%2070'%20preserveAspectRatio='none'%3E%3Cpath%20d='M0,34%20C300,10%20640,10%20860,32%20C1080,54%201260,54%201440,30%20L1440,70%20L0,70%20Z'%20fill='%230068B3'%20fill-opacity='0.16'/%3E%3Cpath%20d='M0,42%20C360,20%201020,20%201440,44%20L1440,70%20L0,70%20Z'%20fill='%230068B3'%20fill-opacity='0.34'/%3E%3Cpath%20d='M0,50%20C420,32%201000,32%201440,50%20L1440,70%20L0,70%20Z'%20fill='%23121B2B'/%3E%3C/svg%3E")}
@media(max-width:860px){.site-footer::before{height:38px}}
@media(max-width:520px){.site-footer::before{height:28px}}
/* GSAP-Hintergrund-Morph: Inhalts-Sektionen transparent, body-Hintergrund wird animiert */
body.bg-morph .section,body.bg-morph .section--alt{background:transparent}
.shead{max-width:62ch;margin:0 auto 40px;text-align:center}
.shead .kicker{margin-bottom:6px}
.shead h2{font-size:clamp(28px,3.4vw,40px);color:var(--color-navy);margin-bottom:12px}
.shead p{color:var(--color-text-muted);font-size:17px;line-height:1.6}

/* --- Karten Variante B --- */
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(248px,1fr));gap:24px;align-items:stretch}
.card{position:relative;display:flex;flex-direction:column;background:#fff;border:1px solid #d3dfea;border-radius:var(--radius-lg);box-shadow:var(--shadow-card);padding:30px 26px;transition:box-shadow 320ms var(--ease-out)}
.card.card-b{align-items:center;text-align:center}
.card:hover{box-shadow:0 0 34px 4px rgba(0,94,162,.22)}
.ic-img{width:104px;height:104px;object-fit:contain;margin:6px 0 16px;filter:drop-shadow(0 8px 14px rgba(0,73,125,.16));background:radial-gradient(circle at 50% 46%,rgba(86,155,205,.22) 0%,rgba(86,155,205,.10) 40%,rgba(86,155,205,0) 70%)}
.card h3,.card h4{position:relative;z-index:1;font-family:var(--font-sans);font-weight:var(--fw-semibold);font-size:var(--fs-h4);color:var(--color-navy);margin-bottom:10px}
.card p{position:relative;z-index:1;font-size:var(--fs-small);color:var(--color-text-muted)}
.card.card-b p{min-height:4.4em}
.more{position:relative;z-index:1;display:inline-flex;align-items:center;gap:6px;margin-top:auto;padding-top:18px;font-size:14px;font-weight:var(--fw-semibold);color:var(--color-primary);text-decoration:none}
.card.card-b .more{align-self:center}
.more svg{width:16px;height:16px;fill:none;stroke:currentColor;stroke-width:2;transition:transform var(--motion-base) var(--ease-out)}
.card:hover .more svg{transform:translateX(4px)}
.card .more:focus-visible,.cardD .more:focus-visible{outline:2px solid var(--color-primary);outline-offset:3px;border-radius:4px}

/* Karte A — flache Icon-Kachel + Outline-Wasserzeichen */
.card .ic{position:relative;z-index:1;width:58px;height:58px;border-radius:16px;background:var(--gradient-brand);display:flex;align-items:center;justify-content:center;margin-bottom:18px;box-shadow:0 10px 22px rgba(0,94,162,.30)}
.card .ic::after{content:"";position:absolute;inset:0;border-radius:16px;box-shadow:inset 0 1px 0 rgba(255,255,255,.4);pointer-events:none}
.card .ic svg{width:28px;height:28px;fill:none;stroke:#fff;stroke-width:1.8}
.card .watermark{position:absolute;right:-22px;bottom:-22px;width:128px;height:128px;color:var(--color-blue-pale);opacity:.6;z-index:0;pointer-events:none}
.card .watermark svg{width:100%;height:100%;fill:none;stroke:currentColor;stroke-width:1.5}

/* --- Karten Variante C --- */
.fgrid{display:grid;grid-template-columns:1fr 1fr;gap:22px;align-items:stretch;margin-top:26px}
.fcard{display:flex;gap:18px;align-items:flex-start;height:100%;padding:24px;border:1px solid #d3dfea;border-radius:var(--radius-lg);background:#fff;box-shadow:var(--shadow-card);text-decoration:none;color:inherit;transition:box-shadow .32s var(--ease-out)}
.fcard:hover{box-shadow:0 0 34px 4px rgba(0,94,162,.22)}
.fcard:focus-visible{outline:2px solid var(--color-primary);outline-offset:3px}
.fcard > img{flex:none;width:104px;height:104px;padding:13px;box-sizing:border-box;object-fit:contain;background:var(--color-blue-pale);border:1px solid #dbe9f6;border-radius:18px;filter:drop-shadow(0 6px 12px rgba(0,73,125,.12))}
.fcard .ftext{display:flex;flex-direction:column;flex:1;min-width:0}
.fcard .ftext h4{font-family:var(--font-sans);font-weight:var(--fw-semibold);font-size:var(--fs-h4);color:var(--color-navy);margin-bottom:6px}
.fcard .ftext p{font-size:var(--fs-small);color:var(--color-text-muted)}
.farrow{align-self:flex-start;margin-top:14px;color:var(--color-primary);display:inline-flex;align-items:center;gap:6px;font-size:14px;font-weight:var(--fw-semibold)}
.farrow svg{width:20px;height:20px;fill:none;stroke:currentColor;stroke-width:2;transition:transform .32s var(--ease-out)}
.fcard:hover .farrow svg{transform:translateX(4px)}
@media(max-width:768px){.fgrid{grid-template-columns:1fr}}
@media(max-width:480px){.fcard{flex-direction:column}}

/* Karte D — 3D-Eck-Icon */
.cardD{position:relative;overflow:hidden;display:flex;flex-direction:column;background:#fff;border:1px solid #d3dfea;border-radius:var(--radius-lg);box-shadow:var(--shadow-card);padding:24px;min-height:180px;transition:box-shadow .32s var(--ease-out)}
.cardD:hover{box-shadow:0 0 34px 4px rgba(0,94,162,.22)}
.cardD .bgicon{position:absolute;right:-16px;bottom:-16px;width:148px;height:148px;object-fit:contain;opacity:1;pointer-events:none;z-index:0;filter:drop-shadow(0 6px 12px rgba(0,73,125,.12));-webkit-mask-image:linear-gradient(135deg,transparent 20%,#000 56%);mask-image:linear-gradient(135deg,transparent 20%,#000 56%);transition:transform .32s var(--ease-out)}
.cardD:hover .bgicon{transform:scale(1.05)}
.cardD h4{position:relative;z-index:1;font-family:var(--font-sans);font-weight:var(--fw-semibold);font-size:var(--fs-h4);margin-bottom:8px}
.cardD p{position:relative;z-index:1;font-size:var(--fs-small);color:var(--color-text-muted);max-width:30ch}
.cardD .more{margin-top:auto}

/* Karte E — Outline-Wasserzeichen */
.cardE{position:relative;overflow:hidden;display:flex;flex-direction:column;background:#fff;border:1px solid #d3dfea;border-radius:var(--radius-lg);box-shadow:var(--shadow-card);padding:24px;min-height:180px;transition:box-shadow .32s var(--ease-out)}
.cardE:hover{box-shadow:0 0 34px 4px rgba(0,94,162,.22)}
.cardE .ewm{position:absolute;right:-10px;bottom:-10px;width:108px;height:108px;object-fit:contain;opacity:.92;pointer-events:none;z-index:0;filter:drop-shadow(0 5px 10px rgba(0,73,125,.12));-webkit-mask-image:linear-gradient(135deg,transparent 24%,#000 60%);mask-image:linear-gradient(135deg,transparent 24%,#000 60%)}
.cardE h4{position:relative;z-index:1;font-family:var(--font-sans);font-weight:var(--fw-semibold);font-size:var(--fs-h4);margin-bottom:8px}
.cardE p{position:relative;z-index:1;font-size:var(--fs-small);color:var(--color-text-muted);max-width:30ch}
.cardE .more{margin-top:auto}

/* --- Versicherungsargument --- */
.argblock{display:grid;grid-template-columns:1.45fr .8fr;gap:48px;align-items:center}
@media(max-width:860px){.argblock{grid-template-columns:1fr;gap:28px}}
.argblock h2{font-size:clamp(26px,3.2vw,38px);color:var(--color-navy);margin-bottom:16px;line-height:1.18}
.argblock p{font-size:16px;line-height:1.68;color:var(--color-text);margin-bottom:16px;max-width:62ch}
.facts{display:flex;flex-direction:column;justify-content:center;gap:0;background:var(--color-blue-pale);border:1px solid #dbe9f6;border-radius:var(--radius-lg);padding:24px}
.fact{display:flex;gap:16px;align-items:center}
.fact img{flex:none;width:60px;height:60px;object-fit:contain}
.fact b{display:block;font-family:var(--font-sans);font-weight:var(--fw-semibold);font-size:16px;color:var(--color-navy)}
.fact span{font-size:13px;color:var(--color-text-muted)}
.fact+.fact{border-top:1px solid rgba(255,255,255,.7);margin-top:16px;padding-top:16px}

/* --- Trust-Grid / Kennzahlen --- */
.trustgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
@media(max-width:860px){.trustgrid{grid-template-columns:1fr 1fr}}
@media(max-width:480px){.trustgrid{grid-template-columns:1fr}}
.tcard{display:flex;flex-direction:column;align-items:center;text-align:center;padding:28px 18px;border:1px solid #d3dfea;border-radius:var(--radius-lg);background:#fff;box-shadow:var(--shadow-card)}
.tcard .tmedia{height:74px;display:flex;align-items:center;justify-content:center;margin:0 0 16px}
.tcard .tmedia img{height:60px;width:auto;max-width:100%;object-fit:contain}
.tcard .num{font-family:var(--font-serif);font-weight:400;font-size:4.2rem;line-height:1;color:var(--color-primary)}
.tcard h3,.tcard h4{font-family:var(--font-sans);font-weight:var(--fw-semibold);font-size:17px;color:var(--color-navy);margin-bottom:6px;min-height:2.6em}
.tcard p{font-size:13.5px;color:var(--color-text-muted);line-height:1.5}

/* --- Ueber mich (ohne Personenfoto) --- */
.about{display:grid;grid-template-columns:.85fr 1.15fr;gap:48px;align-items:center}
@media(max-width:860px){.about{grid-template-columns:1fr;gap:28px}}
.about-media{background:var(--color-blue-pale);border:1px solid #dbe9f6;border-radius:var(--radius-lg);padding:24px;text-align:center}
.about-media img{margin:0 auto;max-height:260px;width:auto;filter:drop-shadow(0 14px 26px rgba(0,73,125,.18))}
.about-media .cap{margin-top:12px;font-size:13px;color:var(--color-text-muted)}
.about h2{font-size:clamp(26px,3.2vw,38px);color:var(--color-navy);margin-bottom:16px}
.about p{font-size:16px;line-height:1.68;color:var(--color-text);margin-bottom:16px;max-width:60ch}

/* --- Lead-CTA --- */
.leadcta{position:relative;z-index:2;overflow:hidden;border-radius:var(--radius-lg);padding:54px 36px;color:#fff;text-align:center;background:linear-gradient(120deg,#0068B3,#00497D,#005EA2,#196EAB,#00497D,#0068B3);background-size:300% 300%;animation:ctaGradient 18s ease-in-out infinite;box-shadow:0 26px 54px rgba(0,73,125,.30)}
.leadcta > *{position:relative;z-index:1}
.leadcta h2,.leadcta h3{color:#fff;font-size:clamp(26px,3.2vw,38px);margin-bottom:14px}
.leadcta > p{max-width:60ch;margin:0 auto 26px;color:rgba(255,255,255,.85);font-size:16px;line-height:1.6}
.leadsteps{display:flex;gap:18px;justify-content:center;flex-wrap:wrap;margin-bottom:30px}
.leadstep{display:flex;gap:14px;align-items:center;text-align:left;padding:4px 6px;max-width:340px}
.leadstep img{flex:none;width:58px;height:58px;object-fit:contain;background:#fff;border-radius:14px;padding:7px;box-sizing:border-box}
.leadstep b{display:block;font-family:var(--font-sans);font-weight:var(--fw-semibold);font-size:15px}
.leadstep span{font-size:13px;color:rgba(255,255,255,.82)}
.leadcta .btn-primary{background:#fff;color:var(--color-primary-dark);border-color:#fff}
.leadcta .btn-primary:hover{background:var(--color-blue-pale)}
.leadphone{margin-top:16px;font-size:15px;color:rgba(255,255,255,.85)}
.leadphone strong{color:#fff}

/* --- CTA-Banner (animierter Blau-Verlauf) --- */
.cta-banner{position:relative;overflow:hidden;color:#fff;border-radius:var(--radius-lg);padding:48px 32px;text-align:center;background:linear-gradient(120deg,#0068B3,#00497D,#005EA2,#196EAB,#00497D,#0068B3);background-size:300% 300%;animation:ctaGradient 18s ease-in-out infinite}
@keyframes ctaGradient{0%{background-position:0% 50%}50%{background-position:100% 50%}100%{background-position:0% 50%}}
@media (prefers-reduced-motion: reduce){.cta-banner,.leadcta{animation:none}}
.cta-banner > *{position:relative;z-index:1}
.cta-banner h3{color:#fff;font-size:var(--fs-h2);margin-bottom:8px}
.cta-banner p{color:#dbe9f6;margin-bottom:20px}
.cta-banner .btn-primary{background:#fff;color:var(--color-primary-dark)}
.cta-banner .btn-primary:hover{background:var(--color-blue-pale)}

/* --- Footer --- */
.site-footer{background:var(--color-navy);color:#cdd9e6;padding:104px 0 28px;font-size:14.5px;margin-top:-46px}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px}
@media(max-width:760px){.footer-grid{grid-template-columns:1fr;gap:28px}}
.site-footer h2,.site-footer h5{font-family:var(--font-display);font-weight:600;font-size:13px;color:var(--color-blue-light);margin-bottom:14px;letter-spacing:.16em;text-transform:uppercase}
.site-footer a{color:#dbe6f1;text-decoration:none;transition:color .18s}
.site-footer a:hover{color:#fff;text-decoration:underline;text-underline-offset:3px}
.site-footer ul{list-style:none;display:flex;flex-direction:column;gap:9px}
.footer-brand p{color:#9fb3c9;max-width:36ch;line-height:1.6;margin-top:10px}
.footer-kessel{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.08);border-radius:var(--radius-md);padding:8px 14px;margin-top:14px;font-weight:var(--fw-semibold);color:#fff;font-size:13px}
.footer-kessel .k{background:#fff;color:var(--color-navy);border-radius:var(--radius-sm);padding:2px 7px;font-weight:var(--fw-bold)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.12);margin-top:40px;padding-top:20px;display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;color:#90a6bd;font-size:13px}
.footer-bottom a{color:#aebfd2;text-decoration:none;transition:color .18s}
.footer-bottom a:hover{color:#fff;text-decoration:underline;text-underline-offset:3px}
.footer-bottom .credit{color:#7e93a9}
.footer-bottom .credit a{color:#dbe6f1;text-decoration:underline;text-underline-offset:2px}
.footer-bottom .credit a:hover{color:#fff}

/* --- Trust-Badges (inline) --- */
.trust{display:inline-flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-pill);padding:8px 16px;font-weight:var(--fw-semibold);font-size:var(--fs-small);box-shadow:var(--shadow-subtle)}
.trust .stars{color:var(--color-warn)}
.kessel{display:inline-flex;align-items:center;gap:8px;background:var(--color-navy);color:#fff;border-radius:var(--radius-md);padding:10px 16px;font-size:var(--fs-small);font-weight:var(--fw-semibold)}
.kessel .k{background:#fff;color:var(--color-navy);border-radius:var(--radius-sm);padding:2px 7px;font-weight:var(--fw-bold);letter-spacing:.04em}
.badge{display:inline-flex;align-items:center;gap:6px;background:var(--color-blue-pale);color:var(--color-primary-dark);border-radius:var(--radius-pill);padding:6px 14px;font-size:13px;font-weight:var(--fw-semibold)}

/* --- Formular --- */
.field{margin-bottom:16px}
.field label{display:block;font-size:var(--fs-small);font-weight:var(--fw-semibold);margin-bottom:6px}
.field input,.field textarea,.field select{width:100%;min-height:48px;border:1px solid var(--color-border);border-radius:var(--radius-md);padding:12px 14px;font-family:var(--font-sans);font-size:15px;color:var(--color-text);background:#fff}
.field textarea{min-height:130px;resize:vertical}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-primary)}
.field.is-error input,.field.is-error textarea{border-color:var(--color-error);box-shadow:0 0 0 2px rgba(239,68,68,.25)}
.field .err{color:var(--color-error);font-size:13px;margin-top:6px}
.field .hint{color:var(--color-text-muted);font-size:13px;margin-top:6px}
.upload{border:1.5px dashed var(--color-border);border-radius:var(--radius-md);padding:20px;text-align:center;color:var(--color-text-muted);font-size:14px;background:var(--color-bg-alt);cursor:pointer}
.upload:hover{border-color:var(--color-primary);color:var(--color-primary)}
.check{display:flex;align-items:flex-start;gap:10px;font-size:14px;color:var(--color-text)}
.check input{flex:none;width:20px;height:20px;min-height:0;margin-top:2px;accent-color:var(--color-primary)}
.form-note{border-radius:var(--radius-md);padding:14px 16px;font-size:14px;margin-top:8px}
.form-note.ok{background:#ecfdf3;border:1px solid #abefc6;color:#067647}
.form-note.bad{background:#fef3f2;border:1px solid #fecdc9;color:#b42318}
.honey{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}

/* --- Notice / Notfall-Alert --- */
.notice{padding:2px 0 2px 16px;border-left:3px solid var(--color-primary);background:none;font-size:15px;line-height:1.6;color:var(--color-text)}
.notice strong{display:block;font-family:var(--font-display);font-weight:600;letter-spacing:.14em;text-transform:uppercase;font-size:12px;color:var(--color-primary);margin-bottom:5px}
.alert-notdienst{display:flex;gap:16px;align-items:center;border-left:4px solid var(--color-notdienst);background:#fef2f2;border-radius:var(--radius-md);padding:18px 20px}
.alert-notdienst .icn{flex:none;width:46px;height:46px;border-radius:12px;background:var(--color-notdienst);color:#fff;display:flex;align-items:center;justify-content:center;font-size:22px}
.alert-notdienst b{display:block;color:#991b1b;font-family:var(--font-sans);font-weight:var(--fw-semibold)}
.alert-notdienst span{font-size:14px;color:var(--color-text)}

/* --- Accordion (FAQ, single-open) --- */
.acc{max-width:760px;margin:0 auto;border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden;background:#fff}
.acc details{border-bottom:1px solid var(--color-border)}
.acc details:last-child{border-bottom:none}
.acc summary{cursor:pointer;padding:18px 20px;font-weight:var(--fw-semibold);list-style:none;display:flex;align-items:center;gap:14px}
.acc summary::-webkit-details-marker{display:none}
.acc .q{display:flex;align-items:center;gap:12px;flex:1}
.acc .qi{flex:none;width:34px;height:34px;border-radius:10px;background:var(--color-blue-pale);color:var(--color-primary);display:flex;align-items:center;justify-content:center;transition:background .5s var(--ease-out),color .5s var(--ease-out)}
.acc .qi svg{width:18px;height:18px;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.acc details[open] .qi{background:var(--color-primary);color:#fff}
.acc details[open] summary{color:var(--color-primary-dark)}
.acc .pm{position:relative;flex:none;width:18px;height:18px}
.acc .pm::before,.acc .pm::after{content:"";position:absolute;background:var(--color-primary);border-radius:2px;transition:transform .5s var(--ease-out),opacity .5s var(--ease-out)}
.acc .pm::before{left:0;right:0;top:8px;height:2px}
.acc .pm::after{top:0;bottom:0;left:8px;width:2px;transform-origin:center}
.acc details[open] .pm::after{transform:scaleY(0)}
.acc summary{transition:color .5s var(--ease-out)}
.acc .body{padding:2px 20px 18px 66px;color:var(--color-text-muted);font-size:15px;overflow:hidden}
@media(max-width:560px){.acc .body{padding-left:20px}}

/* --- Vergleichstabelle --- */
.compare-wrap{overflow-x:auto}
.compare{width:100%;border-collapse:collapse;min-width:520px;background:#fff;border-radius:var(--radius-lg);overflow:hidden}
.compare th,.compare td{padding:14px 18px;text-align:left;border-bottom:1px solid var(--color-border);font-size:15px}
.compare thead th{font-family:var(--font-sans);font-weight:var(--fw-semibold);background:var(--color-blue-pale);color:var(--color-primary-dark)}
.compare thead th:last-child{background:var(--color-primary);color:#fff}
.compare td:first-child{font-weight:var(--fw-semibold);color:var(--color-navy)}
.compare tbody tr:last-child td{border-bottom:none}
.compare tbody tr{transition:background-color .15s}
.compare tbody tr:hover{background:#f2f7fc}
.compare td.yes{color:var(--color-primary-dark);font-weight:600}
.compare td.no{color:var(--color-text-muted)}
.compare .yes{color:var(--color-success);font-weight:var(--fw-bold)}
.compare .no{color:var(--color-text-muted)}

/* --- Prozess-Stepper --- */
.steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:32px;counter-reset:step}
.step{position:relative;display:flex;flex-direction:column;align-items:center;text-align:center;background:#fff;border:1px solid #d3dfea;border-radius:var(--radius-lg);box-shadow:var(--shadow-card);padding:30px 22px}
.step::before{counter-increment:step;content:counter(step);display:flex;align-items:center;justify-content:center;width:58px;height:58px;border-radius:50%;background:radial-gradient(circle at 34% 28%,rgba(255,255,255,.6),rgba(255,255,255,0) 46%),var(--gradient-brand);color:#fff;font-family:var(--font-serif);font-size:25px;margin-bottom:16px;box-shadow:inset 0 2px 4px rgba(255,255,255,.4),inset 0 -4px 8px rgba(0,73,125,.55),0 12px 22px rgba(0,94,162,.34)}
.step:not(:last-child)::after{content:"";position:absolute;top:50%;left:calc(100% + 3px);transform:translateY(-50%);width:26px;height:12px;background:url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2026%2012'%3E%3Cpath%20d='M1%206h20'%20stroke='%23569BCD'%20stroke-width='2'%20fill='none'%20stroke-linecap='round'/%3E%3Cpath%20d='M18%202l5%204-5%204'%20stroke='%23569BCD'%20stroke-width='2'%20fill='none'%20stroke-linecap='round'%20stroke-linejoin='round'/%3E%3C/svg%3E") center/contain no-repeat}
@media(max-width:640px){.steps{grid-template-columns:1fr}.step:not(:last-child)::after{top:auto;bottom:-26px;left:50%;right:auto;transform:translateX(-50%) rotate(90deg)}}
.step h3,.step h4{font-family:var(--font-sans);font-weight:var(--fw-semibold);font-size:var(--fs-h4);color:var(--color-navy);margin-bottom:8px}
.step p{font-size:var(--fs-small);color:var(--color-text-muted)}

/* --- Symptom-/Problem-Liste --- */
.symptoms{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px}
.symptom{display:flex;gap:14px;align-items:flex-start;background:#fff;border:1px solid #d3dfea;border-radius:var(--radius-md);padding:18px}
.symptom img{flex:none;width:46px;height:46px;object-fit:contain}
.symptom b{display:block;font-family:var(--font-sans);font-weight:var(--fw-semibold);font-size:15px;color:var(--color-navy);margin-bottom:3px}
.symptom span{font-size:13.5px;color:var(--color-text-muted)}

/* --- Text + Bild --- */
.textimg{display:grid;grid-template-columns:1fr 1fr;gap:44px;align-items:center}
.textimg.flip .textimg-media{order:-1}
@media(max-width:860px){.textimg{grid-template-columns:1fr;gap:26px}.textimg.flip .textimg-media{order:0}}
.textimg-media img{width:100%;border-radius:var(--radius-lg);box-shadow:0 18px 44px rgba(0,73,125,.18);object-fit:cover}
.textimg h2{font-size:clamp(24px,3vw,34px);color:var(--color-navy);margin-bottom:14px}
.textimg p{font-size:16px;line-height:1.68;color:var(--color-text);margin-bottom:14px;max-width:60ch}
.checklist{list-style:none;display:flex;flex-direction:column;gap:10px;margin:6px 0 4px}
.checklist li{display:flex;gap:10px;align-items:flex-start;font-size:15px;color:var(--color-text)}
.checklist li::before{content:"";flex:none;width:20px;height:20px;margin-top:1px;background:var(--color-success);border-radius:50%;-webkit-mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='none' stroke='white' stroke-width='3' stroke-linecap='round' stroke-linejoin='round' d='M5 12l4 4 10-10'/></svg>") center/14px no-repeat;mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='none' stroke='white' stroke-width='3' stroke-linecap='round' stroke-linejoin='round' d='M5 12l4 4 10-10'/></svg>") center/14px no-repeat}

/* --- Referenzen: Vorher/Nachher --- */
.projgrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:24px}
.proj{background:#fff;border:1px solid #d3dfea;border-radius:var(--radius-lg);box-shadow:var(--shadow-card);overflow:hidden}
.proj .ba{position:relative}
.ba-toggle{position:absolute;top:10px;left:50%;transform:translateX(-50%);z-index:2;display:flex;gap:2px;background:rgba(18,27,43,.55);border-radius:var(--radius-pill);padding:3px}
.ba-toggle button{border:0;background:none;color:#fff;font-family:var(--font-sans);font-weight:var(--fw-semibold);font-size:12px;padding:5px 14px;border-radius:var(--radius-pill);cursor:pointer;opacity:.85}
.ba-toggle button.is-active{background:var(--color-primary);opacity:1}
.ba-stage{position:relative;aspect-ratio:4/3}
.ba-img{position:absolute;inset:0;opacity:0;transition:opacity .35s var(--ease-out)}
.ba-img img{width:100%;height:100%;object-fit:cover;display:block}
.ba-img .phimg{width:100%;height:100%;background:var(--color-blue-pale);display:flex;align-items:center;justify-content:center;color:var(--color-text-muted);font-size:13px}
.ba .ba-v{opacity:1}
.ba.show-n .ba-v{opacity:0}
.ba.show-n .ba-n{opacity:1}
.proj .pb{padding:18px 20px}
.proj .pb .tag{font-size:12px;color:var(--color-primary);font-weight:var(--fw-semibold)}
.proj .pb h3,.proj .pb h4{font-family:var(--font-sans);font-weight:var(--fw-semibold);font-size:16px;color:var(--color-navy);margin:4px 0 6px}
.proj .pb p{font-size:14px;color:var(--color-text-muted)}

/* --- Testimonials / Google-Bewertungen --- */
.testigrid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
@media(max-width:860px){.testigrid{grid-template-columns:1fr;max-width:460px;margin-inline:auto}}
.testi{position:relative;background:#fff;border:1px solid #d3dfea;border-radius:var(--radius-lg);box-shadow:var(--shadow-card);padding:28px 24px 22px}
.testi .stars{color:var(--color-warn);letter-spacing:2px;margin-bottom:10px;display:block;text-align:center}
.testi blockquote{font-size:15px;line-height:1.6;color:var(--color-text);margin-bottom:14px}
.testi .who{display:flex;align-items:center;gap:12px;margin-top:6px}
.review-embed{border:1px solid #d3dfea;border-radius:var(--radius-lg);background:linear-gradient(180deg,var(--color-blue-pale),#fff);padding:30px 24px;text-align:center}

/* --- Einzugsgebiet: SVG-Deutschlandkarte, BW+Bayern pulsierend (kein externer Dienst, kein Consent) --- */
.geomap{max-width:380px;margin:0 auto;position:relative}
.geomap svg{width:100%;height:auto;display:block;overflow:visible}
.geo-st{fill:#e6edf3;stroke:#fff;stroke-width:1.6;stroke-linejoin:round}
.geo-hl{fill:var(--color-primary);animation:geopulse 5s ease-in-out infinite}
@keyframes geopulse{0%,100%{fill:#005EA2}50%{fill:#4A90C8}}
.geo-badge{fill:#fff;stroke:var(--color-primary-dark);stroke-width:2.5;filter:drop-shadow(0 2px 3px rgba(0,73,125,.3))}
/* Transporter-Marker nutzt das 3D-Icon icon_transporter.webp via SVG <image> */
.geo-ping-wave{fill:#fff;opacity:.6;filter:blur(1px);transform-box:fill-box;transform-origin:center;animation:geoping 5s ease-out infinite}
.geo-van-img{filter:drop-shadow(0 0 5px rgba(255,255,255,.95)) drop-shadow(0 2px 4px rgba(0,73,125,.35))}
@keyframes geoping{0%{transform:scale(.55);opacity:.6}80%,100%{transform:scale(2.6);opacity:0}}
.geo-legend{display:flex;align-items:center;justify-content:center;gap:8px;margin-top:14px;font-size:13.5px;color:var(--color-text-muted)}
.geo-legend .geo-dot{width:13px;height:13px;border-radius:3px;background:var(--color-primary);flex:none}
@media(prefers-reduced-motion:reduce){.geo-hl,.geo-ping-wave{animation:none}.geo-hl{fill:var(--color-primary)}.geo-ping-wave{opacity:.35}}

/* --- 404-Seite --- */
.err404{font-family:var(--font-display);font-weight:600;font-size:clamp(80px,18vw,168px);line-height:.9;color:var(--color-blue-pale);letter-spacing:2px;margin-bottom:6px}
.err-links{margin-top:6px}
.err-links h3{font-family:var(--font-sans);font-weight:var(--fw-semibold);font-size:15px;color:var(--color-navy);margin-bottom:12px}
.err-links ul{list-style:none;display:flex;flex-wrap:wrap;gap:10px 26px;justify-content:center}
.err-links a{color:var(--color-primary);text-decoration:none;font-weight:var(--fw-medium)}
.err-links a:hover{text-decoration:underline}

/* --- Lead-Magnet-Box --- */
.leadmagnet{display:grid;grid-template-columns:auto 1fr auto;gap:20px;align-items:center;background:var(--color-blue-pale);border:1px solid #dbe9f6;border-radius:var(--radius-lg);padding:24px 26px}
.leadmagnet img{width:84px;height:84px;object-fit:contain}
.leadmagnet h3,.leadmagnet h4{font-family:var(--font-sans);font-weight:var(--fw-semibold);font-size:18px;color:var(--color-navy);margin-bottom:4px}
.leadmagnet p{font-size:14px;color:var(--color-text-muted)}
@media(max-width:680px){.leadmagnet{grid-template-columns:1fr;text-align:center}.leadmagnet img{margin:0 auto}}

/* --- Cookie-Banner --- */
.cookie{position:fixed;left:20px;right:20px;bottom:20px;z-index:90;max-width:560px;margin:0 auto;background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:0 18px 50px rgba(18,27,43,.22);padding:20px 22px}
.cookie p{font-size:14px;color:var(--color-text-muted);margin-bottom:14px}
.cookie .row{display:flex;gap:10px;flex-wrap:wrap}
.cookie .btn{padding:10px 18px;font-size:14px}

/* --- Scroll-to-Top --- */
.to-top{position:fixed;right:20px;bottom:20px;z-index:80;width:48px;height:48px;border-radius:50%;border:none;background:var(--color-primary);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 8px 22px rgba(0,94,162,.35);opacity:0;visibility:hidden;transform:translateY(8px);transition:opacity .3s var(--ease-out),transform .3s var(--ease-out),background .2s var(--ease-out)}
.to-top svg{width:22px;height:22px;fill:none;stroke:currentColor;stroke-width:2.4;stroke-linecap:round;stroke-linejoin:round}
.to-top:hover{background:var(--color-primary-dark)}
.to-top.show{opacity:1;visibility:visible;transform:none}
.to-top:focus-visible{outline:2px solid var(--color-primary);outline-offset:3px}
@media(prefers-reduced-motion:reduce){.to-top{transition:none}}

/* --- Fliesstext-Sektion --- */
.prose{max-width:760px;margin:0 auto}
.prose p{font-size:16px;line-height:1.7;color:var(--color-text);margin-bottom:14px}
.prose p:last-child{margin-bottom:0}
.prose h3{font-family:var(--font-sans);font-weight:var(--fw-semibold);font-size:1.15rem;color:var(--color-navy);margin:20px 0 8px}

/* --- Sprechblase (Was ist …? / Notfall-Intro) --- */
.qbubble{position:relative;max-width:760px;margin:0 auto;display:grid;grid-template-columns:auto 1fr;gap:22px;background:#fff;border:1px solid #d3dfea;border-radius:var(--radius-lg);box-shadow:var(--shadow-card);padding:30px 32px}
.qbubble-icon{flex:none;width:64px;height:64px;border-radius:50%;background:var(--color-blue-pale);display:flex;align-items:center;justify-content:center}
.qbubble-icon img{width:40px;height:40px;object-fit:contain}
.qbubble-body{min-width:0}
.qbubble h2{font-family:var(--font-serif);font-weight:var(--fw-regular);font-size:clamp(24px,3vw,32px);color:var(--color-navy);line-height:1.2;margin-bottom:14px}
.qbubble p{font-size:16px;line-height:1.7;color:var(--color-text);margin-bottom:14px}
.qbubble p:last-child{margin-bottom:0}
.qbubble::before,.qbubble::after{content:"";position:absolute;left:46px;width:0;height:0;border-style:solid}
.qbubble::before{bottom:-16px;border-width:16px 18px 0 0;border-color:#d3dfea transparent transparent transparent}
.qbubble::after{bottom:-14px;border-width:15px 17px 0 0;border-color:#fff transparent transparent transparent}
.qbubble.qbubble--alert{border-color:#fecaca;background:#fef2f2}
.qbubble--alert .qbubble-icon{background:#fee2e2}
.qbubble--alert h2{color:#991b1b}
.qbubble--alert::before{border-top-color:#fecaca}
.qbubble--alert::after{border-top-color:#fef2f2}
@media(max-width:560px){.qbubble{grid-template-columns:1fr;gap:14px;padding:24px 22px}.qbubble-icon{width:54px;height:54px}.qbubble-icon img{width:34px;height:34px}.qbubble::before,.qbubble::after{left:34px}}
.infopair{display:grid;grid-template-columns:1fr 1fr;gap:22px}
@media(max-width:680px){.infopair{grid-template-columns:1fr}}
.infopair .ip{background:#fff;border:1px solid #d3dfea;border-radius:var(--radius-lg);box-shadow:var(--shadow-card);padding:26px 24px}
.infopair .ip h3,.infopair .ip h4{font-family:var(--font-sans);font-weight:var(--fw-semibold);font-size:var(--fs-h4);color:var(--color-navy);margin-bottom:8px}
.infopair .ip p{font-size:15px;line-height:1.6;color:var(--color-text-muted)}
.infopair .ip .big{font-family:var(--font-serif);font-size:1.5rem;color:var(--color-primary);display:block;margin-bottom:6px}

/* --- Rechtstext-Layout (Impressum/Datenschutz) --- */
.legal{max-width:760px;margin:0 auto}
.legal h2{font-size:1.5rem;color:var(--color-navy);margin:28px 0 10px}
.legal h3{font-family:var(--font-sans);font-weight:var(--fw-semibold);font-size:1.05rem;color:var(--color-navy);margin:20px 0 8px}
.legal p,.legal li{font-size:15px;line-height:1.7;color:var(--color-text);margin-bottom:10px}
.legal ul{padding-left:20px}

/* --- Scroll-Reveal --- */
.reveal{opacity:0;transform:translateY(18px);transition:opacity .7s var(--ease-out),transform .7s var(--ease-out)}
.reveal.visible{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}html{scroll-behavior:auto}}

/* --- Feinschliff: Testimonial, Google-Widget, Icon-Select --- */
.testi::before{content:"\201C";position:absolute;top:6px;right:22px;font-family:var(--font-serif);font-size:60px;line-height:1;color:var(--color-blue-pale)}
.testi .who .av{flex:none;width:40px;height:40px;border-radius:50%;background:var(--gradient-brand);color:#fff;display:flex;align-items:center;justify-content:center;font-family:var(--font-serif);font-size:15px;letter-spacing:.5px}
.testi .who .nm{font-family:var(--font-sans);font-weight:var(--fw-semibold);font-size:14px;color:var(--color-navy)}
.testi .who .src{font-size:12px;color:var(--color-text-muted)}
.review-embed .rate{font-family:var(--font-serif);font-size:3rem;line-height:1;color:var(--color-primary)}
.review-embed .rstars{color:var(--color-warn);letter-spacing:3px;font-size:20px;margin:2px 0 4px}
.review-embed .rmeta{color:var(--color-text-muted);font-size:14px;margin:6px 0 16px}
/* Icon-Dropdown (custom select, barrierefrei) */
.iconselect{position:relative}
.iconselect .isbtn{width:100%;min-height:48px;display:flex;align-items:center;gap:10px;border:1px solid var(--color-border);border-radius:var(--radius-md);padding:10px 14px;background:#fff;font-family:var(--font-sans);font-size:15px;color:var(--color-text);cursor:pointer;text-align:left}
.iconselect .isbtn .isarrow{margin-left:auto;transition:transform .2s;color:var(--color-text-muted)}
.iconselect.open .isbtn{border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-primary)}
.iconselect.open .isbtn .isarrow{transform:rotate(180deg)}
.iconselect .isbtn.placeholder{color:var(--color-text-muted)}
.iconselect svg{width:20px;height:20px;flex:none;fill:none;stroke:var(--color-primary);stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.iconselect .islist{position:absolute;top:calc(100% + 6px);left:0;right:0;background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:0 14px 34px rgba(18,27,43,.16);padding:6px;z-index:30;max-height:300px;overflow:auto;display:none;list-style:none}
.iconselect.open .islist{display:block}
.iconselect .isopt{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--radius-sm);font-size:15px;color:var(--color-text);cursor:pointer}
.iconselect .isopt:hover,.iconselect .isopt.is-active{background:var(--color-blue-pale)}
.btn[disabled],.btn:disabled{opacity:.5;cursor:not-allowed;pointer-events:none}
.leadphone a{color:#fff;text-decoration:underline;text-underline-offset:3px}
.leadphone a:hover{color:var(--color-blue-pale)}

.nav .navparent{cursor:default}
.nav .navparent.active{color:var(--color-primary)}
.site-footer .fico{width:15px;height:15px;display:inline-block;vertical-align:-2px;margin-right:7px;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
/* (ehemalige .site-header::after-Welle entfernt -> jetzt nahtlos via ::before, siehe oben) */
/* Scroll-Stack-Karten (3.6): Text links sticky, Karten stapeln beim Scrollen (CSS-sticky) */
.stackwrap{display:grid;grid-template-columns:1fr 1.1fr;gap:48px;align-items:start}
.stack-text{position:sticky;top:110px}
.stack-cards{display:flex;flex-direction:column;gap:24px}
.scard{position:sticky;top:110px;background:#fff;border:1px solid #d3dfea;border-radius:var(--radius-lg);box-shadow:0 14px 34px rgba(18,27,43,.10);padding:28px 26px;min-height:190px}
.scard:nth-child(2){top:128px}
.scard:nth-child(3){top:146px}
.scard:nth-child(4){top:164px}
.scard-n{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:50%;background:radial-gradient(circle at 34% 28%,rgba(255,255,255,.55),rgba(255,255,255,0) 46%),var(--gradient-brand);color:#fff;font-family:var(--font-serif);font-size:18px;margin-bottom:12px;box-shadow:inset 0 1px 3px rgba(255,255,255,.4),0 6px 14px rgba(0,94,162,.28)}
.scard h4{font-family:var(--font-sans);font-weight:var(--fw-semibold);font-size:18px;color:var(--color-navy);margin-bottom:6px}
.scard p{color:var(--color-text-muted);font-size:14.5px;line-height:1.6}
@media(max-width:860px){.stackwrap{grid-template-columns:1fr;gap:22px}.stack-text{position:static}.scard,.scard:nth-child(2),.scard:nth-child(3),.scard:nth-child(4){top:90px}}
.stack-cards .fcard{position:sticky;top:110px;height:auto}
.stack-cards .fcard:nth-child(2){top:128px}
.stack-cards .fcard:nth-child(3){top:146px}
.stack-cards .fcard:nth-child(4){top:164px}
@media(max-width:860px){.stack-cards .fcard,.stack-cards .fcard:nth-child(2),.stack-cards .fcard:nth-child(3),.stack-cards .fcard:nth-child(4){top:90px}}

.footer-logo{height:44px;width:auto;display:block;margin-bottom:14px;filter:brightness(0) invert(1);opacity:.95}
@media(max-width:980px){.nav .has-sub > a::after,.nav .has-sub > .navparent::after{display:none}}

.section:has(.leadcta){padding-bottom:0;z-index:3}
/* Footer-Wellen bleiben auch bei CTA-Overlap sichtbar: CTA-Box liegt davor (z-index:3), Welle scheint seitlich hervor */
