/* =============================================================
   SHK-Notruf-KI — styles.css
   Design-System: BOLD UTILITY / SIGNAL (dringlich · klar · funktional)
   Ein Service von NovaData Solutions
   ============================================================= */

/* ---------- TOKENS ---------- */
:root{
  /* Leitfarbe: Signal-Rot */
  --accent:#E11D2A;
  --accent-deep:#B81722;
  --accent-soft:#FBE0E1;
  --accent-lite:#F26B6B;
  --accent-glow:rgba(225,29,42,.3);
  --on-accent:#ffffff;

  /* Flächen / Hintergrund (hell) */
  --bg:#F2F3F5;
  --bg-ice:#E7E9ED;
  --surface:#ffffff;

  /* Text (Anthrazit) */
  --ink:#1A1D21;
  --ink-soft:#4A5159;
  --ink-faint:#889099;
  --line:rgba(26,29,33,.10);

  /* dunkle Kontrast-Bänder (ndbrand) */
  --dark:#1A1D21;
  --dark-2:#262A30;
  --on-dark:#EEF0F2;
  --on-dark-soft:#9AA2AB;

  /* Form */
  --radius-lg:20px;
  --radius-md:14px;
  --shadow-lg:0 30px 70px -34px rgba(26,29,33,.45);
  --shadow-sm:0 10px 30px -16px rgba(26,29,33,.35);
  --ease:cubic-bezier(.16,1,.3,1);

  --font-display:'Archivo',-apple-system,BlinkMacSystemFont,sans-serif;
  --font-body:'Public Sans',-apple-system,BlinkMacSystemFont,sans-serif;

  --wrap:1200px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  font-family:var(--font-body);font-weight:400;font-size:17px;line-height:1.6;
  color:var(--ink);background:var(--bg);
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:var(--font-display);font-weight:800;line-height:1.04;letter-spacing:-.02em;color:var(--ink)}
::selection{background:var(--accent);color:#fff}

/* ---------- LAYOUT PRIMITIVES ---------- */
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 clamp(20px,5vw,48px)}
.sec{padding:clamp(64px,9vw,128px) 0}
.eyebrow{display:inline-flex;align-items:center;gap:.55em;font-family:var(--font-body);font-weight:700;
  font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;color:var(--accent)}
.eyebrow::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--accent);
  box-shadow:0 0 0 4px var(--accent-soft);animation:sig-pulse 2.4s var(--ease) infinite}
@keyframes sig-pulse{0%,100%{box-shadow:0 0 0 4px var(--accent-soft)}50%{box-shadow:0 0 0 7px rgba(225,29,42,.06)}}

.sec-head{max-width:720px}
.sec-head.center{margin:0 auto;text-align:center}
.sec-head .eyebrow{margin-bottom:1.1rem}
.sec-head h2{font-size:clamp(2rem,4.4vw,3.3rem);margin-bottom:1rem}
.sec-head p{color:var(--ink-soft);font-size:1.13rem;max-width:60ch}
.sec-head.center p{margin-inline:auto}

/* ---------- BUTTONS ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.55em;
  font-family:var(--font-body);font-weight:600;font-size:1rem;line-height:1;
  padding:.92em 1.5em;border-radius:12px;border:1.5px solid transparent;cursor:pointer;
  transition:transform .25s var(--ease),background .25s var(--ease),box-shadow .25s var(--ease),border-color .25s;white-space:nowrap}
.btn svg{width:1.15em;height:1.15em;flex:none}
.btn-primary{background:var(--accent);color:var(--on-accent);box-shadow:0 12px 28px -12px var(--accent-glow)}
.btn-primary:hover{background:var(--accent-deep);transform:translateY(-2px);box-shadow:0 18px 36px -14px var(--accent-glow)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--line)}
.btn-ghost:hover{border-color:var(--ink);transform:translateY(-2px)}
.btn-lg{font-size:1.06rem;padding:1.05em 1.8em;border-radius:14px}

/* ---------- REVEAL ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1!important;transform:none!important;transition:none}}

/* ---------- HEADER ---------- */
.site-head{position:fixed;inset:0 0 auto 0;z-index:60;transition:background .3s var(--ease),box-shadow .3s var(--ease),border-color .3s}
.site-head{border-bottom:1px solid transparent}
.site-head.scrolled{background:rgba(242,243,245,.86);backdrop-filter:saturate(160%) blur(14px);
  -webkit-backdrop-filter:saturate(160%) blur(14px);border-bottom-color:var(--line);box-shadow:0 1px 0 rgba(26,29,33,.02)}
