/* ============================================================
   WEGDAMIT — DER ENTRÜMPLER · Design System
   Dunkel · modern & kräftig · Neon-Grün
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Anton&family=Archivo:ital,wght@0,400;0,500;0,600;0,700;0,800;1,500&display=swap');

:root{
  /* Colors */
  --bg:        #0A0C0A;
  --bg-2:      #101410;
  --bg-3:      #161B16;
  --panel:     #12161200;
  --ink:       #FFFFFF;
  --ink-soft:  rgba(255,255,255,.66);
  --ink-faint: rgba(255,255,255,.42);
  --ink-dim:   rgba(255,255,255,.14);
  --line:      rgba(255,255,255,.10);
  --line-soft: rgba(255,255,255,.06);
  --green:     #46FA24;
  --green-2:   #3BFD19;
  --green-deep:#2BC413;
  --green-ink: #06210A;     /* text on green */
  --green-glow: rgba(70,250,36,.32);

  /* Type */
  --display: 'Anton', 'Archivo', sans-serif;
  --sans: 'Archivo', system-ui, sans-serif;

  /* Layout */
  --maxw: 1240px;
  --gut: clamp(20px, 5vw, 64px);
  --radius: 16px;
  --radius-lg: 26px;
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  margin:0;
  background:var(--bg);
  color:var(--ink);
  font-family:var(--sans);
  font-size:17px;
  line-height:1.6;
  font-weight:400;
  letter-spacing:.005em;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
::selection{ background:var(--green); color:var(--green-ink); }

/* Subtle background grain + glow */
body::before{
  content:"";
  position:fixed; inset:0; pointer-events:none; z-index:0;
  background:
    radial-gradient(900px 600px at 82% -8%, rgba(70,250,36,.10), transparent 60%),
    radial-gradient(700px 500px at -6% 18%, rgba(70,250,36,.05), transparent 55%);
}

/* ---------- Layout helpers ---------- */
.wrap{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:var(--gut); position:relative; z-index:1; }
.section{ padding-block:clamp(64px, 9vw, 130px); position:relative; z-index:1; }
.section--tight{ padding-block:clamp(48px,6vw,80px); }

/* ---------- Eyebrow / kicker ---------- */
.kicker{
  display:inline-flex; align-items:center; gap:10px;
  font-size:13px; font-weight:700; letter-spacing:.22em; text-transform:uppercase;
  color:var(--green); margin:0 0 22px;
}
.kicker::before{ content:""; width:26px; height:2px; background:var(--green); display:block; box-shadow:0 0 12px var(--green-glow); }
.kicker--center::after{ content:""; width:26px; height:2px; background:var(--green); display:block; box-shadow:0 0 12px var(--green-glow); }

/* ---------- Headlines ---------- */
.display{
  font-family:var(--display);
  font-weight:400;
  text-transform:uppercase;
  line-height:.92;
  letter-spacing:.005em;
  margin:0;
}
.h-hero{ font-size:clamp(54px, 9.5vw, 150px); }
.h-xl{ font-size:clamp(40px, 6.5vw, 92px); }
.h-lg{ font-size:clamp(32px, 4.6vw, 64px); }
.h-md{ font-size:clamp(26px, 3.2vw, 42px); }
.lede{ font-size:clamp(18px,1.5vw,22px); color:var(--ink-soft); max-width:60ch; }
.text-green{ color:var(--green); }
.dot-green{ color:var(--green); }
/* grüner Punkt oben auf dem O */
.oe{ position:relative; display:inline-block; }
.oe::after{ content:""; position:absolute; left:50%; top:0.10em; transform:translateX(-50%); width:0.15em; height:0.15em; border-radius:50%; background:var(--green); box-shadow:0 0 12px var(--green-glow); }
.text-soft{ color:var(--ink-soft); }
.stroke{
  -webkit-text-stroke:1.6px rgba(255,255,255,.55);
  color:transparent;
}

/* ---------- Buttons ---------- */
.btn{
  --bh:58px;
  display:inline-flex; align-items:center; justify-content:center; gap:11px;
  height:var(--bh); padding:0 26px;
  font-family:var(--sans); font-weight:700; font-size:15.5px; letter-spacing:.02em;
  border-radius:999px; border:1.5px solid transparent; cursor:pointer;
  transition:transform .18s ease, background .2s ease, box-shadow .2s ease, color .2s ease, border-color .2s ease;
  white-space:nowrap;
}
.btn svg{ width:18px; height:18px; }
.btn--green{ background:var(--green); color:var(--green-ink); box-shadow:0 0 0 rgba(70,250,36,0); }
.btn--green:hover{ background:var(--green-2); transform:translateY(-2px); box-shadow:0 14px 34px -10px var(--green-glow); }
.btn--ghost{ background:transparent; color:var(--ink); border-color:var(--line); }
.btn--ghost:hover{ border-color:var(--green); color:var(--green); transform:translateY(-2px); }
.btn--dark{ background:rgba(255,255,255,.06); color:var(--ink); border-color:var(--line); }
.btn--dark:hover{ background:rgba(255,255,255,.12); transform:translateY(-2px); }
.btn--sm{ --bh:46px; padding:0 20px; font-size:14px; }
.btn--lg{ --bh:64px; padding:0 34px; font-size:17px; }

/* arrow chip inside buttons reuses brand arrow */
.arrowmark{ display:inline-block; width:16px; height:16px; }

/* ---------- Header ---------- */
.site-header{
  position:sticky; top:0; z-index:50;
  background:rgba(10,12,10,.72);
  backdrop-filter:blur(16px) saturate(140%);
  border-bottom:1px solid var(--line-soft);
}
.nav{ display:flex; align-items:center; justify-content:space-between; height:84px; gap:24px; }
.brand{ display:flex; align-items:center; gap:0; flex-shrink:0; }
.brand img{ height:38px; width:auto; }
.nav-links{ display:flex; align-items:center; gap:6px; margin-left:auto; }
.nav-links a{
  font-size:15px; font-weight:600; color:var(--ink-soft); white-space:nowrap;
  padding:10px 16px; border-radius:999px; transition:color .15s, background .15s; letter-spacing:.01em;
}
.nav-links a:hover{ color:var(--ink); }
.nav-links a.active{ color:var(--ink); }
.nav-links a.active::after{ content:""; }
.nav-cta{ display:flex; align-items:center; gap:10px; margin-left:14px; }
.nav-phone{ display:inline-flex; align-items:center; gap:9px; font-weight:700; font-size:15px; color:var(--ink); white-space:nowrap; }
.nav-phone .dot{ width:8px;height:8px;border-radius:50%;background:var(--green);box-shadow:0 0 10px var(--green-glow); }
.burger{ display:none; }

/* Mobile menu */
.mobile-menu{
  display:none; flex-direction:column; gap:6px;
  padding:18px var(--gut) 30px;
  border-top:1px solid var(--line); background:var(--bg-2);
}
.mobile-menu a{ font-size:18px; font-weight:600; color:var(--ink-soft); padding:12px 2px; }
.mobile-menu a.active, .mobile-menu a:hover{ color:var(--ink); }
.mobile-menu .mm-phone{ color:var(--green); font-weight:700; margin-top:6px; }
body.menu-open .mobile-menu{ display:flex; }

/* ---------- Footer ---------- */
.site-footer{ background:var(--bg-2); border-top:1px solid var(--line); position:relative; z-index:1; }
.footer-top{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:40px; padding-block:64px 48px; }
.footer-brand img{ height:42px; margin-bottom:20px; }
.footer-col h4{ font-size:13px; letter-spacing:.18em; text-transform:uppercase; color:var(--ink-faint); margin:0 0 18px; font-weight:700; }
.footer-col a, .footer-col p{ display:block; color:var(--ink-soft); font-size:15px; margin:0 0 12px; transition:color .15s; }
.footer-col a:hover{ color:var(--green); }
.footer-bottom{ display:flex; justify-content:space-between; align-items:center; gap:20px; padding-block:24px; border-top:1px solid var(--line); flex-wrap:wrap; }
.footer-bottom p{ margin:0; font-size:13.5px; color:var(--ink-faint); }
.footer-bottom .links{ display:flex; gap:22px; }
.footer-bottom .links a{ font-size:13.5px; color:var(--ink-faint); }
.footer-bottom .links a:hover{ color:var(--ink); }

