*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font:16px/1.6 -apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Inter,Helvetica,Arial,sans-serif;background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;transition:background .35s,color .35s}
:root{--bg:#0b0f14;--surface:#0f172a;--glass:rgba(13,18,28,.55);--ring:rgba(255,255,255,.08);--text:#e5e7eb;--muted:#9ca3af;--accent:#0ea5e9;--danger:#ef4444;--hot:#ef4444;--hot2:#f97316;--shadow:0 20px 60px rgba(0,0,0,.45)}
:root[data-theme=light]{--bg:#f6f8fc;--surface:#ffffff;--glass:rgba(255,255,255,.75);--ring:rgba(2,6,23,.12);--text:#0b1220;--muted:#475569;--accent:#0ea5e9;--danger:#e11d48;--hot:#e11d48;--hot2:#f59e0b;--shadow:0 30px 60px rgba(2,6,23,.08)}
a{color:inherit;text-decoration:none}
.sr{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

.badge{display:inline-block;padding:.4rem .7rem;border:1px solid var(--ring);border-radius:999px;background:linear-gradient(180deg,rgba(255,255,255,.06),rgba(255,255,255,.02));font-weight:700;font-size:.8rem;color:var(--muted)}
.btn{display:inline-flex;align-items:center;gap:.6rem;background:var(--accent);color:#fff;border:none;border-radius:12px;padding:.95rem 1.25rem;font-weight:800;letter-spacing:.2px;box-shadow:0 12px 24px rgba(14,165,233,.25);transition:transform .15s ease,filter .2s ease}
.btn:hover{transform:translateY(-1px);filter:brightness(1.04)}
.btn--ghost{background:transparent;color:var(--text);border:1px solid var(--ring);box-shadow:none}
.btn--big{font-size:1.05rem}

.hdr{position:sticky;top:0;z-index:60;background:rgba(10,14,20,.5);backdrop-filter:blur(14px);border-bottom:1px solid var(--ring)}
.hdr__in{max-width:1200px;margin:0 auto;padding:14px 20px;display:flex;align-items:center;gap:14px}
.brand--wordmark{font-weight:900;letter-spacing:.16em;font-size:1.05rem;color:#e5e7eb}
:root[data-theme=light] .brand--wordmark{color:#0b1220}
.nav{margin-left:auto;display:flex;gap:12px}
.nav a{padding:.55rem .8rem;border-radius:12px;color:#cbd5e1}
.nav a:hover,.nav a.active{background:rgba(255,255,255,.06);color:#fff}
.nav__hot{background:rgba(239,68,68,.18);color:#fecaca;border:1px solid rgba(239,68,68,.35)}
.pill{display:inline-flex;align-items:center;gap:.6rem;margin-left:8px;height:38px;padding:0 .9rem;border-radius:999px;border:1px solid var(--ring);background:linear-gradient(180deg,rgba(255,255,255,.06),rgba(255,255,255,.02));color:var(--text);cursor:pointer;box-shadow:0 10px 24px rgba(0,0,0,.18)}
.pill__dot{width:18px;height:18px;border-radius:999px;background:linear-gradient(135deg,#38bdf8,#ef4444)}
.pill__lbl{font-weight:700;font-size:.9rem}

.banner {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 9999;
  background: linear-gradient(90deg, #1e3a8a, #0ea5e9);
  color: #fff;
  text-align: center;
  padding: .8rem 1rem;
  box-shadow: 0 2px 10px rgba(0,0,0,0.25);
  animation: slideDown .6s ease forwards;
}
.banner__inner {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: .75rem;
  flex-wrap: wrap;
}
#bannerText {
  font-size: 1rem;
  line-height: 1.5;
}
#bannerText a {
  color: #fff;
  font-weight: 600;
  text-decoration: underline;
}
#bannerClose {
  background: rgba(255,255,255,0.2);
  border: none;
  color: #fff;
  font-size: 1.2rem;
  padding: .2rem .6rem;
  border-radius: 50%;
  cursor: pointer;
  transition: background 0.2s ease;
}
#bannerClose:hover {
  background: rgba(255,255,255,0.35);
}
@keyframes slideDown {
  from { transform: translateY(-100%); opacity: 0; }
  to { transform: translateY(0); opacity: 1; }
}
.hero{position:relative;min-height:86vh;display:grid;place-items:center;overflow:hidden}
.hero__bg{position:absolute;inset:0;background-size:cover;background-position:center;transform:scale(1.08)}
.hero__glass{position:relative;z-index:2;max-width:1000px;margin:0 20px;padding:44px 34px;border-radius:22px;background:var(--glass);backdrop-filter:blur(12px);border:1px solid var(--ring);box-shadow:var(--shadow);text-align:center}
.hero__logo{height:250px;display:block;margin:10px auto 12px}
.lead{font-size:18px;color:var(--muted);max-width:760px;margin:0 auto}
.cta{display:flex;gap:.85rem;justify-content:center;margin-top:18px}

.sect{position:relative;padding:104px 0}
.sect--alt{background:linear-gradient(180deg,rgba(255,255,255,.02),rgba(255,255,255,.01))}
.sect__in{max-width:1200px;margin:0 auto;padding:0 20px}
.cols{display:grid;grid-template-columns:1.1fr .9fr;gap:28px;align-items:center}
.cols--rev{grid-template-columns:.9fr 1.1fr}
.col{width:100%}
.ph{height:420px;border-radius:18px;border:1px solid var(--ring);background-size:cover;background-position:center;box-shadow:var(--shadow)}
.ph--sm{height:220px;margin-top:18px}
.lift{transition:transform .35s ease,box-shadow .35s ease}
.lift:hover{transform:translateY(-4px);box-shadow:0 30px 60px rgba(0,0,0,.35)}

.team{margin-top:22px}
.team__ph{height:420px}

.ticks{margin:20px 0 0;padding:0;list-style:none;display:grid;gap:12px}
.ticks li{position:relative;padding-left:28px}
.ticks li:before{content:"";position:absolute;left:0;top:.6em;width:18px;height:18px;border-radius:999px;background:linear-gradient(135deg,#38bdf8,#ef4444)}

.chips{display:flex;flex-wrap:wrap;gap:10px}
.chips span{display:inline-flex;padding:.55rem .85rem;border-radius:999px;border:1px solid var(--ring);background:linear-gradient(180deg,rgba(255,255,255,.06),rgba(255,255,255,.02));font-weight:700;color:var(--muted)}

.stats{display:flex;flex-wrap:wrap;justify-content:center;gap:18px;margin-top:20px}
.stat{min-width:120px;border:1px solid var(--ring);border-radius:14px;background:linear-gradient(180deg,rgba(255,255,255,.05),rgba(255,255,255,.02));padding:16px;text-align:center}
.stat strong{display:block;font-size:28px}
.stat span{color:var(--muted);font-size:.9rem}

.refs{margin:20px 0 0;padding:0;list-style:none}
.refs--fold{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.ref details{border:1px solid var(--ring);border-radius:14px;background:linear-gradient(180deg,rgba(255,255,255,.05),rgba(255,255,255,.02));overflow:hidden}
.ref summary{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:16px;cursor:pointer}
.ref summary::-webkit-details-marker{display:none}
.ref summary::after{content:"›";transition:transform .2s ease}
.ref details[open] summary::after{transform:rotate(90deg)}
.ref em{color:var(--muted);font-style:normal}
.ref__media{height:240px;background-size:cover;background-position:center;border-top:1px solid var(--ring)}

.card{background:linear-gradient(180deg,rgba(255,255,255,.05),rgba(255,255,255,.02));border:1px solid var(--ring);border-radius:16px;padding:18px;box-shadow:var(--shadow)}
.card input,.card textarea{width:100%;padding:12px 14px;border-radius:12px;border:1px solid var(--ring);background:rgba(2,6,23,.55);color:var(--text);margin-bottom:12px}
:root[data-theme=light] .card input,:root[data-theme=light] .card textarea{background:#fff;border-color:var(--ring);color:var(--text)}

.tbl table{width:100%;border-collapse:collapse}
.tbl th,.tbl td{padding:.95rem;border-bottom:1px solid var(--ring);text-align:left}

.sect--panic{position:relative;background:linear-gradient(135deg,var(--hot),var(--hot2));color:#fff}
.sect--panic .badge{border-color:rgba(255,255,255,.25);color:#fff;background:rgba(255,255,255,.12)}
.panic__hdr{display:grid;gap:18px;justify-items:center;margin-bottom:34px}
.panic__title{font-size:44px;line-height:1.1;text-align:center;margin:.3rem 0 .4rem}
.panic__lead{text-align:center;font-size:18px;opacity:.95;margin-bottom:6px}
.panic__badge{display:inline-block;padding:.55rem .9rem;border-radius:999px;border:1px solid rgba(255,255,255,.25);font-weight:800;letter-spacing:.06em}
.panic__cta{display:flex;gap:.9rem;justify-content:center;margin-top:8px;margin-bottom:0}
.notdienst-fold{margin-top:26px}

.ftr{border-top:1px solid var(--ring);background:rgba(2,6,23,.8)}
.ftr__in{max-width:1200px;margin:0 auto;padding:30px 20px;display:grid;place-items:center;text-align:center;color:#cbd5e1}
.ftr a{color:inherit;text-decoration:underline dotted}

[data-reveal]{opacity:0;transform:translateY(14px);transition:opacity .6s ease,transform .6s ease}
[data-reveal].in{opacity:1;transform:none}
.zoom-in{transform:scale(.96);opacity:0;transition:opacity .7s ease,transform .7s ease}
.zoom-in.in{transform:scale(1);opacity:1}

@media (max-width:1100px){
  .cols,.cols--rev{grid-template-columns:1fr}
  .refs--fold{grid-template-columns:1fr 1fr}
  .hero__logo{height:108px}
}
@media (max-width:640px){
  .refs--fold{grid-template-columns:1fr}
}
.refs-modern{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:18px}
.ref-card{border:1px solid var(--ring);border-radius:16px;background:linear-gradient(180deg,rgba(255,255,255,.05),rgba(255,255,255,.02));overflow:hidden;transition:transform .25s ease,box-shadow .25s ease}
.ref-card:hover{transform:translateY(-4px);box-shadow:0 24px 60px rgba(0,0,0,.25)}
.ref-card summary{list-style:none;cursor:pointer}
.ref-card summary::-webkit-details-marker{display:none}
.ref-figure{height:220px;background-size:cover;background-position:center;position:relative;margin:0}
.ref-figure::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.0),rgba(0,0,0,.45))}
.ref-title{position:absolute;left:0;right:0;bottom:0;display:flex;justify-content:space-between;align-items:center;gap:10px;padding:12px 14px;color:#fff;font-weight:800;letter-spacing:.2px}
.ref-title em{font-style:normal;opacity:.9}
.ref-body{height:0;overflow:hidden;transition:height .35s ease;background:var(--surface);border-top:1px solid var(--ring)}
.ref-media{height:320px;background-size:cover;background-position:center}
.ref-card[open] .ref-title{background:linear-gradient(180deg,rgba(0,0,0,.0),rgba(0,0,0,.65))}
@media (max-width:1100px){.refs-modern{grid-template-columns:1fr 1fr}}
@media (max-width:640px){.refs-modern{grid-template-columns:1fr}}


.hero { position: relative; min-height:86vh; display:grid; place-items:center; overflow:hidden }
.hero__bg{
  position:absolute; inset:0;
  background-size:cover; background-position:center;
  transform:scale(1.08); 
  opacity:0;
  animation: heroFade 24s infinite;
  will-change: opacity;
}
.hero__bg--1{ animation-delay: 0s }
.hero__bg--2{ animation-delay: 8s }
.hero__bg--3{ animation-delay: 16s }

@keyframes heroFade{
  0%{opacity:0}
  5%{opacity:1}
  33%{opacity:1}
  38%{opacity:0}
  100%{opacity:0}
}

@media (prefers-reduced-motion: reduce){
  .hero__bg{ animation:none; opacity:1 }
  .hero__bg:not(.hero__bg--1){ display:none }
}

/* === Mobile Polish (<= 960px / 640px) === */

/* 1) Header/Navi: kompakter + horizontales Scrollen statt Umbruch */
@media (max-width: 960px){
  .hdr__in{padding:10px 14px; gap:10px}
  .brand--wordmark{font-size:.98rem; letter-spacing:.14em}
  .nav{margin-left:auto; gap:8px; overflow-x:auto; -webkit-overflow-scrolling:touch; scrollbar-width:none}
  .nav::-webkit-scrollbar{display:none}
  .nav a{white-space:nowrap; padding:.5rem .7rem; border-radius:12px; font-size:.95rem}
  .pill{height:36px; padding:0 .8rem}
  .pill__lbl{font-size:.85rem}
}

/* 2) Scroll-Anker: Header-Höhe berücksichtigen (kein "verdeckt" mehr) */
section:target{scroll-margin-top:80px}

/* 3) Hero: weniger Höhe, bessere Typo, Buttons untereinander */
@media (max-width: 960px){
  .hero{min-height:78vh}
  .hero__glass{padding:26px 18px; margin:0 14px; border-radius:18px}
  .hero__logo{height:96px; margin:6px auto 10px}
  .lead{font-size:16px}
  .cta{flex-direction:column; align-items:stretch}
  .cta .btn,.cta .btn--ghost{width:100%; justify-content:center}
}
/* sehr kleine Geräte */
@media (max-width: 360px){
  .hero{min-height:72vh}
  .hero__logo{height:84px}
}

/* 4) Spalten/Grids: auf 1 Spalte, größere Abstände */
@media (max-width: 960px){
  .cols,.cols--rev{grid-template-columns:1fr; gap:18px}
  .sect{padding:72px 0}
  .sect__in{padding:0 14px}
}

/* 5) Bildkacheln: Höhe reduzieren, schneller laden */
@media (max-width: 960px){
  .ph{height:300px}
  .ph--sm{height:180px}
  .team__ph{height:300px}
}
@media (max-width: 640px){
  .ph{height:240px}
  .ph--sm{height:160px}
  .team__ph{height:240px}
}

/* 6) Referenzen-Karten: zwei Spalten -> eine Spalte */
@media (max-width: 960px){
  .refs-modern{grid-template-columns:1fr 1fr}
}
@media (max-width: 640px){
  .refs-modern{grid-template-columns:1fr}
  .ref-figure{height:200px}
  .ref-media{height:240px}
}

/* 7) Formular: Touch-Optimierung & kein iOS-Zoom (16px) */
.card input,.card textarea{font-size:16px}
@media (max-width: 960px){
  #contactForm .btn{width:100%}
  #contactForm label{font-size:15px}
}

/* 8) Notdienst: Abstände/Buttons fingerfreundlich */
@media (max-width: 960px){
  .panic__title{font-size:36px}
  .panic__lead{font-size:16px}
  .panic__cta{flex-direction:column}
  .panic__cta .btn{width:100%; justify-content:center}
  .notdienst-fold{margin-top:18px}
}

/* 9) Footer: kompakter + bessere Zeilenbreite */
@media (max-width: 640px){
  .ftr__in{padding:22px 14px}
  .ftr__in p{margin:.25rem 0}
}

/* 10) iOS Safe-Area (volle Höhe, keine abgeschnittenen Ecken) */
@supports(padding: max(0px)){
  .hdr{padding-left:max(0px, env(safe-area-inset-left)); padding-right:max(0px, env(safe-area-inset-right))}
  .ftr__in{padding-left:max(20px, env(safe-area-inset-left)); padding-right:max(20px, env(safe-area-inset-right))}
}

.contact-cta {
  display: grid;
  gap: .75rem;
  padding: 20px;
}
.contact-cta .btn {
  width: 100%;
  justify-content: center;
}

.btn--whatsapp{
  background:#25D366; color:#fff;
  display:inline-flex; align-items:center; gap:.55rem;
}
.btn--whatsapp:hover{ background:#1ebe5d }
.wa-icon{ width:20px; height:20px; flex-shrink:0; display:inline-block; vertical-align:middle }

.wa-icon {
  width: 20px;
  height: 20px;
}


.fn-mark{margin-left:.25rem; font-weight:800; opacity:.7}
.fn-note{margin-top:.4rem; font-size:.8rem; color:var(--muted)}