.head-inner{display:flex;align-items:center;gap:1.5rem;height:74px}
.brand{display:inline-flex;align-items:center;gap:.6em;font-family:var(--font-display);font-weight:800;
  font-size:1.18rem;letter-spacing:-.02em;color:var(--ink)}
.brand .dot{width:13px;height:13px;border-radius:50%;background:var(--accent);position:relative;flex:none;
  box-shadow:0 0 0 4px var(--accent-soft)}
.brand .dot::after{content:"";position:absolute;inset:0;border-radius:50%;border:2px solid var(--accent);
  animation:nd-pw 2.4s ease-out infinite}
@keyframes nd-pw{0%{transform:scale(1);opacity:.7}100%{transform:scale(2.4);opacity:0}}
@media(prefers-reduced-motion:reduce){.brand .dot::after,.eyebrow::before{animation:none}}
.nav-links{display:flex;align-items:center;gap:1.6rem;margin-left:auto}
.nav-links a{font-weight:500;font-size:.98rem;color:var(--ink-soft);transition:color .2s}
.nav-links a:hover{color:var(--ink)}
.nav-links .nav-nd:hover{color:var(--accent-deep)!important}
.nav-cta{display:flex;align-items:center}
.nav-cta .btn{padding:.7em 1.15em}
.burger{display:none;background:none;border:none;color:var(--ink);cursor:pointer;padding:.4rem;margin-left:auto}
.burger svg{width:28px;height:28px}