/* ---------- Cards / surfaces ---------- */
.card{
  background:linear-gradient(180deg, rgba(255,255,255,.035), rgba(255,255,255,.012));
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:30px;
  position:relative;
  transition:border-color .2s ease, transform .2s ease, background .2s ease;
}
.card:hover{ border-color:rgba(70,250,36,.45); transform:translateY(-4px); }

/* ---------- Badge row ---------- */
.badges{ display:flex; flex-wrap:wrap; gap:14px 26px; }
.badge{ display:inline-flex; align-items:center; gap:10px; font-size:14.5px; font-weight:600; color:var(--ink-soft); }
.badge svg{ width:19px; height:19px; color:var(--green); flex-shrink:0; }

/* ---------- Marquee ---------- */
.marquee{ overflow:hidden; border-block:1px solid var(--line); background:var(--bg-2); }
.marquee__track{ display:flex; gap:46px; width:max-content; animation:marq 34s linear infinite; padding-block:20px; }
.marquee__track span{ font-family:var(--display); text-transform:uppercase; font-size:30px; color:var(--ink); display:inline-flex; align-items:center; gap:46px; letter-spacing:.02em; }
.marquee__track span::after{ content:"●"; color:var(--green); font-size:13px; }
@keyframes marq{ to{ transform:translateX(-50%); } }

/* ---------- Utility ---------- */
.grid{ display:grid; gap:24px; }
.cols-2{ grid-template-columns:repeat(2,1fr); }
.cols-3{ grid-template-columns:repeat(3,1fr); }
.cols-4{ grid-template-columns:repeat(4,1fr); }
.flex{ display:flex; }
.center{ text-align:center; }
.mx-auto{ margin-inline:auto; }
.mt-s{ margin-top:14px; } .mt-m{ margin-top:26px; } .mt-l{ margin-top:44px; }
.gap-s{ gap:12px; } .gap-m{ gap:18px; }
.divider{ height:1px; background:var(--line); border:0; margin:0; }

/* reveal on scroll — only hide when JS is active (.js on <html>) so content
   stays visible without JavaScript */
html.js [data-reveal]{ opacity:0; transform:translateY(26px); transition:opacity .7s cubic-bezier(.2,.7,.2,1), transform .7s cubic-bezier(.2,.7,.2,1); }
html.js [data-reveal].in{ opacity:1; transform:none; }
@media (prefers-reduced-motion: reduce){
  html.js [data-reveal]{ opacity:1; transform:none; transition:none; }
}

image-slot{ display:block; border-radius:var(--radius-lg); overflow:hidden; }

