/* ===================================================================
   ImpfschadenRecht — Design System
   =================================================================== */

:root{
  --blau-dunkel:#1B3A5C;
  --blau-tief:#0F2137;
  --blau-mittel:#2563EB;
  --blau-hell:#EFF6FF;
  --orange:#F97316;
  --orange-hover:#EA6200;
  --gruen:#16A34A;
  --whatsapp:#25D366;
  --whatsapp-hover:#1EB955;
  --rot:#DC2626;
  --rot-tief:#991B1B;
  --text:#334155;
  --text-hell:#64748B;
  --weiss:#FFFFFF;
  --bg-alt:#F8FAFC;
  --border:#E2E8F0;
  --radius:14px;
  --radius-sm:9px;
  --shadow:0 10px 40px rgba(15,33,55,.10);
  --shadow-lg:0 20px 60px rgba(15,33,55,.18);
  --maxw:1180px;
  --space:clamp(56px,8vw,96px);
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:84px}
body{
  font-family:'Inter',system-ui,-apple-system,'Segoe UI',sans-serif;
  color:var(--text);
  line-height:1.7;
  font-size:clamp(15.5px, 14.6px + 0.32vw, 17px);
  background:var(--weiss);
  -webkit-font-smoothing:antialiased;
  overflow-wrap:break-word;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{color:var(--blau-dunkel);line-height:1.18;font-weight:800;
  letter-spacing:-.02em;overflow-wrap:break-word;hyphens:auto}
h2{font-size:clamp(28px,3.6vw,42px)}
h3{font-size:21px;font-weight:700}
h4{font-size:16px;font-weight:700;text-transform:uppercase;letter-spacing:.06em}
p{margin:0}

/* ---------- Icon-System ---------- */
.sprite{position:absolute;width:0;height:0;overflow:hidden}
.ic{display:inline-block;flex:none;width:24px;height:24px;
  fill:none;stroke:currentColor;stroke-width:1.9;
  stroke-linecap:round;stroke-linejoin:round;vertical-align:middle}
.ic--brand{stroke:none;fill:currentColor}

/* ---------- Sichtbarer Tastatur-Fokus (a11y) ---------- */
:focus-visible{outline:3px solid var(--blau-mittel);outline-offset:2px;
  border-radius:4px}
.hero :focus-visible,.urgency :focus-visible,.contact :focus-visible,
.stats :focus-visible,.footer :focus-visible{outline-color:#fff}

.container{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.container--narrow{max-width:820px}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  font-family:inherit;font-weight:600;font-size:17px;cursor:pointer;
  padding:15px 30px;border:none;border-radius:var(--radius-sm);
  transition:transform .15s ease,box-shadow .2s ease,background .2s ease;
  text-align:center;line-height:1.2;max-width:100%;min-width:0;
}
.btn:hover{transform:translateY(-2px)}
.btn--primary{background:var(--orange);color:#fff;box-shadow:0 8px 22px rgba(249,115,22,.32)}
.btn--primary:hover{background:var(--orange-hover);box-shadow:0 12px 28px rgba(249,115,22,.42)}
.btn--whatsapp{background:var(--whatsapp);color:#fff;box-shadow:0 8px 22px rgba(37,211,102,.3)}
.btn--whatsapp:hover{background:var(--whatsapp-hover)}
.btn--light{background:#fff;color:var(--rot-tief)}
.btn--light:hover{background:#fff5f5}
.btn--lg{padding:18px 36px;font-size:18px}
.btn--sm{padding:10px 20px;font-size:15px}
.btn--block{width:100%}
.btn__ic{width:20px;height:20px}

.badge{
  display:inline-block;font-size:13px;font-weight:700;letter-spacing:.07em;
  text-transform:uppercase;color:var(--blau-mittel);
  background:var(--blau-hell);padding:7px 16px;border-radius:30px;margin-bottom:18px;
}
.badge--light{color:#fff;background:rgba(255,255,255,.16);
  -webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}

/* ---------- Announcement Bar ---------- */
.announce{background:var(--rot);color:#fff;font-size:14.5px;font-weight:500}
.announce__inner{display:flex;align-items:center;justify-content:center;gap:18px;
  padding:11px 24px;flex-wrap:wrap;text-align:center}
.announce__cta{font-weight:700;text-decoration:underline;white-space:nowrap}

/* ---------- Nav ---------- */
.nav{position:sticky;top:0;z-index:100;background:#fff;
  border-bottom:1px solid transparent;transition:box-shadow .25s,border-color .25s}
.nav--scrolled{box-shadow:0 4px 24px rgba(15,33,55,.09);border-color:var(--border)}
.nav__inner{display:flex;align-items:center;justify-content:space-between;
  gap:24px;height:66px}
.nav__logo{font-size:22px;font-weight:800;color:var(--blau-dunkel);letter-spacing:-.03em}
.nav__logo span{color:var(--orange)}
.nav__links{display:flex;align-items:center;gap:30px}
.nav__links a{font-size:15.5px;font-weight:500;color:var(--text);transition:color .15s}
.nav__links a:hover{color:var(--blau-mittel)}
.nav__links-cta{display:none}
.nav__actions{display:flex;align-items:center;gap:14px}
.nav__toggle{display:none;width:42px;height:42px;border:none;background:transparent;
  cursor:pointer;align-items:center;justify-content:center;border-radius:8px}
.nav__bars,.nav__bars::before,.nav__bars::after{
  display:block;width:24px;height:2.5px;border-radius:2px;
  background:var(--blau-dunkel);transition:transform .25s ease,opacity .2s ease}
.nav__bars{position:relative}
.nav__bars::before,.nav__bars::after{content:"";position:absolute;left:0}
.nav__bars::before{top:-7px}
.nav__bars::after{top:7px}
.nav--open .nav__bars{background:transparent}
.nav--open .nav__bars::before{transform:translateY(7px) rotate(45deg)}
.nav--open .nav__bars::after{transform:translateY(-7px) rotate(-45deg)}

/* ---------- Hero ---------- */
.hero{
  position:relative;color:#fff;overflow:hidden;
  background:linear-gradient(135deg,#1B3A5C 0%,#152e49 55%,#0F2137 100%);
}
.hero__overlay{
  position:absolute;inset:0;
  background:
    linear-gradient(115deg,rgba(27,58,92,.93) 0%,rgba(21,46,73,.86) 55%,rgba(15,33,55,.88) 100%),
    url('/img/hero.jpg');
  background-size:cover;background-position:center;
}
.hero__grid{position:relative;display:grid;grid-template-columns:1.05fr .95fr;
  gap:56px;align-items:center;padding:clamp(56px,8vw,90px) 24px}
.hero__content h1{color:#fff;font-size:clamp(34px,5vw,56px);margin:16px 0 20px}
.hero__content h1 span{color:var(--orange)}
.hero__lead{font-size:clamp(16px,1.1vw + 12px,19px);color:#cdd9e6;
  max-width:540px;margin-bottom:30px}
.hero__cta{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:30px}
.hero__trust{list-style:none;display:flex;flex-wrap:wrap;gap:10px 26px}
.hero__trust li{font-size:14.5px;color:#aebfd0;position:relative;padding-left:24px}
.hero__trust li::before{content:"✓";position:absolute;left:0;color:var(--gruen);
  font-weight:800}

/* ---------- Card / Form ---------- */
.card{background:#fff;border-radius:var(--radius);padding:34px;
  box-shadow:var(--shadow-lg);color:var(--text)}
.card__title{font-size:clamp(20px,1.2vw + 15px,23px);margin-bottom:4px}
.card__sub{font-size:14px;color:var(--text-hell);margin-bottom:22px}

.form{display:flex;flex-direction:column;gap:13px}
.form__row{display:flex;gap:13px}
.form__row>*{flex:1;min-width:0}
.form input,.form select,.form textarea{
  font-family:inherit;font-size:16px;color:var(--text);
  padding:14px 16px;border:1.5px solid var(--border);
  border-radius:var(--radius-sm);background:#fff;width:100%;
  transition:border-color .15s,box-shadow .15s;
}
.form input::placeholder,.form textarea::placeholder{color:#94A3B8}
.form input:focus,.form select:focus,.form textarea:focus{
  outline:none;border-color:var(--blau-mittel);
  box-shadow:0 0 0 4px rgba(37,99,235,.12)}
.form select{-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%2364748B' d='M6 8 0 0h12z'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 16px center;padding-right:42px}
.form select:invalid{color:#94A3B8}
.form textarea{resize:vertical;min-height:96px}
.form__note{font-size:12.5px;color:var(--text-hell);line-height:1.5;margin-top:2px}
.form__note a{color:var(--blau-mittel);text-decoration:underline}
.form__msg{font-size:14.5px;font-weight:600;margin-top:4px;display:none}
.form__msg.is-ok{display:block;color:var(--gruen)}
.form__msg.is-err{display:block;color:var(--rot)}
.hp{position:absolute!important;left:-9999px!important;width:1px!important;
  height:1px!important;opacity:0!important;pointer-events:none}

.form--dark input,.form--dark select,.form--dark textarea{
  background:rgba(255,255,255,.07);border-color:rgba(255,255,255,.18);color:#fff}
.form--dark input::placeholder,.form--dark textarea::placeholder{color:#9fb2c6}
.form--dark select{color:#fff;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%239fb2c6' d='M6 8 0 0h12z'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 16px center}
.form--dark select:invalid{color:#9fb2c6}
.form--dark select option{color:#1B3A5C}
.form--dark .form__note{color:#9fb2c6}
.form--dark .form__note a{color:#9ec5ff}

/* ---------- Sections ---------- */
.section{padding:var(--space) 0}
.section--alt{background:var(--bg-alt)}
.section--blue{background:var(--blau-hell)}
.section__head{max-width:780px;margin:0 auto clamp(40px,5vw,56px);text-align:center}
.section__head h2{margin-bottom:14px}
.section__head p{font-size:clamp(16px,1vw + 12px,19px);color:var(--text-hell)}
.section__bridge{text-align:center;font-size:clamp(18px,1.4vw + 12px,22px);
  font-weight:700;color:var(--blau-dunkel);margin-top:46px}

.grid{display:grid;gap:24px}
.grid--3{grid-template-columns:repeat(3,1fr)}
.grid--4{grid-template-columns:repeat(4,1fr)}

/* ---------- Stats ---------- */
.stats{background:var(--blau-dunkel);color:#fff;padding:46px 0 30px}
.stats__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;text-align:center}
.stat__num{display:block;font-size:clamp(28px,3.4vw,40px);font-weight:800;
  color:var(--orange);letter-spacing:-.02em}
.stat__label{display:block;font-size:14.5px;color:#b9c7d6;margin-top:6px;line-height:1.5}
.stats__source{text-align:center;font-size:12.5px;color:#A6B6C8;margin-top:26px}

/* ---------- Symptoms ---------- */
.symptom{background:#fff;border:1px solid var(--border);border-radius:var(--radius);
  padding:26px;transition:transform .18s,box-shadow .18s,border-color .18s}
.symptom:hover{transform:translateY(-4px);box-shadow:var(--shadow);
  border-color:transparent}
.symptom__ico{display:block;width:38px;height:38px;color:var(--blau-mittel);margin-bottom:16px}
.symptom h3{margin-bottom:7px}
.symptom p{font-size:15px;color:var(--text-hell)}

.callout{margin-top:46px;background:var(--blau-hell);border-left:5px solid var(--blau-mittel);
  border-radius:var(--radius);padding:30px 34px;display:flex;align-items:center;
  justify-content:space-between;gap:28px;flex-wrap:wrap}
.callout p{font-size:17px;flex:1;min-width:280px}
.callout--dark{background:var(--blau-dunkel);border-left-color:var(--orange);color:#fff}
.callout--dark p{color:#dce6f0}

/* ---------- Problem ---------- */
.prob{background:#fff;border-radius:var(--radius);padding:32px 28px;
  box-shadow:var(--shadow);border-top:4px solid var(--rot)}
.prob__mark{display:inline-flex;align-items:center;justify-content:center;
  width:42px;height:42px;border-radius:50%;background:#FEE2E2;color:var(--rot);
  font-size:20px;font-weight:800;margin-bottom:18px}
.prob h3{margin-bottom:11px}
.prob p{font-size:15.5px;color:var(--text-hell);margin-bottom:16px}
.prob__stat{font-size:13.5px;font-weight:700;color:var(--rot);
  background:#FEE2E2;padding:6px 13px;border-radius:7px;display:inline-block}

/* ---------- USP ---------- */
.usp{background:#fff;border:1px solid var(--border);border-radius:var(--radius);
  padding:30px 26px;transition:transform .18s,box-shadow .18s}
.usp:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.usp__ico{display:block;width:36px;height:36px;color:var(--blau-mittel);margin-bottom:16px}
.usp h3{margin-bottom:10px;font-size:19px}
.usp p{font-size:15px;color:var(--text-hell)}

/* ---------- 3 Wege ---------- */
.ways{align-items:stretch}
.way{background:#fff;border-radius:var(--radius);padding:32px 28px;position:relative;
  box-shadow:var(--shadow);border-top:5px solid var(--blau-mittel);
  display:flex;flex-direction:column}
.way--blue{border-top-color:var(--blau-mittel)}
.way--orange{border-top-color:var(--orange)}
.way--green{border-top-color:var(--gruen)}
.way__badge{position:absolute;top:-13px;right:24px;background:var(--orange);
  color:#fff;font-size:12px;font-weight:700;padding:6px 14px;border-radius:20px;
  text-transform:uppercase;letter-spacing:.04em}
.way__no{font-size:40px;font-weight:800;color:var(--border);line-height:1}
.way h3{margin:8px 0 4px;font-size:22px}
.way__law{font-size:14px;font-weight:600;color:var(--blau-mittel)}
.way hr{border:none;border-top:1px solid var(--border);margin:18px 0}
.way__for{font-size:14.5px;color:var(--text-hell);margin-bottom:12px}
.way__hl{font-size:14px;background:#FFF7ED;color:#9A3412;padding:11px 14px;
  border-radius:8px;margin-bottom:14px;font-weight:500}
.way__list{list-style:none;margin-bottom:14px;display:flex;flex-direction:column;gap:7px}
.way__list li{font-size:14.5px;padding-left:25px;position:relative}
.way__list--ok li::before{content:"✓";position:absolute;left:0;color:var(--gruen);font-weight:800}
.way__list--warn li::before{content:"!";position:absolute;left:0;color:var(--orange);
  font-weight:800;width:16px;text-align:center}
.way__list--warn li{color:var(--text-hell)}
.way__court{margin-top:auto;font-size:13px;color:var(--text-hell);
  border-top:1px solid var(--border);padding-top:14px;font-weight:500}

/* ---------- Urgency ---------- */
.urgency{background:linear-gradient(135deg,var(--rot) 0%,var(--rot-tief) 100%);
  color:#fff;padding:var(--space) 0}
.urgency__grid{display:grid;grid-template-columns:1.3fr 1fr;gap:56px;align-items:center}
.urgency__ico{display:block;width:46px;height:46px;color:#fff;margin-bottom:16px}
.urgency h2{color:#fff;margin-bottom:18px}
.urgency p{color:#ffe2e2;margin-bottom:16px;font-size:17px}
.urgency .btn{margin-top:12px}
.timeline{list-style:none;display:flex;flex-direction:column;gap:14px}
.timeline li{background:rgba(255,255,255,.10);border-radius:10px;padding:15px 20px;
  font-size:15.5px;border-left:4px solid rgba(255,255,255,.35)}
.timeline li span{display:block;font-size:13px;font-weight:700;text-transform:uppercase;
  letter-spacing:.05em;opacity:.8;margin-bottom:2px}
.timeline--now{background:rgba(255,255,255,.22)!important;
  border-left-color:#fff!important;font-weight:700}
.timeline--end{opacity:.65}

/* ---------- Steps ---------- */
.step{background:#fff;border:1px solid var(--border);border-radius:var(--radius);
  padding:32px 26px;text-align:center;position:relative}
.step__no{position:absolute;top:-18px;left:50%;transform:translateX(-50%);
  width:38px;height:38px;border-radius:50%;background:var(--blau-mittel);color:#fff;
  font-weight:800;display:flex;align-items:center;justify-content:center;font-size:17px}
.step:last-child .step__no{background:var(--orange)}
.step__ico{display:block;width:38px;height:38px;color:var(--blau-mittel);margin:16px auto 14px}
.step h3{margin-bottom:10px}
.step p{font-size:15px;color:var(--text-hell);margin-bottom:16px}
.step__time{font-size:13px;font-weight:700;color:var(--blau-mittel);
  background:var(--blau-hell);padding:6px 14px;border-radius:7px;display:inline-block}
.hint{margin-top:42px;background:#F0FDF4;border:1px solid #BBF7D0;border-radius:var(--radius);
  padding:22px 26px;font-size:16px;color:#14532D;
  display:flex;align-items:flex-start;gap:16px}
.hint__ico{width:30px;height:30px;color:var(--gruen);flex:none;margin-top:1px}
.hint strong{color:#14532D}

/* ---------- FAQ ---------- */
.faq{display:flex;flex-direction:column;gap:12px}
.faq__item{background:#fff;border:1px solid var(--border);border-radius:var(--radius-sm);
  overflow:hidden;transition:box-shadow .18s}
.faq__item[open]{box-shadow:var(--shadow)}
.faq__item summary{display:block;font-size:17px;font-weight:700;color:var(--blau-dunkel);
  padding:20px 56px 20px 24px;cursor:pointer;list-style:none;position:relative}
.faq__item summary::-webkit-details-marker{display:none}
.faq__item summary::after{content:"+";position:absolute;right:24px;top:50%;
  transform:translateY(-50%);font-size:24px;font-weight:400;color:var(--blau-mittel);
  transition:transform .2s}
.faq__item[open] summary::after{transform:translateY(-50%) rotate(45deg)}
.faq__body{padding:0 24px 22px}
.faq__body p{color:var(--text-hell);font-size:15.5px}

/* ---------- Contact ---------- */
.contact{background:var(--blau-dunkel);color:#fff;padding:var(--space) 0}
.contact__grid{display:grid;grid-template-columns:1.4fr 1fr;gap:50px;align-items:start}
.contact__form h2{color:#fff;margin-bottom:6px}
.contact__sub{color:#9fb2c6;margin-bottom:28px;font-size:16px}
.contact__info{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);
  border-radius:var(--radius);padding:32px}
.contact__info h3{color:#fff;margin-bottom:22px;font-size:19px}
.contact__line{display:flex;gap:16px;align-items:center;padding:15px 0;
  border-bottom:1px solid rgba(255,255,255,.10);font-size:15px;color:#cdd9e6}
.contact__line:hover strong{color:var(--orange)}
.contact__line:last-of-type{border-bottom:none}
.contact__ico{width:44px;height:44px;padding:11px;flex:none;border-radius:50%;
  background:rgba(255,255,255,.07);color:var(--orange);
  transition:background .15s ease}
.contact__line:hover .contact__ico{background:rgba(249,115,22,.16)}
.contact__line strong{color:#fff;font-size:16px}
.contact__rsv{margin-top:22px;background:rgba(249,115,22,.12);
  border:1px solid rgba(249,115,22,.3);border-radius:10px;padding:18px}
.contact__rsv strong{color:var(--orange);display:block;margin-bottom:6px}
.contact__rsv p{font-size:14px;color:#cdd9e6}

/* ---------- Footer ---------- */
.footer{background:var(--blau-tief);color:#94A3B8;padding:64px 0 0}
.footer__grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.4fr;gap:40px;
  padding-bottom:48px}
.footer__logo{font-size:21px;font-weight:800;color:#fff;display:block;margin-bottom:14px}
.footer__logo span{color:var(--orange)}
.footer p{font-size:14.5px;margin-bottom:12px;line-height:1.65}
.footer__disc{font-size:12.5px;color:#94A3B8}
.footer h4{color:#fff;margin-bottom:16px}
.footer__grid a{display:block;font-size:14.5px;margin-bottom:10px;
  transition:color .15s}
.footer__grid a:hover{color:#fff}
.footer__bottom{border-top:1px solid rgba(255,255,255,.08);padding:22px 0;
  font-size:13px;color:#94A3B8}

/* ---------- Floating WhatsApp ---------- */
.wa-float{position:fixed;bottom:24px;right:24px;z-index:95;width:58px;height:58px;
  border-radius:50%;background:var(--whatsapp);color:#fff;display:flex;
  align-items:center;justify-content:center;
  box-shadow:0 6px 22px rgba(37,211,102,.45);
  opacity:0;visibility:hidden;transform:translateY(16px) scale(.85);
  transition:opacity .25s ease,transform .25s ease,box-shadow .2s ease}
.wa-float--show{opacity:1;visibility:visible;transform:translateY(0) scale(1)}
.wa-float--hidden{opacity:0;visibility:hidden;transform:translateY(16px) scale(.85)}
.wa-float:hover,.wa-float:focus-visible{box-shadow:0 8px 28px rgba(37,211,102,.6)}
.wa-float .ic{width:34px;height:34px}
.wa-float::after{content:attr(data-tip);position:absolute;right:72px;
  background:var(--blau-dunkel);color:#fff;font-size:13px;font-weight:600;
  white-space:nowrap;padding:9px 14px;border-radius:8px;
  box-shadow:0 6px 18px rgba(15,33,55,.25);
  opacity:0;pointer-events:none;transform:translateX(6px);
  transition:opacity .18s ease,transform .18s ease}
.wa-float:hover::after,.wa-float:focus-visible::after{opacity:1;transform:translateX(0)}
/* ===================================================================
   Responsive — Stufen:
   LG (Basis) ≥1024px · MD Tablet 640–1023px · SM Phone ≤639px · XS ≤379px
   =================================================================== */

/* ===== MD — Tablet & alles unter Desktop (≤1023px) ===== */
@media (max-width:1023px){
  /* Navigation → Burger-Menü */
  .nav__toggle{display:flex}
  .nav__cta{display:none}
  .nav__links{
    position:absolute;top:100%;left:0;right:0;
    flex-direction:column;align-items:stretch;gap:0;
    background:#fff;border-top:1px solid var(--border);
    box-shadow:0 16px 30px rgba(15,33,55,.12);
    padding:8px 0;
    opacity:0;visibility:hidden;transform:translateY(-10px);
    transition:opacity .22s ease,transform .22s ease,visibility .22s;
  }
  .nav--open .nav__links{opacity:1;visibility:visible;transform:translateY(0)}
  .nav__links a:not(.nav__links-cta){padding:15px 24px;font-size:16px;
    border-bottom:1px solid var(--bg-alt)}
  .nav__links a.nav__links-cta{display:block;margin:14px 24px 8px;
    color:#fff;text-align:center}

  /* Layout-Raster */
  .hero__grid{grid-template-columns:1fr;gap:40px}
  .hero__form{max-width:480px;width:100%;margin:0 auto}
  .grid--3,.grid--4{grid-template-columns:repeat(2,1fr)}
  /* einzelne Rest-Karte zentrieren statt links als "Waise" */
  .grid--3 > :last-child:nth-child(odd){
    grid-column:1 / -1;max-width:560px;width:100%;margin-inline:auto}
  .stats__grid{grid-template-columns:repeat(2,1fr);gap:30px 24px}
  .urgency__grid,.contact__grid{grid-template-columns:1fr;gap:40px}
  .footer__grid{grid-template-columns:1fr 1fr;gap:32px}

  /* Callout ab Tablet gestapelt: Text volle Breite, Button darunter */
  .callout{flex-direction:column;align-items:flex-start;text-align:left;gap:20px}
  .callout p{min-width:0}

  /* kleineres Hero-Bild (Performance auf Tablet) */
  .hero__overlay{background-image:
    linear-gradient(115deg,rgba(27,58,92,.93) 0%,rgba(21,46,73,.86) 55%,rgba(15,33,55,.88) 100%),
    url('/img/hero.jpg')}

  /* Tooltip am Floating-Button auf Touch ausblenden */
  .wa-float::after{display:none}
}

/* ===== SM — Phones (≤639px) ===== */
@media (max-width:639px){
  .grid--3,.grid--4,.stats__grid{grid-template-columns:1fr;gap:20px}
  .grid--3 > :last-child:nth-child(odd){max-width:none;margin-inline:0}
  .footer__grid{grid-template-columns:1fr;gap:28px}
  .form__row{flex-direction:column}
  .callout{padding:24px 22px}
  .announce__inner{font-size:12px;line-height:1.4;gap:7px;padding:9px 16px}
  .hero__cta{flex-direction:column;align-items:stretch}
  .hero__cta .btn{width:100%}
  .hero__grid{padding:48px 20px}
  .container{padding:0 20px}
  .card,.contact__info{padding:24px}
  .way,.prob,.usp,.step,.symptom{padding-left:22px;padding-right:22px}
  .section__head{margin-bottom:34px}
  .hero__overlay{background-image:
    linear-gradient(115deg,rgba(27,58,92,.94) 0%,rgba(21,46,73,.88) 55%,rgba(15,33,55,.9) 100%),
    url('/img/hero.jpg')}
}

/* ===== XS — kleine/ältere Phones (≤379px) — Overflow-Schutz ===== */
@media (max-width:379px){
  .container{padding:0 16px}
  .hero__grid{padding:40px 16px}
  .card,.contact__info{padding:20px}
  .btn{padding:14px 20px;font-size:16px}
  .btn--lg{padding:15px 22px;font-size:16px}
  .btn--sm{padding:9px 16px;font-size:14px}
  .nav__logo,.footer__logo{font-size:19px}
  .badge{font-size:12px;padding:6px 13px}
  .way,.prob,.usp,.step,.symptom{padding:24px 18px}
  .callout{padding:20px 18px}
  .announce__inner{font-size:11.5px;gap:6px;padding:8px 14px}
  .wa-float{width:52px;height:52px;bottom:16px;right:16px}
  .wa-float .ic{width:30px;height:30px}
}

@media(prefers-reduced-motion:reduce){
  *{scroll-behavior:auto!important;transition:none!important;animation:none!important}
}

/* ---------- Legal Pages ---------- */
.legal-hero{background:var(--blau-dunkel);color:#fff;padding:54px 0}
.legal-hero a{color:#9ec5ff}
.legal-hero h1{color:#fff;font-size:clamp(28px,4vw,40px)}
.legal-hero .back{font-size:14.5px;color:#9fb2c6;display:inline-block;margin-bottom:16px}
.legal-hero .back:hover{color:#fff}
.legal{padding:56px 0 80px}
.legal .container{max-width:820px}
.legal h2{font-size:22px;margin:38px 0 12px}
.legal h2:first-child{margin-top:0}
.legal h3{font-size:17px;margin:24px 0 8px}
.legal p,.legal li{font-size:15.5px;color:var(--text);margin-bottom:12px;line-height:1.75}
.legal ul{margin:0 0 14px 22px}
.legal li{margin-bottom:6px}
.legal a{color:var(--blau-mittel);text-decoration:underline}
.legal strong{color:var(--blau-dunkel)}
.legal .muted{color:var(--text-hell);font-size:14px}
.legal hr{border:none;border-top:1px solid var(--border);margin:34px 0}
