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

/* ── 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}

/* ── Design Tokens ── */
: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)}

/* ── Resets & Base ── */
*{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;overflow-x:clip}
body{font-size:17px;line-height:1.6}
a{color:inherit}img{max-width:100%;display:block}

/* === Eckige Ecken (Design-Intent: square corners) === */
.skip-link,
.alert__phone .num,
.nav-dd__menu,
.nav-dd__menu a,
.btn,
.btn--xl,
.btn--xxl,
.phero h1 .mark,
.chip,
.phero__panel,
.panel__row,
.panel__row .ic,
.stats,
.hbar__item .ic,
.content h2 .mark,
.check-list li .ic,
.pullquote,
.pullquote .mark,
.side-card,
.side-card--accent::before,
.side-card ul a,
.team__img,
.team__badge,
.team__text h2 .mark,
.team__stat,
.case,
.case .tag,
.final,
.final h2 .mark,
.foot-cta__btn,
.foot-badge,
.cookie,
.cookie__btn,
.menu-toggle,
.menu-toggle span,
.hero h1 .mark,
.hero__phone-call,
.hero__phone-call .ic,
.hero__panel,
.hero__row,
.hero__row .ic,
.section-head h2 .mark,
.why__card,
.btn--side,
details.faq,
details.faq summary::after,
.form-card,
.form-card input,
.form-card textarea,
.form-card select,
.checkbox-row input,
.leistung-image,
.leistung-label,
.leistung-number,
.leistungen-cta,
.lm2-mapwrap,
.lm2-maplabel,
.lm2-coords,
.lm2-card,
.lm2-badge,
.lm2-btn-white,
.lm2-btn-orange,
.cases-bg h2 .mark,
.blog-list,
.blog-row::before{border-radius:0}
/* Circular elements (keep round) */
.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,.map-head .badge .dot,.map-pin .head,.final::before,.final::after,.foot-cta::before,.lm-pin,.lm-pin--you .ring,.livemap__panel::after,.lm2-dot-o,.lm2-dot-g,.team__badge::before,.phero__panel::before,.pullquote::before,.side-card--accent::before,.lm-pin--mini,.lm-pin--you,.lm-pin--you .ring{border-radius:50%}

/* ── Layout ── */
.container{max-width:1240px;margin:0 auto;padding:0 32px}

/* ── Shared Components ── */
.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;font-weight:700;text-decoration:none}
.skip-link:focus{left:0}

/* ── Header ── */
.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;font-family:'JetBrains Mono',monospace}
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}
.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 ── */
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);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;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}

/* ── Buttons ── */
.btn{display:inline-flex;align-items:center;gap:10px;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}
.btn--xxl{padding:22px 36px;font-size:18px}

/* ── Breadcrumbs ── */
.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)}

/* ── Page Hero (.phero) ── */
.phero{padding:8px 0 60px;position:relative;overflow:hidden}
.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;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;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)}
.phero__panel{background:var(--ink);color:#fff;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)}
.panel__row .ic{width:38px;height:38px;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 ── */
.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 ── */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:0;background:var(--ink);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}

/* ── H-Bar ── */
.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;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}

/* ── 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;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}

/* ── Content Grid ── */
.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;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;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;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;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}

/* ── Sidebar ── */
.side{position:sticky;top:120px;display:flex;flex-direction:column;gap:18px}
.side-card{background:var(--paper);border:1px solid var(--line);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: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 ── */
.team-bg{background:var(--paper)}
.team-grid{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.team__img{position:relative;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;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;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);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 ── */
.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);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;text-transform:uppercase}
.case .tag--yellow{background:var(--hi);color:var(--ink)}
.case .tag--ink{background:var(--ink);color:#fff}

/* ── Final CTA ── */
.final{background:var(--accent);color:#fff;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;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;overflow:hidden}
.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;display: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;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;font-size:12px;font-weight:700;color:#fff;font-family:'JetBrains Mono',monospace;letter-spacing:.02em}
.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}

/* ── Mobile 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;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;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:#fff;color:var(--ink)}
.cookie__btn--decline:hover{background:rgba(255,255,255,.82)}
@media (max-width:760px){.cookie{left:12px;right:12px;bottom:84px;padding:18px}}

/* ── Hero (Startseite) ── */
.hero{padding:20px 0 80px;position:relative;overflow:hidden}
.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;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);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;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}