/* ---------- HERO (BOLD UTILITY / SIGNAL — "Anruf kommt rein") ---------- */
.hero{position:relative;padding:clamp(120px,17vw,178px) 0 clamp(64px,8vw,104px);overflow:hidden;
  background:radial-gradient(120% 80% at 78% 8%,#fff 0%,var(--bg) 46%,var(--bg-ice) 100%)}
.hero-bg{position:absolute;inset:0;z-index:0;pointer-events:none}
.hero-bg .img{position:absolute;inset:0;background-size:cover;background-position:center;
  -webkit-mask-image:linear-gradient(255deg,#000 0%,transparent 58%);mask-image:linear-gradient(255deg,#000 0%,transparent 58%);opacity:.5}
.hero-bg::after{content:"";position:absolute;inset:0;
  background:linear-gradient(90deg,var(--bg) 8%,rgba(242,243,245,.2) 52%,transparent 78%)}
.hero-grid{position:relative;z-index:2;display:grid;grid-template-columns:minmax(0,1.18fr) minmax(0,.92fr);
  gap:clamp(36px,6vw,84px);align-items:center}

.hero-flag{display:inline-flex;align-items:center;gap:.7em;background:var(--ink);color:#fff;
  font-family:var(--font-body);font-weight:700;font-size:.78rem;letter-spacing:.04em;
  padding:.6em 1.05em .6em .8em;border-radius:100px;margin-bottom:1.5rem}
.hero-flag .live{display:inline-flex;align-items:center;gap:.5em}
.hero-flag .blip{width:9px;height:9px;border-radius:50%;background:var(--accent-lite);position:relative}
.hero-flag .blip::after{content:"";position:absolute;inset:0;border-radius:50%;background:var(--accent);
  animation:blip 1.5s ease-out infinite}
@keyframes blip{0%{transform:scale(1);opacity:.9}100%{transform:scale(3);opacity:0}}
@media(prefers-reduced-motion:reduce){.hero-flag .blip::after{animation:none}}

.hero h1{font-size:clamp(2.5rem,6.4vw,4.7rem);margin-bottom:1.3rem}
.hero h1 .sig{color:var(--accent)}
.hero .lead{font-size:clamp(1.1rem,1.7vw,1.32rem);color:var(--ink-soft);max-width:40ch;margin-bottom:2rem;line-height:1.55}
.hero .lead b{color:var(--ink);font-weight:600}
.hero-cta{display:flex;flex-wrap:wrap;gap:.9rem;margin-bottom:1.9rem}
.hero-meta{display:flex;flex-wrap:wrap;gap:1.1rem 1.8rem}
.hero-meta span{display:inline-flex;align-items:center;gap:.5em;font-size:.92rem;color:var(--ink-soft);font-weight:500}
.hero-meta svg{width:1.1em;height:1.1em;color:var(--accent);flex:none}

/* — Notruf-Ring / Telefon-Visual (RIPPLE/PULSE Signature) — */
.hero-call{position:relative;display:flex;justify-content:center;align-items:center;min-height:clamp(360px,42vw,480px)}
.ring-stage{position:relative;width:clamp(260px,30vw,340px);height:clamp(260px,30vw,340px);
  display:flex;align-items:center;justify-content:center}
.ring{position:absolute;inset:0;margin:auto;border-radius:50%;border:1.5px solid var(--accent);
  width:100%;height:100%;opacity:0;animation:notruf-ring 3.2s var(--ease) infinite}
.ring:nth-child(2){animation-delay:1.06s}
.ring:nth-child(3){animation-delay:2.13s}
@keyframes notruf-ring{0%{transform:scale(.42);opacity:.0}10%{opacity:.85}100%{transform:scale(1.18);opacity:0}}
.ring-core{position:relative;z-index:2;width:clamp(120px,15vw,166px);height:clamp(120px,15vw,166px);border-radius:50%;
  background:radial-gradient(ellipse at 34% 28%,var(--accent-lite) 0%,var(--accent) 48%,var(--accent-deep) 100%);
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 0 60px var(--accent-glow),0 24px 50px -18px var(--accent-glow),inset 0 2px 6px rgba(255,255,255,.25);
  animation:core-buzz 1.6s var(--ease) infinite}
@keyframes core-buzz{0%,100%{transform:scale(1) rotate(0)}25%{transform:scale(1.03) rotate(-3deg)}75%{transform:scale(1.03) rotate(3deg)}}
.ring-core svg{width:clamp(46px,6vw,64px);height:auto;color:#fff;filter:drop-shadow(0 2px 6px rgba(0,0,0,.25))}
.call-tag{position:absolute;z-index:3;background:var(--surface);border:1px solid var(--line);
  box-shadow:var(--shadow-sm);border-radius:14px;padding:.7em .95em;display:flex;align-items:center;gap:.65em;
  font-family:var(--font-body)}
.call-tag .lbl{font-size:.72rem;color:var(--ink-faint);font-weight:600;letter-spacing:.04em;text-transform:uppercase;line-height:1.2}
.call-tag .val{font-family:var(--font-display);font-weight:800;font-size:1.02rem;color:var(--ink);line-height:1.1}
.call-tag.t-time{top:6%;left:-6%;animation:floaty 5s ease-in-out infinite}
.call-tag.t-from{bottom:14%;right:-8%;animation:floaty 5s ease-in-out infinite .8s}
.call-tag .icn{width:32px;height:32px;border-radius:9px;background:var(--accent-soft);color:var(--accent-deep);
  display:flex;align-items:center;justify-content:center;flex:none}
.call-tag .icn svg{width:17px;height:17px}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-9px)}}
@media(prefers-reduced-motion:reduce){
  .ring,.ring-core,.call-tag{animation:none!important}
  .ring{opacity:.3;transform:scale(1)}
  .ring:nth-child(3){opacity:.16}
}

/* ---------- TICKER / Sub-Hero Streifen ---------- */
.urg-strip{background:var(--ink);color:var(--on-dark);overflow:hidden;border-block:1px solid rgba(255,255,255,.06)}
.urg-track{display:flex;gap:0;white-space:nowrap;animation:marq 34s linear infinite;will-change:transform}
.urg-strip:hover .urg-track{animation-play-state:paused}
.urg-track span{display:inline-flex;align-items:center;gap:.7em;padding:1.05em 2rem;font-weight:600;font-size:.96rem;letter-spacing:.01em}
.urg-track span i{width:6px;height:6px;border-radius:50%;background:var(--accent);flex:none}
.urg-track b{color:var(--accent-lite);font-family:var(--font-display);font-weight:800}
@keyframes marq{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media(prefers-reduced-motion:reduce){.urg-track{animation:none;flex-wrap:wrap;white-space:normal;justify-content:center}}

/* ---------- SCENARIO TIMELINE (EIGENE SECTION) ---------- */
.scenario{position:relative;background:linear-gradient(180deg,var(--bg) 0%,var(--surface) 100%);overflow:hidden}
.scenario::before{content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(60% 50% at 88% 0%,var(--accent-glow),transparent 55%);opacity:.5}
.scn-signal{position:absolute;top:-8%;right:-6%;width:min(46vw,560px);aspect-ratio:16/9;z-index:0;pointer-events:none;
  background-size:cover;background-position:center;opacity:.16;mix-blend-mode:multiply;
  -webkit-mask-image:radial-gradient(closest-side,#000 30%,transparent 78%);mask-image:radial-gradient(closest-side,#000 30%,transparent 78%)}
.scenario .wrap{position:relative;z-index:1}
@media(max-width:760px){.scn-signal{top:0;right:-20%;width:90vw;opacity:.1}}
.scn-head{display:flex;flex-wrap:wrap;align-items:flex-end;justify-content:space-between;gap:1.5rem;margin-bottom:clamp(40px,6vw,72px)}
.scn-head .sec-head{margin:0}
.scn-clock{display:inline-flex;align-items:center;gap:.7em;background:var(--ink);color:#fff;border-radius:14px;
  padding:.8em 1.15em;font-family:var(--font-display);font-weight:800;font-size:1.25rem;letter-spacing:.02em;box-shadow:var(--shadow-sm)}
.scn-clock .dotlive{width:10px;height:10px;border-radius:50%;background:var(--accent);position:relative}
.scn-clock .dotlive::after{content:"";position:absolute;inset:0;border-radius:50%;background:var(--accent);animation:blip 1.6s ease-out infinite}
@media(prefers-reduced-motion:reduce){.scn-clock .dotlive::after{animation:none}}

.timeline{position:relative;display:grid;gap:clamp(14px,2.4vw,22px)}
/* vertikale Signal-Linie */
.timeline::before{content:"";position:absolute;left:calc(clamp(64px,8vw,94px) + 26px);top:18px;bottom:18px;width:2px;
  background:linear-gradient(180deg,var(--accent) 0%,var(--accent-deep) 70%,transparent 100%);opacity:.5}
.tl-step{position:relative;display:grid;grid-template-columns:clamp(64px,8vw,94px) auto 1fr;gap:clamp(16px,2.5vw,30px);align-items:start}
.tl-time{font-family:var(--font-display);font-weight:800;font-size:clamp(1rem,1.4vw,1.25rem);color:var(--ink);
  text-align:right;padding-top:14px;letter-spacing:.01em;white-space:nowrap}
.tl-time small{display:block;font-family:var(--font-body);font-weight:600;font-size:.7rem;color:var(--ink-faint);
  text-transform:uppercase;letter-spacing:.1em;margin-top:.2em}
.tl-node{position:relative;z-index:2;width:54px;height:54px;border-radius:50%;background:var(--surface);
  border:2px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--ink-soft);
  box-shadow:var(--shadow-sm);transition:transform .4s var(--ease),border-color .4s,color .4s,background .4s}
.tl-node svg{width:24px;height:24px}
.tl-step.is-ki .tl-node{background:var(--accent);border-color:var(--accent);color:#fff;
  box-shadow:0 0 0 6px var(--accent-soft),0 14px 30px -12px var(--accent-glow)}
.tl-step.is-ki .tl-node::after{content:"";position:absolute;inset:-2px;border-radius:50%;border:2px solid var(--accent);
  animation:nd-pw 2.6s ease-out infinite}
@media(prefers-reduced-motion:reduce){.tl-step.is-ki .tl-node::after{animation:none}}
.tl-step.is-win .tl-node{background:var(--ink);border-color:var(--ink);color:var(--accent-lite)}
/* progressive Aktivierung beim Scroll (app.js setzt .seen) */
.tl-node{transform:scale(.82);opacity:.55}
.tl-step.seen .tl-node{transform:scale(1);opacity:1}
@media(prefers-reduced-motion:reduce){.tl-node{transform:none;opacity:1}}
.tl-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-md);
  padding:clamp(18px,2.4vw,26px) clamp(20px,2.6vw,30px);box-shadow:var(--shadow-sm);
  transition:transform .4s var(--ease),box-shadow .4s var(--ease)}
.tl-step:hover .tl-card{transform:translateX(4px);box-shadow:var(--shadow-lg)}
.tl-card .who{display:inline-flex;align-items:center;gap:.5em;font-family:var(--font-body);font-weight:700;
  font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);margin-bottom:.5rem}
.tl-step.is-call .tl-card .who{color:var(--ink-faint)}
.tl-step.is-win .tl-card .who{color:var(--accent)}
.tl-card h3{font-size:clamp(1.18rem,1.9vw,1.5rem);margin-bottom:.45rem}
.tl-card p{color:var(--ink-soft);font-size:1.02rem;max-width:54ch}
.tl-card .qt{margin-top:.85rem;padding:.7em 1em;border-left:3px solid var(--accent);background:var(--bg);
  border-radius:0 10px 10px 0;font-style:italic;color:var(--ink);font-size:.98rem}
.scn-foot{margin-top:clamp(36px,5vw,56px);display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:1.2rem;
  text-align:center}
.scn-foot p{color:var(--ink-soft);font-size:1.05rem;max-width:46ch}
.scn-foot b{color:var(--ink);font-weight:700}

/* ---------- WAS DIE NOTRUF-KI KANN ---------- */
.caps{background:var(--surface)}
.cap-shots{display:grid;grid-template-columns:1fr 1fr;gap:clamp(16px,2.4vw,24px);margin-top:clamp(40px,6vw,60px)}
.cap-shot{position:relative;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-lg);
  border:1px solid var(--line);aspect-ratio:16/10;margin:0}
