/* ════════════════════════════════════════════════════════════════
   Rohrkonzept — Shared Stylesheet
   Self-hosted Fonts (DSGVO-konform) + alle Seiten-Styles
   Erstellt: 2026-06-25
   ════════════════════════════════════════════════════════════════ */

/* ── Self-hosted Fonts ── */
@font-face{font-family:'Manrope';font-style:normal;font-weight:200 800;font-display:swap;src:url('fonts/manrope-latin-ext-wght-normal.woff2') format('woff2');unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}
@font-face{font-family:'Manrope';font-style:normal;font-weight:200 800;font-display:swap;src:url('fonts/manrope-latin-wght-normal.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:'JetBrains Mono';font-style:normal;font-weight:100 800;font-display:swap;src:url('fonts/jetbrains-mono-latin-ext-wght-normal.woff2') format('woff2');unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}
@font-face{font-family:'JetBrains Mono';font-style:normal;font-weight:100 800;font-display:swap;src:url('fonts/jetbrains-mono-latin-wght-normal.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}

/* ── Main Styles ── */
:root{--bg:#f4f5f7;--paper:#fff;--ink:#0a1628;--ink-2:#3d4a63;--ink-3:#6b768b;--line:#e4e7ee;--line-2:#dbe0ea;--accent:#ff4d18;--accent-deep:#d63a0c;--hi:#ffd43b;--hi-soft:#fff4c4;--ok:#16a34a;--shadow-sm:0 1px 0 rgba(10,22,40,.04),0 2px 8px rgba(10,22,40,.04);--shadow-md:0 14px 40px -16px rgba(10,22,40,.25)}
  *{box-sizing:border-box}
  html,body{margin:0;background:var(--bg);color:var(--ink);font-family:'Manrope',ui-sans-serif,system-ui,sans-serif;-webkit-font-smoothing:antialiased}
  body{font-size:17px;line-height:1.6}
  a{color:inherit}img{max-width:100%;display:block}
  .container{max-width:1240px;margin:0 auto;padding:0 32px}
  .eyebrow{display:inline-flex;align-items:center;gap:10px;font-family:'JetBrains Mono',monospace;font-size:12px;letter-spacing:.04em;color:var(--ink-2);font-weight:600;text-transform:uppercase}
  .eyebrow .dot{width:8px;height:8px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 4px rgba(255,77,24,.18);animation:pulse 1.6s infinite}
  @keyframes pulse{0%,100%{box-shadow:0 0 0 4px rgba(255,77,24,.18)}50%{box-shadow:0 0 0 8px rgba(255,77,24,.02)}}
  .skip-link{position:absolute;left:-9999px;top:0;background:var(--ink);color:#fff;padding:12px 18px;z-index:100;border-radius:0 0 10px 0;font-weight:700;text-decoration:none}
  .skip-link:focus{left:0}
  .header-stack{position:sticky;top:0;z-index:50;background:var(--paper)}
  .header-stack.scrolled header.site{box-shadow:0 4px 16px -8px rgba(10,22,40,.15)}
  .alert{background:var(--accent);color:#fff;font-weight:700;font-size:13.5px}
  .alert__inner{display:flex;align-items:center;justify-content:space-between;height:42px;gap:24px}
  .alert__left{display:flex;align-items:center;gap:10px}
  .alert__left svg{width:18px;height:18px}
  .alert__phone{display:inline-flex;align-items:center;gap:8px;color:#fff;text-decoration:none;font-weight:800}
  .alert__phone .num{background:rgba(0,0,0,.18);padding:5px 12px;border-radius:6px;font-family:'JetBrains Mono',monospace}
  header.site{background:var(--paper);border-bottom:1px solid var(--line)}
  .site__inner{display:flex;align-items:center;justify-content:space-between;gap:24px;padding-block:14px}
  .brand{display:flex;align-items:center;gap:14px;text-decoration:none;color:var(--ink)}
  .brand__mark{width:68px;height:68px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
  .brand__mark img{width:100%;height:100%;object-fit:contain;display:block}
  .brand__name{font-weight:900;font-size:22px;letter-spacing:-.02em}
  .brand__name em{font-style:normal;color:var(--accent)}
  .brand__sub{display:block;font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--ink-3);margin-top:1px}
  nav.main{display:flex;gap:28px;align-items:center}
  nav.main > a, nav.main .nav-dd__toggle{color:var(--ink-2);text-decoration:none;font-weight:800;font-size:13px;letter-spacing:.08em;text-transform:uppercase;padding:10px 0;display:inline-flex;align-items:center;border-bottom:3px solid transparent;border-top:3px solid transparent;transition:color .18s,border-color .18s}
  nav.main > a:hover, nav.main .nav-dd__toggle:hover{color:var(--ink);border-bottom-color:var(--line-2)}
  nav.main > a.active{color:var(--ink);border-bottom-color:var(--accent)}
  .nav-dd{position:relative;display:flex;align-items:center}
  .nav-dd__toggle{gap:6px;cursor:pointer}
  .nav-dd__toggle.active{color:var(--ink);border-bottom-color:var(--accent)}
  .nav-dd__toggle svg{width:10px;height:10px;transition:transform .2s}
  .nav-dd:hover .nav-dd__toggle svg{transform:rotate(180deg)}
  .nav-dd__menu{position:absolute;top:calc(100% + 6px);left:0;min-width:240px;background:#fff;border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow-md);padding:8px;opacity:0;visibility:hidden;transform:translateY(-6px);transition:opacity .18s,transform .18s,visibility .18s;z-index:30}
  .nav-dd:hover .nav-dd__menu,.nav-dd:focus-within .nav-dd__menu,.nav-dd.is-open .nav-dd__menu{opacity:1;visibility:visible;transform:translateY(0)}
  .nav-dd.is-open .nav-dd__toggle svg{transform:rotate(180deg)}
  .nav-dd.is-open .nav-dd__toggle{color:var(--ink);border-bottom-color:var(--accent)}
  .nav-dd__menu a{display:flex;align-items:center;gap:10px;padding:11px 14px;text-decoration:none;color:var(--ink-2);font-weight:700;font-size:14px;text-transform:none;letter-spacing:0;border-radius:8px;transition:background .12s,color .12s}
  .nav-dd__menu a:hover{background:var(--bg);color:var(--ink)}
  .nav-dd__menu a.active{background:var(--bg);color:var(--ink)}
  .nav-dd__menu a::before{content:"";width:5px;height:5px;border-radius:50%;background:var(--accent);flex-shrink:0;opacity:.5}
  .btn{display:inline-flex;align-items:center;gap:10px;border-radius:12px;padding:13px 22px;font-weight:700;text-decoration:none;font-size:15px;border:2px solid transparent;transition:transform .15s,background .15s;line-height:1;white-space:nowrap;cursor:pointer;font-family:inherit}
  .btn--call{background:var(--accent);color:#fff;box-shadow:0 6px 16px -4px rgba(255,77,24,.55)}
  .btn--call:hover{background:var(--accent-deep);transform:translateY(-1px)}
  .btn--ghost{background:var(--paper);color:var(--ink);border-color:var(--line-2)}
  .btn--ghost:hover{border-color:var(--ink)}
  .btn--ink{background:var(--ink);color:#fff}
  .btn--ink:hover{background:#000}
  .btn svg{width:18px;height:18px}
  .btn--xl{padding:18px 28px;font-size:17px;border-radius:14px}
  .breadcrumbs{font-family:'JetBrains Mono',monospace;font-size:12px;color:var(--ink-3);margin:32px 0 16px;letter-spacing:.04em;text-transform:uppercase}
  .breadcrumbs a{text-decoration:none;color:var(--ink-3)}.breadcrumbs span{color:var(--ink)}
  .phero{padding:8px 0 60px;position:relative;overflow:hidden;background-image:linear-gradient(105deg,rgba(255,255,255,.96) 0%,rgba(255,255,255,.88) 38%,rgba(255,255,255,.6) 70%,rgba(255,255,255,.55) 100%),linear-gradient(180deg,transparent 0%,rgba(244,245,247,.55) 100%),url('img/Kanalreinigung.webp');background-size:cover;background-position:center;background-repeat:no-repeat}
  .phero::after{content:"";position:absolute;inset:0;pointer-events:none;background:radial-gradient(circle at 18% 35%,rgba(255,255,255,.55) 0%,transparent 60%)}
  .phero > .container{position:relative;z-index:2}
  .phero__grid{display:grid;grid-template-columns:1.1fr 1fr;gap:48px;align-items:center}
  .phero h1{font-size:72px;font-weight:900;line-height:.95;letter-spacing:-.035em;margin:18px 0 22px;text-wrap:balance}
  .phero h1 .mark{background:var(--hi);padding:0 8px;border-radius:6px;display:inline-block;transform:rotate(-1deg)}
  .phero h1 .accent{color:var(--accent)}
  .phero p.lead{font-size:18px;color:var(--ink-2);max-width:560px;margin:0 0 28px;line-height:1.6}
  .phero__actions{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
  .hero__chips{display:flex;flex-wrap:wrap;gap:10px;margin-top:24px}
  .chip{display:inline-flex;align-items:center;gap:8px;background:var(--paper);border:1px solid var(--line);padding:8px 14px;border-radius:999px;font-size:13.5px;font-weight:600;color:var(--ink-2)}
  .chip svg{width:14px;height:14px;color:var(--ok)}
  .phero__panel{background:var(--ink);color:#fff;border-radius:24px;padding:32px;position:relative;overflow:hidden;box-shadow:var(--shadow-md)}
  .phero__panel::before{content:"";position:absolute;right:-40px;top:-40px;width:180px;height:180px;border-radius:50%;background:radial-gradient(circle,rgba(255,77,24,.35),transparent 70%)}
  .panel__big{font-size:90px;font-weight:900;letter-spacing:-.035em;line-height:1;margin:0 0 2px;position:relative}
  .panel__big em{font-style:normal;color:var(--hi)}
  .panel__big small{font-size:24px;color:rgba(255,255,255,.65);font-weight:700;margin-left:6px}
  .panel__sub{font-size:15px;color:rgba(255,255,255,.7);margin:0 0 28px;position:relative}
  .panel__rows{display:flex;flex-direction:column;gap:10px;position:relative}
  .panel__row{display:flex;align-items:center;gap:14px;padding:14px 16px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);border-radius:14px}
  .panel__row .ic{width:38px;height:38px;border-radius:10px;background:rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center;color:var(--hi);flex-shrink:0}
  .panel__row .ic svg{width:20px;height:20px}
  .panel__row b{display:block;font-size:15px;font-weight:700}
  .panel__row span{display:block;font-size:13px;color:rgba(255,255,255,.55);font-family:'JetBrains Mono',monospace;margin-top:2px}
  .ticker{background:var(--ink);color:#fff;padding:18px 0;border-top:1px solid rgba(255,255,255,.06);overflow:hidden}
  .ticker__inner{display:flex;align-items:center;gap:48px;animation:scroll 28s linear infinite;white-space:nowrap}
  .ticker__item{display:inline-flex;align-items:center;gap:10px;font-family:'JetBrains Mono',monospace;font-size:14px;color:rgba(255,255,255,.75);font-weight:600;letter-spacing:.01em}
  .ticker__item svg{width:16px;height:16px;color:var(--hi)}
  .ticker__dot{width:6px;height:6px;border-radius:50%;background:var(--accent);flex-shrink:0}
  @keyframes scroll{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
  .stats{display:grid;grid-template-columns:repeat(4,1fr);gap:0;background:var(--ink);border-radius:24px;overflow:hidden;color:#fff;position:relative}
  .stat{padding:36px 32px;position:relative;border-right:1px solid rgba(255,255,255,.08)}
  .stat:last-child{border-right:none}
  .stat__big{font-size:64px;font-weight:900;letter-spacing:-.035em;line-height:1;margin:0 0 6px}
  .stat__big em{font-style:normal;color:var(--hi)}
  .stat__big sup{font-size:24px;color:var(--accent);margin-left:4px;vertical-align:super}
  .stat__lbl{font-size:14px;color:rgba(255,255,255,.65);font-family:'JetBrains Mono',monospace;text-transform:uppercase;letter-spacing:.04em}
  .hbar{background:var(--ink);color:#fff;padding:24px 0}
  .hbar__inner{display:grid;grid-template-columns:repeat(4,1fr);gap:32px}
  .hbar__item{display:flex;align-items:center;gap:14px}
  .hbar__item .ic{width:42px;height:42px;border-radius:12px;background:rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--hi)}
  .hbar__item .ic svg{width:22px;height:22px}
  .hbar__item b{display:block;font-size:15px;font-weight:800}
  .hbar__item span{display:block;font-size:13px;color:rgba(255,255,255,.65);font-family:'JetBrains Mono',monospace;margin-top:2px}
  section.s{padding:96px 0}
  .pgrid{display:grid;grid-template-columns:1fr 360px;gap:64px;align-items:start}
  .content h2{font-size:42px;font-weight:900;line-height:1.04;letter-spacing:-.03em;margin:0 0 18px;text-wrap:balance}
  .content h2 .accent{color:var(--accent)}
  .content h2 .mark{background:var(--hi);padding:0 6px;border-radius:6px;display:inline-block;transform:rotate(-1deg)}
  .content h2:not(:first-child){margin-top:56px}
  .content p{margin:0 0 18px;color:var(--ink-2);font-size:17px;line-height:1.7}
  .content p strong{color:var(--ink);font-weight:800}
  .check-list{list-style:none;padding:0;margin:24px 0;display:flex;flex-direction:column;gap:12px}
  .check-list li{display:flex;gap:14px;align-items:flex-start;font-size:16px;color:var(--ink-2);line-height:1.55}
  .check-list li .ic{flex:0 0 auto;width:26px;height:26px;background:var(--ink);color:#fff;border-radius:8px;display:flex;align-items:center;justify-content:center;margin-top:1px}
  .check-list li .ic svg{width:14px;height:14px}
  .pullquote{margin:40px 0;padding:36px 40px;background:var(--ink);color:#fff;border-radius:20px;font-size:24px;font-weight:700;line-height:1.3;letter-spacing:-.015em;position:relative;overflow:hidden}
  .pullquote::before{content:"";position:absolute;right:-50px;bottom:-50px;width:200px;height:200px;border-radius:50%;background:radial-gradient(circle,rgba(255,212,59,.18),transparent 65%)}
  .pullquote .mark{background:var(--hi);color:var(--ink);padding:0 8px;border-radius:6px;display:inline-block;transform:rotate(-1deg)}
  .pullquote .quotemark{font-family:'JetBrains Mono',monospace;font-size:12px;color:var(--hi);font-weight:700;letter-spacing:.04em;margin-bottom:10px;display:block;position:relative}
  .side{position:sticky;top:120px;display:flex;flex-direction:column;gap:18px}
  .side-card{background:var(--paper);border:1px solid var(--line);border-radius:18px;padding:26px;box-shadow:var(--shadow-md)}
  .side-card--accent{background:var(--accent);color:#fff;border-color:var(--accent);position:relative;overflow:hidden}
  .side-card--accent::before{content:"";position:absolute;right:-60px;top:-60px;width:160px;height:160px;border-radius:50%;background:rgba(255,255,255,.1)}
  .side-card--accent h3{color:#fff}
  .side-card h3{font-size:22px;font-weight:900;letter-spacing:-.02em;margin:0 0 6px;position:relative}
  .side-card p{font-size:14px;line-height:1.5;color:var(--ink-2);margin:0 0 14px;position:relative}
  .side-card--accent p{color:rgba(255,255,255,.85)}
  .side-card .num{font-family:'JetBrains Mono',monospace;font-size:30px;color:#fff;font-weight:800;letter-spacing:-.02em;display:block;margin:6px 0 16px;position:relative}
  .side-card .btn{width:100%;justify-content:center}
  .side-card ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}
  .side-card ul a{display:flex;justify-content:space-between;align-items:center;text-decoration:none;color:var(--ink);padding:12px 14px;border-radius:10px;border:1px solid var(--line);font-weight:700;font-size:14.5px;transition:border-color .15s,background .15s}
  .side-card ul a:hover{border-color:var(--ink);background:var(--bg)}
  .side-card ul a svg{width:16px;height:16px;color:var(--ink-3)}
  .team-bg{background:var(--paper)}
  .team-grid{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
  .team__img{position:relative;border-radius:24px;overflow:hidden;box-shadow:var(--shadow-md);aspect-ratio:4/5;background:var(--bg)}
  .team__img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s ease}
  .team__img:hover img{transform:scale(1.04)}
  .team__badge{position:absolute;bottom:20px;left:20px;background:var(--ink);color:#fff;padding:12px 18px;border-radius:12px;font-family:'JetBrains Mono',monospace;font-size:12.5px;font-weight:700;letter-spacing:.04em;display:inline-flex;align-items:center;gap:8px}
  .team__badge::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 4px rgba(255,77,24,.25);animation:pulse 1.6s infinite}
  .team__text h2{font-size:42px;font-weight:900;letter-spacing:-.03em;line-height:1.04;margin:14px 0 18px;text-wrap:balance}
  .team__text h2 .accent{color:var(--accent)}
  .team__text h2 .mark{background:var(--hi);padding:0 6px;border-radius:6px;display:inline-block;transform:rotate(-1deg)}
  .team__text p{color:var(--ink-2);font-size:17px;line-height:1.7;margin:0 0 18px}
  .team__text p strong{color:var(--ink);font-weight:800}
  .team__stats{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:24px}
  .team__stat{background:var(--bg);border:1px solid var(--line);border-radius:14px;padding:18px 20px}
  .team__stat b{display:block;font-size:28px;font-weight:900;color:var(--ink);letter-spacing:-.02em;line-height:1;margin-bottom:4px}
  .team__stat b em{font-style:normal;color:var(--accent)}
  .team__stat span{font-size:13px;color:var(--ink-3);font-family:'JetBrains Mono',monospace;font-weight:600;text-transform:uppercase;letter-spacing:.04em}
  @media (max-width:880px){.team-grid{grid-template-columns:1fr;gap:32px}.team__img{aspect-ratio:16/10;max-width:100%}.team__text h2{font-size:32px}}

  .cases-bg{background:var(--paper)}
  .cases{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:48px}
  .case{background:var(--bg);border:1px solid var(--line);border-radius:20px;padding:30px;display:flex;flex-direction:column;gap:14px;position:relative;overflow:hidden}
  .case .num{font-family:'JetBrains Mono',monospace;font-size:14px;color:var(--ink-3);font-weight:700;letter-spacing:.04em}
  .case h3{font-size:22px;font-weight:900;margin:0;letter-spacing:-.02em;color:var(--ink)}
  .case p{margin:0;color:var(--ink-2);font-size:15px;line-height:1.6;flex:1}
  .case .tag{margin-top:6px;display:inline-flex;align-self:flex-start;font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.06em;background:var(--accent);color:#fff;font-weight:800;padding:6px 10px;border-radius:6px;text-transform:uppercase}
  .case .tag--yellow{background:var(--hi);color:var(--ink)}
  .case .tag--ink{background:var(--ink);color:#fff}
  .final{background:var(--accent);color:#fff;border-radius:28px;padding:64px 56px;display:grid;grid-template-columns:1.3fr 1fr;align-items:center;gap:40px;position:relative;overflow:hidden}
  .final::before{content:"";position:absolute;right:-160px;top:-160px;width:360px;height:360px;border-radius:50%;background:rgba(255,255,255,.08)}
  .final::after{content:"";position:absolute;left:-100px;bottom:-100px;width:260px;height:260px;border-radius:50%;background:rgba(0,0,0,.08)}
  .final h2{font-size:54px;line-height:1.02;font-weight:900;letter-spacing:-.035em;margin:0 0 16px;position:relative}
  .final h2 .mark{background:var(--ink);color:#fff;padding:0 8px;border-radius:6px;display:inline-block;transform:rotate(-1deg)}
  .final p{margin:0;color:rgba(255,255,255,.85);font-size:17px;max-width:480px;position:relative;line-height:1.6}
  .final__cta{position:relative;display:flex;flex-direction:column;gap:14px;align-items:flex-start}
  .final__num{font-family:'JetBrains Mono',monospace;font-size:46px;color:#fff;letter-spacing:-.02em;line-height:1;font-weight:800}
  .final small{font-size:13px;color:rgba(255,255,255,.78);font-family:'JetBrains Mono',monospace}
  footer.site{background:var(--ink);color:#bcc4d2;padding:0 0 32px;font-size:14.5px;position:relative;border-top:5px solid var(--accent)}
  .foot-cta{display:flex;align-items:center;justify-content:space-between;gap:40px;padding:64px 0;border-bottom:1px solid rgba(255,255,255,.08);flex-wrap:wrap;position:relative}
  .foot-cta::before{content:"";position:absolute;right:-100px;top:50%;transform:translateY(-50%);width:280px;height:280px;border-radius:50%;background:radial-gradient(circle,rgba(255,77,24,.18),transparent 70%);pointer-events:none}
  .foot-cta__text{position:relative;flex:1;min-width:280px}
  .foot-cta__text h3{font-size:38px;font-weight:900;color:#fff;margin:0 0 10px;letter-spacing:-.025em;line-height:1.05;text-wrap:balance}
  .foot-cta__text h3 .accent{color:var(--accent)}
  .foot-cta__text p{margin:0;color:#9aa5b7;font-size:15.5px;max-width:480px;line-height:1.55}
  .foot-cta__action{position:relative;display:flex;flex-direction:column;gap:14px;align-items:flex-end}
  .foot-cta__num{font-family:'JetBrains Mono',monospace;font-size:34px;color:#fff;font-weight:800;letter-spacing:-.02em;line-height:1}
  .foot-cta__btn{background:var(--accent);color:#fff;padding:16px 30px;border-radius:14px;text-decoration:none;font-weight:800;display:inline-flex;align-items:center;gap:10px;font-size:16px;transition:background .15s,transform .15s;box-shadow:0 8px 24px -8px rgba(255,77,24,.5)}
  .foot-cta__btn:hover{background:var(--accent-deep);transform:translateY(-2px)}
  .foot-cta__btn svg{width:18px;height:18px}
  .foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:56px;padding:64px 0 24px}
  .foot-brand-block{display:flex;flex-direction:column;gap:18px}
  .foot-brand-logo{display:flex;align-items:center;gap:14px;margin-bottom:4px}
  .foot-brand-logo img{width:64px;height:64px;object-fit:contain;flex-shrink:0}
  .foot-brand-logo .name{font-size:28px;color:#fff;font-weight:900;letter-spacing:-.02em;line-height:1}
  .foot-brand-logo .name em{font-style:normal;color:var(--accent)}
  .foot-brand-logo .sub{display:block;font-family:'JetBrains Mono',monospace;font-size:11px;color:#7a8497;letter-spacing:.02em;margin-top:4px;font-weight:600}
  .foot-brand-block .desc{color:#9aa5b7;margin:0;line-height:1.65;max-width:380px;font-size:14.5px}
  .foot-badges{display:flex;flex-wrap:wrap;gap:8px;margin-top:6px}
  .foot-badge{display:inline-flex;align-items:center;gap:6px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);padding:7px 11px;border-radius:8px;font-size:12px;font-weight:700;color:#fff;font-family:'JetBrains Mono',monospace;letter-spacing:.02em}
  .foot-badge svg{width:12px;height:12px;color:var(--hi)}
  .foot-col h4{color:#fff;font-size:12px;letter-spacing:.06em;text-transform:uppercase;font-weight:800;margin:0 0 22px;font-family:'JetBrains Mono',monospace;display:flex;align-items:center;gap:10px}
  .foot-col h4::before{content:"";width:18px;height:2px;background:var(--accent);display:inline-block;flex-shrink:0}
  .foot-col a{color:#bcc4d2;text-decoration:none;display:flex;align-items:center;gap:8px;padding:7px 0;font-size:14.5px;transition:color .15s,transform .15s;font-weight:500}
  .foot-col a:hover{color:#fff;transform:translateX(3px)}
  .foot-col a svg{width:13px;height:13px;color:#5a6478;transition:color .15s;flex-shrink:0}
  .foot-col a:hover svg{color:var(--accent)}
  .foot-col .info{color:#7a8497;font-size:13.5px;line-height:1.6;margin:14px 0 0;font-family:'JetBrains Mono',monospace}
  .foot-bottom{border-top:1px solid rgba(255,255,255,.08);margin-top:48px;padding-top:28px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:18px;color:#7a8497;font-size:13px}
  .foot-bottom-left{display:flex;align-items:center;gap:24px;flex-wrap:wrap}
  .foot-bottom a{color:#bcc4d2;text-decoration:none;transition:color .15s}
  .foot-bottom a:hover{color:#fff}
  .foot-bottom-right{display:flex;gap:24px;align-items:center}
  .foot-made{color:#5a6478;font-family:'JetBrains Mono',monospace;font-size:12.5px}
  .foot-made em{font-style:normal;color:var(--hi);font-weight:700}
  .mcall{display:none}
  @media (max-width:760px){.mcall{display:block;position:fixed;left:0;right:0;bottom:0;z-index:50;background:var(--accent);box-shadow:0 -8px 24px -8px rgba(10,22,40,.35);padding-bottom:env(safe-area-inset-bottom)}.mcall a{display:flex;align-items:center;justify-content:center;gap:10px;color:#fff;text-decoration:none;font-weight:800;padding:16px;font-size:15.5px}.mcall a svg{width:20px;height:20px}body{padding-bottom:68px}}
  .cookie{position:fixed;left:24px;right:24px;bottom:24px;z-index:60;background:var(--ink);color:#fff;border-radius:18px;padding:22px 24px;box-shadow:0 24px 60px -20px rgba(0,0,0,.55);max-width:520px;display:none}
  .cookie.show{display:block}
  .cookie p{margin:0 0 14px;font-size:14px;line-height:1.55;color:rgba(255,255,255,.85)}
  .cookie p a{color:var(--hi);text-decoration:underline}
  .cookie__actions{display:flex;gap:10px;flex-wrap:wrap}
  .cookie__btn{padding:10px 18px;border-radius:10px;font-weight:700;font-size:14px;border:0;cursor:pointer;font-family:inherit}
  .cookie__btn--accept{background:var(--accent);color:#fff}
  .cookie__btn--accept:hover{background:var(--accent-deep)}
  .cookie__btn--decline{background:rgba(255,255,255,.08);color:#fff}
  .cookie__btn--decline:hover{background:rgba(255,255,255,.14)}
  @media (max-width:760px){.cookie{left:12px;right:12px;bottom:84px;padding:18px}}
  @media (max-width:1080px){.phero h1{font-size:48px}.cases{grid-template-columns:1fr 1fr}}
  @media (max-width:880px){.phero__grid,.pgrid{grid-template-columns:1fr;gap:36px}.side{position:static}.hbar__inner{grid-template-columns:1fr 1fr;gap:20px}nav.main{display:none}section.s{padding:64px 0}.phero{padding:8px 0 48px}.final{padding:48px 32px;grid-template-columns:1fr;text-align:left}.final h2{font-size:38px}.panel__big{font-size:64px}.alert__inner{font-size:12.5px;gap:12px}.cases{grid-template-columns:1fr}.foot-grid{grid-template-columns:1fr 1fr;gap:36px;padding:48px 0 16px}.foot-brand-block{grid-column:1 / -1}.foot-cta{padding:48px 0;gap:24px}.foot-cta__text h3{font-size:28px}.foot-cta__action{align-items:flex-start;width:100%}.foot-cta__num{font-size:28px}.foot-bottom{flex-direction:column;align-items:flex-start;gap:10px}}
  @media (max-width:520px){.container{padding:0 18px}.phero h1{font-size:36px}.pullquote{padding:24px;font-size:18px}.phero__panel{padding:24px}.foot-grid{grid-template-columns:1fr}}
  /* === MOBILE OPTIMIERUNG (hinzugefügt) === */
  @media (max-width:640px){
    .alert{font-size:12px}
    .alert__inner{height:auto;min-height:38px;padding:8px 0;gap:10px;flex-wrap:wrap;justify-content:center;text-align:center;line-height:1.25}
    .alert__left{gap:8px;justify-content:center}
    .alert__left svg{width:14px;height:14px;flex-shrink:0}
    .alert__phone{font-size:12.5px;gap:6px;white-space:nowrap}
    .alert__phone .num{padding:3px 9px;font-size:12px}
    .site__inner{gap:10px;padding-block:10px}
    .brand{gap:10px}
    .brand__mark{width:48px;height:48px}
    .brand__name{font-size:18px}
    .brand__sub{font-size:9.5px;letter-spacing:0;margin-top:2px}
    header.site .btn--call{padding:10px 14px;font-size:13.5px;border-radius:10px;gap:6px;white-space:nowrap}
    header.site .btn--call svg{width:16px;height:16px}
  }
  @media (max-width:520px){
    body{font-size:16px}
    .container{padding:0 16px}
    .phero{padding:8px 0 36px}
    .phero h1{font-size:32px;line-height:1.04;margin:14px 0 16px}
    .phero p.lead{font-size:16px;line-height:1.55;margin:0 0 22px}
    .phero__panel{padding:22px}
    .phero__actions{display:flex;flex-direction:column;align-items:stretch;gap:10px;margin-bottom:22px}
    .btn--xl{padding:15px 20px;font-size:15.5px;width:100%;justify-content:center}
    .hero__chips{gap:8px;flex-wrap:wrap}
    .chip{font-size:12.5px;padding:6px 11px}
    section.s{padding:48px 0}
    .content h2{font-size:30px;margin:0 0 14px;line-height:1.08}
    .content p{font-size:16px;line-height:1.65;margin:0 0 14px}
    .check-list li{font-size:15px;gap:10px;line-height:1.5}
    .pullquote{margin:28px 0;padding:22px;font-size:17px;border-radius:16px;line-height:1.35}
    .panel__big{font-size:56px}
    .panel__big small{font-size:18px}
    .panel__sub{font-size:14px;margin:0 0 22px}
    .panel__row b{font-size:14px}
    .panel__row span{font-size:12px}
    .stat__big{font-size:46px}
    .stat__big sup{font-size:18px}
    .stat__lbl{font-size:12.5px}
    .final{padding:36px 22px;border-radius:20px}
    .final h2{font-size:30px;line-height:1.08}
    .breadcrumbs{font-size:11px;margin:22px 0 12px}
    .foot-cta__text h3{font-size:24px;line-height:1.15}
    .foot-cta__num{font-size:24px}
    .team__text h2{font-size:26px;line-height:1.1}
    .team__text p{font-size:15.5px}
    .team__stat b{font-size:24px}
    .side-card h3{font-size:20px}
    .side-card .num{font-size:24px}
    .side-card p{font-size:13.5px}
    .case h3{font-size:20px}
    .case p{font-size:14.5px}
    .eyebrow{font-size:11px}
    .ticker__item{font-size:12.5px}
    .hbar__item b{font-size:14px}
    .hbar__item span{font-size:12px}
  }
  @media (max-width:380px){
    .alert__inner{font-size:11.5px;gap:6px;padding:7px 0}
    .alert__phone{font-size:12px}
    .brand__mark{width:42px;height:42px}
    .brand__name{font-size:16px}
    .brand__sub{display:none}
    header.site .btn--call{padding:9px 12px;font-size:12.5px}
    header.site .btn--call svg{width:14px;height:14px}
    .phero h1{font-size:28px}
    .phero p.lead{font-size:15px}
    .content h2{font-size:26px}
    .content p{font-size:15.5px}
    .final h2{font-size:26px}
    .panel__big{font-size:46px}
    .panel__big small{font-size:16px}
    .stat__big{font-size:38px}
  }
  /* === HAMBURGER MENU === */
  .menu-toggle{display:none;background:transparent;border:0;padding:0;cursor:pointer;width:44px;height:44px;border-radius:10px;align-items:center;justify-content:center;flex-direction:column;gap:5px;flex-shrink:0;-webkit-tap-highlight-color:transparent}
  .menu-toggle span{display:block;width:24px;height:2.5px;background:var(--ink);border-radius:2px;transition:transform .25s,opacity .2s}
  .menu-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7.5px) rotate(45deg)}
  .menu-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
  .menu-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}
  @media (max-width:880px){
    .menu-toggle{display:flex;position:relative;z-index:70}
    header.site .btn--call{display:none}
    body.menu-open{overflow:hidden}

    /* Overlay container */
    nav.main{
      display:none;position:fixed;top:0;left:0;right:0;bottom:0;
      background:var(--paper);z-index:60;
      padding:84px 22px 32px;
      flex-direction:column;align-items:stretch;gap:0;
      overflow-y:auto;-webkit-overflow-scrolling:touch
    }
    nav.main.is-open{display:flex}

    /* Reset the desktop .nav-dd flex-row so children stack vertically */
    nav.main .nav-dd{position:static;display:block;align-items:stretch;width:100%;border:0}

    /* Top-level items */
    nav.main > a{
      display:block;width:100%;
      font-size:17px;font-weight:700;
      text-transform:none;letter-spacing:0;
      padding:18px 6px;border:0;border-bottom:1px solid var(--line);
      color:var(--ink);text-decoration:none;
      box-sizing:border-box
    }
    nav.main > a.active{color:var(--accent)}

    /* Service section label (non-clickable on mobile) */
    nav.main .nav-dd .nav-dd__toggle{
      display:block;width:100%;
      font-size:11px;font-weight:800;
      text-transform:uppercase;letter-spacing:.08em;
      padding:20px 6px 8px;border:0;
      color:var(--ink-3);
      text-decoration:none;cursor:default;
      pointer-events:none;
      box-sizing:border-box
    }
    nav.main .nav-dd .nav-dd__toggle svg{display:none}

    /* Submenu always visible on mobile, stacked vertically */
    nav.main .nav-dd__menu{
      position:static;display:block;
      box-shadow:none;background:transparent;border:0;
      opacity:1;visibility:visible;transform:none;
      min-width:0;width:100%;padding:0 0 8px;margin:0;
      border-bottom:1px solid var(--line)
    }
    nav.main .nav-dd__menu a{
      display:flex;align-items:center;gap:12px;
      padding:14px 10px;font-size:16px;font-weight:600;
      border:0;border-radius:10px;
      color:var(--ink);background:transparent;
      text-decoration:none;
      text-transform:none;letter-spacing:0;
      width:100%;box-sizing:border-box
    }
    nav.main .nav-dd__menu a.active{color:var(--accent);font-weight:800;background:rgba(255,77,24,.08)}
    nav.main .nav-dd__menu a::before{
      content:"";width:6px;height:6px;border-radius:50%;
      background:var(--accent);opacity:.55;flex-shrink:0
    }
    nav.main .nav-dd__menu a.active::before{opacity:1}

    /* Last top-level link should not have a border (visual polish) */
    nav.main > a:last-of-type{border-bottom:0}
  }
  /* === ALERT BAR (verbessert) === */
  @media (max-width:880px){
    .alert{font-size:12.5px}
    .alert__inner{height:auto;min-height:38px;padding:7px 0;gap:12px;line-height:1.3}
    .alert__left{gap:8px}
    .alert__left svg{width:15px;height:15px;flex-shrink:0}
    .alert__phone{font-size:12.5px;gap:6px;white-space:nowrap;flex-shrink:0}
    .alert__phone .num{padding:3px 8px;font-size:12px}
  }
  @media (max-width:640px){
    .alert__inner{flex-wrap:wrap;justify-content:center;text-align:center}
    .alert__cities{display:none}
    .alert__left{justify-content:center}
    .alert__phone{flex-basis:auto}
  }
  @media (max-width:380px){
    .alert__left svg{display:none}
    .alert__phone-label{display:none}
    .alert__inner{gap:8px}
  }
  /* === OVERFLOW-FIX === */
  html,body{overflow-x:clip}
  .foot-cta{overflow:hidden}
  .hero,.phero,section.s{overflow:hidden}
  /* === HEADER MOBILE V2: Alert weg, Anruf-Icon neben Menü === */
  @media (max-width:880px){
    .header-stack .alert{display:none}
    header.site .btn--call{
      display:inline-flex;
      align-items:center;justify-content:center;
      width:44px;height:44px;
      padding:0;gap:0;
      font-size:0;line-height:0;
      border-radius:10px;
      box-shadow:none;
      flex-shrink:0;
      margin-left:auto
    }
    header.site .btn--call svg{width:22px;height:22px;display:block}
    header.site .site__inner{gap:8px}
    .menu-toggle{margin-left:0}
  }
  /* === HERO-SPACING (Mobil) === */
  @media (max-width:880px){
    .phero__grid{gap:56px}
    .hero__chips{margin-top:28px;margin-bottom:8px;gap:10px}
    .phero__panel{padding:28px;border-radius:22px}
    .panel__big{margin:0 0 6px}
    .panel__sub{margin:0 0 26px;font-size:15px;line-height:1.5}
    .panel__rows{gap:14px}
    .panel__row{padding:16px 18px;gap:14px;border-radius:14px}
    .panel__row .ic{width:42px;height:42px}
    .panel__row b{font-size:15px}
    .panel__row span{font-size:12.5px;margin-top:3px}
  }
  @media (max-width:520px){
    .phero{padding:8px 0 56px}
    .phero__grid{gap:44px}
    .phero__panel{padding:26px;border-radius:20px}
    .panel__rows{gap:12px}
    .panel__row{padding:15px 16px}
    .hero__chips{margin-top:24px;gap:9px}
    .phero__actions{margin-bottom:8px}
  }
  /* === HERO (Startseiten-Stil, ersetzt .phero) === */
  .hero{padding:20px 0 80px;position:relative;overflow:hidden;background-image:linear-gradient(105deg, rgba(255,255,255,.96) 0%, rgba(255,255,255,.88) 38%, rgba(255,255,255,.6) 70%, rgba(255,255,255,.55) 100%),linear-gradient(180deg, transparent 0%, rgba(244,245,247,.55) 100%),url('img/Kanalreinigung.webp');background-size:cover;background-position:center;background-repeat:no-repeat}
  .hero::after{content:"";position:absolute;inset:0;pointer-events:none;background:radial-gradient(circle at 18% 35%, rgba(255,255,255,.55) 0%, transparent 60%)}
  .hero > .container{position:relative;z-index:2}
  .hero__grid{display:grid;grid-template-columns:1.05fr 1fr;gap:48px;align-items:center}
  .hero h1{font-size:78px;font-weight:900;line-height:.95;letter-spacing:-.035em;margin:0 0 24px;text-wrap:balance;color:var(--ink)}
  .hero h1 .mark{background:var(--hi);color:var(--ink);padding:0 8px;display:inline-block;border-radius:6px;transform:rotate(-1deg)}
  .hero h1 .accent{color:var(--accent)}
  .hero__sub{font-size:19px;line-height:1.6;color:var(--ink-2);max-width:520px;margin:0 0 32px}
  .hero__actions{display:flex;gap:14px;align-items:center;flex-wrap:wrap;margin-bottom:36px}
  .hero__phone-call{display:flex;align-items:center;gap:14px;background:var(--paper);border:2px solid var(--ink);border-radius:14px;padding:14px 20px;font-weight:700;text-decoration:none;color:var(--ink);transition:transform .15s;font-size:16px}
  .hero__phone-call:hover{transform:translateY(-2px)}
  .hero__phone-call .ic{width:40px;height:40px;background:var(--accent);color:#fff;border-radius:10px;display:flex;align-items:center;justify-content:center}
  .hero__phone-call .ic svg{width:20px;height:20px}
  .hero__phone-call b{display:block;font-family:'JetBrains Mono',monospace;font-size:18px;letter-spacing:.02em;line-height:1.2}
  .hero__phone-call span{display:block;font-size:12px;color:var(--ink-3);font-weight:500;letter-spacing:.06em;text-transform:uppercase}
  .hero__chips{display:flex;flex-wrap:wrap;gap:10px}
  .chip--orange svg{color:var(--accent)}

  /* Trust / Bewertungen */
  .hero__trust{display:flex;align-items:center;gap:11px;flex-wrap:wrap;margin-top:18px}
  .hero__trust .trust-stars{display:inline-flex;gap:1px}
  .hero__trust .trust-stars svg{width:19px;height:19px;display:block}
  .trust-score{font-size:15px;font-weight:800;color:var(--ink);letter-spacing:-.01em}
  .trust-avatars{display:inline-flex;align-items:center;margin-left:4px}
  .trust-av{width:36px;height:36px;border-radius:50%;border:2px solid var(--paper);margin-left:-11px;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:#fff;background:var(--c,#0a1628);overflow:hidden;box-shadow:0 1px 3px rgba(10,22,40,.18)}
  .trust-av:first-child{margin-left:0}
  .trust-av img{width:100%;height:100%;object-fit:cover;display:block}
  .trust-text{font-size:13.5px;color:var(--ink-2);font-weight:600}
  .trust-text b{color:var(--ink);font-weight:800}
  @media (max-width:520px){.hero__trust{gap:9px;margin-top:14px}.hero__trust .trust-stars svg{width:17px;height:17px}.trust-av{width:31px;height:31px;font-size:11px;margin-left:-10px}.trust-text{font-size:12.5px}}
  .hero__panel{background:var(--ink);color:#fff;border-radius:24px;padding:32px;position:relative;overflow:hidden;box-shadow:var(--shadow-md)}
  .hero__panel::before{content:"";position:absolute;right:-40px;top:-40px;width:180px;height:180px;border-radius:50%;background:radial-gradient(circle,rgba(255,77,24,.35),transparent 70%)}
  .hero__panel::after{content:"";position:absolute;left:-60px;bottom:-60px;width:200px;height:200px;border-radius:50%;background:radial-gradient(circle,rgba(255,212,59,.18),transparent 70%)}
  .hero__panel-title{margin:0 0 6px;font-size:14px;font-weight:600;color:rgba(255,255,255,.6);letter-spacing:.04em;text-transform:uppercase;font-family:'JetBrains Mono',monospace;position:relative}
  .hero__panel-big{font-size:64px;font-weight:900;letter-spacing:-.035em;line-height:1;margin:0 0 8px;color:#fff;position:relative}
  .hero__panel-big em{font-style:normal;color:var(--hi)}
  .hero__panel-sub{font-size:15px;color:rgba(255,255,255,.7);margin:0 0 24px;position:relative}
  .hero__rows{display:flex;flex-direction:column;gap:10px;position:relative}
  .hero__row{display:flex;align-items:center;gap:14px;padding:14px 16px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);border-radius:14px}
  .hero__row .ic{width:38px;height:38px;border-radius:10px;background:rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--hi)}
  .hero__row .ic svg{width:20px;height:20px}
  .hero__row b{display:block;font-size:15px;font-weight:700}
  .hero__row span{display:block;font-size:13px;color:rgba(255,255,255,.55);font-family:'JetBrains Mono',monospace;margin-top:2px}
  @media (max-width:1080px){.hero h1{font-size:64px}}
  @media (max-width:880px){.hero__grid{grid-template-columns:1fr;gap:36px}.hero h1{font-size:52px}.hero{padding:14px 0 48px}}
  @media (max-width:520px){.hero h1{font-size:38px;margin:0 0 18px}.hero__sub{font-size:16px;margin:0 0 24px}.hero__actions{margin-bottom:28px}.hero__phone-call{width:100%}.hero__panel{padding:24px;border-radius:20px}.hero__panel-big{font-size:52px}.hero__panel-sub{font-size:14px;margin:0 0 20px}.hero__rows{gap:12px}.hero__row{padding:14px 14px}}

  /* ============ DESIGN-SYSTEM VON STARTSEITE (index.html) — angeglichen ============ */

  /* Sticky Header-Stack (Alert + Header bleiben oben) — Startseite-Stil */

  /* Header */
  header.site{background:var(--paper);border-bottom:1px solid var(--line);padding-block:14px}
  .site__inner{display:flex;align-items:center;justify-content:space-between;gap:24px;max-width:1240px}

  /* HEADER NAV — Unterstrich-Stil (clean) */
  nav.main{display:flex;gap:28px;align-items:center}
  nav.main > a, nav.main .nav-dd__toggle{
    color:var(--ink-2);text-decoration:none;font-weight:800;
    font-size:13px;letter-spacing:.08em;text-transform:uppercase;
    padding:10px 0;display:inline-flex;align-items:center;
    border-bottom:3px solid transparent;
    border-top:3px solid transparent;
    transition:color .18s,border-color .18s;
  }
  nav.main > a:hover, nav.main .nav-dd__toggle:hover{color:var(--ink);border-bottom-color:var(--line-2)}
  nav.main > a.active{color:var(--ink);border-bottom-color:var(--accent)}
  .nav-dd{position:relative;display:flex;align-items:center}
  .nav-dd__toggle{gap:6px;cursor:pointer}
  .nav-dd__toggle.active{color:var(--ink);border-bottom-color:var(--accent)}
  .nav-dd__toggle svg{width:10px;height:10px;transition:transform .2s}
  .nav-dd:hover .nav-dd__toggle svg{transform:rotate(180deg)}
  .nav-dd__menu{position:absolute;top:calc(100% + 6px);left:0;min-width:240px;background:#fff;border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow-md);padding:8px;opacity:0;visibility:hidden;transform:translateY(-6px);transition:opacity .18s,transform .18s,visibility .18s;z-index:30}
  .nav-dd:hover .nav-dd__menu,.nav-dd:focus-within .nav-dd__menu,.nav-dd.is-open .nav-dd__menu{opacity:1;visibility:visible;transform:translateY(0)}
  .nav-dd.is-open .nav-dd__toggle svg{transform:rotate(180deg)}
  .nav-dd.is-open .nav-dd__toggle{color:var(--ink);border-bottom-color:var(--accent)}
  .nav-dd__menu a{display:flex;align-items:center;gap:10px;padding:11px 14px;text-decoration:none;color:var(--ink-2);font-weight:700;font-size:14px;text-transform:none;letter-spacing:0;border-radius:8px;transition:background .12s,color .12s}
  .nav-dd__menu a:hover{background:var(--bg);color:var(--ink)}
  .nav-dd__menu a.active{background:var(--bg);color:var(--ink)}
  .nav-dd__menu a::before{content:"";width:5px;height:5px;border-radius:50%;background:var(--accent);flex-shrink:0;opacity:.5}
  .btn{display:inline-flex;align-items:center;gap:10px;border-radius:12px;padding:13px 22px;font-weight:700;text-decoration:none;font-size:15px;border:2px solid transparent;transition:transform .15s,background .15s,border-color .15s;line-height:1;white-space:nowrap;cursor:pointer;font-family:inherit}
  .btn--call{background:var(--accent);color:#fff;box-shadow:0 6px 16px -4px rgba(255,77,24,.55)}
  .btn--call:hover{background:var(--accent-deep);transform:translateY(-1px)}
  .cta-short{display:none}
  .btn--ghost{background:var(--paper);color:var(--ink);border-color:var(--line-2)}
  .btn--ghost:hover{border-color:var(--ink);background:var(--bg)}
  .btn--ink{background:var(--ink);color:#fff}
  .btn--ink:hover{background:#000}
  .btn svg{width:18px;height:18px}
  .btn--xl{padding:18px 28px;font-size:17px;border-radius:14px}
  .btn--xxl{padding:22px 36px;font-size:18px;border-radius:16px}

  /* HERO */
  .hero{
    padding:20px 0 80px;
    position:relative;
    overflow:hidden;
    background-image:
      linear-gradient(105deg, rgba(255,255,255,.96) 0%, rgba(255,255,255,.88) 38%, rgba(255,255,255,.6) 70%, rgba(255,255,255,.55) 100%),
      linear-gradient(180deg, transparent 0%, rgba(244,245,247,.55) 100%),
      url('img/Hintergrundbild.webp');
    background-size:cover,cover,cover;
    background-position:center;
    background-repeat:no-repeat;
  }
  .hero::after{
    content:"";position:absolute;inset:0;pointer-events:none;
    background:radial-gradient(circle at 18% 35%, rgba(255,255,255,.55) 0%, transparent 60%);
  }
  .hero > .container{position:relative;z-index:2}
  .hero__grid{display:grid;grid-template-columns:1.05fr 1fr;gap:48px;align-items:center}
  .hero h1{font-size:78px;font-weight:900;line-height:.95;letter-spacing:-.035em;margin:0 0 24px;text-wrap:balance}
  .hero h1 .mark{background:var(--hi);color:var(--ink);padding:0 8px;display:inline-block;border-radius:6px;transform:rotate(-1deg)}
  .hero h1 .accent{color:var(--accent)}
  .hero__sub{font-size:19px;line-height:1.6;color:var(--ink-2);max-width:520px;margin:0 0 32px}
  .hero__actions{display:flex;gap:14px;align-items:center;flex-wrap:wrap;margin-bottom:36px}
  .hero__phone-call{display:flex;align-items:center;gap:14px;background:var(--paper);border:2px solid var(--ink);border-radius:14px;padding:14px 20px;font-weight:700;text-decoration:none;color:var(--ink);transition:transform .15s;font-size:16px}
  .hero__phone-call:hover{transform:translateY(-2px)}
  .hero__phone-call .ic{width:40px;height:40px;background:var(--accent);color:#fff;border-radius:10px;display:flex;align-items:center;justify-content:center}
  .hero__phone-call .ic svg{width:20px;height:20px}
  .hero__phone-call b{display:block;font-family:'JetBrains Mono',monospace;font-size:18px;letter-spacing:.02em;line-height:1.2}
  .hero__phone-call span{display:block;font-size:12px;color:var(--ink-3);font-weight:500;letter-spacing:.06em;text-transform:uppercase}

  .hero__chips{display:flex;flex-wrap:wrap;gap:10px}
  .chip{display:inline-flex;align-items:center;gap:8px;background:var(--paper);border:1px solid var(--line);padding:8px 14px;border-radius:999px;font-size:13.5px;font-weight:600;color:var(--ink-2)}
  .chip svg{width:14px;height:14px;color:var(--ok)}
  .chip--orange svg{color:var(--accent)}

  /* Trust / Bewertungen */
  .hero__trust{display:flex;align-items:center;gap:11px;flex-wrap:wrap;margin-top:18px}
  .hero__trust .trust-stars{display:inline-flex;gap:1px}
  .hero__trust .trust-stars svg{width:19px;height:19px;display:block}
  .trust-score{font-size:15px;font-weight:800;color:var(--ink);letter-spacing:-.01em}
  .trust-avatars{display:inline-flex;align-items:center;margin-left:4px}
  .trust-av{width:36px;height:36px;border-radius:50%;border:2px solid var(--paper);margin-left:-11px;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:#fff;background:var(--c,#0a1628);overflow:hidden;box-shadow:0 1px 3px rgba(10,22,40,.18)}
  .trust-av:first-child{margin-left:0}
  .trust-av img{width:100%;height:100%;object-fit:cover;display:block}
  .trust-text{font-size:13.5px;color:var(--ink-2);font-weight:600}
  .trust-text b{color:var(--ink);font-weight:800}
  @media (max-width:520px){.hero__trust{gap:9px;margin-top:14px}.hero__trust .trust-stars svg{width:17px;height:17px}.trust-av{width:31px;height:31px;font-size:11px;margin-left:-10px}.trust-text{font-size:12.5px}}

  /* Visual side - status panel */
  .hero__panel{background:var(--ink);color:#fff;border-radius:24px;padding:32px;position:relative;overflow:hidden;box-shadow:var(--shadow-md)}
  .hero__panel::before{content:"";position:absolute;right:-40px;top:-40px;width:180px;height:180px;border-radius:50%;background:radial-gradient(circle,rgba(255,77,24,.35),transparent 70%)}
  .hero__panel::after{content:"";position:absolute;left:-60px;bottom:-60px;width:200px;height:200px;border-radius:50%;background:radial-gradient(circle,rgba(255,212,59,.18),transparent 70%)}
  .hero__panel-title{margin:0 0 6px;font-size:14px;font-weight:600;color:rgba(255,255,255,.6);letter-spacing:.04em;text-transform:uppercase;font-family:'JetBrains Mono',monospace;position:relative}
  .hero__panel-big{font-size:64px;font-weight:900;letter-spacing:-.035em;line-height:1;margin:0 0 8px;color:#fff;position:relative}
  .hero__panel-big em{font-style:normal;color:var(--hi)}
  .hero__panel-sub{font-size:15px;color:rgba(255,255,255,.7);margin:0 0 24px;position:relative}

  .hero__rows{display:flex;flex-direction:column;gap:10px;position:relative}
  .hero__row{display:flex;align-items:center;gap:14px;padding:14px 16px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);border-radius:14px}
  .hero__row .ic{width:38px;height:38px;border-radius:10px;background:rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--hi)}
  .hero__row .ic svg{width:20px;height:20px}
  .hero__row b{display:block;font-size:15px;font-weight:700}
  .hero__row span{display:block;font-size:13px;color:rgba(255,255,255,.55);font-family:'JetBrains Mono',monospace;margin-top:2px}
  .hero__row .ok{margin-left:auto;color:var(--ok);font-family:'JetBrains Mono',monospace;font-size:12px;font-weight:700;display:inline-flex;align-items:center;gap:4px}

  /* TICKER strip */
  .ticker{background:var(--ink);color:#fff;padding:18px 0;border-top:1px solid rgba(255,255,255,.06);overflow:hidden}
  .ticker__inner{display:flex;align-items:center;gap:48px;animation:scroll 28s linear infinite;white-space:nowrap}
  .ticker__item{display:inline-flex;align-items:center;gap:10px;font-family:'JetBrains Mono',monospace;font-size:14px;color:rgba(255,255,255,.75);font-weight:600;letter-spacing:.01em}
  .ticker__item svg{width:16px;height:16px;color:var(--hi)}
  .ticker__dot{width:6px;height:6px;border-radius:50%;background:var(--accent);flex-shrink:0}
  @keyframes scroll{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

  /* SECTIONS */
  section.s{padding:104px 0}
  .section-head{max-width:740px;margin:0 0 56px}
  .section-head h2{font-size:54px;line-height:1.02;font-weight:900;letter-spacing:-.03em;margin:14px 0 16px;text-wrap:balance}
  .section-head h2 .mark{background:var(--hi);padding:0 8px;display:inline-block;border-radius:6px;transform:rotate(-1deg)}
  .section-head h2 .accent{color:var(--accent)}
  .section-head p{font-size:18px;color:var(--ink-2);margin:0;line-height:1.6;max-width:620px}

  /* STATS */
  .stats{display:grid;grid-template-columns:repeat(4,1fr);gap:0;background:var(--ink);border-radius:24px;overflow:hidden;color:#fff;position:relative}
  .stat{padding:50px 40px;position:relative;border-right:1px solid rgba(255,255,255,.08)}
  .stat:last-child{border-right:none}
  .stat__big{font-size:74px;font-weight:900;letter-spacing:-.035em;line-height:1;margin:0 0 8px}
  .stat__big em{font-style:normal;color:var(--hi)}
  .stat__big sup{font-size:28px;color:var(--accent);margin-left:4px;vertical-align:super}
  .stat__lbl{font-size:14.5px;color:rgba(255,255,255,.65);font-family:'JetBrains Mono',monospace;text-transform:uppercase;letter-spacing:.04em}

  /* PROCESS / Why */
  .why-bg{background:var(--ink);color:#fff}
  .why-bg .section-head h2{color:#fff}
  .why-bg .section-head p{color:rgba(255,255,255,.65)}
  .why-bg .eyebrow{color:rgba(255,255,255,.65)}
  .why{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
  .why__card{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:20px;padding:28px;display:flex;flex-direction:column;gap:14px}
  .why__num{font-family:'JetBrains Mono',monospace;font-size:13px;color:var(--hi);font-weight:700;letter-spacing:.04em}
  .why__big{font-size:48px;font-weight:900;letter-spacing:-.035em;line-height:1}
  .why__big em{font-style:normal;color:var(--accent)}
  .why__t{font-size:18px;font-weight:800;letter-spacing:-.01em;margin:0}
  .why__d{color:rgba(255,255,255,.62);font-size:14.5px;margin:0;line-height:1.55}

  /* REGION */
  .region{display:grid;grid-template-columns:1.05fr .95fr;gap:64px;align-items:center}
  .region h2{font-size:48px;line-height:1.02;font-weight:900;letter-spacing:-.03em;margin:14px 0 18px;text-wrap:balance}
  .region h2 .accent{color:var(--accent)}
  .region p{font-size:17px;color:var(--ink-2);line-height:1.65;margin:0 0 20px}

  /* FAQ */
  .bg-alt{background:var(--bg)}
  .faq-wrap{display:grid;grid-template-columns:1fr 1.4fr;gap:64px;align-items:start}
  .faq-side{position:sticky;top:170px;align-self:start}
  #faq{overflow:visible}
  @media (max-width:880px){.faq-wrap{grid-template-columns:1fr;gap:32px}.faq-side{position:static}}
  .faq-side h2{font-size:46px;line-height:1.02;font-weight:900;letter-spacing:-.03em;margin:14px 0 16px}
  .faq-side h2 .accent{color:var(--accent)}
  .faq-side p{color:var(--ink-2);font-size:17px;line-height:1.6;margin:0 0 24px}
  .btn--side{display:inline-flex;align-items:center;gap:10px;background:var(--ink);color:#fff;text-decoration:none;font-weight:800;font-size:14px;padding:14px 24px;border-radius:12px;letter-spacing:.02em;transition:transform .15s,box-shadow .15s;box-shadow:var(--shadow-sm)}
  .btn--side:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}
  .btn--side svg{width:18px;height:18px;flex-shrink:0}
  .panel__label{font-family:'JetBrains Mono',monospace;font-size:12px;letter-spacing:.06em;text-transform:uppercase;color:rgba(255,255,255,.6);font-weight:600;margin:0 0 8px}
  .panel__btn{display:inline-flex;align-items:center;gap:10px;background:var(--accent);color:#fff;text-decoration:none;font-weight:800;font-size:18px;padding:14px 28px;border-radius:14px;margin-top:18px;transition:transform .15s,box-shadow .15s;box-shadow:0 6px 16px -4px rgba(255,77,24,.55)}
  .panel__btn:hover{transform:translateY(-2px);box-shadow:0 8px 22px -4px rgba(255,77,24,.65)}
  .panel__btn svg{width:20px;height:20px}
  .faqs{display:flex;flex-direction:column;gap:12px}
  details.faq{background:var(--paper);border:1px solid var(--line);border-radius:14px;padding:22px 26px;cursor:pointer;transition:border-color .15s}
  details.faq[open]{border-color:var(--ink)}
  details.faq summary{list-style:none;font-size:18px;font-weight:800;color:var(--ink);display:flex;justify-content:space-between;gap:24px;letter-spacing:-.01em;align-items:center}
  details.faq summary::-webkit-details-marker{display:none}
  details.faq summary::after{content:"+";width:32px;height:32px;border-radius:50%;background:var(--bg);display:flex;align-items:center;justify-content:center;font-size:22px;color:var(--ink);font-weight:300;flex-shrink:0;transition:background .15s,color .15s}
  details.faq[open] summary::after{content:"–";background:var(--accent);color:#fff}
  details.faq p{margin:14px 0 0;color:var(--ink-2);font-size:15.5px;line-height:1.6}
  .form-card{background:var(--paper);border:1px solid var(--line);border-radius:20px;padding:36px;box-shadow:var(--shadow-md)}
  .form-card h3{font-size:26px;font-weight:900;margin:0 0 8px;letter-spacing:-.02em}
  .form-card .lead{color:var(--ink-3);font-size:14.5px;margin:0 0 22px;line-height:1.55}
  .form-card form{display:flex;flex-direction:column;gap:16px}
  .form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
  .form-card label{display:block;font-size:11.5px;font-weight:700;color:var(--ink-2);margin-bottom:6px;font-family:'JetBrains Mono',monospace;letter-spacing:.04em;text-transform:uppercase}
  .form-card input,.form-card textarea{width:100%;border:1.5px solid var(--line-2);border-radius:10px;padding:13px 14px;font:inherit;font-size:15px;background:var(--bg);color:var(--ink);transition:border-color .15s,background .15s;font-family:inherit}
  .form-card input:focus,.form-card textarea:focus{outline:none;border-color:var(--ink);background:var(--paper)}
  .form-card textarea{min-height:110px;resize:vertical}
  .form-card .btn{width:100%;justify-content:center;margin-top:6px}
  .form-card .small{font-size:12.5px;color:var(--ink-3);font-family:'JetBrains Mono',monospace;margin:8px 0 0;text-align:center}

  /* CTA */
  .final{background:var(--accent);color:#fff;border-radius:28px;padding:64px 56px;display:grid;grid-template-columns:1.3fr 1fr;align-items:center;gap:40px;position:relative;overflow:hidden}
  .final::before{content:"";position:absolute;right:-160px;top:-160px;width:360px;height:360px;border-radius:50%;background:rgba(255,255,255,.08)}
  .final::after{content:"";position:absolute;left:-100px;bottom:-100px;width:260px;height:260px;border-radius:50%;background:rgba(0,0,0,.08)}
  .final h2{font-size:58px;line-height:1.02;font-weight:900;letter-spacing:-.035em;margin:0 0 16px;position:relative}
  .final h2 .mark{background:var(--ink);color:#fff;padding:0 8px;border-radius:6px;display:inline-block;transform:rotate(-1deg)}
  .final p{margin:0;color:rgba(255,255,255,.85);font-size:17px;max-width:480px;position:relative;line-height:1.6}
  .final__cta{position:relative;display:flex;flex-direction:column;gap:14px;align-items:flex-start}
  .final__num{font-family:'JetBrains Mono',monospace;font-size:48px;color:#fff;letter-spacing:-.02em;line-height:1;font-weight:800}
  .final .btn--ink{background:var(--ink);color:#fff}
  .final small{font-size:13px;color:rgba(255,255,255,.78);font-family:'JetBrains Mono',monospace}

  /* Footer */
  footer.site{background:var(--ink);color:#bcc4d2;padding:0 0 32px;font-size:14.5px;position:relative;border-top:5px solid var(--accent)}
  .foot-cta{display:flex;align-items:center;justify-content:space-between;gap:40px;padding:64px 0;border-bottom:1px solid rgba(255,255,255,.08);flex-wrap:wrap;position:relative}
  .foot-cta::before{content:"";position:absolute;right:-100px;top:50%;transform:translateY(-50%);width:280px;height:280px;border-radius:50%;background:radial-gradient(circle,rgba(255,77,24,.18),transparent 70%);pointer-events:none}
  .foot-cta__text{position:relative;flex:1;min-width:280px}
  .foot-cta__text h3{font-size:38px;font-weight:900;color:#fff;margin:0 0 10px;letter-spacing:-.025em;line-height:1.05;text-wrap:balance}
  .foot-cta__text h3 .accent{color:var(--accent)}
  .foot-cta__text p{margin:0;color:#9aa5b7;font-size:15.5px;max-width:480px;line-height:1.55}
  .foot-cta__action{position:relative;display:flex;flex-direction:column;gap:14px;align-items:flex-end}
  .foot-cta__num{font-family:'JetBrains Mono',monospace;font-size:34px;color:#fff;font-weight:800;letter-spacing:-.02em;line-height:1}
  .foot-cta__btn{background:var(--accent);color:#fff;padding:16px 30px;border-radius:14px;text-decoration:none;font-weight:800;display:inline-flex;align-items:center;gap:10px;font-size:16px;transition:background .15s,transform .15s;box-shadow:0 8px 24px -8px rgba(255,77,24,.5)}
  .foot-cta__btn:hover{background:var(--accent-deep);transform:translateY(-2px)}
  .foot-cta__btn svg{width:18px;height:18px}

  .foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:56px;padding:64px 0 24px}
  .foot-brand-block{display:flex;flex-direction:column;gap:18px}
  .foot-brand-logo{display:flex;align-items:center;gap:14px;margin-bottom:4px}
  .foot-brand-logo img{width:64px;height:64px;object-fit:contain;flex-shrink:0}
  .foot-brand-logo .name{font-size:28px;color:#fff;font-weight:900;letter-spacing:-.02em;line-height:1}
  .foot-brand-logo .name em{font-style:normal;color:var(--accent)}
  .foot-brand-logo .sub{display:block;font-family:'JetBrains Mono',monospace;font-size:11px;color:#7a8497;letter-spacing:.02em;margin-top:4px;font-weight:600}
  .foot-brand-block .desc{color:#9aa5b7;margin:0;line-height:1.65;max-width:380px;font-size:14.5px}
  .foot-badges{display:flex;flex-wrap:wrap;gap:8px;margin-top:6px}
  .foot-badge{display:inline-flex;align-items:center;gap:6px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);padding:7px 11px;border-radius:8px;font-size:12px;font-weight:700;color:#fff;font-family:'JetBrains Mono',monospace;letter-spacing:.02em}
  .foot-badge svg{width:12px;height:12px;color:var(--hi)}

  .foot-col h4{color:#fff;font-size:12px;letter-spacing:.06em;text-transform:uppercase;font-weight:800;margin:0 0 22px;font-family:'JetBrains Mono',monospace;display:flex;align-items:center;gap:10px}
  .foot-col h4::before{content:"";width:18px;height:2px;background:var(--accent);display:inline-block;flex-shrink:0}
  .foot-col a{color:#bcc4d2;text-decoration:none;display:flex;align-items:center;gap:8px;padding:7px 0;font-size:14.5px;transition:color .15s,transform .15s;font-weight:500}
  .foot-col a:hover{color:#fff;transform:translateX(3px)}
  .foot-col a svg{width:13px;height:13px;color:#5a6478;transition:color .15s;flex-shrink:0}
  .foot-col a:hover svg{color:var(--accent)}
  .foot-col .info{color:#7a8497;font-size:13.5px;line-height:1.6;margin:14px 0 0;font-family:'JetBrains Mono',monospace}

  .foot-bottom{border-top:1px solid rgba(255,255,255,.08);margin-top:48px;padding-top:28px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:18px;color:#7a8497;font-size:13px}
  .foot-bottom-left{display:flex;align-items:center;gap:24px;flex-wrap:wrap}
  .foot-bottom a{color:#bcc4d2;text-decoration:none;transition:color .15s}
  .foot-bottom a:hover{color:#fff}
  .foot-bottom-right{display:flex;gap:24px;align-items:center}
  .foot-made{color:#5a6478;font-family:'JetBrains Mono',monospace;font-size:12.5px}
  .foot-made em{font-style:normal;color:var(--hi);font-weight:700}
  @media (max-width:880px){
    .foot-grid{grid-template-columns:1fr 1fr;gap:36px;padding:48px 0 16px}
    .foot-brand-block{grid-column:1 / -1}
    .foot-cta{padding:48px 0;gap:24px}
    .foot-cta__text h3{font-size:28px}
    .foot-cta__action{align-items:flex-start;width:100%}
    .foot-cta__num{font-size:28px}
    .foot-bottom{flex-direction:column;align-items:flex-start;gap:10px}
  }
  @media (max-width:520px){
    .foot-grid{grid-template-columns:1fr}
    .foot-brand-logo img{width:54px;height:54px}
    .foot-brand-logo .name{font-size:24px}
  }

  /* Mobile sticky call bar */
  .mcall{display:none}
  @media (max-width:760px){
    .mcall{display:block;position:fixed;left:0;right:0;bottom:0;z-index:50;background:var(--accent);box-shadow:0 -8px 24px -8px rgba(10,22,40,.35);padding-bottom:env(safe-area-inset-bottom)}
    .mcall a{display:flex;align-items:center;justify-content:center;gap:10px;color:#fff;text-decoration:none;font-weight:800;padding:16px;font-size:15.5px}
    .mcall a svg{width:20px;height:20px}
    body{padding-bottom:68px}
  }

  /* Cookie banner */
  .cookie{position:fixed;left:24px;right:24px;bottom:24px;z-index:60;background:var(--ink);color:#fff;border-radius:18px;padding:22px 24px;box-shadow:0 24px 60px -20px rgba(0,0,0,.55);max-width:520px;display:none}
  .cookie.show{display:block}
  .cookie p{margin:0 0 14px;font-size:14px;line-height:1.55;color:rgba(255,255,255,.85)}
  .cookie p a{color:var(--hi);text-decoration:underline}
  .cookie__actions{display:flex;gap:10px;flex-wrap:wrap}
  .cookie__btn{padding:10px 18px;border-radius:10px;font-weight:700;font-size:14px;border:0;cursor:pointer;font-family:inherit}
  .cookie__btn--accept{background:var(--accent);color:#fff}
  .cookie__btn--accept:hover{background:var(--accent-deep)}
  .cookie__btn--decline{background:rgba(255,255,255,.08);color:#fff}
  .cookie__btn--decline:hover{background:rgba(255,255,255,.14)}
  @media (max-width:760px){.cookie{left:12px;right:12px;bottom:84px;padding:18px}}

  /* Responsive */
  @media (max-width:1080px){
    .hero h1{font-size:64px}
    .section-head h2{font-size:46px}
    .why,.steps{grid-template-columns:repeat(2,1fr)}
    .services{grid-template-columns:repeat(2,1fr)}
    .svc__img{aspect-ratio:4/3}
    .step__arrow{display:none}
  }
  @media (max-width:680px){
  }
  @media (max-width:880px){
    .hero__grid,.region,.faq-wrap,.contact-grid{grid-template-columns:1fr;gap:36px}
    .stats{grid-template-columns:repeat(2,1fr)}
    .stat{border-right:none;border-bottom:1px solid rgba(255,255,255,.08)}
    .stat:nth-child(2n){border-right:none}
    .stat:nth-last-child(-n+2){border-bottom:none}
    .hero h1{font-size:52px}
    .section-head h2{font-size:38px}
    .final{padding:48px 32px;grid-template-columns:1fr;text-align:left}
    .final h2{font-size:40px}
    nav.main{display:none}
    section.s{padding:72px 0}
    .hero{padding:14px 0 48px}
    .alert__inner{font-size:12.5px;gap:12px}
    .alert__left{flex:1;min-width:0}
    .form-row{grid-template-columns:1fr}
    .final__num{font-size:38px}
  }
  @media (max-width:520px){
    .container{padding:0 18px}
    .hero h1{font-size:40px}
    .services,.why,.steps{grid-template-columns:1fr}
    .stats{grid-template-columns:1fr}
    .stat{border-right:none;border-bottom:1px solid rgba(255,255,255,.08)}
    .stat:last-child{border-bottom:none}
    .section-head h2{font-size:32px}
    .hero__phone-call{width:100%}
    .form-card{padding:26px}
    .hero__panel{padding:24px}
    .hero__panel-big{font-size:52px}
  }
  /* === MOBILE OPTIMIERUNG (hinzugefügt) === */
  @media (max-width:640px){
    .alert{font-size:12px}
    .alert__inner{height:auto;min-height:38px;padding:8px 0;gap:10px;flex-wrap:wrap;justify-content:center;text-align:center;line-height:1.25}
    .alert__left{gap:8px;justify-content:center}
    .alert__left svg{width:14px;height:14px;flex-shrink:0}
    .alert__phone{font-size:12.5px;gap:6px;white-space:nowrap}
    .alert__phone .num{padding:3px 9px;font-size:12px}
    .site__inner{gap:10px}
    header.site{padding-block:10px}
    .brand{gap:10px}
    .brand__mark{width:48px;height:48px}
    .brand__name{font-size:18px}
    .brand__sub{font-size:9.5px;letter-spacing:0;margin-top:2px}
    header.site .btn--call{padding:10px 14px;font-size:13.5px;border-radius:10px;gap:6px;white-space:nowrap}
    header.site .btn--call svg{width:16px;height:16px}
  }
  @media (max-width:520px){
    body{font-size:16px}
    .container{padding:0 16px}
    .phero{padding:8px 0 36px}
    .phero h1{font-size:32px;line-height:1.04;margin:14px 0 16px}
    .phero p.lead{font-size:16px;line-height:1.55;margin:0 0 22px}
    .phero__panel{padding:22px}
    .phero__actions{display:flex;flex-direction:column;align-items:stretch;gap:10px;margin-bottom:22px}
    .btn--xl{padding:15px 20px;font-size:15.5px;width:100%;justify-content:center}
    .hero__chips{gap:8px;flex-wrap:wrap}
    .chip{font-size:12.5px;padding:6px 11px}
    section.s{padding:48px 0}
    .content h2{font-size:30px;margin:0 0 14px;line-height:1.08}
    .content p{font-size:16px;line-height:1.65;margin:0 0 14px}
    .check-list li{font-size:15px;gap:10px;line-height:1.5}
    .pullquote{margin:28px 0;padding:22px;font-size:17px;border-radius:16px;line-height:1.35}
    .panel__big{font-size:56px}
    .panel__big small{font-size:18px}
    .panel__sub{font-size:14px;margin:0 0 22px}
    .panel__row b{font-size:14px}
    .panel__row span{font-size:12px}
    .stat__big{font-size:46px}
    .stat__big sup{font-size:18px}
    .stat__lbl{font-size:12.5px}
    .final{padding:36px 22px;border-radius:20px}
    .final h2{font-size:30px;line-height:1.08}
    .breadcrumbs{font-size:11px;margin:22px 0 12px}
    .foot-cta__text h3{font-size:24px;line-height:1.15}
    .foot-cta__num{font-size:24px}
    .team__text h2{font-size:26px;line-height:1.1}
    .team__text p{font-size:15.5px}
    .team__stat b{font-size:24px}
    .side-card h3{font-size:20px}
    .side-card .num{font-size:24px}
    .side-card p{font-size:13.5px}
    .case h3{font-size:20px}
    .case p{font-size:14.5px}
    .eyebrow{font-size:11px}
    .ticker__item{font-size:12.5px}
    .hbar__item b{font-size:14px}
    .hbar__item span{font-size:12px}
  }
  @media (max-width:380px){
    .alert__inner{font-size:11.5px;gap:6px;padding:7px 0}
    .alert__phone{font-size:12px}
    .brand__mark{width:42px;height:42px}
    .brand__name{font-size:16px}
    .brand__sub{display:none}
    header.site .btn--call{padding:9px 12px;font-size:12.5px}
    header.site .btn--call svg{width:14px;height:14px}
    .phero h1{font-size:28px}
    .phero p.lead{font-size:15px}
    .content h2{font-size:26px}
    .content p{font-size:15.5px}
    .final h2{font-size:26px}
    .panel__big{font-size:46px}
    .panel__big small{font-size:16px}
    .stat__big{font-size:38px}
  }
  /* === HAMBURGER MENU === */
  .menu-toggle{display:none;background:transparent;border:0;padding:0;cursor:pointer;width:44px;height:44px;border-radius:10px;align-items:center;justify-content:center;flex-direction:column;gap:5px;flex-shrink:0;-webkit-tap-highlight-color:transparent}
  .menu-toggle span{display:block;width:24px;height:2.5px;background:var(--ink);border-radius:2px;transition:transform .25s,opacity .2s}
  .menu-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7.5px) rotate(45deg)}
  .menu-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
  .menu-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}
  @media (max-width:880px){
    .menu-toggle{display:flex;position:relative;z-index:70}
    header.site .btn--call{display:none}
    body.menu-open{overflow:hidden}

    /* Overlay container */
    nav.main{
      display:none;position:fixed;top:0;left:0;right:0;bottom:0;
      background:var(--paper);z-index:60;
      padding:84px 22px 32px;
      flex-direction:column;align-items:stretch;gap:0;
      overflow-y:auto;-webkit-overflow-scrolling:touch
    }
    nav.main.is-open{display:flex}

    /* Reset the desktop .nav-dd flex-row so children stack vertically */
    nav.main .nav-dd{position:static;display:block;align-items:stretch;width:100%;border:0}

    /* Top-level items */
    nav.main > a{
      display:block;width:100%;
      font-size:17px;font-weight:700;
      text-transform:none;letter-spacing:0;
      padding:18px 6px;border:0;border-bottom:1px solid var(--line);
      color:var(--ink);text-decoration:none;
      box-sizing:border-box
    }
    nav.main > a.active{color:var(--accent)}

    /* Service section label (non-clickable on mobile) */
    nav.main .nav-dd .nav-dd__toggle{
      display:block;width:100%;
      font-size:11px;font-weight:800;
      text-transform:uppercase;letter-spacing:.08em;
      padding:20px 6px 8px;border:0;
      color:var(--ink-3);
      text-decoration:none;cursor:default;
      pointer-events:none;
      box-sizing:border-box
    }
    nav.main .nav-dd .nav-dd__toggle svg{display:none}

    /* Submenu always visible on mobile, stacked vertically */
    nav.main .nav-dd__menu{
      position:static;display:block;
      box-shadow:none;background:transparent;border:0;
      opacity:1;visibility:visible;transform:none;
      min-width:0;width:100%;padding:0 0 8px;margin:0;
      border-bottom:1px solid var(--line)
    }
    nav.main .nav-dd__menu a{
      display:flex;align-items:center;gap:12px;
      padding:14px 10px;font-size:16px;font-weight:600;
      border:0;border-radius:10px;
      color:var(--ink);background:transparent;
      text-decoration:none;
      text-transform:none;letter-spacing:0;
      width:100%;box-sizing:border-box
    }
    nav.main .nav-dd__menu a.active{color:var(--accent);font-weight:800;background:rgba(255,77,24,.08)}
    nav.main .nav-dd__menu a::before{
      content:"";width:6px;height:6px;border-radius:50%;
      background:var(--accent);opacity:.55;flex-shrink:0
    }
    nav.main .nav-dd__menu a.active::before{opacity:1}

    /* Last top-level link should not have a border (visual polish) */
    nav.main > a:last-of-type{border-bottom:0}
  }
  /* === ALERT BAR (verbessert) === */
  @media (max-width:880px){
    .alert{font-size:12.5px}
    .alert__inner{height:auto;min-height:38px;padding:7px 0;gap:12px;line-height:1.3}
    .alert__left{gap:8px}
    .alert__left svg{width:15px;height:15px;flex-shrink:0}
    .alert__phone{font-size:12.5px;gap:6px;white-space:nowrap;flex-shrink:0}
    .alert__phone .num{padding:3px 8px;font-size:12px}
  }
  @media (max-width:640px){
    .alert__inner{flex-wrap:wrap;justify-content:center;text-align:center}
    .alert__cities{display:none}
    .alert__left{justify-content:center}
    .alert__phone{flex-basis:auto}
  }
  @media (max-width:380px){
    .alert__left svg{display:none}
    .alert__phone-label{display:none}
    .alert__inner{gap:8px}
  }
  /* === OVERFLOW-FIX === */
  html,body{overflow-x:clip}
  .foot-cta{overflow:hidden}
  .hero,.phero,section.s{overflow:hidden}
  /* === HEADER MOBILE V2: Alert weg, Anruf-Icon neben Menü === */
  @media (max-width:880px){
    .header-stack .alert{display:none}
    header.site .btn--call{
      display:inline-flex;
      align-items:center;justify-content:center;
      width:auto;height:auto;
      padding:10px 14px;gap:6px;
      font-size:13.5px;line-height:1;font-weight:700;
      border-radius:10px;
      box-shadow:none;
      flex-shrink:0;
      margin-left:auto
    }
    header.site .btn--call svg{width:17px;height:17px;display:block}
    header.site .btn--call .cta-full{display:none}
    header.site .btn--call .cta-short{display:inline}
    header.site .site__inner{gap:8px}
    .menu-toggle{margin-left:0}
  }
  /* === HERO-SPACING (Mobil) === */
  @media (max-width:880px){
    .phero__grid{gap:56px}
    .hero__chips{margin-top:28px;margin-bottom:8px;gap:10px}
    .phero__panel{padding:28px;border-radius:22px}
    .panel__big{margin:0 0 6px}
    .panel__sub{margin:0 0 26px;font-size:15px;line-height:1.5}
    .panel__rows{gap:14px}
    .panel__row{padding:16px 18px;gap:14px;border-radius:14px}
    .panel__row .ic{width:42px;height:42px}
    .panel__row b{font-size:15px}
    .panel__row span{font-size:12.5px;margin-top:3px}
  }
  @media (max-width:520px){
    .phero{padding:8px 0 56px}
    .phero__grid{gap:44px}
    .phero__panel{padding:26px;border-radius:20px}
    .panel__rows{gap:12px}
    .panel__row{padding:15px 16px}
    .hero__chips{margin-top:24px;gap:9px}
    .phero__actions{margin-bottom:8px}
  }

  /* === LEISTUNGEN V6 (neues Design) === */
  .leistungen-section{background:#fff;padding:96px 64px}
  .leistungen-header{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:64px;gap:40px}
  .leistungen-eyebrow{color:var(--accent);font-family:'JetBrains Mono',ui-monospace,monospace;font-size:12px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;margin-bottom:14px}
  .leistungen-title{font-size:48px;font-weight:900;letter-spacing:-.02em;color:var(--ink);margin:0;line-height:1.05}
  .leistungen-title .mark{background:var(--hi);color:var(--ink);font-size:inherit;font-weight:inherit;font-family:inherit;letter-spacing:inherit;line-height:inherit;padding:0 10px;display:inline-block;border-radius:6px;transform:rotate(-1deg)}
  .leistungen-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:24px}
  .leistung-card{display:flex;flex-direction:column;text-decoration:none;color:inherit}
  .leistung-image{aspect-ratio:4/3;border-radius:4px;margin-bottom:24px;position:relative;overflow:hidden;background:#E8ECF1}
  .leistung-image img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;transition:transform .45s ease}
  .leistung-card:hover .leistung-image img{transform:scale(1.045)}
  .leistung-label{position:absolute;left:20px;bottom:20px;font-size:11px;font-weight:600;letter-spacing:.12em;background:rgba(255,255,255,.88);color:#5B6470;padding:6px 10px;border-radius:2px}
  .leistung-number{position:absolute;right:20px;top:20px;font-size:11px;font-weight:700;letter-spacing:.12em;color:var(--ink);background:#fff;padding:6px 10px;border-radius:2px}
  .leistung-title{font-size:22px;font-weight:800;color:var(--ink);margin:0 0 8px;letter-spacing:-.01em;transition:color .2s ease}
  .leistung-card:hover .leistung-title{color:var(--accent)}
  .leistung-text{font-size:14px;line-height:1.55;color:#5B6470;margin:0}
  .leistungen-footer{display:flex;justify-content:center;align-items:center;gap:24px;margin-top:72px;padding-top:48px;border-top:1px solid var(--line);flex-wrap:wrap}
  .leistungen-footer-text{color:#5B6470;font-size:15px}
  .leistungen-cta{display:inline-flex;align-items:center;gap:10px;background:var(--accent);color:#fff;padding:18px 28px;font-size:14px;font-weight:700;text-decoration:none;border-radius:2px;transition:background .2s ease}
  .leistungen-cta:hover{background:var(--ink)}
  .leistungen-cta svg{width:17px;height:17px}
  @media (max-width:1024px){.leistungen-section{padding:72px 48px}.leistungen-title{font-size:40px}.leistungen-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
  @media (max-width:720px){.leistungen-section{padding:56px 24px}.leistungen-header{flex-direction:column;align-items:flex-start;margin-bottom:40px}.leistungen-title{font-size:32px}.leistungen-grid{grid-template-columns:1fr;gap:32px}.leistungen-footer{flex-direction:column;gap:20px;margin-top:48px;padding-top:32px}.leistungen-footer-text{text-align:center}}
  #lmmap{position:absolute;inset:0}
  .leaflet-container{font-family:'Manrope',sans-serif}
  .lm-pin{display:flex;align-items:center;justify-content:center;border-radius:50%;box-shadow:0 2px 8px rgba(10,22,40,.3)}
  .lm-pin--mini{width:28px;height:28px;background:var(--accent);border:2px solid #fff}
  .lm-pin--mini svg{width:14px;height:14px}
  .lm-pin--you{width:22px;height:22px;background:#1e63d0;border:3px solid #fff;position:relative}
  .lm-pin--you .ring{position:absolute;inset:-3px;border-radius:50%;border:2px solid #1e63d0;animation:lm-ping 1.9s ease-out infinite}
  @keyframes lm-ping{0%{transform:scale(1);opacity:.55}100%{transform:scale(3);opacity:0}}
  .lm-stat{display:flex;gap:26px;flex-wrap:wrap}
  .lm-stat__n{display:block;font-size:25px;font-weight:900;color:#fff;letter-spacing:-.02em}
  .lm-stat__l{display:block;font-size:12px;color:rgba(255,255,255,.6);margin-top:2px}
  @media (max-width:880px){}

  /* Final CTA: volle Breite, kein Grau/Weiß in der Section */
  .final-band{background:var(--accent);padding:84px 0;position:relative;overflow:hidden}
  .final-band::after{content:"";position:absolute;right:-60px;top:-60px;width:360px;height:360px;background:radial-gradient(circle,rgba(255,255,255,.13),transparent 70%);pointer-events:none}
  .final-band .final{background:transparent;padding:0;overflow:visible}
  .final-band .final::before,.final-band .final::after{display:none}
  @media (max-width:640px){.final-band{padding:52px 0}}

  /* === Fahrer-Section (Dark Redesign) === */
  .lm2-sec{background:#0B1220;color:#fff;position:relative;overflow:hidden;padding:96px 0}
  .lm2-ambient{position:absolute;left:-200px;bottom:-200px;width:600px;height:600px;background:radial-gradient(circle,rgba(255,77,31,.12),transparent 60%);pointer-events:none}
  .lm2-inner{position:relative;max-width:1240px;margin:0 auto;padding:0 32px}
  .lm2-head{display:grid;grid-template-columns:1.4fr 1fr;gap:80px;align-items:end;margin-bottom:56px}
  .lm2-eyebrow{display:flex;align-items:center;gap:12px;font-family:'JetBrains Mono',monospace;font-size:13px;letter-spacing:.14em;text-transform:uppercase;color:#9CA3AF;margin-bottom:24px}
  .lm2-dot-o{display:inline-block;width:8px;height:8px;border-radius:50%;background:#FF4D1F;box-shadow:0 0 12px #FF4D1F}
  .lm2-h2{margin:0;font-size:80px;line-height:1;font-weight:900;letter-spacing:-.03em;color:#fff}
  .lm2-sub{margin:0 0 12px;font-size:18px;line-height:1.55;color:#9CA3AF;max-width:480px}
  .lm2-grid{display:grid;grid-template-columns:1.6fr 1fr;gap:32px}
  .lm2-mapwrap{position:relative;border-radius:4px;overflow:hidden;background:#0B1220;border:1px solid #1F2937;isolation:isolate;min-height:600px}
  .lm2-mapwrap #lmmap{width:100%;height:100%}
  .lm2-maplabel{position:absolute;left:20px;top:20px;z-index:500;background:rgba(11,18,32,.92);padding:10px 14px;border-radius:2px;color:#fff;display:flex;align-items:center;gap:10px}
  .lm2-maplabel__t{font-size:14px;font-weight:600;margin-top:1px}
  .lm2-dot-g{display:inline-block;width:6px;height:6px;border-radius:50%;background:#16A34A;animation:pulse-soft 1.8s ease-in-out infinite}
  .lm2-mono{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.12em;color:#9CA3AF;text-transform:uppercase}
  .lm2-coords{position:absolute;right:20px;bottom:20px;z-index:500;font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.08em;color:#0B1220;background:rgba(255,255,255,.92);padding:6px 10px;border-radius:2px}
  .lm2-card{background:#11192B;border:1px solid #1F2937;border-radius:4px;padding:40px 36px;display:flex;flex-direction:column}
  .lm2-badge{display:inline-flex;align-self:flex-start;align-items:center;gap:8px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);padding:8px 14px;border-radius:2px;font-size:13px;font-weight:600;margin-bottom:32px;color:#fff}
  .lm2-h3{margin:0 0 24px;font-size:36px;line-height:1.1;font-weight:800;letter-spacing:-.02em;color:#fff}
  .lm2-region{border-top:1px solid #1F2937;padding-top:24px;margin-bottom:32px}
  .lm2-rlabel{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:#6B7280;margin-bottom:10px}
  .lm2-rcity{display:flex;align-items:center;gap:10px;margin-bottom:12px}
  .lm2-rcity span{font-size:22px;font-weight:700;letter-spacing:-.01em;color:#fff}
  .lm2-rcity svg{width:18px;height:18px;flex-shrink:0}
  .lm2-rmsg{margin:0;font-size:14px;line-height:1.6;color:#9CA3AF}
  .lm2-rmsg strong{color:#fff}
  .lm2-spacer{flex:1}
  .lm2-ctas{display:flex;flex-direction:column;gap:10px}
  .lm2-btn-white{background:#fff;border:none;color:#0B1220;font-weight:700;font-size:15px;padding:16px 20px;border-radius:2px;cursor:pointer;font-family:inherit;display:flex;align-items:center;justify-content:center;gap:8px;text-decoration:none}
  .lm2-btn-orange{background:#FF4D1F;border:none;color:#fff;font-weight:700;font-size:15px;padding:16px 20px;border-radius:2px;cursor:pointer;font-family:inherit;display:flex;align-items:center;justify-content:center;gap:8px;text-decoration:none}
  .lm2-note{margin-top:24px;padding-top:20px;border-top:1px solid #1F2937;display:flex;align-items:flex-start;gap:10px}
  .lm2-note svg{flex-shrink:0;margin-top:3px}
  .lm2-note p{margin:0;font-size:11px;line-height:1.55;color:#6B7280}
  @keyframes pulse-soft{0%,100%{opacity:1}50%{opacity:.45}}
  @media (max-width:980px){.lm2-sec{padding:64px 0}.lm2-inner{padding:0 20px}.lm2-head{grid-template-columns:1fr;gap:20px;margin-bottom:32px}.lm2-h2{font-size:46px}.lm2-grid{grid-template-columns:1fr;gap:18px}.lm2-mapwrap{min-height:380px}.lm2-mapwrap #lmmap{height:380px;min-height:380px}.lm2-card{padding:28px 22px}.lm2-h3{font-size:26px}}
  /* Handy-Feinschliff (kleine Phones) */
  @media (max-width:560px){
    .lm2-sec{padding:44px 0}
    .lm2-inner{padding:0 16px}
    .lm2-h2{font-size:30px;line-height:1.06}
    .lm2-sub{font-size:15px}
    .lm2-h3{font-size:22px;margin-bottom:18px}
    .lm2-badge{margin-bottom:20px}
    .lm2-region{padding-top:18px;margin-bottom:22px}
    .lm2-card{padding:22px 18px}
    .lm2-mapwrap{min-height:300px}
    .lm2-mapwrap #lmmap{height:300px;min-height:300px}
    .lm2-btn-white,.lm2-btn-orange{font-size:14px;padding:14px 18px}
    .stat{padding:28px 22px}
    .stat__lbl{line-height:1.35}
  }

  /* === Eck-Glow für weiße Sektionen (Hintergrund-Verlauf — nahtlos auf Desktop & Handy) === */
  .leistungen-section{background:radial-gradient(circle at top right,rgba(255,77,24,.28),transparent 40%),radial-gradient(circle at bottom left,rgba(17,40,120,.40),transparent 40%),#fff}
  #faq{background:radial-gradient(circle at top right,rgba(255,77,24,.28),transparent 40%),radial-gradient(circle at bottom left,rgba(17,40,120,.40),transparent 40%),var(--paper)}

  /* === ABLAUF in Orange (wie Akut) === */
  #ablauf{background:var(--accent)}
  #ablauf .section-head h2{color:#fff}
  #ablauf .section-head h2 .mark{background:var(--ink);color:#fff}
  #ablauf .section-head p{color:rgba(255,255,255,.88)}
  #ablauf .eyebrow{color:#fff !important}
  #ablauf .eyebrow .dot{background:#fff}
  #ablauf .why__card{background:#fff;border-color:transparent;box-shadow:0 10px 28px -16px rgba(10,22,40,.45)}
  #ablauf .why__num{color:var(--ink)}
  #ablauf .why__big em{color:var(--ink)}
  #ablauf .why__t{color:var(--ink)}
  #ablauf .why__d{color:var(--ink-2)}

  /* === TEST: eckige Ecken (Startseite) — zum Zurücksetzen einfach diesen Block löschen === */
  *{border-radius:0 !important}
  .eyebrow .dot,.nav-dd__menu a::before,.hero__tag .pulse,.trust-av,.hero__panel::before,.hero__panel::after,.hero__panel-head .live .dot,.ticker__dot,.step__arrow,.map-head .badge .dot,.map-pin .head,.final::before,.final::after,.foot-cta::before,.lm-pin,.lm-pin--you .ring,.livemap__panel::after,details.faq summary::after,.lm2-dot-o,.lm2-dot-g{border-radius:50% !important}


  /* Glows auf weißen Service-Sektionen (wie Startseite) */
  .team-bg,.cases-bg{background:radial-gradient(circle at top right,rgba(255,77,24,.28),transparent 40%),radial-gradient(circle at bottom left,rgba(17,40,120,.40),transparent 40%),var(--paper)}

  /* WANN-ANRUFEN-Section orange (wie Ablauf auf der Startseite) */
  .cases-bg{background:var(--accent)}
  .cases-bg .eyebrow{color:#fff}
  .cases-bg .eyebrow .dot{background:#fff;box-shadow:0 0 0 4px rgba(255,255,255,.2)}
  .cases-bg h2{color:#fff}
  .cases-bg h2 .accent{color:var(--ink)}
  .cases-bg .case{background:#fff;border-color:transparent;box-shadow:0 10px 28px -16px rgba(10,22,40,.45)}

  /* "Reaktionen" dunkler Mark (wie "vier klaren" im Ablauf) */
  .cases-bg h2 .mark{background:var(--ink);color:#fff;padding:0 10px;display:inline-block;border-radius:6px;transform:rotate(-1deg)}

  /* Content-Section: Sticky-AKUT-Box wie bei FAQ (overflow:hidden bricht sonst sticky) */
  #einsatz{overflow:visible}
  #einsatz .side{top:200px}

  /* Footer-CTA: komischer oranger Glow entfernt */
  .foot-cta::before{display:none}

/* ── Page-specific Overrides ── */
.phero{padding:8px 0 60px;position:relative;overflow:hidden;background-image:linear-gradient(105deg,rgba(255,255,255,.96) 0%,rgba(255,255,255,.88) 38%,rgba(255,255,255,.6) 70%,rgba(255,255,255,.55) 100%),linear-gradient(180deg,transparent 0%,rgba(244,245,247,.55) 100%),url('img/Rohrsanierung.webp');background-size:cover;background-position:center;background-repeat:no-repeat}
.hero{padding:20px 0 80px;position:relative;overflow:hidden;background-image:linear-gradient(105deg, rgba(255,255,255,.96) 0%, rgba(255,255,255,.88) 38%, rgba(255,255,255,.6) 70%, rgba(255,255,255,.55) 100%),linear-gradient(180deg, transparent 0%, rgba(244,245,247,.55) 100%),url('img/Rohrsanierung.webp');background-size:cover;background-position:center;background-repeat:no-repeat}
/* cases-Section orange (wie kanalreinigung) */
.phero{padding:8px 0 60px;position:relative;overflow:hidden;background-image:linear-gradient(105deg,rgba(255,255,255,.96) 0%,rgba(255,255,255,.88) 38%,rgba(255,255,255,.6) 70%,rgba(255,255,255,.55) 100%),linear-gradient(180deg,transparent 0%,rgba(244,245,247,.55) 100%),url('img/kamerainspektion.webp');background-size:cover;background-position:center;background-repeat:no-repeat}
.hero{padding:20px 0 80px;position:relative;overflow:hidden;background-image:linear-gradient(105deg, rgba(255,255,255,.96) 0%, rgba(255,255,255,.88) 38%, rgba(255,255,255,.6) 70%, rgba(255,255,255,.55) 100%),linear-gradient(180deg, transparent 0%, rgba(244,245,247,.55) 100%),url('img/kamerainspektion.webp');background-size:cover;background-position:center;background-repeat:no-repeat}
/* Page hero */
.phero{padding:8px 0 60px}
.phero__head{max-width:760px}
.phero h1{font-size:68px;font-weight:900;line-height:.96;letter-spacing:-.035em;margin:18px 0 22px;text-wrap:balance}
.phero p.lead{font-size:19px;color:var(--ink-2);max-width:620px;margin:0 0 0;line-height:1.6}
/* Main grid: Form + Info side */
section.s{padding:80px 0}
.kgrid{display:grid;grid-template-columns:1.15fr .85fr;gap:56px;align-items:start}
.form-card{background:var(--paper);border:1px solid var(--line);border-radius:24px;padding:44px;box-shadow:var(--shadow-md)}
.form-card h2{font-size:36px;font-weight:900;letter-spacing:-.025em;margin:8px 0 10px;line-height:1.05}
.form-card h2 .accent{color:var(--accent)}
.form-card .lead{color:var(--ink-2);font-size:16px;margin:0 0 28px;line-height:1.55}
.form-card form{display:flex;flex-direction:column;gap:18px}
.form-card input,.form-card textarea,.form-card select{width:100%;border:1.5px solid var(--line-2);border-radius:12px;padding:14px 16px;font:inherit;font-size:15.5px;background:var(--bg);color:var(--ink);transition:border-color .15s,background .15s;font-family:inherit}
.form-card input:focus,.form-card textarea:focus,.form-card select:focus{outline:none;border-color:var(--ink);background:var(--paper)}
.form-card textarea{min-height:130px;resize:vertical}
.form-card .btn{width:100%;justify-content:center;margin-top:8px;font-size:16px;padding:16px}
.form-card .small{font-size:12.5px;color:var(--ink-3);font-family:'JetBrains Mono',monospace;margin:10px 0 0;text-align:center}
.checkbox-row{display:flex;align-items:flex-start;gap:10px;font-size:13.5px;color:var(--ink-2);line-height:1.5}
.checkbox-row input{width:18px;height:18px;margin-top:2px;flex-shrink:0;border-radius:4px}
.checkbox-row a{color:var(--accent);text-decoration:underline}
/* Side info */
.side{display:flex;flex-direction:column;gap:18px}
/* Final CTA */
.phero h1{font-size:54px}
.kgrid{grid-template-columns:1fr;gap:36px}
.phero h1{font-size:44px}
section.s{padding:60px 0}
.form-card{padding:30px}
.form-card{padding:24px}
.form-card h2{font-size:28px}
/* === KONTAKT: Formular auf Mobil nach ganz oben === */
main#main{display:flex;flex-direction:column}
main#main > .kontakt-form-section{padding-top:24px}
main#main > .kontakt-form-section .form-card .lead{font-size:15.5px}
/* Header-CTA mobil + Signature-Glow Formular-Section (Angleich an neue Seiten) */
@media(max-width:880px){header.site .cta-full{display:none}header.site .cta-short{display:inline}}
.kontakt-form-section{background:radial-gradient(circle at top right,rgba(255,77,24,.28),transparent 40%),radial-gradient(circle at bottom left,rgba(17,40,120,.40),transparent 40%),#fff}
/* "eckig"-Stil wie auf den anderen Seiten */
/* Formular ohne Box, schlicht & mittig (unkompliziert) */
.kgrid{grid-template-columns:1fr}
.form-card{background:transparent;border:none;box-shadow:none;padding:0;max-width:680px;margin:0 auto}
/* Akut-Band randlos (voll an Seiten + unten), wie andere Seiten */
/* Hero-Section dunkelblau + helle Schrift */
.phero--dark{background:var(--ink)}
.phero--dark h1{color:#fff}
.phero--dark h1 .mark{color:var(--ink)}
.phero--dark p.lead{color:rgba(255,255,255,.82)}
.phero--dark .eyebrow{color:rgba(255,255,255,.85)}
.phero .breadcrumbs,.phero--dark .breadcrumbs a{color:rgba(255,255,255,.55)}
.phero--dark .breadcrumbs span{color:#fff}
.phero{padding:8px 0 60px;position:relative;overflow:hidden;background-image:linear-gradient(105deg,rgba(255,255,255,.96) 0%,rgba(255,255,255,.88) 38%,rgba(255,255,255,.6) 70%,rgba(255,255,255,.55) 100%),linear-gradient(180deg,transparent 0%,rgba(244,245,247,.55) 100%),url('img/Hintergrundbild.webp');background-size:cover;background-position:center;background-repeat:no-repeat}
.phero h1{font-size:60px;font-weight:900;line-height:.98;letter-spacing:-.035em;margin:18px 0 22px;text-wrap:balance}
/* === Accessibility: focus-visible === */
:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}
a:focus-visible,
button:focus-visible,
input:focus-visible,
textarea:focus-visible,
select:focus-visible,
details summary:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}
.skip-link:focus-visible {
  left: 0;
  outline: 3px solid var(--accent);
}

/* === Accessibility: reduced motion === */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}

/* Blog-Liste: ein Block, Artikel mit Linie getrennt, orange/blau Glow */
.blog-list-section{background:radial-gradient(circle at bottom left,rgba(17,40,120,.34),transparent 45%),var(--paper)}
.blog-list{background:var(--paper);border:1px solid var(--line);box-shadow:0 24px 70px -34px rgba(10,22,40,.35)}
.blog-row{position:relative;display:block;padding:24px 30px 24px 34px;text-decoration:none;color:var(--ink);border-top:1px solid var(--line);transition:background .18s,padding .18s}
.blog-row:first-child{border-top:none}
.blog-row::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--accent);transform:scaleY(0);transition:transform .2s}
.blog-row:hover{background:rgba(255,77,24,.045);padding-left:40px}
.blog-row:hover::before{transform:scaleY(1)}
.blog-row .eyebrow{color:var(--accent)}
.blog-row h2{font-size:1.2rem;margin:10px 0 7px;line-height:1.25;color:var(--ink);transition:color .18s}
.blog-row:hover h2{color:var(--accent)}
.blog-row h2 .accent{color:var(--accent)}
.blog-row p{color:var(--ink-2);font-size:.93rem;line-height:1.5;margin:0}
.blog-row time{display:block;margin-top:12px;font-size:.74rem;color:var(--ink-3);font-family:'JetBrains Mono',monospace;letter-spacing:.03em}
@media (max-width:560px){.blog-row{padding:22px 20px}}

.form-card h1{font-size:46px;font-weight:900;letter-spacing:-.025em;margin:10px 0 12px;line-height:1.04}
.form-card h1 .accent{color:var(--accent)}
@media (max-width:560px){.form-card h1{font-size:32px}}
