/* =========================================================================
   Wenin Hosting – Stylesheet
   Self-hosted Fonts (DSGVO) · Dark · Mint-Akzent · Mobile-first
   ========================================================================= */

/* ----- Fonts (lokal, kein Google-CDN) ----- */
@font-face{font-family:'Space Grotesk';font-style:normal;font-weight:400;font-display:swap;src:url('../fonts/SpaceGrotesk-400.woff2') format('woff2')}
@font-face{font-family:'Space Grotesk';font-style:normal;font-weight:500;font-display:swap;src:url('../fonts/SpaceGrotesk-500.woff2') format('woff2')}
@font-face{font-family:'Space Grotesk';font-style:normal;font-weight:600;font-display:swap;src:url('../fonts/SpaceGrotesk-600.woff2') format('woff2')}
@font-face{font-family:'Space Grotesk';font-style:normal;font-weight:700;font-display:swap;src:url('../fonts/SpaceGrotesk-700.woff2') format('woff2')}
@font-face{font-family:'Inter';font-style:normal;font-weight:400;font-display:swap;src:url('../fonts/Inter-400.woff2') format('woff2')}
@font-face{font-family:'Inter';font-style:normal;font-weight:500;font-display:swap;src:url('../fonts/Inter-500.woff2') format('woff2')}
@font-face{font-family:'Inter';font-style:normal;font-weight:600;font-display:swap;src:url('../fonts/Inter-600.woff2') format('woff2')}
@font-face{font-family:'Inter';font-style:normal;font-weight:700;font-display:swap;src:url('../fonts/Inter-700.woff2') format('woff2')}
@font-face{font-family:'JetBrains Mono';font-style:normal;font-weight:400;font-display:swap;src:url('../fonts/JetBrainsMono-400.woff2') format('woff2')}
@font-face{font-family:'JetBrains Mono';font-style:normal;font-weight:500;font-display:swap;src:url('../fonts/JetBrainsMono-500.woff2') format('woff2')}
@font-face{font-family:'JetBrains Mono';font-style:normal;font-weight:700;font-display:swap;src:url('../fonts/JetBrainsMono-700.woff2') format('woff2')}

/* ----- Tokens ----- */
:root{
  --bg:#0a0e14;
  --bg-2:#0c1119;
  --surface:#10151e;
  --surface-2:#141b26;
  --line:rgba(255,255,255,.08);
  --line-2:rgba(255,255,255,.14);
  --text:#e8edf4;
  --muted:#94a0b0;
  --muted-2:#6f7c8d;
  --accent:#34e5a1;
  --accent-2:#19b8d6;
  --accent-ink:#04241a;
  --glow:rgba(52,229,161,.45);
  --ok:#34e5a1;
  --warn:#f4bf4a;
  --degr:#ff9d4d;
  --down:#ff5d6c;
  --r-xs:8px; --r-sm:12px; --r:16px; --r-lg:22px; --r-xl:28px;
  --container:1180px;
  --pad:clamp(20px,5vw,40px);
  --font-display:'Space Grotesk',system-ui,-apple-system,'Segoe UI',sans-serif;
  --font-body:'Inter',system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;
  --font-mono:'JetBrains Mono',ui-monospace,'SFMono-Regular',Menlo,Consolas,monospace;
  --shadow:0 24px 60px -24px rgba(0,0,0,.7);
  --shadow-sm:0 8px 24px -12px rgba(0,0,0,.6);
}

/* ----- Reset ----- */
*,*::before,*::after{box-sizing:border-box}
*{margin:0}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  font-family:var(--font-body);
  background:var(--bg);
  color:var(--text);
  line-height:1.6;
  font-size:clamp(15px,.4vw + 14px,16.5px);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;cursor:pointer;border:none;background:none}
ul{list-style:none;padding:0}
:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:4px}
::selection{background:var(--accent);color:var(--accent-ink)}

