@font-face{
  font-family:"Inter";
  src:url("fonts/inter-latin-wght-normal.woff2") format("woff2");
  font-weight:100 900;
  font-style:normal;
  font-display:swap;
  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;
}
:root{
  --cream:#f6f3ec;
  --cream-deep:#efeadf;
  --ink:#171511;
  --ink-soft:#5f5a4f;
  --line:#dfd9cb;
  --dark:#171511;
  --dark-text:#cfc9bb;
  --max:1120px;
  --serif:"Georgia","Times New Roman",serif;
  --sans:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;
  --green:#3c6b4f;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--sans);color:var(--ink);background:var(--cream);line-height:1.7;font-size:17px;font-variant-ligatures:none;font-feature-settings:"liga" 0,"clig" 0,"dlig" 0,"hlig" 0,"calt" 0}
.wrap{max-width:var(--max);margin:0 auto;padding:0 28px}
h1,h2,h3{font-family:var(--serif);font-weight:400;letter-spacing:-.01em;font-variant-ligatures:none;font-feature-settings:"liga" 0,"clig" 0,"dlig" 0,"hlig" 0,"calt" 0}
a:focus-visible,button:focus-visible,summary:focus-visible{outline:2px solid var(--green);outline-offset:3px;border-radius:3px}
main:focus{outline:none}
.skip-link{position:absolute;left:-9999px;top:10px;z-index:100;background:var(--ink);color:var(--cream);padding:10px 18px;border-radius:8px;text-decoration:none;font-size:.95rem}
.skip-link:focus{left:10px}
header{position:sticky;top:0;background:rgba(246,243,236,.92);backdrop-filter:blur(8px);z-index:10;border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:72px}
.logo{font-family:var(--serif);font-size:1.3rem;color:var(--ink);text-decoration:none;letter-spacing:.01em}
nav{display:flex;align-items:center}
nav a{color:var(--ink-soft);text-decoration:none;margin-left:30px;font-size:.95rem}
nav a:hover{color:var(--ink)}
nav .cta{color:var(--cream);background:var(--ink);padding:10px 22px;border-radius:999px;font-size:.92rem}
nav .cta:hover{background:#000;color:var(--cream)}
.nav-toggle{display:none;background:none;border:0;cursor:pointer;color:var(--ink);padding:6px;line-height:0}
.nav-toggle svg{width:26px;height:26px}
@media(max-width:720px){
  .nav-toggle{display:inline-flex}
  nav{position:fixed;top:72px;left:0;right:0;z-index:9;flex-direction:column;align-items:stretch;background:rgba(246,243,236,.98);backdrop-filter:blur(8px);border-bottom:1px solid var(--line);padding:8px 0 16px;display:none;max-height:calc(100vh - 72px);overflow:auto}
  nav.open{display:flex}
  nav a{margin:0;padding:14px 28px;font-size:1.05rem}
  nav .cta{margin:12px 28px 0;text-align:center;padding:14px 22px}
}
.hero{text-align:left}
.hero h1{font-size:clamp(2.4rem,6.5vw,4.4rem);line-height:1.12;max-width:850px}
.hero p.lead{margin-top:30px;max-width:640px;font-size:1.18rem;color:var(--ink-soft)}
.hero .actions{margin-top:42px;display:flex;gap:14px;flex-wrap:wrap}
.btn{display:inline-block;padding:15px 34px;border-radius:999px;text-decoration:none;font-weight:600;font-size:1rem;font-family:var(--sans)}
.btn-primary{background:var(--ink);color:var(--cream)}
.btn-primary:hover{background:#000}
.btn-ghost{border:1.5px solid var(--ink);color:var(--ink)}
.btn-ghost:hover{background:var(--ink);color:var(--cream)}
.kicker{font-size:.82rem;text-transform:uppercase;letter-spacing:.14em;color:var(--ink-soft);margin-bottom:18px;font-family:var(--sans)}
section h2{font-size:clamp(1.9rem,4.5vw,3rem);line-height:1.14;max-width:760px}
section h2 .alt-line{display:block;color:var(--ink-soft)}
section p.sub{color:var(--ink-soft);max-width:620px;margin-top:22px;font-size:1.08rem}
.services{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:26px;margin-top:56px}
.service{background:var(--cream-deep);border:1px solid var(--line);border-radius:18px;padding:42px 36px;display:flex;flex-direction:column}
.service h3{font-size:1.55rem;margin-bottom:14px}
.service p{color:var(--ink-soft);font-size:1rem}
.service ul{margin:20px 0 28px;list-style:none}
.service li{padding:9px 0;border-bottom:1px solid var(--line);color:var(--ink-soft);font-size:.95rem}
.service li:last-child{border-bottom:none}
.service a{margin-top:auto;color:var(--ink);font-weight:600;text-decoration:none;font-size:.95rem}
.service a:hover{text-decoration:underline}
.faq-list{margin-top:48px;max-width:820px}
details{border-bottom:1px solid var(--line)}
summary{cursor:pointer;padding:24px 4px;font-weight:600;list-style:none;display:flex;justify-content:space-between;align-items:center;font-size:1.05rem;font-family:var(--sans)}
summary::-webkit-details-marker{display:none}
summary::after{content:"+";font-family:var(--serif);font-size:1.5rem;color:var(--ink-soft);font-weight:400;margin-left:20px;flex-shrink:0}
details[open] summary::after{content:"–"}
details .a{padding:0 4px 26px;color:var(--ink-soft);max-width:700px}
.contact{background:var(--cream-deep);border-top:1px solid var(--line)}
.contact-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:26px;margin-top:52px}
.contact-card{background:var(--cream);border:1px solid var(--line);border-radius:18px;padding:34px 30px}
.contact-card h3{font-size:1.25rem;margin-bottom:10px}
.contact-card p{color:var(--ink-soft);font-size:.98rem}
.contact-card a{color:var(--ink);font-weight:600;text-decoration:none}
.contact-card a:hover{text-decoration:underline}
footer{background:var(--dark);color:var(--dark-text);padding:64px 0 40px;font-size:.92rem}
footer .cols{display:grid;grid-template-columns:2fr 1fr 1fr;gap:40px;margin-bottom:48px}
@media(max-width:720px){footer .cols{grid-template-columns:1fr}}
footer .brand{font-family:var(--serif);font-size:1.25rem;color:var(--cream)}
footer h4{font-size:.8rem;text-transform:uppercase;letter-spacing:.12em;color:#8d877a;margin-bottom:14px;font-weight:600}
footer a{color:var(--dark-text);text-decoration:none;display:block;padding:4px 0}
footer a:hover{color:var(--cream)}
footer .legal{border-top:1px solid #33302a;padding-top:28px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px}
footer .legal a{display:inline;padding:0;margin-left:18px}
::selection{background:#e9e0c8}
h1,h2,h3{font-weight:440}
.logo{font-weight:520}
nav a:not(.cta){position:relative}
nav a:not(.cta)::after{content:"";position:absolute;left:0;bottom:-5px;width:0;height:1px;background:var(--ink);transition:width .25s ease}
nav a:not(.cta):hover::after{width:100%}
.hero{position:relative;overflow:hidden}
.hero .wrap{position:relative;z-index:1}
.hero h1{font-size:clamp(2.6rem,6.8vw,4.7rem);line-height:1.07}
.hero h1 em{font-style:normal;color:var(--green)}
.hero-badge{display:inline-flex;align-items:center;gap:9px;border:1px solid var(--line);border-radius:999px;padding:7px 17px;font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:36px;background:rgba(255,255,255,.45);text-decoration:none;transition:border-color .2s ease,color .2s ease,background .2s ease}
a.hero-badge:hover{border-color:var(--ink-soft);color:var(--ink);background:rgba(255,255,255,.7)}
.hero-badge::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--green)}
.hero-art{position:absolute;right:-30px;bottom:-6px;width:min(46vw,520px);height:auto;opacity:.6;pointer-events:none}
@media(max-width:900px){.hero-art{display:none}}
.btn{transition:transform .25s ease,background .25s ease,color .25s ease,box-shadow .25s ease}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 12px 28px -14px rgba(23,21,17,.5)}
.btn-ghost:hover{transform:translateY(-2px)}
.kicker{display:flex;align-items:center;gap:12px;color:var(--green)}
.kicker::before{content:"";width:34px;height:1px;background:currentColor}
.service,.contact-card{transition:transform .3s ease,box-shadow .3s ease}
.service:hover,.contact-card:hover{transform:translateY(-6px);box-shadow:0 22px 44px -24px rgba(23,21,17,.28)}
.service a{transition:color .2s ease}
.service a:hover{color:var(--green);text-decoration:none}
summary{transition:color .2s ease}
summary:hover{color:var(--green)}
summary::after{transition:transform .3s ease}
details[open] summary::after{content:"+";transform:rotate(45deg)}
.reveal{opacity:0;transition:opacity .6s ease}
.reveal.in{opacity:1}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transition:none}}
section,[id]{scroll-margin-top:88px}
.logo{display:flex;align-items:center;gap:10px}
.logo svg{width:21px;height:21px;display:block;color:var(--green)}
.logo-since{font-family:var(--sans);font-size:.6rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);align-self:center;position:relative;top:2px}
.hero{background:radial-gradient(1100px 520px at 82% 8%,#ece5d4 0%,rgba(246,243,236,0) 62%)}
.hero-art{opacity:.85}
.hero-art path{stroke:#d8cdb2}
.service .icon{width:48px;height:48px;border-radius:13px;background:var(--cream);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;margin-bottom:24px;color:var(--green)}
.service .icon svg{width:23px;height:23px}
.contact{background:radial-gradient(720px 380px at 85% -8%,rgba(60,107,79,.22),transparent 62%),var(--dark);border-top:none}
.contact .kicker{color:#9db8a6}
.contact h2{color:var(--cream)}
.contact h2 .alt-line{color:#8d877a}
.contact p.sub{color:var(--dark-text)}
.contact-card{background:#211f1a;border:1px solid #36332b}
.contact-card h3{color:var(--cream)}
.contact-card p{color:var(--dark-text)}
.contact-card a{color:var(--cream)}
.contact-card:hover{box-shadow:0 24px 48px -24px rgba(0,0,0,.65)}
footer{border-top:1px solid #33302a}
.hero{padding:96px 0 104px}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:64px;align-items:center}
.hero h1{font-size:clamp(2.3rem,4.6vw,3.8rem)}
.hero-art{right:-90px;bottom:auto;top:24px;opacity:.45;width:min(38vw,440px)}
@media(max-width:920px){.hero-grid{grid-template-columns:1fr;gap:64px}.hero-art{display:none}}
.hero-mock{position:relative;max-width:470px;width:100%;justify-self:end}
@media(max-width:920px){.hero-mock{justify-self:start}}
.mock-window{background:#fff;border:1px solid var(--line);border-radius:18px;box-shadow:0 32px 70px -30px rgba(23,21,17,.35);overflow:hidden}
.mock-head{display:flex;align-items:center;gap:10px;padding:14px 18px;border-bottom:1px solid #efece4;font-size:.8rem;color:var(--ink-soft);font-weight:500}
.mock-head .dots{display:flex;gap:5px}
.mock-head .dots i{width:9px;height:9px;border-radius:50%;background:#e5dfd0}
.mock-body{padding:18px;display:flex;flex-direction:column;gap:12px}
.mock-row{display:flex;justify-content:space-between;align-items:center;gap:12px;background:#faf8f3;border:1px solid #efece4;border-radius:12px;padding:13px 16px;font-size:.88rem;font-weight:500}
.mock-row small{display:block;color:var(--ink-soft);font-weight:400;margin-top:3px;font-size:.76rem}
.pill{font-size:.72rem;font-weight:600;padding:5px 12px;border-radius:999px;white-space:nowrap;flex-shrink:0}
.pill.ok{background:#e3efe6;color:#2c5e3f}
.pill.warn{background:#fdf2dc;color:#8a6116}
.mock-kpi{display:flex;justify-content:space-between;align-items:flex-end;background:var(--dark);border-radius:12px;padding:16px 18px;gap:14px}
.mock-kpi .lab{font-size:.74rem;color:#a39d8e}
.mock-kpi strong{font-size:1.3rem;font-weight:600;color:var(--cream);display:block;margin-top:5px;font-variant-numeric:tabular-nums}
.mock-kpi .bars{display:flex;gap:5px;align-items:flex-end;height:46px}
.mock-kpi .bars i{width:9px;border-radius:3px;background:#4e6f5c;display:block}
.mock-kpi .bars i:last-child{background:#8fbc9e}
section{padding:88px 0}
.service{padding:34px 30px}
.service ul{margin:16px 0 24px}
.service li{padding:8px 0}
.steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:22px;margin-top:48px}
.step{position:relative;background:var(--cream-deep);border:1px solid var(--line);border-radius:18px;padding:30px 26px 28px;transition:transform .3s ease,box-shadow .3s ease}
.step:hover{transform:translateY(-5px);box-shadow:0 20px 40px -24px rgba(23,21,17,.28)}
.step-num{position:absolute;top:26px;right:26px;font-family:var(--serif);font-size:1.05rem;color:#a39b85}
.step .icon{width:46px;height:46px;border-radius:12px;background:var(--cream);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;margin-bottom:18px;color:var(--green)}
.step .icon svg{width:22px;height:22px}
.step h3{font-size:1.15rem;margin-bottom:7px}
.step p{color:var(--ink-soft);font-size:.93rem;line-height:1.55}
.service li{display:flex;align-items:center;gap:11px}
.service li svg{width:18px;height:18px;color:var(--green);flex-shrink:0}
.why-text{max-width:780px;margin-top:36px}
.why-text p{font-size:clamp(1.15rem,2vw,1.4rem);line-height:1.5;color:var(--ink-soft)}
.why-text p+p{margin-top:1.1em}
.why-text .why-q{color:var(--ink);font-weight:500}
.modern-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:26px;margin-top:48px}
.modern-card{display:flex;flex-direction:column}
.modern-card .mock-window{flex:1;display:flex;flex-direction:column;transition:transform .3s ease,box-shadow .3s ease}
.modern-card .mock-window .mock-body{flex:1}
.modern-card:hover .mock-window{transform:translateY(-6px);box-shadow:0 30px 56px -28px rgba(23,21,17,.4)}
.modern-card h3{font-size:1.1rem;line-height:1.25;margin:0 0 16px;min-height:2.5em;text-align:center}
#leistungen p.sub{max-width:none}
.about-text{max-width:720px;margin-top:32px}
.about-text p{color:var(--ink-soft);font-size:1.12rem;line-height:1.7}
.about-text p+p{margin-top:20px}
.m-prog{background:#faf8f3;border:1px solid #efece4;border-radius:12px;padding:13px 16px}
.m-prog-top{display:flex;justify-content:space-between;align-items:baseline;font-size:.82rem;color:var(--ink-soft);margin-bottom:9px}
.m-prog-top strong{font-size:1.05rem;color:var(--ink);font-variant-numeric:tabular-nums}
.m-bar{height:8px;border-radius:99px;background:#e9e3d4;overflow:hidden}
.m-bar span{display:block;height:100%;background:var(--green);border-radius:99px}
.m-vote{background:var(--dark);border-radius:12px;padding:16px 18px}
.m-vote-top{display:flex;justify-content:space-between;align-items:baseline;font-size:.8rem;color:#a39d8e;margin-bottom:10px}
.m-vote-top strong{font-size:1.3rem;color:var(--cream);font-variant-numeric:tabular-nums}
.m-vote-bar{height:9px;border-radius:99px;background:#3a372f;overflow:hidden}
.m-vote-bar span.yes{display:block;height:100%;background:#8fbc9e;border-radius:99px}
.m-vote-legend{display:flex;gap:18px;margin-top:11px;font-size:.74rem;color:#a39d8e}
.m-vote-legend i{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:6px}
.m-vote-legend .dot-yes{background:#8fbc9e}
.m-vote-legend .dot-no{background:#56524a}
.m-live{margin-left:auto;display:inline-flex;align-items:center;gap:6px;font-size:.7rem;font-weight:600;color:#2c5e3f;text-transform:uppercase;letter-spacing:.06em}
.m-live::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--green);animation:badgePulse 1.6s ease-out infinite}
.m-people{display:flex;flex-direction:column;gap:11px;background:#faf8f3;border:1px solid #efece4;border-radius:12px;padding:15px 16px}
.m-avatars{display:flex}
.m-avatars i{width:30px;height:30px;border-radius:50%;background:#e3efe6;border:2px solid #fff;margin-left:-8px;display:flex;align-items:center;justify-content:center;font-size:.66rem;font-weight:600;color:#2c5e3f;font-style:normal}
.m-avatars i:first-child{margin-left:0}
.m-people-lab{font-size:.8rem;color:var(--ink-soft)}
@keyframes badgePulse{0%{box-shadow:0 0 0 0 rgba(60,107,79,.55)}70%{box-shadow:0 0 0 7px rgba(60,107,79,0)}100%{box-shadow:0 0 0 0 rgba(60,107,79,0)}}
.hero-badge::before{animation:badgePulse 1.6s ease-out infinite}
@media(prefers-reduced-motion:reduce){.hero-badge::before,.m-live::before{animation:none}}
@media(max-width:600px){
.wrap{padding:0 20px}
section{padding:48px 0}
.hero{padding:58px 0 50px}
.hero-grid{gap:56px}
.hero-mock{margin-top:6px}
.hero h1{font-size:2.1rem;line-height:1.13}
.hero p.lead{font-size:1.05rem;margin-top:22px}
.hero .actions{margin-top:28px;flex-direction:column;align-items:stretch;gap:12px}
.hero .actions .btn{text-align:center}
.hero-badge{margin-bottom:26px}
.kicker{margin-bottom:14px}
.services,.modern-grid,.steps,.contact-grid{margin-top:30px}
.faq-list{margin-top:28px}
.service{padding:28px 24px}
.why-text{margin-top:24px}
section h2{font-size:1.7rem}
}
/* Theme-Toggle */
.theme-toggle{display:inline-flex;align-items:center;justify-content:center;background:none;border:0;cursor:pointer;color:var(--ink-soft);padding:6px;margin-left:26px;line-height:0}
.theme-toggle:hover{color:var(--ink)}
.theme-toggle svg{width:20px;height:20px}
.theme-toggle .i-sun{display:none}
[data-theme="dark"] .theme-toggle .i-moon{display:none}
[data-theme="dark"] .theme-toggle .i-sun{display:block}
@media(max-width:720px){.theme-toggle{margin:10px 28px 4px}}
/* Sprach-Toggle DE/EN */
.lang-toggle{display:inline-flex;align-items:center;justify-content:center;background:none;border:1px solid var(--line);border-radius:999px;cursor:pointer;color:var(--ink-soft);padding:5px 11px;margin-left:16px;font-family:var(--sans);font-size:.76rem;font-weight:600;letter-spacing:.05em;line-height:1;text-decoration:none}
.lang-toggle:hover{color:var(--ink);border-color:var(--ink-soft)}
@media(max-width:720px){.lang-toggle{margin:6px 28px 10px;align-self:flex-start}}
/* Dark Mode */
[data-theme="dark"]{--cream:#14120d;--cream-deep:#1d1a13;--ink:#f1ece1;--ink-soft:#aba496;--line:#322e27;--dark:#0c0a07;--dark-text:#cfc9bb;--green:#6aa886}
[data-theme="dark"] header{background:rgba(20,18,13,.85)}
[data-theme="dark"] ::selection{background:#36443b}
[data-theme="dark"] .hero{background:radial-gradient(1100px 520px at 82% 8%,#211e15 0%,rgba(20,18,13,0) 62%)}
[data-theme="dark"] .hero-art path{stroke:#37322a}
[data-theme="dark"] .hero-badge{background:rgba(255,255,255,.06)}
[data-theme="dark"] a.hero-badge:hover{background:rgba(255,255,255,.12);color:var(--ink)}
[data-theme="dark"] .btn-primary:hover{background:#fff}
[data-theme="dark"] nav .cta:hover{background:#fff;color:#000}
[data-theme="dark"] .mock-window{background:#211e17;border-color:#322e27;box-shadow:0 30px 60px -28px rgba(0,0,0,.7)}
[data-theme="dark"] .mock-head{border-bottom-color:#2c2820}
[data-theme="dark"] .mock-head .dots i{background:#3a362d}
[data-theme="dark"] .mock-row{background:#191710;border-color:#2c2820}
[data-theme="dark"] .pill.ok{background:#1d3527;color:#8ed0a6}
[data-theme="dark"] .pill.warn{background:#3a2e16;color:#e6b766}
[data-theme="dark"] .mock-kpi strong,[data-theme="dark"] .m-vote-top strong{color:var(--ink)}
[data-theme="dark"] .m-prog,[data-theme="dark"] .m-people{background:#191710;border-color:#2c2820}
[data-theme="dark"] .m-bar{background:#2c2820}
[data-theme="dark"] .m-avatars i{background:#243a2c;border-color:#211e17;color:#8ed0a6}
[data-theme="dark"] .contact h2,[data-theme="dark"] .contact-card h3,[data-theme="dark"] .contact-card a,[data-theme="dark"] footer .brand{color:var(--ink)}
[data-theme="dark"] footer a:hover{color:var(--ink)}

/* Lead-Formular */
.lead-form{margin-top:34px;background:var(--cream);border:1px solid var(--line);border-radius:18px;padding:32px 30px}
.lead-form .lf-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.lead-form label{display:block;font-size:.82rem;font-weight:600;letter-spacing:.02em;color:var(--ink-soft);margin-bottom:7px}
.lead-form .lf-full{grid-column:1 / -1}
.lead-form input,.lead-form select,.lead-form textarea{width:100%;font-family:var(--sans);font-size:1rem;color:var(--ink);background:var(--cream-deep);border:1px solid var(--line);border-radius:10px;padding:12px 14px}
.lead-form textarea{resize:vertical;min-height:96px}
.lead-form input:focus,.lead-form select:focus,.lead-form textarea:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 3px rgba(60,107,79,.15)}
.lead-form .btn{margin-top:6px;border:0;cursor:pointer}
.lf-note{margin-top:14px;font-size:.82rem;color:var(--ink-soft)}
.lf-success{display:none;text-align:center;padding:14px 0}
.lf-success.show{display:block}
.lf-success svg{width:46px;height:46px;color:var(--green);margin-bottom:12px}
.lf-success h3{font-size:1.2rem;margin-bottom:8px}
.lf-success p{color:var(--ink-soft)}
@media(max-width:560px){.lead-form .lf-grid{grid-template-columns:1fr}}

/* Hardfacts / Zahlen-Band */
.facts{background:var(--dark)}
.facts .kicker{color:#9db8a6;margin-bottom:32px}
.facts-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:30px}
.fact-num{font-family:var(--serif);font-size:2.7rem;line-height:1;color:#f6f3ec;letter-spacing:-.02em;font-weight:440}
.fact-num span{font-size:1.05rem;color:#6aa886;margin-left:3px;letter-spacing:0}
.fact-lab{margin-top:13px;font-size:.95rem;line-height:1.5;color:var(--dark-text);max-width:240px}
@media(max-width:760px){.facts-grid{grid-template-columns:1fr 1fr;gap:42px 26px}.fact-num{font-size:2.3rem}}

/* ===== Mobile-Feinschliff (Smartphone) ===== */
@media(max-width:600px){
  .lang-toggle{padding:8px 14px}
}
@media(max-width:480px){
  .hero h1{font-size:1.95rem}
  section h2{font-size:1.55rem}
  .hero p.lead{font-size:1.02rem}
  .facts-grid{gap:30px 18px}
  .fact-num{font-size:1.85rem}
  .fact-lab{font-size:.88rem}
  .service{padding:24px 20px}
  .lead-form{padding:24px 18px}
  .step{padding:26px 22px}
  .contact-card{padding:26px 22px}
}
@media(max-width:360px){
  .facts-grid{grid-template-columns:1fr}
}

/* ===== Schritt-für-Schritt-Buchung ===== */
.booking{margin-top:34px;background:var(--cream);border:1px solid var(--line);border-radius:18px;padding:30px 28px;max-width:680px}
.bk-progress{height:5px;border-radius:99px;background:var(--cream-deep);overflow:hidden;margin-bottom:24px}
.bk-progress span{display:block;height:100%;width:33%;background:var(--green);border-radius:99px;transition:width .35s ease}
.bk-step{display:none}
.bk-step.active{display:block;animation:bkfade .3s ease}
@keyframes bkfade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.bk-count{font-size:.76rem;text-transform:uppercase;letter-spacing:.12em;color:var(--green);font-weight:600;margin-bottom:9px}
.bk-q{font-family:var(--serif);font-size:1.45rem;line-height:1.2;color:var(--ink);margin-bottom:20px;letter-spacing:-.01em}
.bk-options{display:flex;flex-direction:column;gap:10px}
.bk-opt{display:flex;align-items:center;gap:13px;width:100%;text-align:left;background:var(--cream-deep);border:1px solid var(--line);border-radius:12px;padding:17px 20px;font-family:var(--sans);font-size:1.02rem;color:var(--ink);cursor:pointer;transition:border-color .2s ease,background .2s ease,box-shadow .2s ease}
.bk-opt:hover{border-color:var(--green);background:var(--cream);box-shadow:0 10px 26px -18px rgba(23,21,17,.35)}
.bk-opt svg{width:20px;height:20px;color:var(--green);flex-shrink:0}
.bk-opt::after{content:"→";margin-left:auto;color:var(--ink-soft);font-size:1.05rem;transition:transform .2s ease,color .2s ease}
.bk-opt:hover::after{color:var(--green);transform:translateX(4px)}
.bk-nav{margin-top:20px;display:flex;align-items:center;gap:14px;min-height:24px}
.bk-back{background:none;border:0;color:var(--ink-soft);font-family:var(--sans);font-size:.92rem;cursor:pointer;padding:4px 0;display:none}
.bk-back.show{display:inline-flex;align-items:center;gap:6px}
.bk-back:hover{color:var(--ink)}
.bk-summary{display:none}
.bk-cal{min-height:460px}
.bk-fallback{background:var(--cream-deep);border:1px solid var(--line);border-radius:12px;padding:22px;color:var(--ink-soft);font-size:.97rem;line-height:1.6}
.bk-fallback a{color:var(--ink);font-weight:600}
.bk-or{margin-top:30px;font-size:.92rem;color:var(--dark-text);text-align:center}
[data-theme="dark"] .bk-or{color:var(--ink-soft)}
@media(max-width:560px){.booking{padding:24px 18px}.bk-cal{min-height:520px}}

/* ===== Vertikaler Scroll-Fortschritt ===== */
.scroll-rail{position:fixed;left:20px;top:50%;transform:translateY(-50%);z-index:8;display:flex;flex-direction:column;align-items:center;gap:16px}
.scroll-rail .track{width:8px;height:180px;background:var(--line);border-radius:99px;padding:2px;pointer-events:none}
.scroll-rail .track span{display:block;width:100%;height:0;background:var(--green);border-radius:99px;transition:height .12s linear}
.scroll-cta{width:42px;height:42px;border-radius:50%;background:var(--ink);color:var(--cream);display:flex;align-items:center;justify-content:center;text-decoration:none;box-shadow:0 8px 22px -8px rgba(23,21,17,.5);transition:transform .2s ease,background .2s ease}
.scroll-cta:hover{transform:translateY(-3px);background:var(--green);color:#fff}
.scroll-cta svg{width:20px;height:20px}
@media(max-width:820px){.scroll-rail{display:none}}
@media(prefers-reduced-motion:reduce){.scroll-rail .track span{transition:none}}

/* ===== Mobiler Angebot-Button (Floating) ===== */
.fab-cta{position:fixed;right:16px;bottom:16px;z-index:7;display:none;align-items:center;gap:9px;background:var(--ink);color:var(--cream);border-radius:999px;padding:13px 19px;text-decoration:none;font-family:var(--sans);font-size:.95rem;font-weight:600;box-shadow:0 10px 28px -8px rgba(23,21,17,.55);transition:transform .15s ease}
.fab-cta svg{width:18px;height:18px;flex-shrink:0}
.fab-cta:active{transform:scale(.97)}
@media(max-width:820px){.fab-cta{display:inline-flex}}