/* ---------- Radar (Einsatzgebiet) ---------- */
.radar{
  position:relative; width:100%; aspect-ratio:4/5; min-height:420px;
  border:1px solid var(--line); border-radius:var(--radius-lg); overflow:hidden;
  background:radial-gradient(circle at 50% 48%, rgba(70,250,36,.07), rgba(10,12,10,0) 62%), var(--bg-2);
  box-shadow:0 40px 80px -40px rgba(0,0,0,.8);
  display:flex; align-items:center; justify-content:center;
  container-type:size;
}
.radar__scope{ position:relative; width:min(84cqw,84cqh); aspect-ratio:1; }
.radar__ring{ position:absolute; inset:0; border:1px solid rgba(70,250,36,.16); border-radius:50%; }
.radar__ring.r2{ inset:16.6%; } .radar__ring.r3{ inset:33.3%; } .radar__ring.r4{ inset:50%; }
.radar__cross{ position:absolute; background:rgba(70,250,36,.12); }
.radar__cross.h{ left:0; right:0; top:50%; height:1px; }
.radar__cross.v{ top:0; bottom:0; left:50%; width:1px; }
.radar__sweep{
  position:absolute; inset:0; border-radius:50%; z-index:1;
  background:conic-gradient(from 0deg, rgba(70,250,36,.34), rgba(70,250,36,.07) 42deg, transparent 90deg, transparent 360deg);
  animation:radar-spin 4s linear infinite;
}
@keyframes radar-spin{ to{ transform:rotate(360deg); } }
.radar__center{ position:absolute; left:50%; top:50%; transform:translate(-50%,-50%); z-index:4; display:flex; flex-direction:column; align-items:center; gap:7px; }
.radar__center i{ width:14px; height:14px; border-radius:50%; background:var(--green); box-shadow:0 0 0 6px rgba(70,250,36,.16), 0 0 20px var(--green-glow); }
.radar__center b{ font-size:12px; font-weight:800; letter-spacing:.05em; color:var(--ink); background:rgba(10,12,10,.72); padding:3px 9px; border-radius:7px; border:1px solid var(--line); }
.radar__blip{ position:absolute; transform:translate(-50%,-50%); z-index:3; display:flex; align-items:center; gap:7px; cursor:pointer; }
.radar__blip.l{ flex-direction:row-reverse; }
a.radar__blip:hover b{ color:var(--green); }
a.radar__blip:hover i{ transform:scale(1.4); background:#ff2d2d; box-shadow:0 0 18px 3px rgba(255,45,45,.9); }
.radar__blip i{ width:8px; height:8px; border-radius:50%; background:var(--green); box-shadow:0 0 10px var(--green-glow); animation:radar-ping 4s ease-in-out infinite; }
.radar__blip b{ font-size:11px; font-weight:600; color:var(--ink-soft); white-space:nowrap; text-shadow:0 1px 4px rgba(0,0,0,.8); }
@keyframes radar-blip{ 0%,12%,100%{ opacity:.35; transform:scale(.7); } 4%{ opacity:1; transform:scale(1.25); box-shadow:0 0 16px var(--green-glow); } }
@keyframes radar-ping{
  0%,14%,100%{ opacity:.4; transform:scale(.7); background:var(--green); box-shadow:0 0 8px var(--green-glow); }
  4%{ opacity:1; transform:scale(1.5); background:#ff2d2d; box-shadow:0 0 20px 4px rgba(255,45,45,.95); }
  8%{ opacity:.9; transform:scale(1.1); background:#ff5a3c; box-shadow:0 0 12px 1px rgba(255,90,60,.6); }
}
.radar__cap{ position:absolute; left:18px; bottom:18px; z-index:5; font-size:11px; font-weight:700; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-faint); display:inline-flex; align-items:center; gap:8px; }
.radar__cap::before{ content:""; width:7px; height:7px; border-radius:50%; background:var(--green); box-shadow:0 0 9px var(--green-glow); animation:radar-blip 1.8s ease-in-out infinite; }
@media (prefers-reduced-motion: reduce){
  .radar__sweep{ animation:none; } .radar__blip i, .radar__cap::before{ animation:none; opacity:1; transform:none; }
}
@media (max-width:980px){
  .radar{ aspect-ratio:16/10; min-height:0; }
}

/* ============================================================
   PAGE COMPONENTS
   ============================================================ */

/* ---------- Hero ---------- */
.hero{ padding-block:clamp(48px,7vw,92px) clamp(56px,7vw,96px); position:relative; z-index:1; }
.hero__grid{ display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(32px,5vw,72px); align-items:center; }
.hero__copy{ max-width:660px; }
.hero__cta{ display:flex; flex-wrap:wrap; gap:14px; }
.hero__media{ position:relative; }
.hero__photo{ width:100%; aspect-ratio:4/5; min-height:420px; box-shadow:0 40px 80px -40px rgba(0,0,0,.8); }
.hero__photo::part(empty){ }
.hero__tag{
  position:absolute; backdrop-filter:blur(10px);
  background:rgba(10,12,10,.78); border:1px solid var(--line);
  border-radius:14px; padding:12px 16px; font-size:13.5px; font-weight:600;
  display:flex; align-items:center; gap:9px; box-shadow:0 14px 30px -16px rgba(0,0,0,.7);
}
.hero__tag--top{ top:18px; left:18px; color:var(--ink); }
.hero__tag .ht-dot{ width:9px;height:9px;border-radius:50%;background:var(--green);box-shadow:0 0 10px var(--green-glow); }
.hero__tag--price{ right:18px; bottom:30px; flex-direction:column; align-items:flex-start; gap:2px; background:var(--green); border-color:transparent; padding:16px 22px; }
.ht-price-label{ font-family:var(--display); text-transform:uppercase; font-size:30px; line-height:1; color:var(--green-ink); }
.ht-price-sub{ font-size:12.5px; font-weight:600; color:rgba(6,33,10,.7); }

/* ---------- Section head (split) ---------- */
.sec-head{ display:grid; grid-template-columns:1.1fr .9fr; gap:30px; align-items:end; }
.sec-head .lede{ padding-bottom:8px; }

/* ---------- USP ---------- */
.usp-grid{ gap:18px; }
.usp{ padding:30px 26px; border:1px solid var(--line); border-radius:var(--radius); background:linear-gradient(180deg,rgba(255,255,255,.03),rgba(255,255,255,.008)); transition:border-color .2s,transform .2s; }
.usp:hover{ border-color:rgba(70,250,36,.4); transform:translateY(-4px); }
.usp__ico{ width:48px; height:48px; border-radius:12px; display:flex; align-items:center; justify-content:center; background:rgba(70,250,36,.12); margin-bottom:20px; }
.usp__ico svg{ width:24px; height:24px; color:var(--green); }
.usp h3{ font-size:19px; margin:0 0 8px; font-weight:700; }
.usp p{ margin:0; font-size:14.5px; color:var(--ink-soft); line-height:1.55; }

/* ---------- Service cards ---------- */
.svc-grid{ gap:18px; }
.svc{ display:flex; flex-direction:column; min-height:260px; padding:32px 30px; overflow:hidden; }
.svc__num{ font-family:var(--display); font-size:14px; letter-spacing:.1em; color:var(--green); position:absolute; top:26px; right:30px; }
.svc__ico{ width:54px; height:54px; border-radius:13px; background:rgba(255,255,255,.05); display:flex; align-items:center; justify-content:center; margin-bottom:22px; transition:background .2s; }
.svc__ico svg{ width:28px; height:28px; color:var(--ink); transition:color .2s; }
.svc:hover .svc__ico{ background:var(--green); }
.svc:hover .svc__ico svg{ color:var(--green-ink); }
.svc h3{ font-size:22px; margin:0 0 10px; font-weight:700; }
.svc p{ margin:0 0 auto; color:var(--ink-soft); font-size:15px; }
.svc__more{ display:inline-flex; align-items:center; gap:9px; margin-top:22px; font-weight:700; font-size:14px; color:var(--ink); transition:gap .2s,color .2s; }
.svc__more .arrowmark{ width:15px; height:15px; color:var(--green); transition:transform .2s; }
.svc:hover .svc__more{ color:var(--green); }
.svc:hover .svc__more .arrowmark{ transform:translate(2px,-2px); }

/* ---------- Statement / Festpreis ---------- */
.statement__grid{ display:grid; grid-template-columns:.92fr 1.08fr; gap:clamp(32px,5vw,72px); align-items:center; }
.statement__media image-slot{ width:100%; aspect-ratio:5/6; min-height:420px; box-shadow:0 40px 80px -44px rgba(0,0,0,.85); }
.check-list{ list-style:none; margin:0; padding:0; display:grid; gap:13px; }
.check-list li{ position:relative; padding-left:34px; font-size:16px; color:var(--ink-soft); }
.check-list li::before{
  content:""; position:absolute; left:0; top:1px; width:22px; height:22px; border-radius:50%;
  background:rgba(70,250,36,.14);
  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='%2346FA24' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6 9 17l-5-5'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:center;
}

/* ---------- Steps ---------- */
.steps{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; counter-reset:s; }
.step{ padding:30px 26px 32px; border:1px solid var(--line); border-radius:var(--radius); position:relative; background:linear-gradient(180deg,rgba(255,255,255,.03),rgba(255,255,255,.008)); }
.step__num{ font-family:var(--display); font-size:52px; line-height:1; color:transparent; -webkit-text-stroke:1.4px rgba(70,250,36,.55); display:block; margin-bottom:18px; }
.step h3{ font-size:20px; margin:0 0 10px; font-weight:700; }
.step p{ margin:0; color:var(--ink-soft); font-size:14.5px; }
.step:not(:last-child)::after{
  content:""; position:absolute; top:46px; right:-9px; width:18px; height:18px;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24' fill='none' stroke='%2346FA24' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M5 12h14M13 6l6 6-6 6'/%3E%3C/svg%3E");
  background-repeat:no-repeat; z-index:2;
}

/* ---------- Region ---------- */
.region{ background:var(--bg-2); border-block:1px solid var(--line); }
.region__grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(32px,5vw,64px); align-items:center; }
.region__tags{ display:flex; flex-wrap:wrap; gap:11px; }
.region__tags span, .region__tags a{
  display:inline-flex; align-items:center; padding:11px 18px; border-radius:999px;
  border:1px solid var(--line); font-size:14.5px; font-weight:600; color:var(--ink-soft);
  transition:border-color .2s,color .2s,background .2s;
}
.region__tags span:hover{ border-color:var(--green); color:var(--ink); }
.region__tags a{ border-color:rgba(70,250,36,.32); color:var(--ink); }
.region__tags a:hover{ border-color:var(--green); color:var(--green); }
.region__tags span:last-child{ background:rgba(70,250,36,.1); border-color:transparent; color:var(--green); }

/* ---------- CTA band ---------- */
.cta-band{ padding-block:clamp(72px,9vw,120px); position:relative; z-index:1; text-align:center; overflow:hidden; }
.cta-band::before{ content:""; position:absolute; inset:0; background:radial-gradient(600px 360px at 50% 0%, rgba(70,250,36,.14), transparent 65%); pointer-events:none; }
.cta-band__inner{ max-width:760px; margin-inline:auto; position:relative; }
.cta-band__arrow{ width:64px; height:64px; margin:0 auto 26px; color:var(--green); }
.cta-band__arrow .arrowmark{ width:64px; height:64px; filter:drop-shadow(0 0 22px var(--green-glow)); }

/* ============================================================
   SUBPAGE COMPONENTS
   ============================================================ */

/* Page hero (interior pages) */
.page-hero{ padding-block:clamp(56px,7vw,96px) clamp(40px,5vw,64px); border-bottom:1px solid var(--line); position:relative; z-index:1; }
.page-hero .lede{ margin-top:22px; }
.page-hero__crumb{ font-size:13px; font-weight:700; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-faint); margin:0 0 18px; }
.page-hero__crumb a{ color:var(--ink-faint); } .page-hero__crumb a:hover{ color:var(--green); }

/* Anchor chip nav */
.chipnav{ display:flex; flex-wrap:wrap; gap:10px; margin-top:34px; }
.chipnav a{ display:inline-flex; align-items:center; gap:8px; padding:10px 18px; border-radius:999px; border:1px solid var(--line); font-size:14px; font-weight:600; color:var(--ink-soft); transition:all .18s; }
.chipnav a:hover{ border-color:var(--green); color:var(--ink); }
.chipnav a span{ color:var(--green); font-family:var(--display); font-size:12px; }