/* ----- Background-Atmosphäre ----- */
body::before{
  content:"";position:fixed;inset:0;z-index:-2;pointer-events:none;
  background:
    radial-gradient(900px 520px at 78% -8%,rgba(52,229,161,.12),transparent 60%),
    radial-gradient(760px 520px at 8% 4%,rgba(25,184,214,.10),transparent 58%),
    linear-gradient(180deg,#0a0e14,#080b10 60%,#090d13);
}
body::after{
  content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;opacity:.4;
  background-image:
    linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px);
  background-size:60px 60px;
  -webkit-mask-image:radial-gradient(circle at 50% 0,#000,transparent 78%);
          mask-image:radial-gradient(circle at 50% 0,#000,transparent 78%);
}

/* ----- Layout ----- */
.container{width:100%;max-width:var(--container);margin-inline:auto;padding-inline:var(--pad)}
[id]{scroll-margin-top:90px}
.nav-mob-cta{display:none}
.section{padding-block:clamp(56px,8vw,110px)}
.section-tight{padding-block:clamp(40px,6vw,72px)}
.skip-link{position:absolute;left:-999px;top:0;background:var(--accent);color:var(--accent-ink);padding:10px 16px;border-radius:0 0 10px 0;z-index:100;font-weight:600}
.skip-link:focus{left:0}

/* ----- Typo-Helfer ----- */
.eyebrow{
  display:inline-flex;align-items:center;gap:.55em;
  font-family:var(--font-mono);font-size:.78rem;font-weight:500;
  letter-spacing:.08em;text-transform:uppercase;color:var(--accent);
}
.eyebrow::before{content:"//";color:var(--accent-2);opacity:.8}
h1,h2,h3,h4{font-family:var(--font-display);font-weight:600;line-height:1.08;letter-spacing:-.02em}
.h-xl{font-size:clamp(2.3rem,6vw,4.2rem);font-weight:700;letter-spacing:-.03em}
.h-lg{font-size:clamp(1.9rem,4vw,2.9rem);font-weight:600;letter-spacing:-.025em}
.lead{font-size:clamp(1.05rem,1.4vw,1.2rem);color:var(--muted);max-width:60ch}
.section-head{max-width:62ch;margin-bottom:clamp(32px,5vw,56px)}
.section-head.center{margin-inline:auto;text-align:center}
.text-grad{background:linear-gradient(100deg,var(--accent),var(--accent-2));-webkit-background-clip:text;background-clip:text;color:transparent}
.muted{color:var(--muted)}

/* ----- Buttons ----- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.55em;
  font-weight:600;font-size:.96rem;line-height:1;
  padding:.92em 1.4em;border-radius:999px;
  transition:transform .18s ease,background .2s ease,border-color .2s,box-shadow .2s;
  border:1px solid transparent;white-space:nowrap;
}
.btn .icon{width:1.15em;height:1.15em}
.btn-sm{padding:.7em 1.1em;font-size:.9rem}
.btn-primary{background:linear-gradient(180deg,#43eaaa,#23cf90);color:var(--accent-ink);box-shadow:0 10px 30px -10px var(--glow)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 16px 38px -10px var(--glow)}
.btn-ghost{background:rgba(255,255,255,.04);border-color:var(--line-2);color:var(--text)}
.btn-ghost:hover{background:rgba(255,255,255,.08);transform:translateY(-2px);border-color:var(--line-2)}
.btn-link{padding:0;color:var(--accent);font-weight:600}
.btn-link .icon{transition:transform .2s}
.btn-link:hover .icon{transform:translateX(4px)}

/* ----- Header / Nav ----- */
.site-header{position:sticky;top:0;z-index:50;background:rgba(10,14,20,.72);backdrop-filter:blur(14px) saturate(140%);border-bottom:1px solid transparent;transition:border-color .3s,background .3s}
.site-header.scrolled{border-bottom-color:var(--line);background:rgba(9,12,18,.86)}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:18px;height:68px}
.brand{display:inline-flex;align-items:center;gap:.6em;font-family:var(--font-display);font-weight:700;font-size:1.22rem;letter-spacing:-.02em;color:var(--text)}
.brand-mark{display:grid;place-items:center;filter:drop-shadow(0 4px 12px var(--glow))}
.brand-mark svg{width:30px;height:30px}
.brand-dot{color:var(--accent)}
.brand-tld{color:var(--muted-2);font-weight:500}
.nav-list{display:flex;align-items:center;gap:6px}
.nav-link{position:relative;display:block;padding:.5em .85em;border-radius:999px;color:var(--muted);font-weight:500;font-size:.95rem;transition:color .2s,background .2s}
.nav-link:hover{color:var(--text);background:rgba(255,255,255,.05)}
.nav-link.is-active{color:var(--text)}
.nav-link-ext::after{content:"↗";margin-left:.32em;font-size:.82em;color:var(--muted-2);vertical-align:1px}
.nav-link.is-active::after{content:"";position:absolute;left:50%;bottom:2px;transform:translateX(-50%);width:5px;height:5px;border-radius:50%;background:var(--accent);box-shadow:0 0 10px var(--glow)}
.header-actions{display:flex;align-items:center;gap:12px}
.nav-toggle{display:none;width:42px;height:42px;border-radius:12px;border:1px solid var(--line);align-items:center;justify-content:center;color:var(--text)}
.nav-toggle .nav-toggle-close{display:none}
.nav-toggle[aria-expanded="true"] .nav-toggle-open{display:none}
.nav-toggle[aria-expanded="true"] .nav-toggle-close{display:block}

/* ----- Hero ----- */
.hero{position:relative;padding-top:clamp(40px,6vw,72px);padding-bottom:clamp(50px,7vw,90px)}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(32px,5vw,64px);align-items:center}
.hero-copy{max-width:620px}
.hero-center{max-width:880px;margin-inline:auto;text-align:center;padding-top:clamp(8px,3vw,32px)}
.hero-center .pill{margin-bottom:1.3rem}
.hero-center .lead{margin-inline:auto}
.hero-center .hero-cta{justify-content:center}
.hero-center .hero-trust{justify-content:center}
.hero h1{margin:.5rem 0 0}
.hero .lead{margin-top:1.25rem}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px;margin-top:2rem}
.hero-trust{display:flex;flex-wrap:wrap;gap:18px 26px;margin-top:2.4rem;padding-top:1.6rem;border-top:1px solid var(--line)}
.hero-trust div{display:flex;align-items:center;gap:.55em;color:var(--muted);font-size:.9rem}
.hero-trust .icon{color:var(--accent);width:18px;height:18px;flex:none}

