/* ============================================================
   ROHNER IMMOBILIEN — Design-System „H / Kinetik, vollendet"
   Gemeinsames Stylesheet aller Unterseiten (Rollout 10.06.2026).
   Kern 1:1 aus dem freigegebenen Finalist H (index.html),
   ergänzt um Unterseiten-Komponenten in derselben Sprache.
   Gesetze: HELL, dunkle Schrift · 1 Gedanke pro Sektion ·
   Trust genau 1× pro Seite · Zielgruppe 40–60 (Body 18px, AA) ·
   Motion ruhig & hochwertig, reduced-motion schaltet alles ab.
   ============================================================ */
:root{
  --navy:#162B50;--navy-tief:#0E1C36;--azur:#0472C7;--azur-l:#0095F7;--cta:#4A89E4;--azur-soft:#cfe2f5;
  --ink:#333333;--grey:#71717B;--hair:#E2E8F0;--bord:#E2E8F0;
  --bg:#FFFFFF;--bg-alt:#F4F4F5;--card:#FFFFFF;--accentcard:#EDF3FA;--gold:#EAB308;
  --grad:linear-gradient(90deg,#0472C7,#0095F7);
  --wrap:1180px;--prose:760px;--gut:clamp(22px,5vw,44px);--ease:cubic-bezier(.2,.7,.2,1);
  --rcard:18px;--shadow:0 34px 70px -38px rgba(14,28,54,.35);
  font-feature-settings:"tnum";
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{font-family:"DM Sans",-apple-system,Segoe UI,Roboto,sans-serif;color:var(--ink);background:var(--bg);line-height:1.7;font-size:18px;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img,video{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 var(--gut)}
h1,h2,h3,h4{font-family:"Manrope",-apple-system,Segoe UI,Roboto,sans-serif;font-weight:800;color:var(--navy);letter-spacing:-.03em;line-height:1.08}
h1{font-size:clamp(36px,4.8vw,56px);line-height:1.06}
h2{font-size:clamp(28px,4vw,44px)}
h3{font-size:clamp(20px,2.3vw,24px)}
.lead{font-size:clamp(18px,1.9vw,20px);color:#333333}
.eyebrow{display:block;font-size:13px;letter-spacing:.2em;text-transform:uppercase;color:var(--azur);font-weight:700;margin-bottom:14px}
section{padding:clamp(64px,8.5vw,112px) 0}
.sec-head{max-width:720px;margin-bottom:clamp(30px,4vw,52px);position:relative;padding-top:24px}
.sec-head::before{content:"";position:absolute;left:3px;top:0;width:2px;height:0;background:var(--azur);transition:height .8s var(--ease) .15s}
.sec-head::after{content:"";position:absolute;left:0;top:0;width:8px;height:8px;border-radius:50%;background:var(--azur);opacity:0;transition:opacity .4s}
.sec-head.reveal.in::before{height:18px}
.sec-head.reveal.in::after{opacity:1}
.rule{width:54px;height:3px;background:var(--grad);border-radius:2px;margin:18px 0 0}
.bg-white{background:#fff}
.bg-cream{background:var(--bg-alt)}
.btn{display:inline-flex;align-items:center;gap:9px;background:var(--cta);color:#fff;padding:16px 30px;border-radius:12px;font-weight:700;font-size:16px;border:0;cursor:pointer;transition:transform .22s var(--ease),background .22s,box-shadow .22s;min-height:52px;will-change:transform}
.btn:hover{background:var(--azur);transform:translateY(-2px);box-shadow:0 18px 36px -18px rgba(14,28,54,.5)}
.btn-ghost{background:#fff;color:var(--navy);border:1.5px solid #CBD5E1}
.btn-ghost:hover{border-color:var(--azur);color:var(--azur);box-shadow:none}
a:focus-visible,button:focus-visible,summary:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:3px solid var(--azur);outline-offset:3px;border-radius:6px}
.skip{position:absolute;left:-9999px;top:0;z-index:300;background:var(--navy);color:#fff;padding:12px 20px;font-weight:700}
.skip:focus{left:0}

/* Header + Scroll-Fortschritt (H) */
.scrollprog{position:fixed;top:0;left:0;height:3px;width:0;background:linear-gradient(90deg,var(--azur),var(--azur-l));z-index:200}
.hd{position:fixed;top:0;left:0;right:0;z-index:90;border-bottom:1px solid transparent;transition:background .3s,box-shadow .3s,border-color .3s}
.hd .wrap{display:flex;align-items:center;justify-content:space-between;height:74px;gap:16px}
.brand{display:flex;align-items:center;gap:12px}
.brand img{height:30px;width:auto;display:block}
.hd.scrolled{background:rgba(255,255,255,.92);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-color:var(--hair);box-shadow:0 8px 30px -26px rgba(14,28,54,.5)}
.nav{display:flex;gap:24px;align-items:center}
.nav a{font-size:15px;font-weight:600;color:var(--ink)}
.nav a:hover{color:var(--azur)}
.nav a.btn{color:#fff;padding:12px 20px;min-height:46px;font-size:15px}
.burger{display:none;background:none;border:0;font-weight:700;color:var(--navy);font-size:16px;align-items:center;gap:7px;cursor:pointer;min-height:44px}

/* Seiten-Hero — HELL, zentrierte Botschaft (H-Muster für Unterseiten) */
.phero{padding:140px 0 clamp(48px,6vw,76px);background:radial-gradient(56% 48% at 84% 14%, rgba(0,149,247,.12), transparent 70%),var(--bg);text-align:center}
.phero .crumb{justify-content:center}
.phero h1{margin:0 auto;max-width:22ch}
.phero h1 em{font-style:normal;color:var(--azur)}
.phero .lead{max-width:56ch;margin:22px auto 0}
.phero .answer{margin:26px auto 0;max-width:62ch;font-size:17px;color:#333333;background:var(--accentcard);border:1px solid #D6E6F7;border-left:3px solid var(--azur);border-radius:12px;padding:18px 22px;text-align:left}
.phero .cta-row{display:flex;gap:14px;flex-wrap:wrap;justify-content:center;margin-top:30px}
.phero .hero-sub{margin-top:18px;font-size:15px;color:var(--grey)}
.thread{width:2px;height:54px;margin:26px auto 0;background:linear-gradient(var(--azur),transparent);transform-origin:top;animation:tgrow 1s 1s var(--ease) both}
@keyframes tgrow{from{transform:scaleY(0)}to{transform:scaleY(1)}}
.crumb{display:flex;gap:6px;flex-wrap:wrap;font-size:13.5px;color:var(--grey);margin-bottom:18px}
.crumb a:hover{color:var(--azur)}
.crumb b{color:var(--ink);font-weight:600}

/* Trustline — die EINE Trust-Instanz der Unterseiten (Logos in Farbe) */
.trustline{background:#fff;border-top:1px solid var(--hair);border-bottom:1px solid var(--hair);padding:22px 0}
.trustline .wrap{display:flex;align-items:center;justify-content:center;gap:clamp(22px,4.5vw,56px);flex-wrap:wrap}
.tl{display:flex;align-items:center;gap:11px;font-size:15px;color:var(--grey)}
.tl b{color:var(--navy);font-size:16px}
.tl .stars{color:var(--gold);letter-spacing:2px;font-size:17px}
.tl img{height:40px;width:auto}
.gicon{width:26px;height:26px;flex:none}

/* Lichtglanz folgt der Maus (auf Bild-Containern) */
.shine{position:relative}
.shine::after{content:"";position:absolute;inset:0;background:radial-gradient(420px circle at var(--mx,50%) var(--my,50%),rgba(255,255,255,.28),transparent 55%);opacity:0;transition:opacity .35s;pointer-events:none}
.shine:hover::after{opacity:1}

/* Prose & Split */
.prose{max-width:var(--prose)}
.prose p{margin:0 0 18px;color:#333333}
.prose h2{margin:0 0 14px}
.prose h3{margin:26px 0 10px}
.prose ul,.prose ol{margin:0 0 18px;padding-left:22px}
.prose li{margin-bottom:9px;color:#333333}
.prose a{color:var(--azur);font-weight:600}
.prose strong{color:var(--navy)}
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(28px,5vw,64px);align-items:center}
.split>*{min-width:0}
.split .imgwrap{border-radius:var(--rcard);overflow:hidden;box-shadow:var(--shadow);aspect-ratio:4/3;background:var(--navy)}
.split .imgwrap img{width:100%;height:100%;object-fit:cover;transition:transform .9s var(--ease)}
.split .imgwrap:hover img{transform:scale(1.04)}

/* Karten / Hub-Grid (H-Sprache) */
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:18px}
.card{display:block;background:#fff;border:1px solid var(--bord);border-radius:var(--rcard);padding:28px;transition:box-shadow .25s,transform .25s,border-color .25s;color:inherit;will-change:transform}
.card:hover{box-shadow:var(--shadow);transform:translateY(-3px);border-color:var(--azur-soft)}
.card h3{font-size:20px;margin-bottom:8px}
.card p{font-size:15px;color:#333333}
.card .more{color:var(--azur);font-weight:700;font-size:14.5px;margin-top:12px;display:inline-block}

/* Wege-Karten mit Bild (H) */
.wege-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(18px,2.6vw,28px)}
.wcard{position:relative;display:flex;flex-direction:column;background:var(--card);border:1px solid var(--bord);border-radius:22px;overflow:hidden;transition:transform .25s var(--ease),box-shadow .25s,border-color .25s;will-change:transform}
.wcard:hover{box-shadow:var(--shadow);border-color:var(--azur-soft)}
.wcard .wim{aspect-ratio:16/7;overflow:hidden}
.wcard .wim img{width:100%;height:100%;object-fit:cover;transition:transform .9s var(--ease)}
.wcard:hover .wim img{transform:scale(1.04)}
.wcard .wtx{padding:clamp(24px,3vw,34px)}
.wcard .k{font-size:clamp(22px,2.4vw,28px);font-weight:800;color:var(--navy);letter-spacing:-.02em;line-height:1.18;max-width:18ch}
.wcard p{color:var(--grey);font-size:16px;margin-top:10px;max-width:46ch}
.wcard .go{display:inline-flex;align-items:center;gap:8px;margin-top:20px;color:var(--azur);font-weight:700;font-size:16px}

/* Daten-Box (BORIS) */
.databox{background:var(--accentcard);border:1px solid #D6E6F7;border-radius:var(--rcard);padding:24px}
.databox table{width:100%;border-collapse:collapse;font-size:15px}
.databox th,.databox td{text-align:left;padding:8px 6px;border-bottom:1px solid #D6E6F7;overflow-wrap:anywhere}
.databox td:last-child{text-align:right;font-variant-numeric:tabular-nums;color:var(--navy);font-weight:700}
.databox .src{font-size:12.5px;color:var(--grey);margin-top:10px}

/* Prozess — Leitlinie + Sticky-Bild (H, für ablauf.html) */
.proz-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(30px,5vw,70px);align-items:start}
.proz-sticky{position:sticky;top:104px;height:min(70vh,560px);border-radius:22px;overflow:hidden;box-shadow:var(--shadow)}
.proz-sticky .pim{position:absolute;inset:0;opacity:0;transition:opacity .7s var(--ease),transform 1.4s var(--ease);transform:scale(1.05)}
.proz-sticky .pim.on{opacity:1;transform:scale(1)}
.proz-sticky .pim img{width:100%;height:100%;object-fit:cover}
.pstep{position:relative;padding:32px 0 32px 76px;border-bottom:1px solid var(--hair)}
.pstep:last-child{border-bottom:0}
.pstep .rline,.pstep .rfill{position:absolute;left:21px;width:2px;top:0;bottom:0}
.pstep .rline{background:var(--hair)}
.pstep .rfill{background:var(--azur);height:0;transition:height 1.1s var(--ease)}
.pstep.in .rfill{height:100%}
.pstep:first-child .rline,.pstep:first-child .rfill{top:54px}
.pstep:last-child .rline{height:54px;bottom:auto}
.pstep:last-child .rfill{max-height:54px}
.pstep .no{position:absolute;left:0;top:32px;z-index:1;display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:50%;background:var(--accentcard);color:var(--azur);font-weight:800;font-size:17px}
.pstep h3{margin-bottom:10px}
.pstep p{color:#333333;max-width:52ch}
.pstep .proof{margin-top:12px;font-size:15px;color:var(--grey);display:inline-flex;gap:9px;align-items:center}
.pstep .proof::before{content:"✓";color:#0D8A3A;font-weight:800}
.pstep .pmob{display:none}

/* Verkauft-Karten (H) */
.sold-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,2.4vw,28px)}
.scard{display:flex;flex-direction:column;background:var(--bg);border:1px solid var(--bord);border-radius:var(--rcard);overflow:hidden;transition:box-shadow .25s,transform .25s}
.scard:hover{box-shadow:var(--shadow);transform:translateY(-3px)}
.scard .m{position:relative;aspect-ratio:4/3;overflow:hidden;background:var(--navy)}
.scard .m img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.scard:hover .m img{transform:scale(1.05)}
.scard .badge{position:absolute;top:14px;left:14px;background:#0D8A3A;color:#fff;font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:6px 12px;border-radius:6px}
.scard .b{display:flex;flex-direction:column;gap:6px;padding:22px}
.scard .loc{font-size:13px;letter-spacing:.12em;text-transform:uppercase;color:var(--azur);font-weight:700}
.scard h3{font-size:19px}
.scard .price{font-size:21px;font-weight:800;color:var(--navy);font-variant-numeric:tabular-nums;margin-top:2px}

/* Stimmen (H) */
.rev-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.rev{background:var(--card);border:1px solid var(--bord);border-radius:var(--rcard);padding:28px;display:flex;flex-direction:column;gap:14px}
.rev .stars{color:var(--gold);letter-spacing:2.5px;font-size:17px}
.rev blockquote{margin:0;font-size:16px;color:#333333;line-height:1.65}
.rev figcaption{margin-top:auto;color:var(--navy);font-weight:700;font-size:15px}
.rev figcaption span{display:block;font-weight:500;color:var(--grey);font-size:13px;margin-top:2px}

/* Team (H-Sprache) */
.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,3vw,36px)}
.tm{text-align:center}
.tm .ph{aspect-ratio:1/1;border-radius:var(--rcard);overflow:hidden;margin-bottom:14px;box-shadow:var(--shadow)}
.tm .ph img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.tm:hover .ph img{transform:scale(1.05)}
.tm h3{font-size:20px;margin-bottom:3px}
.tm .role{font-size:12.5px;letter-spacing:.04em;color:var(--azur);font-weight:700;text-transform:uppercase}

/* FAQ (H) */
.faq{max-width:820px;margin:0 auto}
.faq details{border-bottom:1px solid #E2E8F0}
.faq summary{list-style:none;cursor:pointer;padding:22px 48px 22px 0;position:relative;font-weight:700;color:var(--navy);font-size:18.5px;min-height:44px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";position:absolute;right:4px;top:16px;font-size:28px;color:var(--azur);font-weight:400}
.faq details[open] summary::after{content:"−"}
.faq details p{padding:0 0 22px;color:#333333;max-width:70ch}
.faq-head{max-width:680px;margin:0 auto clamp(30px,4vw,52px);text-align:center;position:relative;padding-top:24px}
.faq-head::before{content:"";position:absolute;left:50%;top:0;width:2px;height:0;background:var(--azur);transition:height .8s var(--ease) .15s}
.faq-head.reveal.in::before{height:16px}

/* CTA-Band — HELL (H-Wert-Muster; Navy-CTA-Bänder sind Geschichte) */
.ctaband{background:var(--accentcard);text-align:center}
.ctaband .wrap{max-width:860px}
.ctaband h2{max-width:20ch;margin:0 auto}
.ctaband .lead{max-width:54ch;margin:18px auto 0}
.ctaband .cta-row{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-top:34px}
.ctaband .phone{display:inline-block;margin-top:26px;font-size:clamp(21px,3vw,28px);font-weight:800;color:var(--navy)}

/* Wertkorridor (H) */
.korridor{margin:40px auto 10px;max-width:560px}
.korridor .band{position:relative;height:54px;border-radius:12px;background:linear-gradient(90deg,rgba(0,149,247,.28),rgba(4,114,199,.78),rgba(0,149,247,.28));border:1px solid #BFD9F5;transform:scaleX(.18);transform-origin:center;transition:transform 1.1s var(--ease)}
.korridor.grow .band{transform:scaleX(1)}
.korridor .band .mid{position:absolute;left:50%;top:-8px;bottom:-8px;width:2px;background:var(--navy);transform:translateX(-50%)}
.korridor .tag{display:block;font-size:13.5px;color:var(--grey);margin-bottom:10px}
.korridor .lbl{display:flex;justify-content:space-between;font-size:14.5px;color:var(--grey);margin-top:10px}

/* Ratgeber: Autorenbox, Artikel-Elemente */
.authorbox{display:flex;gap:16px;align-items:center;background:var(--accentcard);border:1px solid #D6E6F7;border-radius:var(--rcard);padding:18px 20px;margin:30px 0}
.authorbox img{width:60px;height:60px;border-radius:50%;object-fit:cover;flex:none}
.authorbox b{color:var(--navy);display:block}
.authorbox p{font-size:14px;color:#333333;margin:3px 0 0}
.artmeta{font-size:13.5px;color:var(--grey);margin-bottom:6px}
.prose table{width:100%;border-collapse:collapse;font-size:15px;margin:6px 0 22px}
.prose th,.prose td{text-align:left;padding:9px 8px;border-bottom:1px solid var(--hair);vertical-align:top;overflow-wrap:anywhere}
.prose thead th{color:var(--navy);font-weight:700;border-bottom:2px solid var(--hair)}
.prose figure{margin:0 0 22px}
.prose figure img{border-radius:var(--rcard);width:100%;box-shadow:var(--shadow)}
.prose figcaption{font-size:13px;color:var(--grey);margin-top:8px}
.callout,.disclaimer{background:var(--accentcard);border-left:3px solid var(--azur);border-radius:10px;padding:14px 18px;font-size:15px;color:#333333;margin:0 0 18px}

/* Über-uns Schnellzugriff-Chips */
.ueber-quick{display:flex;flex-wrap:wrap;gap:10px;justify-content:center}
.ueber-quick a{font-size:14.5px;font-weight:600;color:var(--navy);background:#fff;border:1px solid var(--bord);padding:10px 18px;border-radius:30px;transition:border-color .2s,color .2s,box-shadow .2s;min-height:44px;display:inline-flex;align-items:center}
.ueber-quick a:hover{border-color:var(--azur);color:var(--azur);box-shadow:0 8px 20px -14px rgba(14,28,54,.45)}

/* Formulare (Kontakt / Bewertung) */
.form{max-width:680px;margin:0 auto;display:grid;gap:18px}
.form label{font-weight:700;color:var(--navy);font-size:15.5px;display:block;margin-bottom:7px}
.form input[type=text],.form input[type=tel],.form input[type=email],.form select,.form textarea{width:100%;background:#fff;border:1.5px solid #CBD5E1;border-radius:12px;padding:14px 16px;font-size:16.5px;font-family:inherit;color:var(--ink);transition:border-color .2s,box-shadow .2s;min-height:52px}
.form textarea{min-height:130px;resize:vertical}
.form input:focus,.form select:focus,.form textarea:focus{border-color:var(--azur);box-shadow:0 0 0 3px rgba(4,114,199,.12);outline:none}
.form .check{display:flex;gap:11px;align-items:flex-start;font-size:14.5px;color:#333333;font-weight:500}
.form .check input{width:20px;height:20px;margin-top:3px;accent-color:var(--azur);flex:none}
.form .hint{font-size:13.5px;color:var(--grey)}
.form .btn{justify-self:start}

/* 4-Schritt-Wertrechner — HELL (Umzug von der Startseite, H-Sprache) */
.calc{max-width:760px;margin:34px auto 0;background:#fff;border:1px solid var(--bord);border-radius:22px;padding:clamp(24px,4vw,44px);box-shadow:var(--shadow)}
.calc-prog{height:6px;background:var(--accentcard);border-radius:3px;margin-bottom:8px;overflow:hidden}
.calc-prog i{display:block;height:100%;width:25%;background:linear-gradient(90deg,var(--azur),var(--azur-l));border-radius:3px;transition:width .5s var(--ease)}
.calc-meta{display:flex;justify-content:space-between;font-size:12.5px;color:var(--grey);margin-bottom:24px}
.calc .q{display:none;animation:qfade .5s}
.calc .q.on{display:block}
@keyframes qfade{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}
.calc .q h3{font-size:24px;margin-bottom:6px}
.calc .q p.sub{color:var(--grey);font-size:15px;margin-bottom:22px}
.opts{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px}
.opt{border:1.5px solid var(--bord);background:#fff;color:var(--ink);border-radius:12px;padding:18px;cursor:pointer;font-weight:600;font-size:15px;text-align:left;transition:.18s;font-family:inherit}
.opt:hover{border-color:var(--azur-l);transform:translateY(-2px)}
.opt.sel{border-color:var(--azur);background:var(--accentcard);box-shadow:0 0 0 3px rgba(4,114,199,.12)}
.opt small{display:block;color:var(--grey);font-weight:500;margin-top:4px;font-size:12.5px}
.calc .field{display:flex;flex-direction:column;gap:10px}
.calc .field input[type=range]{width:100%;accent-color:var(--azur);min-height:44px}
.calc .field .val{font-size:38px;font-weight:800;color:var(--navy);font-variant-numeric:tabular-nums}
.calc-nav{display:flex;justify-content:space-between;margin-top:28px;gap:12px}
.calc .lnk{background:none;border:0;color:var(--grey);font-weight:600;cursor:pointer;font-size:14.5px;min-height:44px}
.calc .lnk:hover{color:var(--navy)}
.calc .result{text-align:center;display:none}
.calc .result.on{display:block;animation:qfade .6s}
.calc .result .corr{font-size:clamp(30px,5vw,52px);font-weight:800;color:var(--navy);font-variant-numeric:tabular-nums;letter-spacing:-.02em;margin:6px 0}
.calc .result .corr em{color:var(--azur);font-style:normal}
.calc .bar{position:relative;height:14px;border-radius:8px;background:linear-gradient(90deg,rgba(0,149,247,.28),rgba(4,114,199,.78),rgba(0,149,247,.28));max-width:480px;margin:22px auto 8px}
.calc .bar .mid{position:absolute;top:-6px;width:3px;height:26px;background:var(--navy);left:50%;border-radius:2px;box-shadow:0 0 0 4px rgba(14,28,54,.08)}
.calc .bar-lbl{display:flex;justify-content:space-between;max-width:480px;margin:0 auto;font-size:13px;color:var(--grey);font-variant-numeric:tabular-nums}
.calc .honest{margin:26px auto 0;max-width:540px;font-size:14.5px;color:#333333;background:var(--accentcard);border:1px solid #D6E6F7;border-radius:12px;padding:16px 20px;text-align:left}
.calc .honest b{color:var(--navy)}
.calc .disc{font-size:12.5px;color:var(--grey);margin-top:18px}

/* Regionen-Karte (Leaflet, Umzug auf lp-Seiten) */
.map-wrap{border-radius:var(--rcard);overflow:hidden;border:1px solid var(--bord);box-shadow:var(--shadow)}
.map-canvas{height:480px;width:100%;background:#e8edf3;z-index:1}
.map-legend{font-size:13.5px;color:var(--grey);margin-top:14px}
.map-legend b{color:var(--navy)}
.leaflet-popup-content{font-family:"Manrope",sans-serif}
.pop b{font-weight:800;color:var(--navy);font-size:16px}
.pop .v{font-size:22px;font-weight:800;color:var(--azur);margin:4px 0}
.pop small{color:var(--grey)}

/* Footer (H) */
footer{background:#0E1C36;color:#a7b5c5;padding:60px 0 44px;font-size:15px;position:relative}
footer::after{content:"";position:absolute;inset:0;background:url("pattern-giebel.svg") repeat;background-size:120px 84px;opacity:.04;pointer-events:none}
footer>*{position:relative;z-index:1}
.foot-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:30px;margin-bottom:30px}
footer .brand img{height:38px;width:auto;margin-bottom:12px}
footer h4{color:#fff;font-size:12.5px;letter-spacing:.08em;text-transform:uppercase;margin-bottom:13px}
footer .foot-grid a{display:block;margin-bottom:8px}
footer .foot-grid a:hover{color:#fff}
.claim{font-style:italic;color:#cdd8e3}
.foot-bottom{border-top:1px solid rgba(255,255,255,.12);padding-top:20px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:8px;font-size:13px;color:#8d9dae}
.mobilebar{display:none}

/* Reveals (IO-Basis; GSAP veredelt nur Hero/Rail) */
.reveal{opacity:0;transform:translateY(20px);transition:opacity .75s var(--ease),transform .75s var(--ease)}
.reveal.in{opacity:1;transform:none}
.d1{transition-delay:.08s}.d2{transition-delay:.16s}.d3{transition-delay:.24s}

@media(max-width:980px){
  .phero{padding-top:118px}
  .wege-grid{grid-template-columns:1fr}
  .split{grid-template-columns:1fr;gap:26px}
  .proz-grid{grid-template-columns:1fr}
  .proz-sticky{display:none}
  .pstep{padding-left:0}
  .pstep .rline,.pstep .rfill{display:none}
  .pstep .no{position:static;margin-bottom:14px}
  .pstep .pmob{display:block;border-radius:var(--rcard);overflow:hidden;margin-bottom:18px;aspect-ratio:16/10}
  .pstep .pmob img{width:100%;height:100%;object-fit:cover}
  .sold-grid,.rev-grid{grid-template-columns:1fr;max-width:460px;margin-left:auto;margin-right:auto}
  .team-grid{grid-template-columns:1fr;max-width:380px;margin:0 auto}
  .foot-grid{grid-template-columns:1fr 1fr}
  .map-canvas{height:380px}
}
@media(max-width:760px){
  .nav{display:none}
  .burger{display:inline-flex}
  .nav.open{display:flex;position:absolute;top:74px;left:0;right:0;flex-direction:column;align-items:stretch;background:var(--bg);padding:14px var(--gut) 22px;gap:2px;border-bottom:1px solid var(--hair);box-shadow:0 18px 40px -24px rgba(14,28,54,.4)}
  .nav.open a{padding:14px 2px;font-size:17px;border-bottom:1px solid var(--hair)}
  .nav.open a.btn{color:#fff;margin-top:10px;justify-content:center;border-bottom:0}
  .mobilebar{display:flex;position:fixed;left:0;right:0;bottom:0;z-index:120;gap:10px;padding:10px 14px calc(10px + env(safe-area-inset-bottom));background:rgba(255,255,255,.96);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-top:1px solid var(--hair);box-shadow:0 -8px 24px -16px rgba(14,28,54,.4)}
  .mobilebar a{flex:1;justify-content:center;padding:14px 10px;font-size:15.5px}
  footer{padding-bottom:104px}
  .foot-grid{grid-template-columns:1fr;gap:24px}
}
@media(prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  .thread{animation:none}
  .korridor .band{transform:none;transition:none}
  .proz-sticky .pim{transition:opacity .3s;transform:none}
  .sec-head::before,.faq-head::before,.pstep .rfill{transition:none}
  .calc .q,.calc .result{animation:none}
  .split .imgwrap img,.tm .ph img,.scard .m img,.wcard .wim img{transition:none}
}
