/* ===================== Self-hosted Fonts (DSGVO — kein Google-CDN) ===================== */
/* Variable Fonts: ein woff2 je Familie deckt alle Schnitte ab. Subset: latin (inkl. Umlaute + €). */
@font-face{
  font-family:'Space Grotesk';
  font-style:normal;
  font-weight:400 700;
  font-display:swap;
  src:url('fonts/space-grotesk-latin.woff2') format('woff2');
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;
}
@font-face{
  font-family:'JetBrains Mono';
  font-style:normal;
  font-weight:400 600;
  font-display:swap;
  src:url('fonts/jetbrains-mono-latin.woff2') format('woff2');
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;
}

:root{
  --bg:#070d1a;
  --bg-1:#0b1424;
  --bg-2:#101c33;
  --line:#1b2a47;
  --line-2:#243657;
  --ink:#e8eefb;
  --ink-dim:#a0adc7;
  --ink-mute:#5e6c8a;
  --wp:#21759B;
  --wp-2:#2b8fc0;
  --blue:#3b82f6;
  --cyan:#22d3ee;
  --ok:#22c55e;
  --warn:#f59e0b;
  --bad:#ef4444;
  --bad-2:#7f1d1d;
  --radius:14px;
  --radius-sm:8px;
  --shadow: 0 1px 0 rgba(255,255,255,.04) inset, 0 30px 60px -20px rgba(0,0,0,.6);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  background:
    radial-gradient(1200px 600px at 80% -10%, rgba(33,117,155,.18), transparent 60%),
    radial-gradient(900px 500px at 0% 20%, rgba(59,130,246,.10), transparent 60%),
    var(--bg);
  color:var(--ink);
  font-family:'Space Grotesk', system-ui, sans-serif;
  font-size:16px;
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
.mono{font-family:'JetBrains Mono', ui-monospace, monospace; font-feature-settings:"ss02"}
a{color:inherit; text-decoration:none; -webkit-tap-highlight-color:rgba(43,143,192,.25)}
button{font:inherit; color:inherit; cursor:pointer; border:0; background:none; -webkit-tap-highlight-color:rgba(43,143,192,.25)}
img{display:block; max-width:100%}

/* ===================== Layout ===================== */
.wrap{max-width:1280px; margin:0 auto; padding:0 32px}
@media (max-width:640px){ .wrap{padding:0 20px} }

/* ===================== Top status strip ===================== */
.topbar{
  border-bottom:1px solid var(--line);
  background:rgba(7,13,26,.7);
  backdrop-filter:blur(8px);
  font-family:'JetBrains Mono', ui-monospace, monospace;
  font-size:12px;
  color:var(--ink-dim);
}
.topbar-inner{
  display:flex; justify-content:space-between; align-items:center;
  padding:9px 32px;
}
.topbar .pill{display:inline-flex; align-items:center; gap:8px}
.dot{width:7px; height:7px; border-radius:50%; background:var(--ok); box-shadow:0 0 0 4px rgba(34,197,94,.15); animation: pulse 2.2s infinite}
@keyframes pulse{ 0%,100%{box-shadow:0 0 0 4px rgba(34,197,94,.15)} 50%{box-shadow:0 0 0 4px rgba(34,197,94,.3)} }
.topbar .meta{display:flex; gap:22px}
.topbar .meta span{color:var(--ink-mute)}
.topbar .meta b{color:var(--ink); font-weight:500}

/* ===================== Nav ===================== */
.nav{
  position:sticky; top:0; z-index:20;
  border-bottom:1px solid var(--line);
  background:rgba(7,13,26,.85);
  backdrop-filter:blur(12px);
}
.nav-inner{
  display:flex; align-items:center; justify-content:space-between;
  padding:14px 32px;
  max-width:1280px; margin:0 auto;
}
.brand{display:flex; align-items:center; gap:12px}
.brand-mark{
  width:34px; height:34px; border-radius:9px;
  background:linear-gradient(135deg,#0e2244,#1d3e74);
  border:1px solid var(--line-2);
  display:grid; place-items:center;
  position:relative;
}
.brand-mark::before{
  content:""; width:18px; height:18px; border-radius:50%;
  border:2px solid var(--wp-2);
  background: radial-gradient(circle at 30% 30%, var(--wp-2) 0 4px, transparent 5px);
}
.brand-name{font-weight:600; letter-spacing:-.01em}
.brand-name b{color:var(--wp-2)}

/* Hamburger toggle — hidden on desktop, shown <=880px */
.nav-toggle{
  display:none;
  width:44px; height:44px; border-radius:10px;
  align-items:center; justify-content:center;
  flex-direction:column; gap:5px;
  border:1px solid var(--line-2); background:rgba(255,255,255,.02);
}
.nav-toggle-bar{
  display:block; width:20px; height:2px; border-radius:2px; background:var(--ink);
  transition: transform .2s ease, opacity .2s ease;
}
.nav.is-open .nav-toggle-bar:nth-child(1){ transform:translateY(7px) rotate(45deg) }
.nav.is-open .nav-toggle-bar:nth-child(2){ opacity:0 }
.nav.is-open .nav-toggle-bar:nth-child(3){ transform:translateY(-7px) rotate(-45deg) }
.brand-sub{font-family:'JetBrains Mono', monospace; font-size:10px; color:var(--ink-mute); letter-spacing:.08em; text-transform:uppercase; margin-top:1px}
.nav-links{display:flex; gap:8px; align-items:center}
.nav-links a{
  font-size:14px; color:var(--ink-dim); padding:8px 14px; border-radius:8px;
  transition: color .15s, background .15s;
}
.nav-links a:hover{color:var(--ink); background:rgba(255,255,255,.04)}
.btn{
  display:inline-flex; align-items:center; gap:8px;
  padding:10px 18px; border-radius:10px;
  font-weight:500; font-size:14px;
  transition: transform .12s, background .15s, box-shadow .15s;
}
.btn:active{transform:translateY(1px)}
.btn-primary{
  background:linear-gradient(180deg, var(--wp-2), var(--wp));
  color:#fff;
  box-shadow:0 1px 0 rgba(255,255,255,.18) inset, 0 8px 24px -8px rgba(33,117,155,.6);
}
.btn-primary:hover{filter:brightness(1.08)}
.btn-ghost{ border:1px solid var(--line-2); background:rgba(255,255,255,.02)}
.btn-ghost:hover{background:rgba(255,255,255,.05)}
.btn-arrow::after{content:"→"; font-family:'JetBrains Mono', monospace}

@media (max-width:880px){
  .nav-toggle{ display:flex }
  .nav-links{
    position:absolute; top:100%; left:0; right:0;
    flex-direction:column; align-items:stretch; gap:4px;
    padding:12px 20px 18px;
    background:rgba(7,13,26,.97); backdrop-filter:blur(12px);
    border-bottom:1px solid var(--line);
    transform:translateY(-12px); opacity:0; pointer-events:none;
    transition: opacity .2s ease, transform .2s ease;
  }
  .nav.is-open .nav-links{ transform:none; opacity:1; pointer-events:auto }
  .nav-links a{ font-size:16px; padding:14px 12px; min-height:44px; display:flex; align-items:center }
  .nav-links .btn{ justify-content:center; margin-top:6px }
}
/* Touch-Targets: alle Buttons mind. 44px hoch */
.btn{ min-height:44px }

/* ===================== Hero ===================== */
.hero{padding:64px 0 40px; position:relative}
.hero-grid{display:grid; grid-template-columns: 1fr; gap:48px}
.hero-head{ max-width:880px }
.tag{
  display:inline-flex; align-items:center; gap:10px;
  font-family:'JetBrains Mono', monospace;
  font-size:11px; letter-spacing:.12em; text-transform:uppercase;
  color:var(--wp-2);
  padding:6px 12px; border-radius:999px;
  border:1px solid rgba(43,143,192,.4);
  background:rgba(43,143,192,.08);
}
h1.display{
  font-size: clamp(32px, 6.2vw, 84px);
  font-weight:700;
  line-height:0.98;
  letter-spacing:-.035em;
  margin: 18px 0 22px;
  text-wrap: balance;
}
h1.display em{font-style:normal; color:var(--ink-mute); font-weight:400}
h1.display .accent{
  background:linear-gradient(180deg,#7cc8ec,var(--wp-2));
  -webkit-background-clip:text; background-clip:text; color:transparent;
}
.lede{
  font-size: clamp(17px, 1.4vw, 19px);
  color:var(--ink-dim); max-width:640px; line-height:1.55;
}
.hero-cta{display:flex; gap:12px; align-items:center; flex-wrap:wrap; margin-top:32px}
.hero-cta .btn{padding:14px 22px; font-size:15px}
.hero-cta .meta{
  font-family:'JetBrains Mono', monospace; font-size:12px; color:var(--ink-mute);
  display:inline-flex; gap:14px; margin-left:6px; flex-wrap:wrap;
}
.hero-cta .meta b{color:var(--ink); font-weight:500}

/* Split-screen panels */
.split{
  margin-top:56px;
  display:grid; grid-template-columns: 1fr 1fr; gap:0;
  border:1px solid var(--line);
  border-radius:18px;
  overflow:hidden;
  background:var(--bg-1);
}
@media (max-width:880px){ .split{grid-template-columns:1fr} }
.panel{ padding:28px 28px 24px; position:relative}
.panel + .panel{ border-left:1px solid var(--line) }
@media (max-width:880px){ .panel + .panel{border-left:0; border-top:1px solid var(--line)} }
.panel-bad{
  background:
    radial-gradient(600px 280px at 80% 110%, rgba(239,68,68,.15), transparent 60%),
    linear-gradient(180deg, rgba(127,29,29,.08), transparent 70%);
}
.panel-good{
  background:
    radial-gradient(600px 280px at 20% 110%, rgba(34,197,94,.14), transparent 60%),
    linear-gradient(180deg, rgba(43,143,192,.08), transparent 70%);
}
.panel-head{
  display:flex; justify-content:space-between; align-items:center;
  font-family:'JetBrains Mono', monospace; font-size:11px; letter-spacing:.1em; text-transform:uppercase;
  margin-bottom:18px;
}
.panel-head .lbl{color:var(--ink-mute)}
.panel-head .state{display:inline-flex; align-items:center; gap:8px; font-weight:600}
.state.bad{color:var(--bad)}
.state.good{color:var(--ok)}
.state .dot{width:7px; height:7px}
.state.bad .dot{background:var(--bad); box-shadow:0 0 0 4px rgba(239,68,68,.15); animation:pulse 1.4s infinite}
.state.good .dot{background:var(--ok)}

.row{
  display:flex; align-items:center; gap:14px;
  padding:14px 0;
  border-top:1px dashed var(--line-2);
  font-family:'JetBrains Mono', monospace; font-size:13px;
}
.row:first-of-type{border-top:0}
.row .ico{
  width:28px; height:28px; border-radius:7px;
  display:grid; place-items:center; flex:none;
  font-size:14px; font-weight:600;
}
.row.bad .ico{background:rgba(239,68,68,.13); color:var(--bad)}
.row.good .ico{background:rgba(34,197,94,.13); color:var(--ok)}
.row .key{color:var(--ink); font-weight:500; flex:none; min-width:130px}
.row .val{color:var(--ink-dim)}
.row.bad .val{color:#fca5a5}
.row.good .val{color:#86efac}
.row .age{margin-left:auto; color:var(--ink-mute); font-size:11px}

.panel-foot{
  margin-top:18px; padding-top:14px;
  display:flex; justify-content:space-between; align-items:center;
  font-family:'JetBrains Mono', monospace; font-size:11px;
  color:var(--ink-mute);
}
.cost{font-size:22px; font-weight:600; font-family:'Space Grotesk', sans-serif; letter-spacing:-.01em}
.cost.bad{color:#fca5a5}
.cost.good{color:#86efac}
.cost small{font-size:11px; color:var(--ink-mute); font-weight:400; font-family:'JetBrains Mono', monospace; display:block; letter-spacing:.06em; text-transform:uppercase}

/* Hero floating numbers behind */
.hero::before{
  content:""; position:absolute; right:-100px; top:-50px; width:600px; height:600px;
  background: conic-gradient(from 200deg, transparent 0deg, rgba(43,143,192,.08) 40deg, transparent 100deg);
  filter: blur(50px);
  pointer-events:none;
}

/* ===================== Section common ===================== */
section{padding:80px 0; position:relative}
.section-head{margin-bottom:48px; display:flex; justify-content:space-between; align-items:end; gap:32px; flex-wrap:wrap}
.section-head .left{max-width:600px}
.section-head .eyebrow{
  font-family:'JetBrains Mono', monospace;
  font-size:11px; letter-spacing:.18em; text-transform:uppercase;
  color:var(--wp-2);
  display:flex; align-items:center; gap:10px;
}
.section-head .eyebrow::before{content:""; width:24px; height:1px; background:var(--wp-2)}
.section-head h2{
  font-size: clamp(32px, 4vw, 52px);
  font-weight:700; line-height:1.02; letter-spacing:-.025em;
  margin: 14px 0 0;
  text-wrap: balance;
}
.section-head .sub{color:var(--ink-dim); max-width:520px; font-size:15px}

/* ===================== Services grid ===================== */
.services{
  display:grid; grid-template-columns: repeat(3, 1fr); gap:1px;
  background:var(--line);
  border:1px solid var(--line);
  border-radius:14px;
  overflow:hidden;
}
@media (max-width:980px){ .services{grid-template-columns:repeat(2,1fr)} }
@media (max-width:620px){ .services{grid-template-columns:1fr} }
.svc{
  background:var(--bg-1);
  padding:28px;
  transition: background .2s;
  position:relative;
  display:flex; flex-direction:column;
}
.svc:hover{background:var(--bg-2)}
.svc-num{
  font-family:'JetBrains Mono', monospace; font-size:11px;
  color:var(--ink-mute); letter-spacing:.1em;
}
.svc-title{
  display:flex; justify-content:space-between; align-items:start;
  margin-top:12px; margin-bottom:8px;
}
.svc-title h3{font-size:20px; font-weight:600; margin:0; letter-spacing:-.01em}
.svc-sla{
  font-family:'JetBrains Mono', monospace; font-size:11px;
  padding:4px 10px; border-radius:999px;
  background:rgba(43,143,192,.12); color:var(--wp-2);
  border:1px solid rgba(43,143,192,.3);
  white-space:nowrap;
}
.svc p{color:var(--ink-dim); font-size:14px; line-height:1.55; margin:0}
.svc-bar{
  margin-top:auto; height:3px; border-radius:2px;
  background:var(--line);
  overflow:hidden; position:relative;
}
.svc p{ margin-bottom:20px }
.svc-bar::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(90deg, var(--wp-2), var(--cyan));
  width: var(--w, 100%);
}

/* ===================== Stats ===================== */
.stats{
  display:grid; grid-template-columns:repeat(4,1fr);
  gap:24px;
  padding:48px 0;
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
}
@media (max-width:760px){ .stats{grid-template-columns:repeat(2,1fr)} }
.stat .num{
  font-size: clamp(40px, 5vw, 64px);
  font-weight:700; letter-spacing:-.04em; line-height:1;
  background:linear-gradient(180deg, #fff, #87a6cf);
  -webkit-background-clip:text; background-clip:text; color:transparent;
}
.stat .num small{
  font-size:.5em; vertical-align:top; margin-left:2px; color:var(--wp-2); background:none; -webkit-text-fill-color:var(--wp-2);
}
.stat .lbl{
  font-family:'JetBrains Mono', monospace; font-size:11px;
  letter-spacing:.12em; text-transform:uppercase; color:var(--ink-mute);
  margin-top:10px;
}

/* ===================== Comparison ===================== */
.compare{
  display:grid; grid-template-columns: 1fr auto 1fr; gap:0;
  border:1px solid var(--line); border-radius:18px; overflow:hidden;
  background:var(--bg-1);
}
@media (max-width:880px){ .compare{grid-template-columns:1fr; }
  .compare .divider{display:none}
}
.compare .col{padding:36px}
.compare .col.bad{
  background:
    linear-gradient(180deg, rgba(127,29,29,.18), transparent 70%);
}
.compare .col.good{
  background:
    linear-gradient(180deg, rgba(43,143,192,.16), transparent 70%);
}
.compare .col h3{
  display:flex; align-items:center; gap:12px;
  font-size:18px; margin:0 0 24px; font-weight:600;
  font-family:'JetBrains Mono', monospace; letter-spacing:.04em;
}
.compare .col.bad h3{color:#fca5a5}
.compare .col.good h3{color:#86efac}
.compare .divider{
  width:1px; background:var(--line); position:relative;
}
.compare .divider::after{
  content:"vs";
  position:absolute; top:50%; left:50%; transform:translate(-50%,-50%);
  background:var(--bg-1); border:1px solid var(--line);
  font-family:'JetBrains Mono', monospace; font-size:11px;
  width:34px; height:34px; border-radius:50%; display:grid; place-items:center;
  color:var(--ink-mute);
}
.compare ul{list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:14px}
.compare li{display:flex; gap:14px; align-items:flex-start; font-size:14px; color:var(--ink-dim)}
.compare li .icon{
  width:22px; height:22px; border-radius:6px; flex:none;
  display:grid; place-items:center; font-size:12px; font-weight:700;
  margin-top:1px;
}
.compare .bad li .icon{background:rgba(239,68,68,.13); color:var(--bad)}
.compare .good li .icon{background:rgba(34,197,94,.13); color:var(--ok)}
.compare li b{display:block; color:var(--ink); font-weight:500; margin-bottom:2px; font-size:14px}
.compare li.big{
  font-size:20px; color:var(--ink); font-weight:600;
  padding:10px 0 14px; border-bottom:1px dashed var(--line-2);
}
.compare li.big .icon{width:28px; height:28px; font-size:14px}

/* ===================== Pricing ===================== */
.pricing{
  display:grid; grid-template-columns: 1.1fr 1fr; gap:48px; align-items:start;
}
@media (max-width:880px){ .pricing{grid-template-columns:1fr} .pricing-side{position:static} }
.pricing-side{ position:sticky; top:88px; align-self:start }
.price-card{
  border:1px solid var(--line-2);
  border-radius:20px;
  padding:34px;
  background:
    radial-gradient(400px 200px at 100% 0%, rgba(43,143,192,.16), transparent 60%),
    linear-gradient(180deg, var(--bg-2), var(--bg-1));
  box-shadow: var(--shadow);
  position:relative;
  overflow:hidden;
}
.price-card::after{
  content:""; position:absolute; inset:0;
  background:
    radial-gradient(circle at 100% 100%, rgba(34,211,238,.12), transparent 60%);
  pointer-events:none;
}
.price-head{
  display:flex; justify-content:space-between; align-items:start; margin-bottom:24px;
}
.price-head .label{
  font-family:'JetBrains Mono', monospace; font-size:11px; letter-spacing:.14em; text-transform:uppercase;
  color:var(--ink-mute);
}
.price-badge{
  font-family:'JetBrains Mono', monospace; font-size:11px;
  background:linear-gradient(135deg, var(--ok), #16a34a);
  color:#062b14; font-weight:700; padding:5px 10px; border-radius:6px;
}
.price-amount{
  display:flex; align-items:baseline; gap:8px;
  font-weight:700; letter-spacing:-.03em;
}
.price-amount .euro{ font-size:72px; line-height:1 }
.price-amount .per{ color:var(--ink-mute); font-size:14px; font-family:'JetBrains Mono', monospace}
.price-sub{ color:var(--ink-dim); font-size:14px; margin-top:8px}
.price-list{
  margin:24px 0;
  display:flex; flex-direction:column; gap:10px;
  font-size:14px;
}
.price-list .ln{
  display:flex; gap:12px; align-items:start;
  padding:8px 0; border-top:1px solid var(--line);
}
.price-list .ln:first-child{border-top:0}
.price-list .ln::before{
  content:"✓"; color:var(--ok); font-weight:700; flex:none;
}
.price-list .ln span{color:var(--ink-dim)}
.price-list .ln b{color:var(--ink); font-weight:500; display:block}
.price-actions{display:flex; gap:12px; flex-wrap:wrap; margin-top:8px}
.price-actions .btn-whatsapp{ flex:1 0 100%; justify-content:center }
.price-foot{
  margin-top:18px; padding-top:18px; border-top:1px dashed var(--line-2);
  font-family:'JetBrains Mono', monospace; font-size:11px; color:var(--ink-mute);
  display:flex; justify-content:space-between; gap:12px; flex-wrap:wrap;
}

.pricing-side h3{
  font-size: clamp(28px, 3vw, 40px); margin:0 0 18px; line-height:1.05; letter-spacing:-.02em;
}
.pricing-side p{color:var(--ink-dim); font-size:15px; max-width:440px; margin:0 0 22px}
.trust-list{display:flex; flex-direction:column; gap:14px; margin:0; padding:0; list-style:none}
.trust-list li{display:flex; gap:14px; align-items:center; font-size:14px; color:var(--ink-dim)}
.trust-list li .ck{
  width:24px; height:24px; border-radius:50%;
  border:1px solid rgba(43,143,192,.4); background:rgba(43,143,192,.1);
  display:grid; place-items:center; color:var(--wp-2); font-weight:700; flex:none;
}

/* ===================== FAQ ===================== */
.faq{display:flex; flex-direction:column; gap:0; border-top:1px solid var(--line); border-bottom:1px solid var(--line)}
details.faq-item{ padding:24px 0; border-bottom:1px solid var(--line); cursor:pointer}
details.faq-item:last-child{border-bottom:0}
details.faq-item summary{
  display:flex; align-items:start; gap:18px;
  list-style:none; font-size:18px; font-weight:500; letter-spacing:-.01em;
}
details.faq-item summary::-webkit-details-marker{display:none}
details.faq-item summary::before{
  content:""; width:14px; height:14px; flex:none; margin-top:6px;
  background: linear-gradient(var(--wp-2),var(--wp-2)), linear-gradient(var(--wp-2),var(--wp-2));
  background-size: 14px 2px, 2px 14px;
  background-position: center; background-repeat:no-repeat;
  transition: transform .2s;
}
details[open].faq-item summary::before{
  background-size: 14px 2px, 0 0;
}
details.faq-item summary .num{
  font-family:'JetBrains Mono', monospace; font-size:13px; color:var(--ink-mute); flex:none;
  min-width:36px;
}
details.faq-item p{
  margin: 12px 0 0 68px;
  color:var(--ink-dim); font-size:15px; max-width:720px;
}

/* ===================== About / CTA ===================== */
.cta{
  border-radius:24px; padding:64px 48px;
  background:
    radial-gradient(600px 300px at 80% 30%, rgba(43,143,192,.25), transparent 70%),
    radial-gradient(500px 250px at 10% 80%, rgba(34,211,238,.15), transparent 70%),
    var(--bg-1);
  border:1px solid var(--line-2);
  text-align:center;
  position:relative;
  overflow:hidden;
}
.cta::before{
  content:""; position:absolute; inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.02) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.02) 1px, transparent 1px);
  background-size: 24px 24px;
  mask-image: radial-gradient(circle at center, black 30%, transparent 70%);
  pointer-events:none;
}
.cta > *{position:relative}
.cta h2{font-size: clamp(36px, 5vw, 60px); font-weight:700; line-height:1.02; letter-spacing:-.03em; margin:0 0 18px}
.cta p{color:var(--ink-dim); max-width:560px; margin:0 auto 28px; font-size:16px}
.cta .row-trust{
  display:flex; justify-content:center; gap:24px; flex-wrap:wrap;
  font-family:'JetBrains Mono', monospace; font-size:12px; color:var(--ink-mute);
  margin-top:32px;
}
.cta .row-trust span::before{content:"✓ "; color:var(--ok)}

/* ===================== Footer ===================== */
footer{
  border-top:1px solid var(--line); padding:56px 0 32px;
  margin-top:80px; font-size:14px; color:var(--ink-dim);
}
.foot-grid{display:grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap:48px; margin-bottom:48px}
@media (max-width:880px){ .foot-grid{grid-template-columns:1fr 1fr; gap:32px} }
.foot-grid h4{font-family:'JetBrains Mono', monospace; font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-mute); margin:0 0 14px}
.foot-grid ul{list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:10px}
.foot-grid a:hover{color:var(--wp-2)}
.foot-grid .about p{margin:14px 0 18px; max-width:340px; color:var(--ink-dim); font-size:14px}
.foot-bottom{
  display:flex; justify-content:space-between; align-items:center;
  padding-top:24px; border-top:1px solid var(--line);
  font-family:'JetBrains Mono', monospace; font-size:11px; color:var(--ink-mute);
  letter-spacing:.06em; flex-wrap:wrap; gap:12px;
}
.foot-bottom .partner{
  display:flex; align-items:center; gap:10px;
  color:var(--ink-mute);
}
.foot-bottom .legal{display:flex; gap:18px; flex-wrap:wrap}
.offer-badge{ display:inline-flex; align-items:center; gap:10px; padding:7px 12px; border:1px solid var(--line-2); border-radius:10px; background:rgba(255,255,255,.02); transition: background .15s }
.offer-badge:hover{ background:rgba(255,255,255,.05) }
.offer-badge img{ height:30px; width:auto }
.offer-badge small{ display:block; font-size:9px; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-mute); line-height:1.3 }
.offer-badge b{ display:block; font-size:13px; font-weight:600; color:var(--ink); font-family:'Space Grotesk', sans-serif; line-height:1.2 }

/* scroll reveal helper */
.reveal{opacity:0; transform:translateY(12px); transition: opacity .6s ease, transform .6s ease}
.reveal.is-in{opacity:1; transform:none}

/* ===================== Logo + Update Animations ===================== */
.brand{ gap:14px }
.brand-logo{ height:44px; width:auto; display:block; filter: drop-shadow(0 4px 16px rgba(43,143,192,.25)); }
.brand-logo-foot{ height:50px; width:auto; display:block; opacity:.95 }
/* Mobil: Topbar ausblenden + Footer-Logo proportional skalieren (statt fixer Höhe → keine Verzerrung) */
@media (max-width:880px){
  .topbar{ display:none }
  .brand-logo-foot{ height:auto; width:min(220px, 100%) }
}
/* Phones: vertikale Abstände straffen (Desktop unverändert) */
@media (max-width:640px){
  .hero{ padding:24px 0 24px }
  section{ padding:44px 0 }
  .section-head{ margin-bottom:28px }
  .hero-cta{ margin-top:24px }
}
@media (max-width:480px){ .brand-logo{ height:38px } }

/* SVG mark used in topbar + hero — recreates the two-circle logo, animatable */
.mark{ display:inline-block; vertical-align:middle }
.mark .ring-outer{ transform-origin:50px 50px; animation: spin-cw 14s linear infinite }
.mark .ring-inner{ transform-origin:50px 50px; animation: spin-ccw 9s linear infinite }
.mark .ring-outer, .mark .ring-inner{ fill:none; stroke:currentColor; stroke-linecap:round }
@keyframes spin-cw{ to{ transform: rotate(360deg) } }
@keyframes spin-ccw{ to{ transform: rotate(-360deg) } }

/* Hero watermark — giant rotating mark behind the headline */
.hero{ overflow:hidden }
.hero-mark{
  position:absolute; right:-160px; top:-120px;
  width: 720px; height:720px;
  color: rgba(43,143,192,.10);
  pointer-events:none; z-index:0;
  filter: blur(.3px);
}
.hero-mark .ring-outer{ animation-duration: 48s }
.hero-mark .ring-inner{ animation-duration: 32s }
.hero .wrap{ position:relative; z-index:1 }
@media (max-width:880px){ .hero-mark{ width:520px; height:520px; right:-200px; top:-160px } }

/* Topbar spinner mark replaces the green dot */
.topbar .mark{ color: var(--wp-2); margin-right:2px }
.topbar .pill{ gap:10px }

/* Counter — monospaced, prevent layout shift */
.count{ display:inline-block; min-width:1.5ch; text-align:right; font-variant-numeric: tabular-nums }

/* Logo entrance: fade + slight rise on first paint (passt zur Wortmarke) */
@keyframes logo-settle{
  0%   { opacity:0; transform: translateY(6px) scale(.97); filter: blur(3px) }
  100% { opacity:1; transform: none; filter: blur(0) }
}
.brand-logo{ animation: logo-settle 1.1s cubic-bezier(.2,.8,.2,1) both }

/* Status row reveal — stagger each row like a system check ticking off */
.panel .row{ opacity:0; transform: translateX(-8px); transition: opacity .45s ease, transform .45s ease }
.panel.is-in .row{ opacity:1; transform:none }
.panel.is-in .row:nth-child(2){ transition-delay: .05s }
.panel.is-in .row:nth-child(3){ transition-delay: .15s }
.panel.is-in .row:nth-child(4){ transition-delay: .25s }
.panel.is-in .row:nth-child(5){ transition-delay: .35s }
.panel.is-in .row:nth-child(6){ transition-delay: .45s }
.panel.is-in .row:nth-child(7){ transition-delay: .55s }

/* Service bars: fill on reveal */
.svc .svc-bar::after{ width:0; transition: width 1.2s cubic-bezier(.2,.8,.2,1) }
.services.is-in .svc:nth-child(1) .svc-bar::after{ width: var(--w, 100%); transition-delay:.05s }
.services.is-in .svc:nth-child(2) .svc-bar::after{ width: var(--w, 100%); transition-delay:.15s }
.services.is-in .svc:nth-child(3) .svc-bar::after{ width: var(--w, 100%); transition-delay:.25s }
.services.is-in .svc:nth-child(4) .svc-bar::after{ width: var(--w, 100%); transition-delay:.35s }
.services.is-in .svc:nth-child(5) .svc-bar::after{ width: var(--w, 100%); transition-delay:.45s }
.services.is-in .svc:nth-child(6) .svc-bar::after{ width: var(--w, 100%); transition-delay:.55s }

/* Service card hover: subtle lift + accent corner */
.svc{ transition: background .2s, transform .2s }
.svc:hover{ transform: translateY(-2px) }
.svc::after{
  content:""; position:absolute; right:14px; top:14px; width:6px; height:6px; border-radius:50%;
  background: var(--wp-2); opacity:0; transition: opacity .2s, transform .2s;
}
.svc:hover::after{ opacity:1; box-shadow:0 0 0 4px rgba(43,143,192,.18) }

/* Stat numbers animate up on reveal */
.stat .num{ opacity:0; transform: translateY(8px); transition: opacity .6s ease, transform .6s ease }
.stats.is-in .stat .num{ opacity:1; transform:none }
.stats.is-in .stat:nth-child(2) .num{ transition-delay:.1s }
.stats.is-in .stat:nth-child(3) .num{ transition-delay:.2s }
.stats.is-in .stat:nth-child(4) .num{ transition-delay:.3s }

@media (prefers-reduced-motion: reduce){
  *, *::before, *::after{ animation-duration:.001ms !important; animation-iteration-count:1 !important; transition-duration:.001ms !important; scroll-behavior:auto !important }
  .mark .ring-outer, .mark .ring-inner{ animation:none }
  .brand-logo{ animation:none }
  .reveal{ opacity:1 !important; transform:none !important }
  .panel .row, .stat .num, .svc .svc-bar::after{ opacity:1; transform:none; width: var(--w, 100%) }
  details.faq-item summary::before{ transition:none }
}

/* ===================== Rechtsseiten (Impressum/Datenschutz/AGB/Widerruf) ===================== */
.legal-wrap{ max-width:820px; margin:0 auto; padding:48px 32px 80px }
@media (max-width:640px){ .legal-wrap{ padding:32px 20px 56px } }
.legal-wrap h1{ font-size:clamp(28px,4vw,44px); font-weight:700; letter-spacing:-.02em; margin:0 0 8px }
.legal-wrap .legal-sub{ color:var(--ink-mute); font-family:'JetBrains Mono',monospace; font-size:12px; letter-spacing:.08em; text-transform:uppercase; margin-bottom:32px }
.legal-wrap h2{ font-size:22px; font-weight:600; letter-spacing:-.01em; margin:40px 0 12px; padding-top:20px; border-top:1px solid var(--line) }
.legal-wrap h3{ font-size:17px; font-weight:600; margin:24px 0 8px }
.legal-wrap p,.legal-wrap li{ color:var(--ink-dim); font-size:15px; line-height:1.7 }
.legal-wrap ul{ padding-left:22px; margin:8px 0 }
.legal-wrap a{ color:var(--wp-2); text-decoration:underline; text-underline-offset:2px }
.legal-wrap a:hover{ color:#7cc8ec }
.legal-wrap .todo{ background:rgba(245,158,11,.10); border:1px solid rgba(245,158,11,.4); color:#fcd34d; border-radius:8px; padding:10px 14px; font-size:13px; margin:6px 0 }
.legal-back{ display:inline-flex; align-items:center; gap:8px; margin-top:40px; color:var(--wp-2); font-family:'JetBrains Mono',monospace; font-size:13px }

/* Datenschutz/AGB: vierte Überschriftenebene (Anwalts-HTML nutzt h4) */
.legal-wrap h4{ font-size:15px; font-weight:600; color:var(--ink); margin:18px 0 6px }

/* ===================== WhatsApp-Kontakt ===================== */
.btn-whatsapp{ background:#25D366; color:#04210f }
.btn-whatsapp:hover{ filter:brightness(1.07) }
.btn-whatsapp svg{ width:18px; height:18px; fill:currentColor }

.wa-float{
  position:fixed; right:20px; bottom:calc(20px + env(safe-area-inset-bottom, 0px));
  width:56px; height:56px; border-radius:50%;
  background:#25D366; display:grid; place-items:center;
  z-index:50; box-shadow:0 8px 24px -6px rgba(0,0,0,.5), 0 1px 0 rgba(255,255,255,.2) inset;
  transition: transform .15s ease;
}
.wa-float:hover{ transform:scale(1.06) }
.wa-float svg{ width:30px; height:30px; fill:#fff }