.cap-shot img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .6s var(--ease)}
.cap-shot:hover img{transform:scale(1.04)}
.cap-shot::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(26,29,33,.82) 100%)}
.cap-shot figcaption{position:absolute;left:0;right:0;bottom:0;z-index:2;padding:clamp(16px,2.2vw,22px);
  color:#fff;font-family:var(--font-display);font-weight:700;font-size:clamp(1.05rem,1.6vw,1.32rem);line-height:1.2}
.cap-shot .tag{display:block;font-family:var(--font-body);font-weight:700;font-size:.72rem;letter-spacing:.14em;
  text-transform:uppercase;color:var(--accent-lite);margin-bottom:.45rem}
.cap-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(16px,2.4vw,24px);margin-top:clamp(20px,3vw,28px)}
.cap{position:relative;background:var(--bg);border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:clamp(26px,3.4vw,40px);overflow:hidden;transition:transform .4s var(--ease),box-shadow .4s var(--ease),border-color .4s}
.cap::before{content:"";position:absolute;inset:0;border-radius:inherit;padding:1px;pointer-events:none;
  background:linear-gradient(135deg,var(--accent),transparent 42%);opacity:0;transition:opacity .4s;
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude}
.cap:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:transparent}
.cap:hover::before{opacity:1}
.cap-ic{width:54px;height:54px;border-radius:14px;background:var(--accent-soft);color:var(--accent-deep);
  display:flex;align-items:center;justify-content:center;margin-bottom:1.3rem}