.pill{display:inline-flex;align-items:center;gap:.6em;padding:.45em .9em;border-radius:999px;border:1px solid var(--line-2);background:rgba(255,255,255,.03);font-size:.84rem;color:var(--muted);font-weight:500}
.pill .dot{width:8px;height:8px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 0 var(--glow);animation:pulse 2.4s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 var(--glow)}70%{box-shadow:0 0 0 8px transparent}100%{box-shadow:0 0 0 0 transparent}}

/* ----- Live-Status-Card (Hero) ----- */
.status-card{
  position:relative;display:block;border-radius:var(--r-lg);padding:22px;
  background:linear-gradient(180deg,rgba(20,27,38,.9),rgba(14,19,28,.92));
  border:1px solid var(--line-2);box-shadow:var(--shadow);
  backdrop-filter:blur(6px);color:inherit;
  transition:transform .25s ease,border-color .25s ease;
}
.status-card:hover{transform:translateY(-4px);border-color:rgba(52,229,161,.4)}
.sc-link{margin-top:16px;padding-top:14px;border-top:1px solid var(--line);display:flex;align-items:center;justify-content:flex-end;gap:.4em;font-size:.85rem;font-weight:600;color:var(--accent)}
.sc-link .icon{transition:transform .2s}
.status-card:hover .sc-link .icon{transform:translateX(4px)}
.status-card::before{content:"";position:absolute;inset:0;border-radius:inherit;padding:1px;background:linear-gradient(140deg,var(--glow),transparent 40%);-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none;opacity:.6}
.sc-head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding-bottom:16px;margin-bottom:16px;border-bottom:1px solid var(--line)}
.sc-title{display:flex;align-items:center;gap:.6em;font-family:var(--font-mono);font-size:.82rem;letter-spacing:.04em;color:var(--muted)}
.sc-badge{display:inline-flex;align-items:center;gap:.5em;font-size:.82rem;font-weight:600;color:var(--accent);padding:.32em .7em;border-radius:999px;background:rgba(52,229,161,.1);border:1px solid rgba(52,229,161,.25)}
.sc-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:.62em 0}
.sc-row + .sc-row{border-top:1px dashed var(--line)}
.sc-row .name{display:flex;align-items:center;gap:.7em;color:var(--text);font-size:.95rem;font-weight:500}
.sc-row .val{font-family:var(--font-mono);font-size:.82rem;color:var(--muted)}
.dot{width:9px;height:9px;border-radius:50%;flex:none;background:var(--ok);box-shadow:0 0 10px var(--glow)}
.dot.warn{background:var(--warn);box-shadow:0 0 10px rgba(244,191,74,.5)}
.dot.down{background:var(--down);box-shadow:0 0 10px rgba(255,93,108,.5)}
.sc-foot{margin-top:18px;padding-top:16px;border-top:1px solid var(--line);display:flex;align-items:flex-end;justify-content:space-between;gap:16px}
.sc-uptime{font-family:var(--font-display);font-weight:700;font-size:2rem;line-height:1;letter-spacing:-.02em}
.sc-uptime span{font-size:.8rem;font-weight:500;color:var(--muted);font-family:var(--font-mono);display:block;margin-top:.4em;letter-spacing:0}
.spark{display:flex;align-items:flex-end;gap:3px;height:42px}
.spark i{width:5px;border-radius:2px;background:linear-gradient(180deg,var(--accent),rgba(52,229,161,.25));height:var(--h,40%);animation:rise .7s ease backwards}
@keyframes rise{from{height:6px;opacity:.3}}

