/* PV-Mont – Design uebernommen aus bevorzugter Version */
:root{
    --ink:#14202B;--ink-2:#1B2A38;--steel:#2C3E4E;--concrete:#ECEFF1;--paper:#FFFFFF;
    --line:#DBE0E3;--line-d:rgba(255,255,255,.12);--mute:#5C6B78;--mute-d:#9FB2C2;
    --hi:#F4A52A;--hi-deep:#E08A12;--r:14px;--maxw:1180px;
  }
  *{box-sizing:border-box;margin:0;padding:0}
  html{scroll-behavior:smooth}
  body{font-family:"IBM Plex Sans",system-ui,sans-serif;color:var(--ink);background:var(--paper);line-height:1.6;-webkit-font-smoothing:antialiased}
  h1,h2,h3{font-family:"Archivo",system-ui,sans-serif;line-height:1.04;letter-spacing:-.01em}
  a{color:inherit;text-decoration:none}
  .wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
  .mono{font-family:"IBM Plex Mono",monospace}
  .safetyline{height:4px;width:64px;background:var(--hi);position:relative;border-radius:2px}
  .safetyline::after{content:"";position:absolute;left:72px;top:0;height:4px;width:28px;border-radius:2px;background:repeating-linear-gradient(45deg,var(--hi) 0 5px,transparent 5px 10px)}
  .eyebrow{font-family:"IBM Plex Mono",monospace;font-size:12.5px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--hi-deep)}
  .eyebrow.on-dark{color:var(--hi)}
  header{position:sticky;top:0;z-index:50;background:rgba(20,32,43,.92);backdrop-filter:blur(8px);border-bottom:1px solid var(--line-d)}
  .nav{display:flex;align-items:center;justify-content:space-between;height:68px}
  .brand{display:flex;align-items:center;gap:11px;color:#fff}
  .brand .mark{width:30px;height:30px;border-radius:7px;background:var(--hi);position:relative;flex:none;display:grid;place-items:center}
  .brand .mark::before{content:"";width:13px;height:13px;border:3px solid var(--ink);border-radius:2px;transform:rotate(45deg)}
  .brand b{font-family:"Archivo";font-weight:800;font-size:19px;letter-spacing:.02em}
  .brand b span{color:var(--hi)}
  nav ul{display:flex;gap:28px;list-style:none}
  nav a{color:var(--mute-d);font-size:15px;font-weight:500;transition:color .2s}
  nav a:hover{color:#fff}
  .phone-btn{display:inline-flex;align-items:center;gap:8px;background:var(--hi);color:var(--ink);font-weight:600;font-size:15px;padding:10px 18px;border-radius:9px;transition:transform .15s,background .2s}
  .phone-btn:hover{background:#fff;transform:translateY(-1px)}
  .phone-btn svg{width:17px;height:17px}
  .hero{background:radial-gradient(1100px 500px at 78% -10%,rgba(244,165,42,.16),transparent 60%),linear-gradient(180deg,var(--ink) 0%,var(--ink-2) 100%);color:#fff;padding:74px 0 84px;overflow:hidden}
  .hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center}
  .hero h1{font-size:clamp(34px,5vw,56px);font-weight:900;margin:18px 0 0}
  .hero h1 em{font-style:normal;color:var(--hi)}
  .hero .sub{color:var(--mute-d);font-size:18px;max-width:32em;margin-top:20px}
  .hero-actions{display:flex;flex-wrap:wrap;gap:14px;margin-top:32px}
  .btn{display:inline-flex;align-items:center;gap:9px;font-weight:600;font-size:16px;padding:14px 24px;border-radius:10px;transition:transform .15s,background .2s,border-color .2s;cursor:pointer}
  .btn-primary{background:var(--hi);color:var(--ink)}
  .btn-primary:hover{background:#ffb742;transform:translateY(-2px)}
  .btn-ghost{border:1px solid var(--line-d);color:#fff}
  .btn-ghost:hover{border-color:var(--hi);color:var(--hi)}
  .photo-slot{position:relative;border-radius:var(--r);overflow:hidden;aspect-ratio:4/5;border:1px solid var(--line-d);background:#16242F}
  .photo-slot img{width:100%;height:100%;object-fit:cover;display:block}
  .spec-plate{position:absolute;left:16px;bottom:16px;background:rgba(20,32,43,.82);backdrop-filter:blur(4px);border:1px solid var(--line-d);border-left:3px solid var(--hi);border-radius:8px;padding:9px 13px}
  .spec-plate .mono{font-size:11.5px;letter-spacing:.08em;color:#fff;display:block}
  .spec-plate .mono.dim{color:var(--mute-d);margin-top:2px}
  .trust{background:var(--concrete);border-bottom:1px solid var(--line)}
  .trust-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:28px;padding:30px 0}
  .trust-item h4{font-family:"Archivo";font-weight:800;font-size:16px}
  .trust-item p{color:var(--mute);font-size:14px;margin-top:3px}
  .trust-item .ic{color:var(--hi-deep);margin-bottom:8px}
  .trust-item .ic svg{width:22px;height:22px}
  section{padding:84px 0}
  .sec-head{max-width:660px;margin-bottom:44px}
  .sec-head h2{font-size:clamp(28px,3.6vw,40px);font-weight:800;margin:16px 0 0}
  .sec-head p{color:var(--mute);font-size:17px;margin-top:14px}
  .cards{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
  .card{background:var(--paper);border:1px solid var(--line);border-radius:var(--r);padding:30px 26px;transition:transform .2s,box-shadow .2s,border-color .2s}
  .card:hover{transform:translateY(-4px);box-shadow:0 18px 40px -22px rgba(20,32,43,.4);border-color:#c7d0d6}
  .card .num{font-family:"IBM Plex Mono";font-size:13px;font-weight:600;color:var(--hi-deep)}
  .card h3{font-size:21px;font-weight:800;margin:14px 0 10px}
  .card p{color:var(--mute);font-size:15px}
  .card .more{display:inline-flex;align-items:center;gap:6px;margin-top:18px;font-weight:600;font-size:14.5px}
  .card .more::after{content:"->";color:var(--hi-deep);transition:transform .2s;font-family:"IBM Plex Mono"}
  .card:hover .more::after{transform:translateX(4px)}
  .partner{background:linear-gradient(180deg,var(--ink-2),var(--ink));color:#fff}
  .partner .sec-head h2{color:#fff}.partner .sec-head p{color:var(--mute-d)}
  .reasons{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line-d);border:1px solid var(--line-d);border-radius:var(--r);overflow:hidden}
  .reason{background:var(--ink);padding:30px 28px}
  .reason h4{font-family:"Archivo";font-weight:700;font-size:18px;display:flex;align-items:center;gap:11px}
  .reason h4::before{content:"";width:9px;height:9px;background:var(--hi);border-radius:2px;flex:none;transform:rotate(45deg)}
  .reason p{color:var(--mute-d);font-size:15px;margin-top:11px;padding-left:20px}
  .ref-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
  .ref{border-radius:var(--r);overflow:hidden;position:relative;aspect-ratio:3/4;border:1px solid var(--line);display:flex;align-items:flex-end;transition:transform .2s}
  .ref:hover{transform:translateY(-4px)}
  .ref img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
  .ref .plate{position:relative;z-index:1;width:100%;background:linear-gradient(180deg,transparent,rgba(20,32,43,.92));padding:42px 16px 15px;border-bottom:3px solid var(--hi)}
  .ref .plate .t{color:#fff;font-family:"Archivo";font-weight:700;font-size:15px}
  .ref .plate .d{font-family:"IBM Plex Mono";font-size:12px;color:var(--hi);letter-spacing:.05em;margin-top:4px}
  .refnote{color:var(--mute);font-size:13.5px;margin-top:20px}
  .contact{background:var(--concrete)}
  .contact-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:48px;align-items:center}
  .contact h2{font-size:clamp(28px,3.6vw,40px);font-weight:800;margin:16px 0 0}
  .contact p.lead{color:var(--mute);font-size:17px;margin-top:14px;max-width:30em}
  .contact-actions{display:flex;flex-wrap:wrap;gap:14px;margin-top:28px}
  .contact-card{background:var(--ink);color:#fff;border-radius:var(--r);padding:34px 32px;border-left:4px solid var(--hi)}
  .contact-card .row{display:flex;align-items:flex-start;gap:14px;padding:14px 0;border-bottom:1px solid var(--line-d)}
  .contact-card .row:last-child{border-bottom:0}
  .contact-card .row svg{width:20px;height:20px;color:var(--hi);flex:none;margin-top:3px}
  .contact-card .row .k{font-family:"IBM Plex Mono";font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--mute-d)}
  .contact-card .row .v{font-size:16px;font-weight:500;margin-top:2px}
  .placeholder-pill{display:inline-block;font-family:"IBM Plex Mono";font-size:11px;background:rgba(244,165,42,.16);color:var(--hi);border:1px dashed rgba(244,165,42,.5);border-radius:6px;padding:2px 7px;margin-left:6px}
  footer{background:var(--ink);color:var(--mute-d);padding:54px 0 30px}
  .foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:32px;padding-bottom:34px;border-bottom:1px solid var(--line-d)}
  footer .brand b{color:#fff}
  footer h5{font-family:"IBM Plex Mono";font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--mute-d);margin-bottom:14px}
  footer a{display:block;color:#cdd8df;font-size:14.5px;padding:4px 0;transition:color .2s}
  footer a:hover{color:var(--hi)}
  .foot-bottom{display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;padding-top:22px;font-size:13px}
  .foot-addr{color:#cdd8df;font-size:14.5px;margin-top:12px;line-height:1.7}
  .reveal{opacity:0;transform:translateY(18px);transition:opacity .6s ease,transform .6s ease}
  .reveal.in{opacity:1;transform:none}
  :focus-visible{outline:3px solid var(--hi);outline-offset:3px;border-radius:4px}
  @media (prefers-reduced-motion:reduce){*{transition:none!important;animation:none!important}.reveal{opacity:1;transform:none}}
  @media(max-width:920px){
    .hero-grid,.contact-grid{grid-template-columns:1fr;gap:36px}
    .cards{grid-template-columns:1fr 1fr}.ref-grid{grid-template-columns:1fr 1fr}
    .trust-grid{grid-template-columns:1fr 1fr;gap:22px}.reasons{grid-template-columns:1fr}
    .foot-grid{grid-template-columns:1fr 1fr}nav ul{display:none}
    .photo-slot{aspect-ratio:16/11}
  }
  @media(max-width:560px){.cards,.ref-grid{grid-template-columns:1fr}.hero{padding:54px 0 60px}section{padding:60px 0}.nav-cta .label{display:none}}

/* === Additional: Referenzen + Features === */
.frow{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;margin-bottom:64px}
.frow:last-child{margin-bottom:0}
.frow .media{border-radius:var(--r);overflow:hidden;aspect-ratio:4/3;border:1px solid var(--line);position:relative}
.frow .media img{width:100%;height:100%;object-fit:cover}
.frow.rev .txt{order:2}.frow.rev .media{order:1}
.frow h3{font-size:26px;font-weight:800;margin:14px 0 12px}
.frow p{color:var(--mute);font-size:16px}
.ulist{list-style:none;margin-top:18px}
.ulist li{position:relative;padding-left:30px;margin:10px 0;color:var(--ink);font-size:15.5px}
.ulist li::before{content:"";position:absolute;left:0;top:7px;width:14px;height:14px;background:var(--hi);border-radius:3px;transform:rotate(45deg)}
.gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.gtile{border-radius:var(--r);overflow:hidden;position:relative;aspect-ratio:3/4;border:1px solid var(--line);display:flex;align-items:flex-end;transition:transform .2s}
.gtile:hover{transform:translateY(-4px)}
.gtile img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.gtile .plate{position:relative;left:0;bottom:0;width:100%;border-left:0;border-radius:0;background:linear-gradient(180deg,transparent,rgba(20,32,43,.92));padding:40px 14px 13px;border-bottom:3px solid var(--hi)}
.gtile .plate .t{color:#fff;font-family:"Archivo";font-weight:700;font-size:14px}
.gtile .plate .d{font-family:"IBM Plex Mono";font-size:11px;color:var(--hi);letter-spacing:.05em;margin-top:3px}
.tags{display:flex;flex-wrap:wrap;gap:10px;margin-top:30px}
.tag{font-family:"IBM Plex Mono";font-size:12px;letter-spacing:.05em;background:var(--concrete);border:1px solid var(--line);border-radius:999px;padding:7px 14px;color:var(--ink)}
.note{color:var(--mute);font-size:13.5px;margin-top:22px}
.ctaband{background:linear-gradient(120deg,var(--ink),var(--ink-2));color:#fff;border-radius:18px;padding:48px 44px;display:flex;align-items:center;justify-content:space-between;gap:32px;flex-wrap:wrap}
.ctaband h3{font-size:clamp(24px,3vw,32px);font-weight:800;max-width:18em}
.ctaband p{color:var(--mute-d);margin-top:8px}
.btn-dark{border:1px solid var(--line);color:var(--ink)}
.btn-dark:hover{border-color:var(--hi-deep);color:var(--hi-deep)}
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.step{background:var(--paper);border:1px solid var(--line);border-radius:var(--r);padding:26px 22px}
.step .n{font-family:"IBM Plex Mono";font-weight:600;color:var(--hi-deep);font-size:13px}
.step h4{font-family:"Archivo";font-size:18px;font-weight:700;margin:8px 0 8px}
.step p{color:var(--mute);font-size:14.5px}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:32px;padding-bottom:34px;border-bottom:1px solid var(--line-d)}
footer h5{font-family:"IBM Plex Mono";font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--mute-d);margin-bottom:14px}
footer a{display:block;color:#cdd8df;font-size:14.5px;padding:4px 0;transition:color .2s}
footer a:hover{color:var(--hi)}
.foot-addr{color:#cdd8df;font-size:14.5px;margin-top:12px;line-height:1.7}
.foot-bottom{display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;padding-top:22px;font-size:13px}
.plate{position:absolute;left:14px;bottom:14px;background:rgba(20,32,43,.82);border-left:3px solid var(--hi);border-radius:8px;padding:7px 11px}
.plate .mono{font-size:11px;letter-spacing:.07em;color:#fff;display:block}
.plate .mono.dim{color:var(--mute-d)}
.pagehero{background:linear-gradient(180deg,var(--ink),var(--ink-2));color:#fff;padding:54px 0 58px}
.crumb{font-family:"IBM Plex Mono";font-size:12px;letter-spacing:.06em;color:var(--mute-d);margin-bottom:16px}
.crumb a:hover{color:var(--hi)}
.pagehero h1{font-size:clamp(30px,4.4vw,46px);font-weight:900;margin-top:14px}
.pagehero p{color:var(--mute-d);font-size:18px;max-width:40em;margin-top:14px}
/* Reinigungsrechner */

:root{--ink:#14202B;--ink-2:#1B2A38;--concrete:#ECEFF1;--paper:#FFFFFF;--line:#DBE0E3;--line-d:rgba(255,255,255,.12);
--mute:#5C6B78;--mute-d:#9FB2C2;--hi:#F4A52A;--hi-deep:#E08A12;--green:#2BA36B;--red:#D9534F;--r:14px;--maxw:1180px;}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:"IBM Plex Sans",system-ui,sans-serif;color:var(--ink);background:var(--paper);line-height:1.6;-webkit-font-smoothing:antialiased}
h1,h2,h3{font-family:"Archivo",system-ui,sans-serif;line-height:1.06;letter-spacing:-.01em}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.mono{font-family:"IBM Plex Mono",monospace}
.safetyline{height:4px;width:64px;background:var(--hi);position:relative;border-radius:2px}
.safetyline::after{content:"";position:absolute;left:72px;top:0;height:4px;width:28px;border-radius:2px;background:repeating-linear-gradient(45deg,var(--hi) 0 5px,transparent 5px 10px)}
.eyebrow{font-family:"IBM Plex Mono",monospace;font-size:12.5px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--hi)}
header{position:sticky;top:0;z-index:50;background:rgba(20,32,43,.92);backdrop-filter:blur(8px);border-bottom:1px solid var(--line-d)}
.nav{display:flex;align-items:center;justify-content:space-between;height:68px}
.brand{display:flex;align-items:center;gap:11px;color:#fff}
.brand .mark{width:30px;height:30px;border-radius:7px;background:var(--hi);position:relative;flex:none;display:grid;place-items:center}
.brand .mark::before{content:"";width:13px;height:13px;border:3px solid var(--ink);border-radius:2px;transform:rotate(45deg)}
.brand b{font-family:"Archivo";font-weight:800;font-size:19px}
.brand b span{color:var(--hi)}
nav ul{display:flex;gap:26px;list-style:none}
nav a{color:var(--mute-d);font-size:15px;font-weight:500;transition:color .2s}
nav a:hover{color:#fff}
.phone-btn{display:inline-flex;align-items:center;gap:8px;background:var(--hi);color:var(--ink);font-weight:600;font-size:15px;padding:10px 18px;border-radius:9px}
.phone-btn svg{width:17px;height:17px}
.pagehero{background:linear-gradient(180deg,var(--ink),var(--ink-2));color:#fff;padding:50px 0 54px}
.crumb{font-family:"IBM Plex Mono";font-size:12px;letter-spacing:.06em;color:var(--mute-d);margin-bottom:16px}
.crumb a:hover{color:var(--hi)}
.pagehero h1{font-size:clamp(30px,4.4vw,46px);font-weight:900;margin-top:14px}
.pagehero p{color:var(--mute-d);font-size:18px;max-width:42em;margin-top:14px}
.calcwrap{display:grid;grid-template-columns:1.15fr .85fr;gap:28px;margin-top:-34px;position:relative;z-index:5;padding-bottom:18px}
.panel{background:var(--paper);border:1px solid var(--line);border-radius:18px;padding:26px;box-shadow:0 24px 60px -34px rgba(20,32,43,.45)}
.result{background:linear-gradient(165deg,var(--ink),var(--ink-2));color:#fff;border:1px solid var(--ink-2);position:sticky;top:88px;align-self:start}
.modes{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:22px}
.mode{border:1.5px solid var(--line);border-radius:12px;padding:14px 16px;cursor:pointer;transition:.18s;background:var(--paper)}
.mode:hover{border-color:#c2ccd2}
.mode.on{border-color:var(--hi-deep);background:rgba(244,165,42,.08)}
.mode .t{font-family:"Archivo";font-weight:800;font-size:16px;display:flex;align-items:center;gap:8px}
.mode .t .dot{width:10px;height:10px;border-radius:3px;background:var(--line);transform:rotate(45deg)}
.mode.on .t .dot{background:var(--hi-deep)}
.mode .d{font-size:12.5px;color:var(--mute);margin-top:4px}
.field{margin:18px 0}
.field>label{font-weight:600;font-size:15px;display:flex;justify-content:space-between;align-items:baseline;gap:10px}
.field .hint{font-size:12.5px;color:var(--mute);font-weight:400;margin-top:3px}
.val{font-family:"IBM Plex Mono";font-weight:600;color:var(--hi-deep);font-size:15px}
input[type=range]{width:100%;margin-top:12px;accent-color:var(--hi-deep);height:6px}
.num{width:100%;margin-top:8px;padding:11px 13px;border:1.5px solid var(--line);border-radius:10px;font-family:"IBM Plex Mono";font-size:15px;color:var(--ink)}
.num:focus{outline:none;border-color:var(--hi-deep)}
.seg{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}
.seg button{flex:1 1 auto;min-width:80px;border:1.5px solid var(--line);background:var(--paper);border-radius:10px;padding:10px 8px;font:inherit;font-size:13.5px;font-weight:600;color:var(--mute);cursor:pointer;transition:.15s}
.seg button:hover{border-color:#c2ccd2}
.seg button.on{border-color:var(--hi-deep);background:rgba(244,165,42,.10);color:var(--ink)}
select.num{font-family:"IBM Plex Sans";cursor:pointer}
.derived{margin-top:10px;font-family:"IBM Plex Mono";font-size:12.5px;color:var(--hi-deep);background:rgba(244,165,42,.08);border:1px dashed rgba(244,165,42,.5);border-radius:9px;padding:8px 12px}
/* roof types */
.rooftypes{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:10px}
.rooftype{border:1.5px solid var(--line);border-radius:12px;padding:12px 10px 11px;cursor:pointer;text-align:center;transition:.15s;background:var(--paper)}
.rooftype:hover{border-color:#c2ccd2}
.rooftype.on{border-color:var(--hi-deep);background:rgba(244,165,42,.08)}
.rooftype svg{width:100%;height:46px;display:block;margin-bottom:6px}
.rooftype .rt{font-family:"Archivo";font-weight:700;font-size:13.5px;line-height:1.15}
.rooftype .ra{font-family:"IBM Plex Mono";font-size:11px;color:var(--mute);margin-top:2px}
.rooftype.on .ra{color:var(--hi-deep)}
.infonote{display:flex;gap:10px;background:rgba(217,83,79,.07);border:1px solid rgba(217,83,79,.25);border-radius:10px;padding:11px 13px;margin-top:12px;font-size:12.5px;color:#7a3b39}
.infonote svg{width:18px;height:18px;flex:none;color:var(--red);margin-top:1px}
.pricenote{font-size:12px;color:var(--mute);margin-top:8px;line-height:1.5}
.advtitle{font-family:"IBM Plex Mono";font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--mute);margin:24px 0 2px}
.two{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.hide{display:none!important}
.result .eyebrow{color:var(--hi)}
.bignum{font-family:"Archivo";font-weight:900;font-size:44px;line-height:1;margin:6px 0 2px}
.bignum.green{color:#54d39b}
.subnum{color:var(--mute-d);font-size:14px}
.bar{height:14px;border-radius:8px;background:rgba(255,255,255,.14);overflow:hidden;margin:22px 0 8px;display:flex}
.bar .lost{background:var(--hi);height:100%}
.barleg{display:flex;justify-content:space-between;font-size:12px;color:var(--mute-d)}
.payback{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:18px;padding:14px 16px;border-radius:12px;background:rgba(255,255,255,.05);border:1px solid var(--line-d)}
.payback .pl{font-size:13px;color:var(--mute-d)}
.payback .pv{font-family:"Archivo";font-weight:800;font-size:24px}
.payback .pv.green{color:#54d39b}.payback .pv.amber{color:var(--hi)}.payback .pv.grey{color:var(--mute-d)}
.rrow{display:flex;justify-content:space-between;align-items:baseline;padding:11px 0;border-bottom:1px solid var(--line-d);gap:14px}
.rrow:last-of-type{border-bottom:0}
.rrow .k{color:var(--mute-d);font-size:14px}
.rrow .k small{display:block;color:#7d8c98;font-size:11.5px;font-family:"IBM Plex Mono"}
.rrow .v{font-family:"IBM Plex Mono";font-weight:600;font-size:16px;text-align:right;white-space:nowrap}
.verdict{border-radius:12px;padding:16px 18px;margin-top:16px;font-size:14.5px;border-left:4px solid}
.verdict.green{background:rgba(43,163,107,.16);border-color:#54d39b}
.verdict.amber{background:rgba(244,165,42,.16);border-color:var(--hi)}
.verdict.grey{background:rgba(159,178,194,.14);border-color:var(--mute-d)}
.verdict b{font-family:"Archivo"}
.cta{display:inline-flex;align-items:center;gap:9px;background:var(--hi);color:var(--ink);font-weight:600;padding:13px 22px;border-radius:10px;margin-top:18px;font-size:15px}
.disc{font-size:12px;color:var(--mute-d);margin-top:14px;line-height:1.5}
/* 3-year plan */
.plan{background:var(--concrete);padding:54px 0}
.plan .eyebrow{color:var(--hi-deep)}
.plan h2{font-size:clamp(24px,3vw,34px);font-weight:800;margin:14px 0 6px}
.planHead{display:inline-flex;align-items:center;gap:10px;background:var(--ink);color:#fff;border-radius:999px;padding:10px 20px;font-family:"Archivo";font-weight:700;font-size:16px;margin:6px 0 8px}
.planHead .dot{width:11px;height:11px;border-radius:3px;background:var(--hi);transform:rotate(45deg)}
.planlead{color:var(--mute);font-size:15.5px;max-width:62ch;margin-bottom:24px}
.plangrid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.planyear{background:var(--paper);border:1px solid var(--line);border-radius:var(--r);padding:22px;position:relative;overflow:hidden}
.planyear::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--line)}
.planyear.clean::before{background:var(--green)}
.planyear.check::before{background:var(--mute-d)}
.planyear .py{font-family:"IBM Plex Mono";font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--mute)}
.planyear .pmeas{display:flex;align-items:center;gap:9px;font-family:"Archivo";font-weight:800;font-size:18px;margin:8px 0 6px}
.planyear .pmeas .pic{width:30px;height:30px;border-radius:8px;display:grid;place-items:center;flex:none}
.planyear.clean .pic{background:rgba(43,163,107,.14);color:var(--green)}
.planyear.check .pic{background:rgba(159,178,194,.18);color:var(--mute)}
.planyear .pic svg{width:18px;height:18px}
.planyear .pdesc{font-size:13.5px;color:var(--mute);min-height:38px}
.planyear .pnet{font-family:"IBM Plex Mono";font-weight:600;font-size:16px;margin-top:8px}
.planyear .pnet.pos{color:var(--green)}
.plansum{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:18px;margin-top:20px;background:var(--ink);color:#fff;border-radius:16px;padding:24px 28px;border-left:4px solid var(--hi)}
.plansum .big{font-family:"Archivo";font-weight:900;font-size:30px}
.plansum .big.pos{color:#54d39b}
.plansum .txt{font-size:14px;color:var(--mude-d);color:var(--mute-d);max-width:52ch}
.plansum .txt b{color:#fff}
.plansum .cta{margin-top:0}
.combo{display:flex;gap:14px;align-items:flex-start;background:var(--paper);border:1px solid var(--line);border-left:4px solid var(--hi);border-radius:14px;padding:18px 20px;margin-top:18px}
.combo .ci{width:38px;height:38px;border-radius:10px;flex:none;display:grid;place-items:center;background:rgba(244,165,42,.14);color:var(--hi-deep)}
.combo .ci svg{width:20px;height:20px}
.combo .ct{font-size:14.5px;color:#36444f}
.combo .ct b{color:var(--ink)}
/* why */
.why{padding:54px 0 10px}
.why h2{font-size:clamp(24px,3vw,32px);font-weight:800;margin:14px 0 6px}
.why .lead{color:var(--mute);font-size:16px;max-width:60ch;margin-bottom:26px}
.whygrid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.whycard{background:var(--paper);border:1px solid var(--line);border-radius:var(--r);padding:24px 22px}
.whycard .ic{width:42px;height:42px;border-radius:11px;display:grid;place-items:center;background:rgba(244,165,42,.12);color:var(--hi-deep);margin-bottom:14px}
.whycard.warn .ic{background:rgba(217,83,79,.12);color:var(--red)}
.whycard .ic svg{width:22px;height:22px}
.whycard h3{font-size:18px;font-weight:800;margin-bottom:8px}
.whycard p{color:var(--mute);font-size:14px}
.whycard .big{font-family:"Archivo";font-weight:900;font-size:30px;color:var(--ink);line-height:1}
.source{font-size:12px;color:var(--mute);margin-top:18px}
.source a{color:var(--hi-deep)}
details.explain{margin:34px auto 60px;max-width:var(--maxw)}
details.explain summary{cursor:pointer;font-weight:600;color:var(--hi-deep);font-size:15px;list-style:none;display:inline-flex;align-items:center;gap:8px}
details.explain summary::before{content:"+";font-family:"IBM Plex Mono";color:var(--hi-deep)}
details.explain[open] summary::before{content:"\2013"}
details.explain .box{border:1px solid var(--line);border-radius:14px;padding:22px 24px;margin-top:14px;background:var(--concrete)}
details.explain h4{font-family:"Archivo";margin:14px 0 8px}
details.explain ol{margin-left:20px;color:#36444f;font-size:15px}
details.explain li{margin:7px 0}
.tariff{width:100%;border-collapse:collapse;margin-top:8px;font-size:14px}
.tariff th,.tariff td{text-align:left;padding:8px 10px;border-bottom:1px solid var(--line)}
.tariff th{font-family:"IBM Plex Mono";font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--mute)}
.tariff td.p{font-family:"IBM Plex Mono";font-weight:600;color:var(--ink)}
footer{background:var(--ink);color:var(--mute-d);padding:46px 0 28px}
.foot-bottom{display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-size:13px;border-top:1px solid var(--line-d);padding-top:20px}
footer a{color:#cdd8df}footer a:hover{color:var(--hi)}
.footlinks a{margin-right:16px}
:focus-visible{outline:3px solid var(--hi);outline-offset:2px;border-radius:6px}
@media(max-width:920px){.calcwrap{grid-template-columns:1fr;margin-top:-20px}.result{position:static}nav ul{display:none}.whygrid{grid-template-columns:1fr 1fr}.plangrid{grid-template-columns:1fr}}
@media(max-width:560px){.two{grid-template-columns:1fr}.bignum{font-size:36px}.whygrid{grid-template-columns:1fr}}

/* Router */
.page{ display:block }
.page.active{ display:block }
nav a.active{color:#fff;border-bottom:2px solid var(--hi);padding-bottom:4px}
/* Responsive extras */
@media(max-width:920px){
  .gallery{grid-template-columns:1fr 1fr}
  .steps{grid-template-columns:1fr 1fr}
  .foot-grid{grid-template-columns:1fr 1fr}
  .frow{grid-template-columns:1fr;gap:24px;margin-bottom:48px}
  .frow.rev .txt{order:1}.frow.rev .media{order:2}
}
@media(max-width:560px){
  .gallery,.steps{grid-template-columns:1fr}
  .ctaband{padding:34px 26px}
}

/* === Ergänzungen: Mobile-Menü + Foto-Platzhalter === */
.burger{display:none;background:none;border:0;color:#fff;cursor:pointer;padding:6px;margin-left:4px}
.burger svg{width:26px;height:26px}
.nav-right{display:flex;align-items:center;gap:14px}
.phimg{position:absolute;inset:0;width:100%;height:100%;display:flex;align-items:center;justify-content:center;
  text-align:center;padding:16px;background:linear-gradient(135deg,#1B2A38,#16242F);color:#9FB2C2;
  font-family:"IBM Plex Mono",monospace;font-size:11.5px;letter-spacing:.05em;line-height:1.5}
.photo-slot .phimg{font-size:12.5px}
.legal{max-width:820px}
.legal h2{font-family:"Archivo";font-size:22px;font-weight:800;margin:30px 0 10px}
.legal h3{font-family:"Archivo";font-size:17px;font-weight:700;margin:22px 0 8px}
.legal p,.legal li{color:#36444f;font-size:15.5px;margin-bottom:10px}
.legal ul,.legal ol{margin-left:20px}
.dl{display:grid;grid-template-columns:auto 1fr;gap:8px 22px;margin:14px 0}
.dl dt{font-weight:600;color:var(--ink)}
.dl dd{margin:0;color:#36444f}
.flag{display:inline-block;font-family:"IBM Plex Mono";font-size:11px;background:rgba(244,165,42,.16);
  color:var(--hi-deep);border:1px dashed rgba(244,165,42,.55);border-radius:6px;padding:2px 7px;margin-left:4px}
.notice{background:rgba(244,165,42,.10);border-left:4px solid var(--hi);border-radius:0 10px 10px 0;padding:14px 18px;margin:18px 0;font-size:14.5px;color:#5a4a23}
.field-f{margin-bottom:16px}
.field-f label{display:block;font-weight:600;font-size:14.5px;margin-bottom:6px}
.field-f input,.field-f select,.field-f textarea{width:100%;padding:12px 13px;border:1.5px solid var(--line);border-radius:10px;font:inherit;font-size:15px;color:var(--ink);background:#fff}
.field-f input:focus,.field-f select:focus,.field-f textarea:focus{outline:none;border-color:var(--hi-deep)}
.f2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.formcard{background:#fff;border:1px solid var(--line);border-radius:18px;padding:28px;box-shadow:0 24px 60px -34px rgba(20,32,43,.45)}
@media(max-width:920px){
  .burger{display:block}
  nav ul.open{display:flex;position:absolute;top:68px;left:0;right:0;flex-direction:column;
    background:rgba(20,32,43,.98);padding:18px 24px;gap:18px;border-bottom:1px solid var(--line-d);z-index:60}
  nav ul.open a{color:#fff}
}
@media(max-width:560px){.f2{grid-template-columns:1fr}}

/* === "Auf einen Blick"-Übersicht direkt unter dem Header === */
.overview{background:var(--paper);border-bottom:1px solid var(--line)}
.overview .wrap{padding-top:24px;padding-bottom:24px}
.ov-head{margin-bottom:16px}
.ov-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.ov-item{display:flex;align-items:center;gap:13px;padding:15px 17px;border:1px solid var(--line);border-radius:var(--r);background:#fff;transition:transform .15s,border-color .2s,box-shadow .2s}
.ov-item:hover{transform:translateY(-3px);border-color:#c7d0d6;box-shadow:0 14px 30px -20px rgba(20,32,43,.45)}
.ov-ic{width:42px;height:42px;border-radius:11px;background:rgba(244,165,42,.12);color:var(--hi-deep);display:grid;place-items:center;flex:none}
.ov-ic svg{width:22px;height:22px}
.ov-item b{font-family:"Archivo";font-weight:800;font-size:15.5px;display:block;color:var(--ink);line-height:1.15}
.ov-item span{font-size:12.5px;color:var(--mute);display:block;margin-top:3px;line-height:1.3}
@media(max-width:920px){.ov-grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.ov-grid{grid-template-columns:1fr}}

/* === Foto in Leistungs-Kacheln === */
.card .card-img{display:block;width:100%;height:160px;object-fit:cover;border-radius:11px;margin-bottom:18px;border:1px solid var(--line)}

/* === Artikel-Titelbild (Wissensbibliothek) === */
.article-hero{display:block;width:100%;height:340px;object-fit:cover;border-radius:14px;margin:0 0 26px;border:1px solid var(--line)}
@media(max-width:640px){.article-hero{height:220px}}

/* === Header-CTAs (stärker sichtbar) === */
.phone-btn2{display:inline-flex;align-items:center;gap:8px;background:rgba(244,165,42,.14);border:1px solid var(--hi);color:#fff;font-weight:700;font-size:14.5px;padding:9px 15px;border-radius:9px;transition:.18s}
.phone-btn2 svg{width:16px;height:16px;color:var(--hi)}
.phone-btn2:hover{background:var(--hi);border-color:var(--hi);color:var(--ink);text-decoration:none}.phone-btn2:hover svg{color:var(--ink)}
.cta-head{background:var(--hi);color:var(--ink);font-weight:700;font-size:14.5px;padding:10px 18px;border-radius:9px;transition:.18s;white-space:nowrap}
.cta-head:hover{background:#fff;transform:translateY(-1px);text-decoration:none}
@media(max-width:760px){ .phone-btn2 span{display:none} }
@media(max-width:480px){ .phone-btn2{display:none} }

.combo .ct a{color:var(--hi-deep);font-weight:700;text-decoration:none}.combo .ct a:hover{color:var(--hi);text-decoration:underline}
.disclaimer{background:#FBFAF7;border:1px solid var(--line);border-left:4px solid var(--hi);border-radius:12px;padding:14px 18px;margin:16px 0;font-size:13px;color:var(--mute);line-height:1.55}.disclaimer b{color:var(--ink)}.disclaimer a{color:var(--hi-deep);font-weight:600}

.form-card{background:#fff;border:1px solid var(--line);border-radius:16px;padding:30px 28px;box-shadow:0 26px 60px -34px rgba(20,32,43,.42)}.form-card .form-head{font-family:'Archivo',sans-serif;font-weight:800;font-size:20px;color:var(--ink);margin-bottom:3px}.form-card .form-sub{font-size:13.5px;color:var(--mute);margin-bottom:22px;line-height:1.5}.anfrage-form{display:flex;flex-direction:column;gap:16px}.anfrage-form label{display:flex;flex-direction:column;gap:7px;font-family:'IBM Plex Mono',monospace;font-size:11px;font-weight:600;letter-spacing:.09em;text-transform:uppercase;color:var(--mute)}.anfrage-form input,.anfrage-form select,.anfrage-form textarea{font-family:'IBM Plex Sans',system-ui,sans-serif;font-weight:400;font-size:15px;letter-spacing:0;text-transform:none;color:var(--ink);padding:12px 14px;border:1px solid var(--line);border-radius:10px;background:var(--concrete);width:100%;transition:border-color .18s,box-shadow .18s,background .18s}.anfrage-form input::placeholder,.anfrage-form textarea::placeholder{color:#9aa7b1}.anfrage-form select{appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%235C6B78' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 13px center;padding-right:38px}.anfrage-form input:focus,.anfrage-form select:focus,.anfrage-form textarea:focus{outline:none;background:#fff;border-color:var(--hi);box-shadow:0 0 0 3px rgba(244,165,42,.18)}.anfrage-form textarea{resize:vertical;min-height:112px}.anfrage-form .fg2{display:grid;grid-template-columns:1fr 1fr;gap:16px}.anfrage-form .hp{position:absolute!important;left:-9999px!important;width:1px;height:1px;overflow:hidden}.anfrage-form button{margin-top:4px;width:100%;justify-content:center;font-size:16px;font-weight:700;padding:15px 26px;border:none;border-radius:10px;cursor:pointer}.anfrage-form .formnote{font-family:'IBM Plex Sans',sans-serif;font-size:12px;letter-spacing:0;text-transform:none;font-weight:400;color:var(--mute);line-height:1.55;margin-top:2px}.anfrage-form .formnote a{color:var(--hi-deep);font-weight:600}@media(max-width:640px){.anfrage-form .fg2{grid-template-columns:1fr}.form-card{padding:24px 20px}}