/* Service detail rows */
.lservice{ display:block; max-width:780px; margin-inline:auto; padding-block:clamp(40px,5vw,72px); border-bottom:1px solid var(--line-soft); scroll-margin-top:100px; }
.lservice__num{ font-family:var(--display); font-size:clamp(60px,8vw,108px); line-height:.8; color:transparent; -webkit-text-stroke:1.5px rgba(70,250,36,.5); display:block; margin-bottom:18px; }
.lservice h2{ font-size:clamp(30px,3.6vw,46px); }
.lservice__copy p.lede{ margin-top:18px; }
.feat-list{ list-style:none; margin:26px 0 0; padding:0; display:grid; grid-template-columns:1fr 1fr; gap:12px 24px; }
.feat-list li{ position:relative; padding-left:28px; font-size:15px; color:var(--ink-soft); }
.feat-list li::before{ content:""; position:absolute; left:0; top:7px; width:14px; height:14px; border-radius:4px; background:rgba(70,250,36,.16);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 24 24' fill='none' stroke='%2346FA24' stroke-width='4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6 9 17l-5-5'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:center; }

/* About: values + stats */
.values{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.value{ padding:32px 28px; border:1px solid var(--line); border-radius:var(--radius); background:linear-gradient(180deg,rgba(255,255,255,.03),rgba(255,255,255,.008)); }
.value__ico{ width:50px;height:50px;border-radius:12px;background:rgba(70,250,36,.12);display:flex;align-items:center;justify-content:center;margin-bottom:20px; }
.value__ico svg{ width:25px;height:25px;color:var(--green); }
.value h3{ font-size:20px; margin:0 0 9px; }
.value p{ margin:0; color:var(--ink-soft); font-size:14.5px; }
.statline{ display:grid; grid-template-columns:repeat(4,1fr); gap:0; border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; }
.statline > div{ padding:34px 28px; border-right:1px solid var(--line); }
.statline > div:last-child{ border-right:0; }
.statline .num{ font-family:var(--display); font-size:clamp(38px,4.5vw,58px); line-height:1; color:var(--green); }
.statline .lbl{ margin-top:10px; font-size:14px; color:var(--ink-soft); }

.about-split{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(32px,5vw,72px); align-items:center; }
.about-split image-slot{ width:100%; aspect-ratio:4/5; min-height:380px; box-shadow:0 40px 80px -44px rgba(0,0,0,.85); }

/* Contact */
.contact-grid{ display:grid; grid-template-columns:1.15fr .85fr; gap:clamp(32px,5vw,60px); align-items:start; }
.form{ background:linear-gradient(180deg,rgba(255,255,255,.04),rgba(255,255,255,.01)); border:1px solid var(--line); border-radius:var(--radius-lg); padding:clamp(26px,3.5vw,42px); }
.field{ margin-bottom:20px; }
.field label{ display:block; font-size:13.5px; font-weight:600; color:var(--ink-soft); margin-bottom:9px; letter-spacing:.01em; }
.field input, .field select, .field textarea{
  width:100%; background:rgba(0,0,0,.35); border:1px solid var(--line); border-radius:12px;
  color:var(--ink); font-family:var(--sans); font-size:15.5px; padding:14px 16px; transition:border-color .18s, background .18s; outline:none;
}
.field textarea{ resize:vertical; min-height:120px; }
.field input:focus, .field select:focus, .field textarea:focus{ border-color:var(--green); background:rgba(0,0,0,.5); }
.field input::placeholder, .field textarea::placeholder{ color:var(--ink-faint); }
.field-row{ display:grid; grid-template-columns:1fr 1fr; gap:18px; }
.form .btn{ width:100%; }
.form__note{ font-size:12.5px; color:var(--ink-faint); margin-top:14px; text-align:center; }
.form__success{ display:none; text-align:center; padding:30px 10px; }
.form__success.show{ display:block; }
.form__success .chk{ width:64px;height:64px;border-radius:50%;background:var(--green);display:flex;align-items:center;justify-content:center;margin:0 auto 22px; }
.form__success .chk svg{ width:32px;height:32px;color:var(--green-ink); }

.contact-cards{ display:grid; gap:16px; }
.ccard{ display:flex; gap:16px; align-items:flex-start; padding:24px; border:1px solid var(--line); border-radius:var(--radius); background:linear-gradient(180deg,rgba(255,255,255,.03),rgba(255,255,255,.008)); transition:border-color .2s; }
.ccard:hover{ border-color:rgba(70,250,36,.4); }
.ccard__ico{ width:46px;height:46px;border-radius:11px;background:rgba(70,250,36,.12);display:flex;align-items:center;justify-content:center;flex-shrink:0; }
.ccard__ico svg{ width:22px;height:22px;color:var(--green); }
.ccard h4{ margin:0 0 5px; font-size:16px; }
.ccard a, .ccard p{ margin:0; color:var(--ink-soft); font-size:15px; }
.ccard a:hover{ color:var(--green); }

/* ============================================================
   KOSTENRECHNER
   ============================================================ */
.calc-grid{ display:grid; grid-template-columns:1.32fr .68fr; gap:clamp(24px,3vw,44px); align-items:start; }
.calc-card{
  background:linear-gradient(180deg,rgba(255,255,255,.04),rgba(255,255,255,.012));
  border:1px solid var(--line); border-radius:var(--radius-lg);
  padding:clamp(22px,3vw,40px);
}
.calc-step{ padding-block:clamp(22px,2.4vw,30px); border-top:1px solid var(--line-soft); }
.calc-step:first-child{ border-top:0; padding-top:2px; }
.calc-step__head{ display:flex; align-items:baseline; gap:13px; margin-bottom:18px; flex-wrap:wrap; }
.calc-step__num{ font-family:var(--display); font-size:15px; color:var(--green); letter-spacing:.06em; }
.calc-step__title{ font-size:18px; font-weight:700; margin:0; letter-spacing:.005em; }
.calc-step__hint{ margin-left:auto; font-size:13px; color:var(--ink-faint); font-weight:600; }

/* option tiles */
.calc-opts{ display:grid; gap:11px; }
.calc-opts.c4{ grid-template-columns:repeat(4,1fr); }
.calc-opts.c3{ grid-template-columns:repeat(3,1fr); }
.calc-opts.c2{ grid-template-columns:repeat(2,1fr); }
.calc-opt{
  cursor:pointer; position:relative; display:flex; flex-direction:column; gap:6px; align-items:flex-start;
  padding:15px 15px 14px; border:1.5px solid var(--line); border-radius:14px; background:rgba(0,0,0,.26);
  transition:border-color .18s, background .18s, transform .15s; min-height:100%;
}
.calc-opt:hover{ border-color:rgba(70,250,36,.45); }
.calc-opt input{ position:absolute; opacity:0; pointer-events:none; }
.calc-opt__ico{ width:28px; height:28px; color:var(--ink-soft); transition:color .18s; }
.calc-opt__ico svg{ width:28px; height:28px; }
.calc-opt__t{ font-size:15px; font-weight:700; line-height:1.2; }
.calc-opt__s{ font-size:12px; color:var(--ink-faint); line-height:1.35; }
.calc-opt__check{
  position:absolute; top:12px; right:12px; width:20px; height:20px; border-radius:50%;
  border:1.5px solid var(--line); display:flex; align-items:center; justify-content:center;
  transition:background .18s, border-color .18s; opacity:0;
}
.calc-opt__check svg{ width:12px; height:12px; color:var(--green-ink); }
.calc-opt:has(input:checked){ border-color:var(--green); background:rgba(70,250,36,.08); }
.calc-opt:has(input:checked) .calc-opt__ico{ color:var(--green); }
.calc-opt:has(input:checked) .calc-opt__check{ opacity:1; background:var(--green); border-color:var(--green); }

/* checkbox-style (extras) tiles */
.calc-opt--row{ flex-direction:row; align-items:center; gap:13px; padding-right:44px; }
.calc-opt--row .calc-opt__ico{ flex-shrink:0; }
.calc-opt--row .calc-opt__t{ font-size:15px; }
.calc-opt--row .calc-opt__check{ border-radius:6px; }

/* size slider */
.calc-slider{ }
.calc-slider__val{ display:flex; align-items:baseline; gap:8px; margin-bottom:18px; }
.calc-slider__num{ font-family:var(--display); font-size:clamp(34px,4vw,48px); line-height:1; color:var(--ink); }
.calc-slider__unit{ font-size:18px; font-weight:700; color:var(--green); }
.calc-range{
  -webkit-appearance:none; appearance:none; width:100%; height:6px; border-radius:999px;
  background:rgba(255,255,255,.12); outline:none; cursor:pointer; margin:6px 0;
}
.calc-range::-webkit-slider-thumb{
  -webkit-appearance:none; appearance:none; width:26px; height:26px; border-radius:50%;
  background:var(--green); border:4px solid var(--bg-2); cursor:grab;
  box-shadow:0 0 0 1px var(--green), 0 6px 18px -4px var(--green-glow);
}
.calc-range::-webkit-slider-thumb:active{ cursor:grabbing; }
.calc-range::-moz-range-thumb{
  width:22px; height:22px; border-radius:50%; background:var(--green); border:4px solid var(--bg-2);
  box-shadow:0 0 0 1px var(--green); cursor:grab;
}
.calc-range__scale{ display:flex; justify-content:space-between; font-size:12.5px; color:var(--ink-faint); margin-top:8px; font-weight:600; }

/* result panel */
.calc-result{ position:sticky; top:104px; border:1px solid var(--line); border-radius:var(--radius-lg); overflow:hidden; background:var(--bg-2); }
.calc-result__top{ padding:30px clamp(22px,2.5vw,32px) 28px; background:radial-gradient(120% 90% at 50% 0%, rgba(70,250,36,.12), transparent 70%); border-bottom:1px solid var(--line); }
.calc-result__label{ font-size:12px; font-weight:700; letter-spacing:.2em; text-transform:uppercase; color:var(--green); margin:0 0 14px; }
.calc-result__price{ font-family:var(--display); font-size:clamp(38px,4.4vw,56px); line-height:1; color:var(--ink); letter-spacing:.01em; transition:opacity .2s; }
.calc-result__price .sep{ color:var(--green); margin:0 .12em; }
.calc-result__sub{ font-size:13.5px; color:var(--ink-faint); margin:14px 0 0; line-height:1.5; }
.calc-result__sub b{ color:var(--ink-soft); font-weight:700; }
.calc-result__body{ padding:24px clamp(22px,2.5vw,32px) 28px; }
.calc-result__body .btn{ width:100%; }
.calc-result__call{ display:block; text-align:center; margin-top:14px; font-size:14px; color:var(--ink-soft); }
.calc-result__call b{ color:var(--ink); }
.calc-result__call:hover b{ color:var(--green); }
.calc-bene{ list-style:none; margin:24px 0 0; padding:22px 0 0; border-top:1px solid var(--line); display:grid; gap:12px; }
.calc-bene li{ position:relative; padding-left:30px; font-size:14px; color:var(--ink-soft); }
.calc-bene li::before{
  content:""; position:absolute; left:0; top:1px; width:19px; height:19px; border-radius:50%;
  background:rgba(70,250,36,.14);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2346FA24' stroke-width='3.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6 9 17l-5-5'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:center;
}

/* info prose block under calculator */
.calc-info{ max-width:74ch; }
.calc-info h2{ font-size:clamp(26px,3vw,40px); }
.calc-info p{ color:var(--ink-soft); font-size:16.5px; margin:18px 0 0; }
.calc-info p b{ color:var(--ink); font-weight:700; }
.calc-note{ margin-top:26px; padding:20px 22px; border:1px solid var(--line); border-radius:var(--radius); background:rgba(255,255,255,.02); font-size:14.5px; color:var(--ink-faint); line-height:1.6; }

@media (max-width:980px){
  .calc-grid{ grid-template-columns:1fr; }
  .calc-result{ position:static; }
}

/* Leistungen im Detail */
.detail-grid{ gap:30px 44px; }
.detail-grid .check-list{ gap:18px; }
.detail-grid .check-list li{ display:flex; align-items:flex-start; gap:14px; padding-left:0; font-size:16.5px; line-height:1.45; color:var(--ink); }
.detail-grid .check-list li::before{ position:static; flex:0 0 auto; left:auto; top:auto; margin-top:1px; }
.detail-sub{ font-size:13px; letter-spacing:.16em; text-transform:uppercase; color:var(--green); font-weight:700; margin:0 0 20px; padding-bottom:14px; border-bottom:1px solid var(--line); }
@media (max-width:620px){
  .calc-opts.c4{ grid-template-columns:repeat(2,1fr); }
  .calc-opts.c3{ grid-template-columns:repeat(2,1fr); }
  .calc-opt{ min-width:0; padding:13px 13px 12px; }
  .calc-opt__t, .calc-opt__s{ overflow-wrap:anywhere; }
}
@media (max-width:380px){
  .calc-opts.c4, .calc-opts.c3, .calc-opts.c2{ grid-template-columns:1fr; }
}

/* ---------- Rechner-Callout (starker Hinweis) ---------- */
.calc-promo{ margin-top:clamp(26px,3vw,34px); padding:clamp(20px,2.4vw,26px); border-radius:var(--radius-lg);
  background:linear-gradient(135deg, rgba(70,250,36,.14), rgba(70,250,36,.04));
  border:1px solid rgba(70,250,36,.45); position:relative; overflow:hidden; }
.calc-promo::after{ content:""; position:absolute; right:-30px; top:-30px; width:160px; height:160px; border-radius:50%;
  background:radial-gradient(circle, rgba(70,250,36,.22), transparent 70%); pointer-events:none; }
.calc-promo__top{ display:flex; align-items:center; gap:13px; margin-bottom:10px; }
.calc-promo__ico{ width:44px; height:44px; flex-shrink:0; border-radius:12px; background:var(--green); display:flex; align-items:center; justify-content:center; box-shadow:0 8px 22px -8px var(--green-glow); }
.calc-promo__ico svg{ width:24px; height:24px; color:var(--green-ink); }
.calc-promo__badge{ font-size:11px; font-weight:800; letter-spacing:.12em; text-transform:uppercase; color:var(--green); }
.calc-promo h3{ font-size:clamp(19px,2.2vw,23px); font-weight:800; margin:0 0 6px; letter-spacing:.005em; }
.calc-promo p{ margin:0 0 18px; font-size:15px; color:var(--ink-soft); line-height:1.55; }
.calc-promo .btn{ width:100%; justify-content:center; }
.calc-promo__note{ display:block; text-align:center; margin-top:11px; font-size:13px; color:var(--ink-faint); }

/* ---------- Responsive ---------- */
@media (max-width:1100px){
  .nav-phone{ display:none; }
}
@media (max-width:980px){
  .footer-top{ grid-template-columns:1fr 1fr; gap:34px; }
  .cols-4{ grid-template-columns:repeat(2,1fr); }
  .hero__grid{ grid-template-columns:1fr; gap:40px; }
  .hero__photo{ aspect-ratio:16/10; min-height:0; }
  .sec-head{ grid-template-columns:1fr; gap:18px; align-items:start; }
  .statement__grid{ grid-template-columns:1fr; gap:36px; }
  .statement__media image-slot{ aspect-ratio:16/10; min-height:0; }
  .region__grid{ grid-template-columns:1fr; gap:30px; }
  .steps{ grid-template-columns:repeat(2,1fr); }
  .step:not(:last-child)::after{ display:none; }
  .usp-grid{ grid-template-columns:repeat(2,1fr); }
  .lservice{ grid-template-columns:1fr; gap:34px; }
  .lservice:nth-child(even) .lservice__media{ order:0; }
  .lservice__media image-slot{ aspect-ratio:16/10; min-height:0; }
  .contact-grid{ grid-template-columns:1fr; }
  .values{ grid-template-columns:1fr; }
  .statline{ grid-template-columns:repeat(2,1fr); }
  .statline > div:nth-child(2){ border-right:0; }
  .statline > div:nth-child(-n+2){ border-bottom:1px solid var(--line); }
  .about-split{ grid-template-columns:1fr; gap:34px; }
  .about-split image-slot{ aspect-ratio:16/10; min-height:0; }
}
@media (max-width:760px){
  body{ font-size:16px; }
  .nav-links, .nav-phone{ display:none; }
  .burger{ display:inline-flex; }
  .cols-2,.cols-3,.cols-4{ grid-template-columns:1fr; }
  .footer-top{ grid-template-columns:1fr 1fr; }
  .marquee__track span{ font-size:24px; }
  .svc-grid{ grid-template-columns:1fr; }
  .steps,.usp-grid{ grid-template-columns:1fr; }
  .hero__tag--price{ right:14px; }
  .nav-cta .btn{ display:none; }
  .feat-list{ grid-template-columns:1fr; }
  .field-row{ grid-template-columns:1fr; }
}
@media (max-width:480px){
  .footer-top{ grid-template-columns:1fr; }
}

/* ============================================================
   PROOF & CONTENT BLOCKS
   ============================================================ */

/* ---------- Vorher / Nachher Slider ---------- */
.ba{ position:relative; width:100%; aspect-ratio:16/10; border-radius:var(--radius-lg); overflow:hidden; border:1px solid var(--line); box-shadow:0 40px 80px -44px rgba(0,0,0,.85); --pos:50%; user-select:none; touch-action:pan-y; }
.ba__layer{ position:absolute; inset:0; }
.ba__layer image-slot{ width:100%; height:100%; display:block; border-radius:0; }
.ba__before{ clip-path:inset(0 calc(100% - var(--pos)) 0 0); z-index:2; }
.ba__divider{ position:absolute; top:0; bottom:0; left:var(--pos); width:2px; background:var(--green); box-shadow:0 0 16px var(--green-glow); z-index:4; transform:translateX(-1px); cursor:ew-resize; }
.ba__handle{ position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); width:48px; height:48px; border-radius:50%; background:var(--green); color:var(--green-ink); display:flex; align-items:center; justify-content:center; box-shadow:0 6px 22px -4px var(--green-glow); }
.ba__handle svg{ width:24px; height:24px; }
.ba__tag{ position:absolute; bottom:16px; z-index:3; font-size:11.5px; font-weight:800; letter-spacing:.14em; text-transform:uppercase; padding:7px 13px; border-radius:999px; background:rgba(10,12,10,.74); backdrop-filter:blur(8px); border:1px solid var(--line); pointer-events:none; }
.ba__tag--l{ left:16px; }
.ba__tag--r{ right:16px; color:var(--green); }

/* ---------- Kundenstimmen ---------- */
.tg{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.tcard{ display:flex; flex-direction:column; padding:28px 26px; border:1px solid var(--line); border-radius:var(--radius); background:linear-gradient(180deg,rgba(255,255,255,.035),rgba(255,255,255,.01)); transition:border-color .2s,transform .2s; }
.tcard:hover{ border-color:rgba(70,250,36,.4); transform:translateY(-4px); }
.tcard__stars{ display:flex; gap:3px; margin-bottom:16px; color:var(--green); }
.tcard__stars svg{ width:18px; height:18px; }
.tcard__text{ margin:0 0 22px; font-size:16px; color:var(--ink); line-height:1.55; }
.tcard__who{ display:flex; align-items:center; gap:13px; margin-top:auto; }
.tcard__av{ width:42px; height:42px; border-radius:50%; background:rgba(70,250,36,.14); color:var(--green); display:flex; align-items:center; justify-content:center; font-family:var(--display); font-size:18px; flex-shrink:0; }
.tcard__name{ font-size:14.5px; font-weight:700; }
.tcard__meta{ font-size:13px; color:var(--ink-faint); }
.reviews-cta{ display:flex; align-items:center; justify-content:center; gap:18px; flex-wrap:wrap; margin-top:36px; }
.reviews-score{ display:inline-flex; align-items:center; gap:12px; font-size:15px; color:var(--ink-soft); }
.reviews-score b{ font-family:var(--display); font-size:30px; color:var(--ink); }
.reviews-score .gstars{ display:flex; gap:2px; color:var(--green); }
.reviews-score .gstars svg{ width:18px; height:18px; }

/* ---------- FAQ ---------- */
.faq{ max-width:880px; margin-inline:auto; }
.faq__item{ border-bottom:1px solid var(--line); }
.faq__item:first-child{ border-top:1px solid var(--line); }
.faq__q{ width:100%; text-align:left; background:none; border:0; color:var(--ink); font-family:var(--sans); font-size:clamp(17px,2vw,20px); font-weight:700; padding:26px 52px 26px 0; cursor:pointer; position:relative; display:block; letter-spacing:.005em; }
.faq__q::after{ content:""; position:absolute; right:6px; top:50%; width:18px; height:18px; transform:translateY(-50%);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24' fill='none' stroke='%2346FA24' stroke-width='2.4' stroke-linecap='round'%3E%3Cpath d='M12 5v14M5 12h14'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:center; transition:transform .25s ease; }
.faq__item.open .faq__q::after{ transform:translateY(-50%) rotate(135deg); }
.faq__a{ max-height:0; overflow:hidden; transition:max-height .3s ease; }
.faq__a p{ margin:0; padding:0 52px 28px 0; color:var(--ink-soft); font-size:16px; max-width:74ch; line-height:1.6; }

/* ---------- Dashboard (animierte Zahlen + Balken) ---------- */
.dash{ border:1px solid var(--line); border-radius:var(--radius-lg); background:linear-gradient(180deg,rgba(255,255,255,.04),rgba(255,255,255,.01)); padding:clamp(24px,3.4vw,44px); }
.dash__kpis{ display:grid; grid-template-columns:repeat(4,1fr); gap:20px; }
.kpi{ padding:4px 6px; border-left:2px solid rgba(70,250,36,.4); padding-left:18px; }
.kpi__num{ font-family:var(--display); font-size:clamp(34px,4vw,52px); line-height:1; color:var(--green); }
.kpi__lbl{ margin-top:10px; font-size:14px; color:var(--ink-soft); max-width:20ch; }
.dash__chart{ margin-top:clamp(28px,3vw,42px); padding-top:clamp(24px,3vw,36px); border-top:1px solid var(--line); }
.dash__chart-head{ display:flex; align-items:baseline; justify-content:space-between; gap:16px; margin-bottom:24px; flex-wrap:wrap; }
.dash__chart-head h3{ margin:0; font-size:18px; font-weight:700; }
.dash__chart-head span{ font-size:13px; color:var(--ink-faint); font-weight:600; letter-spacing:.04em; }
.dash-checks{ list-style:none; margin:0; padding:0; display:grid; grid-template-columns:1fr 1fr; gap:18px 44px; }
.dash-checks li{ display:flex; align-items:flex-start; gap:14px; font-size:16px; color:var(--ink); line-height:1.4; }
.dash-checks svg{ width:22px; height:22px; flex-shrink:0; margin-top:1px; color:var(--green-ink); background:var(--green); border-radius:50%; padding:4px; box-shadow:0 0 14px var(--green-glow); animation:check-ping 4s ease-in-out infinite; }
.dash-checks li:nth-child(1) svg{ animation-delay:0s; }
.dash-checks li:nth-child(2) svg{ animation-delay:.35s; }
.dash-checks li:nth-child(3) svg{ animation-delay:.7s; }
.dash-checks li:nth-child(4) svg{ animation-delay:1.05s; }
.dash-checks li:nth-child(5) svg{ animation-delay:1.4s; }
.dash-checks li:nth-child(6) svg{ animation-delay:1.75s; }
@keyframes check-ping{
  0%, 68%, 100%{ background:var(--green); box-shadow:0 0 14px var(--green-glow); transform:scale(1); }
  80%{ background:#ff2d2d; box-shadow:0 0 20px 4px rgba(255,45,45,.9); transform:scale(1.18); }
  90%{ background:#ff5a3c; box-shadow:0 0 12px 1px rgba(255,90,60,.55); transform:scale(1.06); }
}
@media (prefers-reduced-motion: reduce){ .dash-checks svg{ animation:none; } }
.bars{ display:grid; grid-auto-flow:column; grid-auto-columns:1fr; align-items:end; gap:clamp(6px,1vw,14px); height:200px; }
.bar{ display:flex; flex-direction:column; justify-content:flex-end; height:100%; gap:10px; }
.bar__fill{ width:100%; height:0; border-radius:7px 7px 0 0; background:linear-gradient(180deg,var(--green),var(--green-deep)); transition:height 1.1s cubic-bezier(.2,.7,.2,1); min-height:3px; }
.bar__lbl{ text-align:center; font-size:11.5px; color:var(--ink-faint); font-weight:600; }
.dash__trust{ display:flex; flex-wrap:wrap; gap:14px 32px; margin-top:clamp(24px,3vw,34px); padding-top:clamp(22px,2.6vw,30px); border-top:1px solid var(--line); }
.dash__trust span{ display:inline-flex; align-items:center; gap:10px; font-size:15px; font-weight:600; color:var(--ink-soft); }
.dash__trust svg{ width:19px; height:19px; color:var(--green); flex-shrink:0; }

/* ---------- Typische Fälle ---------- */
.cases{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; }
.case{ padding:28px 24px; border:1px solid var(--line); border-radius:var(--radius); background:linear-gradient(180deg,rgba(255,255,255,.03),rgba(255,255,255,.008)); transition:border-color .2s,transform .2s; }
.case:hover{ border-color:rgba(70,250,36,.4); transform:translateY(-4px); }
.case__ico{ width:46px; height:46px; border-radius:12px; background:rgba(70,250,36,.12); display:flex; align-items:center; justify-content:center; margin-bottom:18px; }
.case__ico svg{ width:24px; height:24px; color:var(--green); }
.case h3{ font-size:18px; margin:0 0 9px; font-weight:700; }
.case p{ margin:0; font-size:14px; color:var(--ink-soft); line-height:1.55; }

/* ---------- Team ---------- */
.team{ display:grid; grid-template-columns:repeat(5,1fr); gap:16px; }
.tmember{ display:flex; flex-direction:column; border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; background:linear-gradient(180deg,rgba(255,255,255,.035),rgba(255,255,255,.008)); transition:border-color .2s,transform .2s; }
.tmember:hover{ border-color:rgba(70,250,36,.45); transform:translateY(-5px); }
.tmember__photo{ position:relative; aspect-ratio:3/4; overflow:hidden; }
.tmember__photo img{ width:100%; height:100%; object-fit:cover; transition:transform .55s cubic-bezier(.2,.7,.2,1); }
.tmember:hover .tmember__photo img{ transform:scale(1.05); }
.tmember__photo::after{ content:""; position:absolute; inset:0; background:linear-gradient(to top, rgba(10,12,10,.94) 5%, rgba(10,12,10,.35) 32%, transparent 52%); }
.tmember__badge{ position:absolute; top:13px; left:13px; z-index:2; font-size:10.5px; font-weight:800; letter-spacing:.08em; text-transform:uppercase; color:var(--green-ink); background:var(--green); padding:5px 11px; border-radius:999px; box-shadow:0 6px 18px -6px var(--green-glow); }
.tmember__cap{ position:absolute; left:18px; right:16px; bottom:15px; z-index:2; }
.tmember__cap h3{ font-size:18px; margin:0 0 4px; font-weight:700; letter-spacing:.005em; }
.tmember__cap .role{ font-size:11.5px; font-weight:700; letter-spacing:.09em; text-transform:uppercase; color:var(--green); }
.tmember__bio{ padding:16px 18px 20px; font-size:13.5px; color:var(--ink-soft); line-height:1.5; margin:0; }

/* ---------- Google Maps ---------- */
.map-embed{ border:1px solid var(--line); border-radius:var(--radius-lg); overflow:hidden; box-shadow:0 30px 70px -44px rgba(0,0,0,.85); }
.map-embed iframe{ display:block; width:100%; height:clamp(320px,42vw,460px); border:0; filter:grayscale(.4) contrast(.95) brightness(.92); }

/* Consent-Platzhalter für externe Einbettungen */
.embed-consent{ height:clamp(320px,42vw,460px); display:flex; align-items:center; justify-content:center; text-align:center; padding:30px; background:var(--bg-3); }
.embed-consent__inner{ max-width:380px; display:flex; flex-direction:column; align-items:center; gap:12px; }
.embed-consent__ico{ width:54px; height:54px; border-radius:14px; background:rgba(70,250,36,.12); display:flex; align-items:center; justify-content:center; }
.embed-consent__ico svg{ width:28px; height:28px; color:var(--green); }
.embed-consent h4{ font-size:18px; font-weight:700; margin:2px 0 0; }
.embed-consent p{ font-size:14.5px; color:var(--ink-soft); line-height:1.55; margin:0 0 6px; }
.embed-consent__note{ font-size:12.5px; color:var(--ink-faint); }
.embed-consent__note a{ color:var(--green); }

/* ---------- Fahrzeug-Showcase (clean) ---------- */
.van-clean{ width:100%; aspect-ratio:16/9; object-fit:cover; object-position:center; border-radius:var(--radius-lg); border:1px solid var(--line); box-shadow:0 40px 80px -44px rgba(0,0,0,.85); }
@media (max-width:760px){ .van-clean{ aspect-ratio:4/3; } }

@media (max-width:980px){
  .tg{ grid-template-columns:1fr 1fr; }
  .dash__kpis{ grid-template-columns:1fr 1fr; gap:24px; }
  .cases{ grid-template-columns:1fr 1fr; }
  .team{ grid-template-columns:repeat(3,1fr); gap:16px; }
  .bars{ height:170px; }
}
@media (max-width:620px){
  .tg{ grid-template-columns:1fr; }
  .cases{ grid-template-columns:1fr; }
  .team{ grid-template-columns:repeat(2,1fr); }
  .dash-checks{ grid-template-columns:1fr; gap:15px; }
  .bar__lbl{ font-size:9.5px; }
}

/* ---------- Warum uns (Checkliste + 100%-Gauges) ---------- */
.why{ position:relative; overflow:hidden; }
.why::before{ content:""; position:absolute; inset:0; background:radial-gradient(700px 420px at 50% -10%, rgba(70,250,36,.10), transparent 60%); pointer-events:none; }
.why-grid{ display:grid; grid-template-columns:1fr 1fr; gap:14px 56px; max-width:940px; margin:0 auto; }
.why-grid .check-list li{ font-size:16.5px; color:var(--ink); }
.gauges{ display:grid; grid-template-columns:repeat(4,1fr); gap:28px; max-width:940px; margin:clamp(40px,5vw,64px) auto 0; }
.gauge__top{ display:flex; align-items:baseline; justify-content:space-between; gap:8px; }
.gauge__num{ font-family:var(--display); font-size:clamp(28px,3vw,38px); line-height:1; color:var(--green); }
.gauge__ico{ width:26px; height:26px; color:var(--green); }
.gauge__ico svg{ width:26px; height:26px; }
.gauge__lbl{ margin-top:12px; font-size:14px; font-weight:600; color:var(--ink-soft); }
.gauge__track{ height:7px; border-radius:999px; background:rgba(255,255,255,.10); margin-top:14px; overflow:hidden; }
.gauge__fill{ height:100%; width:0; border-radius:999px; background:linear-gradient(90deg,var(--green-deep),var(--green)); box-shadow:0 0 14px var(--green-glow); transition:width 1.2s cubic-bezier(.2,.7,.2,1); }

/* ---------- Vergleichstabelle ---------- */
.vs{ border:1px solid var(--line); border-radius:var(--radius-lg); overflow:hidden; }
.vs__head{ display:grid; grid-template-columns:1fr 1fr; }
.vs__head > div{ padding:20px clamp(20px,2.4vw,30px); font-size:16px; font-weight:800; letter-spacing:.01em; display:flex; align-items:center; gap:11px; }
.vs__head .good{ background:var(--green); color:var(--green-ink); }
.vs__head .bad{ background:rgba(255,255,255,.07); color:var(--ink-soft); }
.vs__head svg{ width:20px; height:20px; }
.vs__row{ display:grid; grid-template-columns:1fr 1fr; border-top:1px solid var(--line); }
.vs__cell{ padding:24px clamp(20px,2.4vw,30px); }
.vs__cell.good{ background:rgba(70,250,36,.045); border-right:1px solid var(--line); }
.vs__cell h4{ margin:0 0 8px; font-size:16px; font-weight:700; display:flex; align-items:center; gap:10px; }
.vs__cell h4 svg{ width:18px; height:18px; flex-shrink:0; }
.vs__cell.good h4 svg{ color:var(--green); }
.vs__cell.bad h4{ color:var(--ink-soft); }
.vs__cell.bad h4 svg{ color:var(--ink-faint); }
.vs__cell p{ margin:0; font-size:14.5px; color:var(--ink-soft); line-height:1.55; }
.vs__cell.bad p{ color:var(--ink-faint); }
.promise{ display:flex; gap:16px; align-items:flex-start; margin-top:28px; padding:24px 28px; border:1px solid rgba(70,250,36,.4); border-radius:var(--radius); background:rgba(70,250,36,.06); }
.promise__ico{ width:40px; height:40px; border-radius:11px; background:rgba(70,250,36,.16); display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.promise__ico svg{ width:22px; height:22px; color:var(--green); }
.promise p{ margin:0; font-size:16px; color:var(--ink); line-height:1.6; }
.promise b{ font-weight:800; }

@media (max-width:760px){
  .why-grid{ grid-template-columns:1fr; gap:14px; }
  .gauges{ grid-template-columns:1fr 1fr; gap:24px 28px; }
  .vs__head, .vs__row{ grid-template-columns:1fr; }
  .vs__cell.good{ border-right:0; border-bottom:1px solid var(--line); }
  .vs__head .bad, .vs__head .good{ font-size:15px; }
}

/* ============================================================
   RECHTSSEITEN + COOKIE-BANNER
   ============================================================ */
.legal{ max-width:840px; }
.legal__note{ margin:0 0 34px; padding:16px 20px; border:1px solid rgba(70,250,36,.3); border-radius:var(--radius); background:rgba(70,250,36,.05); font-size:14px; color:var(--ink-soft); line-height:1.6; }
.legal h2{ font-family:var(--sans); font-weight:800; font-size:clamp(20px,2.4vw,26px); margin:46px 0 14px; letter-spacing:.005em; }
.legal h2:first-of-type{ margin-top:0; }
.legal h3{ font-size:17px; font-weight:700; margin:26px 0 8px; }
.legal p{ margin:0 0 14px; font-size:16px; color:var(--ink-soft); line-height:1.7; overflow-wrap:anywhere; }
.legal a{ color:var(--green); }
.legal a:hover{ text-decoration:underline; }
.legal strong{ color:var(--ink); font-weight:700; }
.legal ul{ margin:0 0 16px; padding-left:22px; }
.legal li{ font-size:16px; color:var(--ink-soft); line-height:1.7; margin-bottom:7px; overflow-wrap:anywhere; }
.legal address{ font-style:normal; color:var(--ink-soft); font-size:16px; line-height:1.7; }
.legal-head{ font-weight:600; color:var(--ink); }
.legal-stand{ font-size:14px; color:var(--ink-faint); margin-top:4px; }
.legal-foot{ font-size:15px; }
.legal hr{ border:0; border-top:1px solid var(--line); margin:40px 0; }

/* Cookie-Banner */
.cookie{ position:fixed; left:0; right:0; bottom:0; z-index:200; transform:translateY(120%); transition:transform .4s cubic-bezier(.2,.7,.2,1); }
.cookie.show{ transform:none; }
.cookie__card{ margin:0 auto; max-width:var(--maxw); margin-inline:var(--gut); margin-bottom:18px;
  background:rgba(16,20,16,.92); backdrop-filter:blur(16px) saturate(140%);
  border:1px solid var(--line); border-radius:var(--radius-lg);
  box-shadow:0 30px 70px -20px rgba(0,0,0,.7);
  padding:22px clamp(20px,2.6vw,30px); display:flex; align-items:center; gap:24px; flex-wrap:wrap; }
.cookie__text{ flex:1; min-width:240px; font-size:14px; color:var(--ink-soft); line-height:1.55; }
.cookie__text strong{ color:var(--ink); display:block; font-size:15px; margin-bottom:4px; }
.cookie__text a{ color:var(--green); }
.cookie__btns{ display:flex; gap:12px; flex-wrap:wrap; }
@media (max-width:560px){
  .cookie__card{ flex-direction:column; align-items:stretch; gap:16px; }
  .cookie__btns .btn{ flex:1; }
}

/* ---------- Zwei-Panel: Wir schaffen Platz / Das nehmen wir mit ---------- */
.duo{ display:grid; grid-template-columns:1fr 1fr; gap:18px; }
.duo__card{ padding:clamp(26px,3vw,40px); border:1px solid var(--line); border-radius:var(--radius-lg); background:linear-gradient(180deg,rgba(255,255,255,.04),rgba(255,255,255,.01)); }
.duo__title{ display:flex; align-items:center; gap:14px; margin:0 0 24px; padding-bottom:20px; border-bottom:1px solid var(--line); font-size:clamp(20px,2.3vw,26px); font-weight:800; letter-spacing:.005em; }
.duo__title .ic{ width:44px; height:44px; border-radius:12px; background:rgba(70,250,36,.12); display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.duo__title .ic svg{ width:23px; height:23px; color:var(--green); }
.duo .check-list{ gap:15px; }
.duo .check-list li{ font-size:16.5px; color:var(--ink); }
@media (max-width:760px){ .duo{ grid-template-columns:1fr; } }

/* ---------- Schwebende Kontakt-Buttons (WhatsApp / Telegram) ---------- */
.fab{ position:fixed; right:20px; bottom:22px; z-index:150; display:flex; flex-direction:column; gap:13px; }
.fab a{ width:54px; height:54px; border-radius:50%; display:flex; align-items:center; justify-content:center; color:#fff;
  box-shadow:0 12px 30px -8px rgba(0,0,0,.65); transition:transform .18s ease, box-shadow .18s ease; }
.fab a:hover{ transform:translateY(-3px) scale(1.05); }
.fab a svg{ width:30px; height:30px; }
.fab .fab--wa{ background:#25D366; }
.fab .fab--tg{ background:#229ED9; }
.fab .fab--wa::after{ content:""; position:absolute; width:54px; height:54px; border-radius:50%; box-shadow:0 0 0 0 rgba(37,211,102,.5); animation:fab-pulse 2.4s ease-out infinite; }
@keyframes fab-pulse{ 70%{ box-shadow:0 0 0 14px rgba(37,211,102,0); } 100%{ box-shadow:0 0 0 0 rgba(37,211,102,0); } }
@media (prefers-reduced-motion: reduce){ .fab .fab--wa::after{ animation:none; } }
@media (max-width:560px){ .fab{ right:16px; bottom:16px; } .fab a{ width:50px; height:50px; } .fab a svg{ width:27px; height:27px; } }

/* ---------- Anfragebox-Einbettung ---------- */
.anfragebox{ border-radius:var(--radius-lg); overflow:hidden; border:1px solid var(--line); box-shadow:0 30px 70px -44px rgba(0,0,0,.85); background:var(--bg-2); }
.anfragebox iframe{ display:block; width:100%; border:0; }