/* ----- Logos / Strip ----- */
.assurance{display:flex;flex-wrap:wrap;gap:14px;justify-content:center;align-items:center;color:var(--muted-2);font-family:var(--font-mono);font-size:.82rem}
.assurance span{display:inline-flex;align-items:center;gap:.5em}
.assurance .sep{width:4px;height:4px;border-radius:50%;background:var(--line-2)}

/* ----- Bento / Feature-Grid ----- */
.bento{display:grid;grid-template-columns:repeat(12,1fr);gap:18px}
.card{
  position:relative;border-radius:var(--r);background:var(--surface);
  border:1px solid var(--line);padding:26px;transition:transform .25s ease,border-color .25s,background .25s;
  overflow:hidden;
}
.card:hover{transform:translateY(-4px);border-color:var(--line-2)}
.card-glow::after{content:"";position:absolute;width:240px;height:240px;right:-60px;top:-80px;background:radial-gradient(circle,var(--glow),transparent 65%);opacity:.14;pointer-events:none}
.feat{grid-column:span 3}
.feat .ico{width:46px;height:46px;border-radius:12px;display:grid;place-items:center;background:rgba(52,229,161,.1);border:1px solid rgba(52,229,161,.22);color:var(--accent);margin-bottom:16px}
.feat h3{font-size:1.12rem;margin-bottom:.5rem}
.feat p{color:var(--muted);font-size:.95rem}