/* 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}

/* Visual side - status panel */
.hero__panel{background:var(--ink);color:#fff;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)}
.hero__row .ic{width:38px;height:38px;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}

/* ── 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);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}

/* ── 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;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}
.faqs{display:flex;flex-direction:column;gap:12px}
details.faq{background:var(--paper);border:1px solid var(--line);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 ── */
.form-card{background:var(--paper);border:1px solid var(--line);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 h3{font-size:26px;font-weight:900;margin:0 0 8px;letter-spacing:-.02em}
.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-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,.form-card select{width:100%;border:1.5px solid var(--line-2);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}
.checkbox-row a{color:var(--accent);text-decoration:underline}

/* ── Responsive: Desktop → Tablet ── */
@media (max-width:1080px){
  .hero h1{font-size:64px}
  .section-head h2{font-size:46px}
  .why{grid-template-columns:repeat(2,1fr)}
  .phero h1{font-size:48px}
  .cases{grid-template-columns:1fr 1fr}
}
@media (max-width:880px){
  .hero__grid,.faq-wrap{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}
  .phero__grid,.pgrid{grid-template-columns:1fr;gap:36px}
  .side{position:static}
  .hbar__inner{grid-template-columns:1fr 1fr;gap:20px}
  .phero{padding:8px 0 48px}
  .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 16px}
  body{font-size:16px}
  .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}
  .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}
  .why{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}
  .form-card{padding:26px}
  .foot-grid{grid-template-columns:1fr}
  .foot-brand-logo img{width:54px;height:54px}
  .foot-brand-logo .name{font-size:24px}
  .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}
}

/* === MOBILE OPTIMIERUNG === */
@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;gap:6px;white-space:nowrap}
  header.site .btn--call svg{width:16px;height:16px}
  .alert__cities{display:none}
  .alert__phone{flex-basis:auto}
}
@media (max-width:520px){
  .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;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}
  .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}
  .alert__left svg{display:none}
  .alert__phone-label{display:none}
  .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;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);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}
  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
  }
  nav.main.is-open{display:flex}
  nav.main .nav-dd{position:static;display:block;align-items:stretch;width:100%;border:0}
  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)}
  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}
  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;
    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}
  nav.main > a:last-of-type{border-bottom:0}
}

/* === ALERT BAR (responsive) === */
@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}
}

/* === OVERFLOW-FIX === */
.hero,.phero,section.s{overflow:hidden}

/* === HEADER MOBILE V2: Alert weg, Anruf-Icon neben Menu === */
@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;
    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}
  .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}
  .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}
  .panel__rows{gap:12px}
  .panel__row{padding:15px 16px}
  .hero__chips{margin-top:24px;gap:9px}
  .phero__actions{margin-bottom:8px}
}

/* === LEISTUNGEN V6 === */
.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;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;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}
.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}
.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;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}}

/* ── Leaflet Map ── */
#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}

/* ── Final CTA Band ── */
.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;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;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}
.lm2-card{background:#11192B;border:1px solid #1F2937;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;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;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;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}}
@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 fuer weisse Sektionen === */
.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)}
.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)}

/* === ABLAUF in Orange === */
#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}
#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)}

/* === WANN-ANRUFEN-Section orange === */
.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)}
.cases-bg h2 .mark{background:var(--ink);color:#fff;padding:0 10px;display:inline-block;transform:rotate(-1deg)}

/* Content-Section: Sticky-AKUT-Box */
#einsatz{overflow:visible}
#einsatz .side{top:200px}

/* ── Page-specific Overrides ── */

/* Page hero */
.phero__head{max-width:760px}
.phero h1{font-size:60px;font-weight:900;line-height:.98;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 */
.kgrid{display:grid;grid-template-columns:1.15fr .85fr;gap:56px;align-items:start}

/* Side info */
.side{display:flex;flex-direction:column;gap:18px}

/* Kontakt-page scoped overrides */
.kontakt-page .kgrid{grid-template-columns:1fr}
.kontakt-page .form-card{background:transparent;border:none;box-shadow:none;padding:0;max-width:680px;margin:0 auto}

/* 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}

/* === 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}
@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}

/* === 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 === */
.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}}

/* === Print === */
@media print{
  header.site,.alert-bar,.mcall,.cookie,.foot-cta,.menu-toggle,.skip-link,.hero__actions,.phero__actions,nav.main,.btn--call,.livemap,.lm2{display:none!important}
  body,main,.phero,.hero{color:#000;background:#fff!important}
  a{color:#000;text-decoration:underline}
  .phero h1,.hero h1,h2,h3{color:#000}
  footer.site{border-top:1px solid #ccc;background:#fff}
}