.cap-ic svg{width:27px;height:27px}
.cap h3{font-size:clamp(1.3rem,2vw,1.65rem);margin-bottom:.6rem}
.cap p{color:var(--ink-soft);font-size:1.04rem;line-height:1.6}

/* ---------- VERLORENER-AUFTRAG BAND ---------- */
.lossband{position:relative;background:linear-gradient(150deg,var(--dark),var(--dark-2));color:var(--on-dark);overflow:hidden}
.lossband::before{content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(70% 90% at 14% 110%,var(--accent-glow),transparent 55%)}
.lossband .wrap{position:relative;z-index:1;display:grid;grid-template-columns:minmax(0,1fr) minmax(0,.86fr);
  gap:clamp(36px,6vw,80px);align-items:center}
.lossband .eyebrow{color:var(--accent-lite)}
.lossband .eyebrow::before{background:var(--accent-lite);box-shadow:0 0 0 4px rgba(242,107,107,.18)}
.loss-copy h2{color:#fff;font-size:clamp(2rem,4.2vw,3.2rem);margin-bottom:1.1rem;max-width:18ch}
.loss-copy h2 .sig{color:var(--accent-lite)}
.loss-copy p{color:var(--on-dark-soft);font-size:1.13rem;max-width:48ch;margin-bottom:1.8rem}
.loss-copy .btn-ghost{color:#fff;border-color:rgba(255,255,255,.32)}
.loss-copy .btn-ghost:hover{background:#fff;color:var(--dark);border-color:#fff}
.loss-stats{display:grid;gap:14px}
.loss-stat{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-md);
  padding:clamp(20px,2.6vw,28px);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}
.loss-stat .n{font-family:var(--font-display);font-weight:800;font-size:clamp(2rem,3.6vw,2.9rem);color:#fff;line-height:1;letter-spacing:-.02em}
.loss-stat .n .u{font-size:.42em;color:var(--accent-lite);margin-left:.25em;letter-spacing:0}
.loss-stat p{color:var(--on-dark-soft);font-size:.98rem;margin-top:.5rem;max-width:38ch}

/* ---------- FAQ ---------- */
.faqsec{background:var(--bg)}
.faq{max-width:820px;margin:clamp(36px,5vw,56px) auto 0}
.qa{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-md);margin-bottom:14px;
  overflow:hidden;transition:box-shadow .3s var(--ease),border-color .3s}
.qa[open]{box-shadow:var(--shadow-sm);border-color:rgba(225,29,42,.28)}
.qa summary{list-style:none;cursor:pointer;padding:1.15em 1.4em;font-family:var(--font-display);font-weight:700;
  font-size:1.1rem;color:var(--ink);display:flex;align-items:center;justify-content:space-between;gap:1rem}
.qa summary::-webkit-details-marker{display:none}
.qa summary::after{content:"";width:22px;height:22px;flex:none;border-radius:50%;background:var(--accent-soft);
  position:relative;transition:background .25s}
.qa summary::before{content:"";position:absolute;right:calc(1.4em + 5px);width:12px;height:2px;background:var(--accent-deep);
  transition:transform .3s var(--ease)}
.qa summary{position:relative}
.qa .mark-v{position:absolute;right:calc(1.4em + 10px);width:2px;height:12px;background:var(--accent-deep);
  transition:transform .3s var(--ease);top:50%;margin-top:-6px}
.qa[open] .mark-v{transform:scaleY(0)}
.qa .a{padding:0 1.4em 1.3em;color:var(--ink-soft);font-size:1.04rem;line-height:1.62;max-width:64ch}
.qa.qa-urgent{border-color:rgba(225,29,42,.4);background:linear-gradient(180deg,var(--accent-soft) 0%,var(--surface) 26%)}
.qa.qa-urgent summary{color:var(--accent-deep)}

/* ---------- FOOTER ---------- */
.site-foot{background:var(--ink);color:var(--on-dark-soft);padding:clamp(56px,7vw,84px) 0 2.4rem}
.foot-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:clamp(28px,5vw,64px);padding-bottom:2.6rem;
  border-bottom:1px solid rgba(255,255,255,.08)}
.foot-brand .brand{color:#fff;font-size:1.3rem;margin-bottom:1rem}
.foot-brand .brand .dot{box-shadow:0 0 0 4px rgba(225,29,42,.22)}
.foot-brand p{font-size:.98rem;max-width:38ch;line-height:1.6}
.foot-emer{display:inline-flex;align-items:center;gap:.6em;margin-top:1.3rem;background:rgba(225,29,42,.14);
  border:1px solid rgba(225,29,42,.3);color:#fff;border-radius:12px;padding:.7em 1.05em;font-weight:600;font-size:.96rem}
.foot-emer svg{width:1.15em;height:1.15em;color:var(--accent-lite)}
.foot-col h4{color:#fff;font-family:var(--font-display);font-weight:700;font-size:.82rem;letter-spacing:.12em;
  text-transform:uppercase;margin-bottom:1.1rem}
.foot-col a{display:block;color:var(--on-dark-soft);font-size:.98rem;padding:.32em 0;transition:color .2s}
.foot-col a:hover{color:#fff}
.foot-bottom{display:flex;flex-wrap:wrap;gap:.8rem 1.6rem;justify-content:space-between;align-items:center;
  padding-top:2rem;font-size:.9rem}
.foot-bottom a{color:var(--on-dark-soft);transition:color .2s}
.foot-bottom a:hover{color:#fff}
.foot-bottom .nd a{color:var(--accent-lite);font-weight:600}

/* ---------- STICKY MOBILE CTA ---------- */
.sticky-cta{position:fixed;left:0;right:0;bottom:0;z-index:55;display:none;gap:.7rem;padding:.7rem clamp(14px,4vw,18px);
  background:rgba(242,243,245,.92);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  border-top:1px solid var(--line);box-shadow:0 -8px 28px -18px rgba(26,29,33,.4)}
.sticky-cta .btn{flex:1;padding:.95em 1em}

/* ---------- RESPONSIVE ---------- */
@media(max-width:1000px){
  .hero-grid{grid-template-columns:1fr;gap:clamp(40px,7vw,60px)}
  .hero-call{min-height:340px;order:2}
  .hero-bg .img{opacity:.32}
  .lossband .wrap{grid-template-columns:1fr;gap:2.4rem}
}
@media(max-width:860px){
  .nav-links,.nav-cta{display:none}
  .burger{display:inline-flex}
  .site-head .head-inner{height:64px}
  /* Mobile nav drawer */
  .nav-links.open{display:flex;position:fixed;inset:64px 0 auto 0;flex-direction:column;align-items:stretch;
    gap:0;background:var(--surface);border-bottom:1px solid var(--line);box-shadow:var(--shadow-lg);
    padding:.5rem clamp(20px,5vw,48px) 1.2rem;margin:0}
  .nav-links.open a{padding:.95em 0;border-bottom:1px solid var(--line);font-size:1.05rem}
  .nav-links.open .nav-nd{color:var(--accent)!important;border-bottom:none}
  .cap-grid{grid-template-columns:1fr}
  .cap-shots{grid-template-columns:1fr}
  .sticky-cta{display:flex}
  body{padding-bottom:74px}
  .site-foot{padding-bottom:calc(74px + 2rem)}
}
@media(max-width:680px){
  .foot-grid{grid-template-columns:1fr;gap:2rem}
  .scn-head{flex-direction:column;align-items:flex-start}
  .tl-step{grid-template-columns:auto 1fr;gap:14px}
  .tl-time{grid-column:1/-1;text-align:left;padding-top:0;order:-1;display:flex;align-items:baseline;gap:.6em}
  .tl-time small{margin-top:0}
  .timeline::before{left:26px}
  .call-tag.t-time{left:-2%}
  .call-tag.t-from{right:-2%}
}

/* =============================================================
   LEGAL PAGES (impressum / datenschutz / agb)
   ============================================================= */
body.legal-page{padding-top:74px;background:var(--surface)}
@media(max-width:860px){body.legal-page{padding-top:64px;padding-bottom:0}}
.legal-hero{background:linear-gradient(180deg,var(--bg) 0%,var(--surface) 100%);padding:clamp(48px,7vw,84px) 0 clamp(28px,4vw,44px);
  border-bottom:1px solid var(--line)}
.legal-hero .eyebrow{margin-bottom:.9rem}
.legal-hero h1{font-size:clamp(2.1rem,4.6vw,3.2rem);margin-bottom:.6rem}
.legal-hero p{color:var(--ink-soft);font-size:1.1rem;max-width:60ch}
.legal-body{padding:clamp(40px,6vw,72px) clamp(20px,5vw,48px);max-width:880px}
.legal-body h2{font-size:clamp(1.35rem,2.4vw,1.75rem);margin:2.2rem 0 .8rem;color:var(--ink)}
.legal-body h2:first-child{margin-top:0}
.legal-body h3{font-size:1.12rem;font-weight:700;margin:1.4rem 0 .5rem;color:var(--ink)}
.legal-body p{color:var(--ink-soft);margin-bottom:1rem;line-height:1.66}
.legal-body ul{color:var(--ink-soft);margin:0 0 1.1rem 1.2rem;line-height:1.66}
.legal-body li{margin-bottom:.4rem}
.legal-body a{color:var(--accent-deep);font-weight:500;word-break:break-word}
.legal-body a:hover{text-decoration:underline}
.legal-body strong{color:var(--ink);font-weight:600}
.legal-body hr{border:none;border-top:1px solid var(--line);margin:2.2rem 0}
.legal-body table{width:100%;border-collapse:collapse;margin:1rem 0 1.4rem;font-size:.95rem}
.legal-body th,.legal-body td{text-align:left;padding:.7em .9em;border:1px solid var(--line);color:var(--ink-soft)}
.legal-body th{background:var(--bg);color:var(--ink);font-weight:700;font-family:var(--font-display)}
.legal-note{background:var(--bg);border:1px solid var(--line);border-left:3px solid var(--accent);
  border-radius:0 12px 12px 0;padding:1.1em 1.3em;margin:1.6rem 0;color:var(--ink-soft);font-size:.98rem;line-height:1.6}
.legal-note strong{color:var(--ink)}