/* ----- Service-Cards ----- */
.services{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.svc{display:flex;flex-direction:column;gap:14px;border-radius:var(--r);background:var(--surface);border:1px solid var(--line);padding:26px;transition:transform .25s,border-color .25s}
.svc:hover{transform:translateY(-4px);border-color:var(--line-2)}
.svc.is-featured{background:linear-gradient(180deg,rgba(52,229,161,.07),var(--surface));border-color:rgba(52,229,161,.28)}
.svc-top{display:flex;align-items:center;gap:14px}
.svc .ico{width:48px;height:48px;border-radius:13px;flex:none;display:grid;place-items:center;background:rgba(255,255,255,.05);border:1px solid var(--line-2);color:var(--accent)}
.svc.is-featured .ico{background:rgba(52,229,161,.14);border-color:rgba(52,229,161,.3)}
.svc h3{font-size:1.2rem}
.svc .tag{font-size:.86rem;color:var(--accent);font-weight:500}
.svc p{color:var(--muted);font-size:.95rem;flex:1}
.svc-points{display:grid;gap:.5em;margin-top:2px}
.svc-points li{display:flex;align-items:flex-start;gap:.6em;font-size:.92rem;color:var(--text)}
.svc-points .icon{color:var(--accent);width:18px;height:18px;flex:none;margin-top:1px}
.tag-featured{align-self:flex-start;font-family:var(--font-mono);font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;color:var(--accent-ink);background:var(--accent);padding:.3em .7em;border-radius:999px;font-weight:700}

/* ----- Split / Rechenzentrum ----- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(32px,5vw,64px);align-items:center}
.dc-visual{position:relative;border-radius:var(--r-lg);border:1px solid var(--line-2);background:linear-gradient(180deg,var(--surface-2),var(--surface));padding:28px;box-shadow:var(--shadow)}
.dc-stat{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.dc-stat .box{border:1px solid var(--line);border-radius:var(--r-sm);padding:18px;background:rgba(255,255,255,.02)}
.dc-stat .num{font-family:var(--font-display);font-weight:700;font-size:1.9rem;letter-spacing:-.02em;background:linear-gradient(100deg,var(--accent),var(--accent-2));-webkit-background-clip:text;background-clip:text;color:transparent}
.dc-stat .lab{color:var(--muted);font-size:.86rem;margin-top:.25em}
.dc-list{display:grid;gap:18px;margin-top:6px}
.dc-list li{display:flex;gap:14px;align-items:flex-start}
.dc-list .ico{width:42px;height:42px;border-radius:11px;flex:none;display:grid;place-items:center;background:rgba(52,229,161,.1);border:1px solid rgba(52,229,161,.22);color:var(--accent)}
.dc-list h3{font-size:1.05rem;margin-bottom:.2em}
.dc-list p{color:var(--muted);font-size:.93rem}

/* ----- Pricing ----- */
.pricing{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;align-items:stretch}
.price{position:relative;display:flex;flex-direction:column;gap:16px;border-radius:var(--r-lg);background:var(--surface);border:1px solid var(--line);padding:28px}
.price.is-featured{background:linear-gradient(180deg,rgba(52,229,161,.08),var(--surface));border-color:rgba(52,229,161,.32);box-shadow:var(--shadow)}
.price .badge{position:absolute;top:-12px;right:22px;font-family:var(--font-mono);font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;color:var(--accent-ink);background:var(--accent);padding:.32em .8em;border-radius:999px;font-weight:700}
.price h3{font-size:1.25rem}
.price .desc{color:var(--muted);font-size:.92rem;min-height:2.6em}
.price .amount{display:flex;align-items:baseline;gap:.3em}
.price .amount b{font-family:var(--font-display);font-weight:700;font-size:2.2rem;letter-spacing:-.02em}
.price .amount .per{color:var(--muted);font-size:.9rem}
.price .setup{font-size:.86rem;color:var(--muted);font-family:var(--font-mono)}
.price .amount.amount-req{align-items:center}
.amount-req b{font-size:1.55rem;letter-spacing:-.01em}
.price ul{display:grid;gap:.6em;margin:4px 0}
.price li{display:flex;gap:.6em;align-items:flex-start;font-size:.93rem}
.price li .icon{color:var(--accent);width:18px;height:18px;flex:none;margin-top:1px}
.price .btn{margin-top:auto}
.price-note{margin-top:22px;text-align:center;color:var(--muted-2);font-size:.85rem}

/* ----- CTA-Band ----- */
.cta-band{position:relative;border-radius:var(--r-xl);overflow:hidden;padding:clamp(34px,5vw,60px);background:linear-gradient(120deg,rgba(52,229,161,.14),rgba(25,184,214,.1));border:1px solid var(--line-2);text-align:center}
.cta-band::before{content:"";position:absolute;inset:0;background:radial-gradient(600px 300px at 50% 120%,var(--glow),transparent 60%);opacity:.3}
.cta-band > *{position:relative}
.cta-band h2{margin-bottom:.6rem}
.cta-band .lead{margin:0 auto 1.8rem}
.cta-actions{display:flex;flex-wrap:wrap;gap:14px;justify-content:center}

/* ----- Status-Seite ----- */
.status-hero{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:20px;border-radius:var(--r-lg);padding:26px;border:1px solid var(--line-2);background:linear-gradient(180deg,var(--surface-2),var(--surface))}
.status-hero.ok{border-color:rgba(52,229,161,.3);background:linear-gradient(180deg,rgba(52,229,161,.08),var(--surface))}
.status-big{display:flex;align-items:center;gap:16px}
.status-ring{width:54px;height:54px;border-radius:50%;flex:none;display:grid;place-items:center;background:rgba(52,229,161,.12);border:1px solid rgba(52,229,161,.3);color:var(--accent)}
.status-ring .dot{width:14px;height:14px}
.status-big h1{font-size:1.5rem;font-family:var(--font-display)}
.status-big p{color:var(--muted);font-size:.92rem}
.status-updated{font-family:var(--font-mono);font-size:.82rem;color:var(--muted)}
.status-list{margin-top:26px;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;background:var(--surface)}
.status-item{display:grid;grid-template-columns:1fr auto auto;align-items:center;gap:16px;padding:18px 22px}
.status-item + .status-item{border-top:1px solid var(--line)}
.status-item .name{display:flex;align-items:center;gap:.7em;font-weight:500}
.status-item .uptime{font-family:var(--font-mono);font-size:.85rem;color:var(--muted)}
.status-pill{display:inline-flex;align-items:center;gap:.5em;font-size:.84rem;font-weight:600;padding:.34em .8em;border-radius:999px}
.status-pill.operational{color:var(--ok);background:rgba(52,229,161,.1);border:1px solid rgba(52,229,161,.25)}
.status-pill.maintenance{color:var(--warn);background:rgba(244,191,74,.1);border:1px solid rgba(244,191,74,.25)}
.status-pill.degraded{color:var(--degr);background:rgba(255,157,77,.1);border:1px solid rgba(255,157,77,.25)}
.status-pill.down{color:var(--down);background:rgba(255,93,108,.1);border:1px solid rgba(255,93,108,.25)}
.uptime-track{grid-column:1/-1;display:flex;gap:2px;margin-top:4px}
.uptime-track i{flex:1;height:26px;border-radius:2px;background:var(--ok);opacity:.85}
.uptime-track i.warn{background:var(--warn)}
.uptime-track i.down{background:var(--down)}
.uptime-legend{display:flex;justify-content:space-between;font-family:var(--font-mono);font-size:.74rem;color:var(--muted-2);margin-top:8px}
.maint{border:1px solid var(--line);border-radius:var(--r);padding:22px;background:var(--surface);display:flex;gap:16px}
.maint + .maint{margin-top:14px}
.maint .ico{width:42px;height:42px;border-radius:11px;flex:none;display:grid;place-items:center;background:rgba(244,191,74,.12);border:1px solid rgba(244,191,74,.28);color:var(--warn)}
.maint h3{font-size:1.05rem}
.maint .when{font-family:var(--font-mono);font-size:.82rem;color:var(--accent);margin:.2em 0 .5em}
.maint p{color:var(--muted);font-size:.93rem}
.empty-state{text-align:center;padding:40px 20px;color:var(--muted);border:1px dashed var(--line-2);border-radius:var(--r);background:rgba(255,255,255,.015)}
.empty-state .ico{width:46px;height:46px;margin:0 auto 14px;border-radius:12px;display:grid;place-items:center;background:rgba(52,229,161,.1);color:var(--accent);border:1px solid rgba(52,229,161,.22)}

/* ----- Kontakt ----- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,5vw,56px);align-items:start}
.contact-cards{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.contact-cta{margin-top:18px;display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:22px;border:1px solid var(--line-2);border-radius:var(--r-lg);padding:clamp(22px,3vw,32px);background:linear-gradient(120deg,rgba(52,229,161,.1),rgba(25,184,214,.07))}
.contact-cta h2{font-family:var(--font-display);letter-spacing:-.02em}
.contact-info{display:grid;gap:18px;align-content:start}
.ci{display:flex;gap:14px;align-items:flex-start;border:1px solid var(--line);border-radius:var(--r-sm);padding:18px;background:var(--surface)}
.ci .ico{width:42px;height:42px;border-radius:11px;flex:none;display:grid;place-items:center;background:rgba(52,229,161,.1);border:1px solid rgba(52,229,161,.22);color:var(--accent)}
.ci h3{font-size:.95rem;margin-bottom:.15em}
.ci a,.ci p{color:var(--muted);font-size:.93rem}
.ci a:hover{color:var(--accent)}
.form{border:1px solid var(--line);border-radius:var(--r-lg);padding:clamp(22px,3vw,32px);background:var(--surface);box-shadow:var(--shadow-sm)}
.field{margin-bottom:18px}
.field label{display:block;font-size:.88rem;font-weight:500;margin-bottom:.5em;color:var(--text)}
.field .req{color:var(--accent)}
.field input,.field textarea{
  width:100%;font:inherit;color:var(--text);background:var(--bg-2);
  border:1px solid var(--line-2);border-radius:var(--r-sm);padding:.85em 1em;transition:border-color .2s,box-shadow .2s;
}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(52,229,161,.15)}
.field textarea{resize:vertical;min-height:140px}
.field-hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.consent{display:flex;gap:.7em;align-items:flex-start;font-size:.88rem;color:var(--muted)}
.consent input{margin-top:.25em;width:18px;height:18px;accent-color:var(--accent);flex:none}
.consent a{color:var(--accent)}
.form .btn{width:100%;margin-top:8px}
.form-foot{margin-top:14px;font-size:.82rem;color:var(--muted-2);display:flex;gap:.5em;align-items:center}
.form-foot .icon{color:var(--accent);flex:none}

/* ----- Flash ----- */
.flash-wrap{margin-top:16px;display:grid;gap:10px}
.flash{display:flex;align-items:center;gap:.7em;padding:.85em 1.1em;border-radius:var(--r-sm);font-size:.92rem;font-weight:500}
.flash-icon{display:grid;place-items:center;flex:none}
.flash-ok{background:rgba(52,229,161,.12);border:1px solid rgba(52,229,161,.3);color:var(--accent)}
.flash-error{background:rgba(255,93,108,.1);border:1px solid rgba(255,93,108,.3);color:#ff9aa4}

/* ----- Legal / Prose ----- */
.page-head{padding-block:clamp(40px,6vw,72px) 0}
.prose{max-width:78ch;margin-top:clamp(28px,4vw,44px)}
.prose h2{font-size:1.4rem;margin-top:2.2em;margin-bottom:.6em;padding-top:1.2em;border-top:1px solid var(--line)}
.prose h2:first-of-type{border-top:none;padding-top:0;margin-top:1em}
.prose h3{font-size:1.08rem;margin-top:1.6em;margin-bottom:.4em}
.prose p,.prose li{color:var(--muted);margin-bottom:.9em}
.prose strong{color:var(--text);font-weight:600}
.prose a{color:var(--accent);text-decoration:underline;text-underline-offset:3px}
.prose ul{list-style:disc;padding-left:1.3em;margin-bottom:1em}
.prose ul li{margin-bottom:.4em}
.prose .addr{color:var(--text);font-style:normal;line-height:1.9}
.note-box{border:1px solid var(--line-2);border-left:3px solid var(--accent);background:rgba(52,229,161,.05);border-radius:var(--r-sm);padding:16px 18px;margin:1.4em 0;color:var(--muted);font-size:.9rem}
.note-box strong{color:var(--accent)}

/* ----- 404 ----- */
.notfound{min-height:60vh;display:grid;place-items:center;text-align:center}
.notfound .code{font-family:var(--font-display);font-weight:700;font-size:clamp(5rem,18vw,11rem);line-height:1;background:linear-gradient(180deg,var(--accent),transparent);-webkit-background-clip:text;background-clip:text;color:transparent}

/* ----- Footer ----- */
.site-footer{margin-top:clamp(40px,7vw,90px);border-top:1px solid var(--line);background:linear-gradient(180deg,transparent,rgba(255,255,255,.015))}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.2fr;gap:36px;padding-block:clamp(40px,6vw,64px)}
.footer-claim{color:var(--muted);font-size:.92rem;margin-top:14px;max-width:34ch}
.footer-badges{display:flex;flex-wrap:wrap;gap:10px;margin-top:18px}
.chip{display:inline-flex;align-items:center;gap:.5em;font-size:.8rem;color:var(--muted);border:1px solid var(--line-2);border-radius:999px;padding:.4em .8em}
.chip .icon{color:var(--accent)}
.footer-col h3{font-family:var(--font-body);font-size:.82rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted-2);margin-bottom:16px;font-weight:600}
.footer-col ul{display:grid;gap:.7em}
.footer-col a{color:var(--muted);font-size:.93rem;transition:color .2s}
.footer-col a:hover{color:var(--accent)}
.footer-contact li{display:flex;gap:.6em;align-items:flex-start;color:var(--muted);font-size:.93rem;margin-bottom:.7em}
.footer-contact .icon{color:var(--accent);flex:none;margin-top:2px}
.footer-bottom{display:flex;flex-wrap:wrap;justify-content:space-between;gap:12px;padding-block:22px;border-top:1px solid var(--line);color:var(--muted-2);font-size:.86rem}
.footer-legal{display:flex;gap:18px}
.footer-legal a:hover{color:var(--accent)}

/* ----- Reveal-Animation ----- */
.reveal{opacity:0;transform:translateY(18px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  .pill .dot,.spark i{animation:none}
  .btn:hover,.card:hover,.svc:hover,.status-card:hover{transform:none}
}

/* ----- Responsive ----- */
@media (max-width:1000px){
  .hero-grid{grid-template-columns:1fr;gap:40px}
  .hero-visual{order:-1;max-width:460px}
  .feat{grid-column:span 6}
  .services{grid-template-columns:repeat(2,1fr)}
  .pricing{grid-template-columns:1fr;max-width:460px;margin-inline:auto}
  .split{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:760px){
  .nav,.header-actions .btn{display:none}
  .nav-toggle{display:flex}
  .site-header.nav-open{background:rgba(9,12,18,.97)}
  .nav.open{display:block;position:fixed;inset:68px 0 auto 0;background:rgba(9,12,18,.98);backdrop-filter:blur(16px);border-bottom:1px solid var(--line);padding:14px var(--pad) 24px}
  .nav.open .nav-list{flex-direction:column;align-items:stretch;gap:4px}
  .nav.open .nav-link{padding:.85em 1em;font-size:1.05rem;border-radius:12px}
  .nav.open .nav-link.is-active{background:rgba(52,229,161,.1)}
  .nav.open .nav-link.is-active::after{display:none}
  .nav-mob-cta{display:block;margin-top:10px}
  .services{grid-template-columns:1fr}
  .contact-cards{grid-template-columns:1fr}
  .feat{grid-column:span 12}
  .footer-grid{grid-template-columns:1fr 1fr}
  .footer-brand{grid-column:1/-1}
  .status-item{grid-template-columns:1fr auto;row-gap:6px}
  .status-item .uptime{grid-column:1;grid-row:2;justify-self:start}
  .status-item .status-pill{grid-row:1}
}
@media (max-width:460px){
  .footer-grid{grid-template-columns:1fr}
  .hero-cta .btn{flex:1}
}
