/* =============================================================
   Dell Gebäudedienstleistungen — Design System
   Primärfarbe: Rot (#C8102E). Schriften: Sora (Headings) + Inter (Body), selbst-gehostet.
   Vanilla CSS, keine externen Requests (DSGVO-konform).
   ============================================================= */

/* ---------- Self-hosted Fonts (DSGVO: keine Google-Fonts-Hotlinks) ---------- */
@font-face{font-family:"Inter";src:url("../assets/fonts/inter-400.woff2") format("woff2");font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:"Inter";src:url("../assets/fonts/inter-500.woff2") format("woff2");font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:"Inter";src:url("../assets/fonts/inter-600.woff2") format("woff2");font-weight:600;font-style:normal;font-display:swap}
@font-face{font-family:"Inter";src:url("../assets/fonts/inter-700.woff2") format("woff2");font-weight:700;font-style:normal;font-display:swap}
@font-face{font-family:"Sora";src:url("../assets/fonts/sora-600.woff2") format("woff2");font-weight:600;font-style:normal;font-display:swap}
@font-face{font-family:"Sora";src:url("../assets/fonts/sora-700.woff2") format("woff2");font-weight:700;font-style:normal;font-display:swap}
@font-face{font-family:"Sora";src:url("../assets/fonts/sora-800.woff2") format("woff2");font-weight:800;font-style:normal;font-display:swap}

/* ---------- Design Tokens ---------- */
:root{
  /* Brand-Rot — zentral änderbar */
  --red:#C8102E;
  --red-700:#9B0E22;
  --red-800:#7C0B1B;
  --red-500:#E11D34;
  --red-tint:#FBEAEC;
  --red-tint-2:#F6D9DD;

  /* Neutrale */
  --ink:#14161A;
  --ink-2:#2A2E35;
  --slate:#535A63;
  --slate-2:#868D96;
  --line:#E7E9EC;
  --line-2:#F0F1F3;
  --bg:#FFFFFF;
  --bg-alt:#F6F7F8;
  --bg-dark:#121417;
  --bg-dark-2:#1B1E23;

  /* Radien */
  --radius:14px;
  --radius-sm:10px;
  --radius-lg:24px;
  --radius-pill:999px;

  /* Schatten */
  --shadow-sm:0 1px 2px rgba(20,22,26,.06),0 2px 6px rgba(20,22,26,.05);
  --shadow:0 12px 34px -14px rgba(20,22,26,.22);
  --shadow-lg:0 34px 70px -24px rgba(20,22,26,.30);
  --shadow-red:0 16px 40px -16px rgba(200,16,46,.45);

  /* Typografie */
  --font-head:"Sora","Segoe UI",system-ui,-apple-system,sans-serif;
  --font-body:"Inter",system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;

  /* Layout */
  --container:1200px;
  --container-narrow:900px;
  --gutter:clamp(20px,5vw,40px);
  --space-section:clamp(64px,9vw,124px);

  /* Motion */
  --ease:cubic-bezier(.22,.61,.36,1);
  --ease-out:cubic-bezier(.16,1,.3,1);
  --t:.25s;
  --t-slow:.55s;

  --header-h:76px;
}

/* ---------- Reset & Base ---------- */
*,*::before,*::after{box-sizing:border-box}
*{margin:0}
[hidden]{display:none!important}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;scroll-padding-top:calc(var(--header-h) + 24px)}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--bg);
  line-height:1.65;
  font-size:1.0625rem;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img,svg,video{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button,input,select,textarea{font:inherit;color:inherit}
button{cursor:pointer;background:none;border:none}
ul,ol{list-style:none;padding:0}
:focus-visible{outline:3px solid var(--red-500);outline-offset:3px;border-radius:4px}
::selection{background:var(--red);color:#fff}

/* ---------- Typografie ---------- */
h1,h2,h3,h4,h5{font-family:var(--font-head);font-weight:700;line-height:1.1;letter-spacing:-.02em;color:var(--ink)}
h1{font-size:clamp(2.4rem,5.4vw,4.1rem);font-weight:800;letter-spacing:-.035em}
h2{font-size:clamp(1.9rem,3.6vw,2.9rem);letter-spacing:-.03em}
h3{font-size:clamp(1.3rem,2.1vw,1.65rem)}
h4{font-size:1.15rem;font-weight:600}
p{color:var(--slate)}
strong{font-weight:700;color:var(--ink)}
.lead{font-size:clamp(1.1rem,1.7vw,1.3rem);line-height:1.6;color:var(--slate)}

/* ---------- Layout-Primitives ---------- */
.container{width:100%;max-width:var(--container);margin-inline:auto;padding-inline:var(--gutter)}
.container--narrow{max-width:var(--container-narrow)}
.section{padding-block:var(--space-section)}
.section--alt{background:var(--bg-alt)}
.section--dark{background:var(--bg-dark);color:#fff}
.section--dark h1,.section--dark h2,.section--dark h3,.section--dark h4{color:#fff}
.section--dark p{color:#aeb4bc}
.section--tight{padding-block:clamp(44px,6vw,72px)}
.grid{display:grid;gap:clamp(20px,3vw,32px)}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
@media (max-width:980px){.grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}}
@media (max-width:640px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}

/* ---------- Section Header / Eyebrow ---------- */
.eyebrow{
  display:inline-flex;align-items:center;gap:.5rem;
  font-family:var(--font-body);font-weight:600;font-size:.8rem;
  letter-spacing:.14em;text-transform:uppercase;color:var(--red);
}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--red);border-radius:2px}
.section--dark .eyebrow{color:#ff6b7d}
.section-head{max-width:680px;margin-bottom:clamp(36px,5vw,60px)}
.section-head.center{margin-inline:auto;text-align:center}
.section-head .eyebrow{margin-bottom:1rem}
.section-head p{margin-top:1rem;font-size:1.1rem}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.55rem;
  font-family:var(--font-head);font-weight:600;font-size:.97rem;letter-spacing:-.01em;
  padding:.92em 1.6em;border-radius:var(--radius-pill);
  transition:transform var(--t) var(--ease),box-shadow var(--t) var(--ease),background var(--t),color var(--t),border-color var(--t);
  white-space:nowrap;border:1.5px solid transparent;line-height:1;
}
.btn svg{width:1.1em;height:1.1em}
.btn--primary{background:var(--red);color:#fff;box-shadow:var(--shadow-red)}
.btn--primary:hover{background:var(--red-700);transform:translateY(-2px);box-shadow:0 22px 48px -18px rgba(200,16,46,.6)}
.btn--ghost{background:#fff;color:var(--ink);border-color:var(--line)}
.btn--ghost:hover{border-color:var(--ink);transform:translateY(-2px)}
.btn--outline{background:transparent;color:var(--ink);border-color:var(--ink)}
.btn--outline:hover{background:var(--ink);color:#fff;transform:translateY(-2px)}
.btn--light{background:#fff;color:var(--ink)}
.btn--light:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}
.btn--block{width:100%}
.btn--lg{padding:1.05em 1.9em;font-size:1.05rem}
.section--dark .btn--ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.28)}
.section--dark .btn--ghost:hover{border-color:#fff;background:rgba(255,255,255,.08)}

.btn-arrow{transition:transform var(--t) var(--ease)}
.btn:hover .btn-arrow{transform:translateX(4px)}

/* Text-Link mit Pfeil */
.tlink{display:inline-flex;align-items:center;gap:.45rem;font-family:var(--font-head);font-weight:600;color:var(--red);transition:gap var(--t)}
.tlink svg{width:1.05em;height:1.05em;transition:transform var(--t) var(--ease)}
.tlink:hover{color:var(--red-700)}
.tlink:hover svg{transform:translateX(4px)}

/* ===============================================================
   HEADER
   =============================================================== */
.topbar{
  background:var(--ink);color:#cfd3d8;font-size:.85rem;
  border-bottom:1px solid rgba(255,255,255,.06);
}
.topbar .container{display:flex;align-items:center;justify-content:space-between;height:42px;gap:1.5rem}
.topbar a{display:inline-flex;align-items:center;gap:.45rem;transition:color var(--t)}
.topbar a:hover{color:#fff}
.topbar svg{width:15px;height:15px;color:var(--red-500)}
.topbar-left{display:flex;gap:1.6rem}
.topbar-right{display:flex;gap:1.6rem;align-items:center}
.topbar-badge{display:inline-flex;align-items:center;gap:.4rem;color:#fff}
@media (max-width:860px){.topbar{display:none}}

.site-header{
  position:sticky;top:0;z-index:100;
  background:rgba(255,255,255,.86);
  backdrop-filter:saturate(160%) blur(14px);
  -webkit-backdrop-filter:saturate(160%) blur(14px);
  border-bottom:1px solid transparent;
  transition:box-shadow var(--t),border-color var(--t),background var(--t);
}
.site-header.scrolled{box-shadow:var(--shadow-sm);border-bottom-color:var(--line);background:rgba(255,255,255,.94)}
.site-header .container{display:flex;align-items:center;justify-content:space-between;height:var(--header-h);gap:1.5rem}

/* Logo */
.logo{display:inline-flex;align-items:center;gap:.7rem;flex-shrink:0}
.logo-img{height:48px;width:auto;display:block}
.logo-fallback{align-items:center;gap:.7rem}
@media (max-width:420px){.logo-img{height:40px}}
.logo-mark{width:42px;height:42px;flex-shrink:0;filter:drop-shadow(0 6px 14px rgba(200,16,46,.28))}
.logo-mark .mark-bg{fill:var(--red);transition:fill var(--t)}
.logo-text{display:flex;flex-direction:column;line-height:1}
.logo-text strong{font-family:var(--font-head);font-weight:800;font-size:1.32rem;letter-spacing:-.02em;color:var(--ink)}
.logo-text .logo-sub{display:inline-block;background:var(--red);color:#fff;font-size:.55rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;padding:.16em .42em;border-radius:3px;margin-top:.26rem;transition:background var(--t)}
@media (max-width:420px){.logo-text strong{font-size:1.15rem}.logo-text .logo-sub{font-size:.54rem;letter-spacing:.16em}}

/* Primary nav */
.nav{display:flex;align-items:center;gap:.35rem}
.nav a{
  position:relative;padding:.55rem .72rem;border-radius:var(--radius-sm);white-space:nowrap;
  font-weight:500;font-size:.95rem;color:var(--ink-2);transition:color var(--t),background var(--t);
}
.nav a:hover{color:var(--red)}
.nav a.active{color:var(--red);font-weight:600}
.nav a.active::after{content:"";position:absolute;left:.85rem;right:.85rem;bottom:.28rem;height:2px;background:var(--red);border-radius:2px}
.header-actions{display:flex;align-items:center;gap:.8rem}

/* Mobile toggle */
.nav-toggle{display:none;width:44px;height:44px;border-radius:var(--radius-sm);align-items:center;justify-content:center;border:1px solid var(--line)}
.nav-toggle span{display:block;width:20px;height:2px;background:var(--ink);border-radius:2px;position:relative;transition:transform var(--t) var(--ease),opacity var(--t)}
.nav-toggle span::before,.nav-toggle span::after{content:"";position:absolute;left:0;width:20px;height:2px;background:var(--ink);border-radius:2px;transition:transform var(--t) var(--ease)}
.nav-toggle span::before{top:-6px}.nav-toggle span::after{top:6px}
body.nav-open .nav-toggle span{background:transparent}
body.nav-open .nav-toggle span::before{transform:translateY(6px) rotate(45deg)}
body.nav-open .nav-toggle span::after{transform:translateY(-6px) rotate(-45deg)}

@media (max-width:1040px){
  /* backdrop-filter erzeugt einen Containing-Block fuer position:fixed -> der mobile
     Nav-Drawer wuerde sonst im Header (statt am Viewport) haengen bleiben. Auf Mobil
     daher ohne Effekt + solider Hintergrund. */
  .site-header{backdrop-filter:none;-webkit-backdrop-filter:none;background:#fff}
  .nav-toggle{display:flex}
  .nav{
    position:fixed;inset:0 0 0 auto;width:min(86vw,380px);
    flex-direction:column;align-items:stretch;justify-content:flex-start;gap:.2rem;
    background:#fff;padding:calc(var(--header-h) + 24px) 24px 32px;
    box-shadow:var(--shadow-lg);transform:translateX(100%);
    transition:transform var(--t-slow) var(--ease-out);z-index:99;overflow-y:auto;
  }
  body.nav-open .nav{transform:translateX(0)}
  .nav a{padding:.95rem 1rem;font-size:1.1rem;border-bottom:1px solid var(--line-2)}
  .nav a.active::after{display:none}
  .nav .btn{margin-top:1.2rem}
  .nav-backdrop{position:fixed;inset:0;background:rgba(20,22,26,.45);opacity:0;visibility:hidden;transition:opacity var(--t);z-index:98}
  body.nav-open .nav-backdrop{opacity:1;visibility:visible}
}
.header-actions .btn{display:inline-flex}
@media (max-width:1040px){.header-actions .btn--primary{display:none}}
.nav .btn{display:none}
@media (max-width:1040px){.nav .btn{display:inline-flex}}

/* Sprachumschalter */
.lang-switch{display:inline-flex;align-items:center;gap:.38rem;font-family:var(--font-head);font-weight:600;font-size:.9rem;color:var(--ink-2);padding:.5rem .7rem;border-radius:var(--radius-sm);transition:color var(--t),background var(--t)}
.lang-switch svg{width:17px;height:17px;opacity:.7}
.lang-switch:hover{color:var(--red);background:var(--red-tint)}
.lang-switch--mobile{display:none}
@media (max-width:1040px){
  .header-actions .lang-switch{display:none}
  .lang-switch--mobile{display:flex;justify-content:center;margin-top:1rem;border:1px solid var(--line);font-size:1.05rem;padding:.85rem 1rem}
}

/* ---------- 24/7 Notdienst ---------- */
.nd-badge{display:inline-flex;align-items:center;gap:.55rem;background:var(--red);color:#fff;border-radius:var(--radius-pill);padding:.45rem .9rem .45rem .75rem;box-shadow:var(--shadow-red);transition:background var(--t),transform var(--t) var(--ease)}
.nd-badge:hover{background:var(--red-700);transform:translateY(-1px)}
.nd-badge-txt{display:flex;flex-direction:column;line-height:1.08;text-align:left}
.nd-badge-txt strong{font-family:var(--font-head);font-weight:700;font-size:.8rem;letter-spacing:-.01em}
.nd-badge-txt span{font-size:.73rem;opacity:.92}
.nd-dot{width:9px;height:9px;border-radius:50%;background:#fff;flex-shrink:0;animation:ndpulse 2s infinite}
@keyframes ndpulse{0%{box-shadow:0 0 0 0 rgba(255,255,255,.65)}70%{box-shadow:0 0 0 7px rgba(255,255,255,0)}100%{box-shadow:0 0 0 0 rgba(255,255,255,0)}}
.nd-badge--mobile{display:none}
@media (max-width:1040px){
  .header-actions .nd-badge{display:none}
  .nd-badge--mobile{display:inline-flex;margin-top:1.1rem;justify-content:center}
}
@media (prefers-reduced-motion:reduce){.nd-dot{animation:none}}

/* Footer-Notdienst-Bar */
.nd-bar{display:flex;align-items:center;gap:1rem;flex-wrap:wrap;background:linear-gradient(120deg,var(--red-800),var(--red) 70%,var(--red-500));color:#fff;border-radius:var(--radius);padding:1rem 1.4rem;margin-bottom:clamp(34px,5vw,52px);transition:filter var(--t)}
.nd-bar:hover{filter:brightness(1.06)}
.nd-bar strong{font-family:var(--font-head);font-weight:700}
.nd-bar > span{font-size:.95rem;color:rgba(255,255,255,.92)}
.nd-bar .nd-bar-num{margin-left:auto;display:inline-flex;align-items:center;gap:.5rem;font-family:var(--font-head);font-weight:800;font-size:1.1rem;white-space:nowrap}
.nd-bar .nd-bar-num svg{width:19px;height:19px}
@media (max-width:640px){.nd-bar .nd-bar-num{margin-left:0}}

/* Notdienst-Banner (z. B. Kontaktseite) */
.nd-banner{display:flex;align-items:center;gap:1.1rem;flex-wrap:wrap;background:linear-gradient(120deg,var(--red-800),var(--red) 65%,var(--red-500));color:#fff;border-radius:var(--radius-lg);padding:clamp(1.4rem,3vw,2rem)}
.nd-banner .ndb-ic{width:54px;height:54px;border-radius:50%;background:rgba(255,255,255,.16);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.nd-banner .ndb-ic svg{width:28px;height:28px}
.nd-banner h3{color:#fff;font-size:1.35rem;margin-bottom:.2rem}
.nd-banner p{color:rgba(255,255,255,.9);font-size:.98rem}
.nd-banner .ndb-cta{margin-left:auto}
@media (max-width:640px){.nd-banner .ndb-cta{margin-left:0;width:100%}}

/* ---------- Leistungs-Kacheln & Anker-Navigation ---------- */
.service-tile{text-decoration:none;color:inherit}
.service-tile h3{transition:color var(--t)}
.service-tile:hover h3{color:var(--red)}
/* Gleichgroße, zentrierte Leistungs-Kacheln (Startseite) */
.service-grid{display:flex;flex-wrap:wrap;gap:1.4rem;justify-content:center;align-items:stretch}
.service-grid>.service-tile{flex:1 1 240px;max-width:266px;min-width:0;display:flex;flex-direction:column}
.service-grid>.service-tile p{flex:1 0 auto}
.service-grid>.service-tile h3{font-size:1.08rem;line-height:1.3;overflow-wrap:break-word;-webkit-hyphens:auto;hyphens:auto}
@media(max-width:560px){.service-grid>.service-tile{max-width:none}}
.anchor-nav{display:flex;align-items:center;gap:.9rem 1.2rem;flex-wrap:wrap;padding:1rem 1.3rem;background:var(--bg-alt);border:1px solid var(--line);border-radius:var(--radius)}
.anchor-nav-label{font-family:var(--font-head);font-weight:700;font-size:.88rem;color:var(--slate);flex-shrink:0}
.anchor-pills{display:flex;gap:.5rem;flex-wrap:wrap}
.anchor-pills .pill{transition:background var(--t),color var(--t)}
.anchor-pills .pill:hover{background:var(--red);color:#fff}

/* ===============================================================
   HERO
   =============================================================== */
.hero{position:relative;overflow:hidden;background:var(--bg)}
.hero::before{
  content:"";position:absolute;top:-30%;right:-15%;width:60vw;height:120%;
  background:radial-gradient(closest-side,rgba(200,16,46,.10),transparent 70%);
  pointer-events:none;
}
.hero .container{position:relative;display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(32px,5vw,72px);align-items:center;padding-block:clamp(56px,8vw,104px)}
.hero-eyebrow{margin-bottom:1.4rem}
.hero h1{margin-bottom:1.4rem}
.hero h1 .accent{color:var(--red)}
.hero-lead{max-width:46ch;margin-bottom:2.2rem}
.hero-cta{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:2.4rem}
.hero-trust{display:flex;flex-wrap:wrap;gap:1.4rem 2rem;align-items:center}
.hero-trust-item{display:flex;align-items:center;gap:.6rem;font-size:.92rem;color:var(--slate);font-weight:500}
.hero-trust-item svg{width:20px;height:20px;color:var(--red);flex-shrink:0}

/* Hero visual */
.hero-visual{position:relative}
.hero-card{
  position:relative;border-radius:var(--radius-lg);overflow:hidden;
  aspect-ratio:4/4.4;box-shadow:var(--shadow-lg);
  background:linear-gradient(150deg,#1b1e23,#2a2e35);
}
.hero-card .ph-illustration{position:absolute;inset:0}
.hero-badge{
  position:absolute;background:#fff;border-radius:var(--radius);padding:1rem 1.2rem;
  box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:.85rem;
}
.hero-badge--rating{left:-22px;bottom:64px}
.hero-badge--years{right:-18px;top:48px}
.hero-badge .hb-icon{width:46px;height:46px;border-radius:12px;background:var(--red-tint);display:flex;align-items:center;justify-content:center;color:var(--red);flex-shrink:0}
.hero-badge .hb-icon svg{width:24px;height:24px}
.hero-badge strong{display:block;font-family:var(--font-head);font-size:1.25rem;line-height:1}
.hero-badge span{font-size:.8rem;color:var(--slate)}
.hero-stars{color:var(--red);letter-spacing:1px}
@media (max-width:880px){
  .hero .container{grid-template-columns:1fr;padding-block:48px 64px}
  .hero-visual{order:-1;width:100%;max-width:440px;margin-inline:auto}
  .hero-card{aspect-ratio:4/3.4}
  .hero-badge--rating{left:-8px}.hero-badge--years{right:-8px}
}
@media (max-width:480px){
  .hero-badge{padding:.7rem .85rem}.hero-badge .hb-icon{width:38px;height:38px}
  .hero-badge strong{font-size:1.05rem}.hero-badge span{font-size:.72rem}
}

/* ---------- Marquee / Trust-Logos-Leiste ---------- */
.logobar{border-block:1px solid var(--line);background:#fff}
.logobar .container{display:flex;flex-direction:column;align-items:center;gap:18px;flex-wrap:wrap;justify-content:center;text-align:center;padding-block:26px}
.logobar-label{font-size:.82rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--slate-2);flex-shrink:0}
.logobar-items{display:flex;gap:clamp(20px,4vw,52px) clamp(18px,3vw,40px);align-items:center;flex-wrap:wrap;justify-content:center;color:var(--slate-2)}
.logobar-items span{font-family:var(--font-head);font-weight:700;font-size:1.05rem;color:var(--ink-2);opacity:.55;display:inline-flex;align-items:center;gap:.5rem}
.logobar-items svg{width:22px;height:22px;color:var(--red);opacity:.8}

/* ===============================================================
   CARDS
   =============================================================== */
.card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:clamp(1.5rem,2.5vw,2rem);transition:transform var(--t) var(--ease),box-shadow var(--t) var(--ease),border-color var(--t);
  height:100%;display:flex;flex-direction:column;
}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:transparent}
.card-icon{
  width:58px;height:58px;border-radius:16px;background:var(--red-tint);color:var(--red);
  display:flex;align-items:center;justify-content:center;margin-bottom:1.3rem;
  transition:background var(--t),color var(--t),transform var(--t) var(--ease);
}
.card-icon svg{width:28px;height:28px}
.card:hover .card-icon{background:var(--red);color:#fff;transform:scale(1.06) rotate(-3deg)}
.card h3{margin-bottom:.6rem}
.card p{font-size:.98rem;margin-bottom:1.2rem}
.card .card-foot{margin-top:auto}
.card ul.ticks{margin-bottom:1.2rem}
.ticks li{display:flex;gap:.6rem;align-items:flex-start;font-size:.95rem;color:var(--slate);padding:.28rem 0}
.ticks li svg{width:18px;height:18px;color:var(--red);flex-shrink:0;margin-top:.28rem}

/* Service-Card mit Bild-Platzhalter */
.service-card{padding:0;overflow:hidden}
.service-card .sc-media{aspect-ratio:16/10;position:relative;overflow:hidden}
.service-card .sc-media .ph-illustration{transition:transform var(--t-slow) var(--ease)}
.service-card:hover .sc-media .ph-illustration{transform:scale(1.05)}
.service-card .sc-body{padding:clamp(1.4rem,2.4vw,1.9rem);display:flex;flex-direction:column;flex:1}
.sc-tag{position:absolute;top:14px;left:14px;background:rgba(255,255,255,.92);color:var(--red);font-size:.74rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:.4rem .7rem;border-radius:var(--radius-pill);backdrop-filter:blur(6px)}

/* ===============================================================
   STATS / COUNTER
   =============================================================== */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(20px,3vw,40px)}
@media (max-width:760px){.stats{grid-template-columns:repeat(2,1fr)}}
.stat{text-align:center;position:relative}
.stat .stat-num{font-family:var(--font-head);font-weight:800;font-size:clamp(2.4rem,4.4vw,3.4rem);line-height:1;color:var(--ink);letter-spacing:-.03em}
.section--dark .stat .stat-num{color:#fff}
.stat .stat-num .suffix{color:var(--red)}
.stat .stat-label{margin-top:.6rem;font-size:.96rem;color:var(--slate);font-weight:500}
.section--dark .stat .stat-label{color:#aeb4bc}

/* ===============================================================
   PROCESS / ABLAUF
   =============================================================== */
.process{counter-reset:step;display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(22px,3vw,32px);position:relative}
@media (max-width:880px){.process{grid-template-columns:repeat(2,1fr)}}
@media (max-width:520px){.process{grid-template-columns:1fr}}
.process-step{position:relative;padding-top:1rem}
.process-step .ps-num{
  width:52px;height:52px;border-radius:50%;background:#fff;border:1.5px solid var(--line);
  display:flex;align-items:center;justify-content:center;font-family:var(--font-head);
  font-weight:800;color:var(--red);font-size:1.25rem;margin-bottom:1.1rem;position:relative;z-index:2;
  transition:background var(--t),color var(--t),border-color var(--t),transform var(--t) var(--ease);
}
.process-step:hover .ps-num{background:var(--red);color:#fff;border-color:var(--red);transform:scale(1.08)}
.process-step h4{margin-bottom:.4rem;font-size:1.15rem}
.process-step p{font-size:.95rem}
.process-step:not(:last-child)::after{content:"";position:absolute;top:27px;left:52px;right:-16px;height:1.5px;background:repeating-linear-gradient(90deg,var(--line) 0 8px,transparent 8px 16px)}
@media (max-width:880px){.process-step:not(:last-child)::after{display:none}}

/* ===============================================================
   SPLIT / FEATURE-Block (Bild + Text)
   =============================================================== */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(32px,5vw,72px);align-items:center}
.split.reverse .split-media{order:2}
@media (max-width:880px){.split,.split.reverse{grid-template-columns:1fr}.split.reverse .split-media{order:0}}
.split-media{position:relative;border-radius:var(--radius-lg);overflow:hidden;aspect-ratio:5/4;box-shadow:var(--shadow)}
.split-content h2{margin-bottom:1.1rem}
.split-content .lead{margin-bottom:1.6rem}
.feature-list{display:grid;gap:1.1rem;margin-bottom:2rem}
.feature-list li{display:flex;gap:1rem;align-items:flex-start}
.feature-list .fl-icon{width:42px;height:42px;border-radius:12px;background:var(--red-tint);color:var(--red);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.feature-list .fl-icon svg{width:21px;height:21px}
.feature-list h4{margin-bottom:.2rem}
.feature-list p{font-size:.94rem}

/* ===============================================================
   IMAGE-PLATZHALTER (gebrandet, kein hässliches Grau)
   =============================================================== */
.ph-illustration{
  width:100%;height:100%;position:relative;
  background:linear-gradient(150deg,#1b1e23 0%,#2a2e35 60%,#23262b 100%);
  display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.5);overflow:hidden;
}
.ph-illustration.red{background:linear-gradient(150deg,var(--red-700),var(--red) 60%,var(--red-500))}
.ph-illustration.light{background:linear-gradient(150deg,#eef0f2,#f8f9fa)}
.ph-illustration::after{content:"";position:absolute;inset:0;background-image:radial-gradient(circle at 1px 1px,rgba(255,255,255,.12) 1px,transparent 0);background-size:22px 22px;opacity:.5}
.ph-illustration.light::after{background-image:radial-gradient(circle at 1px 1px,rgba(20,22,26,.07) 1px,transparent 0)}
.ph-illustration .ph-note{position:relative;z-index:2;display:flex;flex-direction:column;align-items:center;gap:.7rem;text-align:center;padding:1rem;font-family:var(--font-head);font-weight:600;font-size:.9rem;letter-spacing:.02em}
.ph-illustration .ph-note svg{width:46px;height:46px;opacity:.85}
.ph-illustration.light .ph-note{color:var(--slate-2)}
.ph-glow{position:absolute;width:60%;aspect-ratio:1;border-radius:50%;filter:blur(60px);opacity:.4}
.ph-glow.a{background:var(--red);top:-10%;right:-10%}
.ph-glow.b{background:#3a7bd5;bottom:-15%;left:-10%;opacity:.25}

/* ===============================================================
   TESTIMONIALS-KARUSSELL
   =============================================================== */
.testimonials{position:relative}
.tcarousel{overflow:hidden}
.ttrack{display:flex;transition:transform var(--t-slow) var(--ease-out)}
.tslide{min-width:100%;padding:.5rem}
@media (min-width:760px){.tslide{min-width:50%}}
.tcard{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:clamp(1.6rem,2.6vw,2.2rem);height:100%}
.tcard .tstars{color:var(--red);font-size:1.05rem;letter-spacing:2px;margin-bottom:1rem}
.tcard blockquote{font-size:1.1rem;line-height:1.6;color:var(--ink-2);margin-bottom:1.5rem}
.tcard .tperson{display:flex;align-items:center;gap:.9rem}
.tcard .tavatar{width:48px;height:48px;border-radius:50%;background:var(--red-tint);color:var(--red);display:flex;align-items:center;justify-content:center;font-family:var(--font-head);font-weight:700;flex-shrink:0}
.tcard .tperson strong{display:block;font-size:.98rem}
.tcard .tperson span{font-size:.85rem;color:var(--slate)}
.tnav{display:flex;gap:.6rem;justify-content:center;margin-top:2rem;align-items:center}
.tdots{display:flex;gap:.5rem}
.tdot{width:9px;height:9px;border-radius:50%;background:var(--line);transition:background var(--t),width var(--t)}
.tdot.active{background:var(--red);width:26px;border-radius:5px}
.tbtn{width:46px;height:46px;border-radius:50%;border:1.5px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--ink);transition:all var(--t)}
.tbtn:hover{border-color:var(--red);color:var(--red);transform:translateY(-2px)}
.tbtn svg{width:20px;height:20px}

/* ===============================================================
   VORHER/NACHHER-SLIDER
   =============================================================== */
.ba-slider{position:relative;border-radius:var(--radius-lg);overflow:hidden;aspect-ratio:16/10;box-shadow:var(--shadow);user-select:none;touch-action:none;cursor:ew-resize}
.ba-img{position:absolute;inset:0}
.ba-after{z-index:1}
.ba-before{z-index:2;width:50%;overflow:hidden;border-right:3px solid #fff}
.ba-before .ba-inner{position:absolute;top:0;left:0;height:100%;width:var(--ba-w,100vw)}
.ba-label{position:absolute;bottom:16px;z-index:3;background:rgba(20,22,26,.7);color:#fff;font-size:.78rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;padding:.4rem .8rem;border-radius:var(--radius-pill);backdrop-filter:blur(4px)}
.ba-label.before{left:16px}.ba-label.after{right:16px}
.ba-handle{position:absolute;top:0;bottom:0;left:50%;width:3px;background:#fff;z-index:4;transform:translateX(-50%)}
.ba-handle::after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:46px;height:46px;border-radius:50%;background:#fff;box-shadow:var(--shadow)}
.ba-handle .ba-grip{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:2;color:var(--red);display:flex}
.ba-handle .ba-grip svg{width:24px;height:24px}

/* ===============================================================
   FAQ-AKKORDEON
   =============================================================== */
.faq{max-width:820px;margin-inline:auto}
.faq-item{border-bottom:1px solid var(--line)}
.faq-q{width:100%;display:flex;align-items:center;justify-content:space-between;gap:1.5rem;padding:1.4rem 0;text-align:left;font-family:var(--font-head);font-weight:600;font-size:1.12rem;color:var(--ink);transition:color var(--t)}
.faq-q:hover{color:var(--red)}
.faq-icon{width:32px;height:32px;flex-shrink:0;border-radius:50%;border:1.5px solid var(--line);display:flex;align-items:center;justify-content:center;position:relative;transition:all var(--t)}
.faq-icon::before,.faq-icon::after{content:"";position:absolute;background:var(--ink);border-radius:2px;transition:transform var(--t) var(--ease),background var(--t)}
.faq-icon::before{width:13px;height:2px}.faq-icon::after{width:2px;height:13px}
.faq-item.open .faq-icon{background:var(--red);border-color:var(--red)}
.faq-item.open .faq-icon::before,.faq-item.open .faq-icon::after{background:#fff}
.faq-item.open .faq-icon::after{transform:scaleY(0)}
.faq-item.open .faq-q{color:var(--red)}
.faq-a{overflow:hidden;max-height:0;transition:max-height var(--t-slow) var(--ease)}
.faq-a-inner{padding:0 0 1.5rem;color:var(--slate);font-size:1rem;max-width:90%}

/* ===============================================================
   CTA-Band
   =============================================================== */
.cta-band{position:relative;overflow:hidden;background:linear-gradient(120deg,var(--red-800),var(--red) 55%,var(--red-500));color:#fff;border-radius:var(--radius-lg)}
.cta-band::before{content:"";position:absolute;inset:0;background-image:radial-gradient(circle at 1px 1px,rgba(255,255,255,.14) 1px,transparent 0);background-size:24px 24px;opacity:.4}
.cta-band .cta-inner{position:relative;padding:clamp(2.4rem,5vw,4rem);display:flex;align-items:center;justify-content:space-between;gap:2rem;flex-wrap:wrap}
.cta-band h2{color:#fff;max-width:18ch}
.cta-band p{color:rgba(255,255,255,.85);margin-top:.8rem;max-width:46ch}
.cta-band .cta-actions{display:flex;gap:1rem;flex-wrap:wrap}

/* ===============================================================
   FORMS
   =============================================================== */
.field{margin-bottom:1.2rem}
.field label{display:block;font-weight:600;font-size:.92rem;margin-bottom:.5rem;color:var(--ink-2)}
.field label .req{color:var(--red)}
.input,.textarea,.select{
  width:100%;padding:.85rem 1rem;border:1.5px solid var(--line);border-radius:var(--radius-sm);
  background:#fff;font-size:1rem;transition:border-color var(--t),box-shadow var(--t);color:var(--ink);
}
.input:focus,.textarea:focus,.select:focus{outline:none;border-color:var(--red);box-shadow:0 0 0 4px var(--red-tint)}
.textarea{min-height:130px;resize:vertical}
.select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23535A63' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center;background-size:18px;padding-right:2.6rem}
.checkbox{display:flex;gap:.7rem;align-items:flex-start;font-size:.92rem;color:var(--slate);cursor:pointer}
.checkbox input{margin-top:.25rem;width:18px;height:18px;accent-color:var(--red);flex-shrink:0}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem}
@media (max-width:560px){.form-row{grid-template-columns:1fr}}
.form-note{font-size:.85rem;color:var(--slate-2);margin-top:1rem}
.form-feedback{padding:1rem 1.2rem;border-radius:var(--radius-sm);font-size:.95rem;margin-top:1rem;display:none}
.form-feedback.ok{display:block;background:#e9f7ef;color:#1e7d4f;border:1px solid #b7e4c9}
.form-feedback.err{display:block;background:var(--red-tint);color:var(--red-700);border:1px solid var(--red-tint-2)}

/* ===============================================================
   INFO-Tiles (Kontaktdaten)
   =============================================================== */
.info-tile{display:flex;gap:1rem;align-items:flex-start;padding:1.3rem;border:1px solid var(--line);border-radius:var(--radius);background:#fff;transition:border-color var(--t),transform var(--t) var(--ease)}
.info-tile:hover{border-color:var(--red);transform:translateY(-3px)}
.info-tile .it-icon{width:48px;height:48px;border-radius:12px;background:var(--red-tint);color:var(--red);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.info-tile .it-icon svg{width:23px;height:23px}
.info-tile h4{margin-bottom:.2rem;font-size:1rem}
.info-tile p,.info-tile a{font-size:.96rem;color:var(--slate)}
.info-tile a:hover{color:var(--red)}

/* ===============================================================
   PAGE-HERO (Unterseiten)
   =============================================================== */
.page-hero{position:relative;background:var(--bg-alt);overflow:hidden;border-bottom:1px solid var(--line)}
.page-hero::before{content:"";position:absolute;top:-40%;right:-10%;width:50vw;height:140%;background:radial-gradient(closest-side,rgba(200,16,46,.08),transparent 70%)}
.page-hero .container{position:relative;padding-block:clamp(48px,7vw,84px)}
.breadcrumb{display:flex;gap:.5rem;align-items:center;font-size:.88rem;color:var(--slate-2);margin-bottom:1.2rem}
.breadcrumb a:hover{color:var(--red)}
.breadcrumb svg{width:14px;height:14px}
.page-hero h1{max-width:18ch;margin-bottom:1rem}
.page-hero p{max-width:60ch;font-size:1.15rem}

/* ===============================================================
   FOOTER
   =============================================================== */
.site-footer{background:var(--bg-dark);color:#aeb4bc;padding-top:clamp(56px,7vw,84px)}
.site-footer .footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.3fr;gap:clamp(28px,4vw,48px);padding-bottom:48px}
@media (max-width:880px){.site-footer .footer-grid{grid-template-columns:1fr 1fr}}
@media (max-width:520px){.site-footer .footer-grid{grid-template-columns:1fr}}
/* Logo im dunklen Footer: dezentes weißes Feld, damit das Original (schwarzes „Dell") sichtbar bleibt */
.site-footer .logo{background:#fff;padding:.5rem .7rem;border-radius:12px}
.site-footer .logo-img{height:40px}
.footer-about p{margin-top:1.2rem;font-size:.94rem;color:#9097a0;max-width:34ch}
.footer-social{display:flex;gap:.7rem;margin-top:1.4rem}
.footer-social a{width:40px;height:40px;border-radius:10px;background:var(--bg-dark-2);display:flex;align-items:center;justify-content:center;color:#aeb4bc;transition:all var(--t)}
.footer-social a:hover{background:var(--red);color:#fff;transform:translateY(-2px)}
.footer-social svg{width:19px;height:19px}
.footer-col h4{color:#fff;font-size:.95rem;letter-spacing:.04em;text-transform:uppercase;margin-bottom:1.2rem;font-family:var(--font-body);font-weight:700}
.footer-col ul{display:grid;gap:.7rem}
.footer-col a{font-size:.94rem;color:#9097a0;transition:color var(--t)}
.footer-col a:hover{color:#fff}
.footer-contact li{display:flex;gap:.7rem;align-items:flex-start;font-size:.94rem;color:#9097a0;margin-bottom:.9rem}
.footer-contact svg{width:18px;height:18px;color:var(--red-500);flex-shrink:0;margin-top:.18rem}
.footer-bottom{border-top:1px solid rgba(255,255,255,.08);padding-block:24px;display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;font-size:.86rem;color:#7d838c}
.footer-bottom a:hover{color:#fff}
.footer-bottom .fb-links{display:flex;gap:1.4rem;flex-wrap:wrap}

/* ===============================================================
   BACK-TO-TOP
   =============================================================== */
.to-top{position:fixed;right:24px;bottom:24px;width:50px;height:50px;border-radius:50%;background:var(--red);color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-red);z-index:90;opacity:0;visibility:hidden;transform:translateY(16px);transition:opacity var(--t),visibility var(--t),transform var(--t) var(--ease),background var(--t)}
.to-top.show{opacity:1;visibility:visible;transform:translateY(0)}
.to-top:hover{background:var(--red-700);transform:translateY(-3px)}
.to-top svg{width:22px;height:22px}

/* ===============================================================
   SCROLL-REVEAL ANIMATIONEN
   =============================================================== */
/* Nur wenn JS aktiv ist (html.js) verstecken — sonst bleibt alles sichtbar (No-JS-Fallback) */
html.js .reveal{opacity:0;transform:translateY(28px);transition:opacity .7s var(--ease-out),transform .7s var(--ease-out)}
html.js .reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}.reveal.d4{transition-delay:.32s}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1!important;transform:none!important;transition:none!important}
  *{animation-duration:.001ms!important;transition-duration:.001ms!important}
}

/* ---------- Utilities ---------- */
.center{text-align:center}
.mt-1{margin-top:1rem}.mt-2{margin-top:2rem}.mb-0{margin-bottom:0}
.text-red{color:var(--red)}
.maxw-prose{max-width:68ch}
.divider{height:1px;background:var(--line);border:0;margin-block:clamp(40px,6vw,72px)}
.pill{display:inline-flex;align-items:center;gap:.5rem;padding:.4rem .9rem;border-radius:var(--radius-pill);background:var(--red-tint);color:var(--red-700);font-size:.84rem;font-weight:600}
.skip-link{position:absolute;left:-999px;top:0;z-index:200;background:var(--red);color:#fff;padding:.7rem 1.2rem;border-radius:0 0 8px 0}
.skip-link:focus{left:0}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}

/* ---------- Rechtsseiten (Impressum / Datenschutz) ---------- */
.legal{padding-block:clamp(40px,6vw,72px)}
.legal .container{max-width:860px}
.legal h2{font-size:1.5rem;margin-top:2.6rem;margin-bottom:.8rem}
.legal h2:first-of-type{margin-top:0}
.legal h3{font-size:1.12rem;margin-top:1.7rem;margin-bottom:.5rem}
.legal p,.legal li{color:var(--slate);margin-bottom:1rem;font-size:1.02rem;line-height:1.7}
.legal ul{list-style:disc;padding-left:1.5rem;margin-bottom:1.2rem}
.legal li{margin-bottom:.5rem}
.legal a{color:var(--red);text-decoration:underline;text-underline-offset:2px}
.legal a:hover{color:var(--red-700)}
.legal strong{color:var(--ink)}
.legal address{font-style:normal;color:var(--slate);line-height:1.8}
.legal-note{background:var(--red-tint);border:1px solid var(--red-tint-2);border-radius:var(--radius-sm);padding:1.1rem 1.3rem;font-size:.94rem;color:var(--red-700);margin-bottom:2rem}
.legal-note strong{color:var(--red-700)}

/* ===============================================================
   TERMINBUCHUNG (Wizard, Kalender, Slots)
   =============================================================== */
.booking{display:grid;grid-template-columns:1fr 360px;gap:clamp(24px,3.5vw,44px);align-items:start}
@media (max-width:920px){.booking{grid-template-columns:1fr}}

/* Schritt-Indikator */
.steps{display:flex;justify-content:space-between;gap:.5rem;margin-bottom:2.4rem;position:relative}
.steps::before{content:"";position:absolute;top:22px;left:8%;right:8%;height:2px;background:var(--line);z-index:0}
.step-i{display:flex;flex-direction:column;align-items:center;gap:.6rem;position:relative;z-index:1;flex:1;text-align:center}
.step-i .si-dot{width:44px;height:44px;border-radius:50%;background:#fff;border:2px solid var(--line);display:flex;align-items:center;justify-content:center;font-family:var(--font-head);font-weight:700;color:var(--slate-2);transition:all var(--t)}
.step-i .si-label{font-size:.8rem;font-weight:600;color:var(--slate-2);transition:color var(--t)}
.step-i.active .si-dot{border-color:var(--red);color:var(--red);box-shadow:0 0 0 4px var(--red-tint)}
.step-i.active .si-label{color:var(--ink)}
.step-i.done .si-dot{background:var(--red);border-color:var(--red);color:#fff}
.step-i.done .si-label{color:var(--ink)}
@media (max-width:560px){.step-i .si-label{display:none}.steps::before{top:22px}}

/* Wizard-Panel */
.wizard{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:clamp(1.4rem,3vw,2.2rem)}
.wstep{display:none;animation:fadeUp .4s var(--ease-out)}
.wstep.active{display:block}
@keyframes fadeUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}
.wstep h2{font-size:clamp(1.4rem,2.4vw,1.8rem);margin-bottom:.4rem}
.wstep .wstep-sub{color:var(--slate);margin-bottom:1.6rem}

/* Leistungs-Auswahl */
.svc-grid{display:grid;grid-template-columns:1fr 1fr;gap:.9rem}
@media (max-width:520px){.svc-grid{grid-template-columns:1fr}}
.svc-opt{position:relative;border:1.5px solid var(--line);border-radius:var(--radius-sm);padding:1.1rem 1.1rem 1.1rem 1rem;cursor:pointer;display:flex;gap:.85rem;align-items:flex-start;transition:border-color var(--t),background var(--t),transform var(--t)}
.svc-opt:hover{border-color:var(--red-tint-2);transform:translateY(-2px)}
.svc-opt input{position:absolute;opacity:0;pointer-events:none}
.svc-opt .svc-ic{width:42px;height:42px;border-radius:11px;background:var(--red-tint);color:var(--red);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all var(--t)}
.svc-opt .svc-ic svg{width:22px;height:22px}
.svc-opt h4{font-size:1rem;margin-bottom:.15rem}
.svc-opt p{font-size:.84rem;line-height:1.45}
.svc-opt::after{content:"";position:absolute;top:.9rem;right:.9rem;width:20px;height:20px;border-radius:50%;border:2px solid var(--line);transition:all var(--t)}
.svc-opt.selected{border-color:var(--red);background:var(--red-tint)}
.svc-opt.selected .svc-ic{background:var(--red);color:#fff}
.svc-opt.selected::after{border-color:var(--red);background:var(--red);box-shadow:inset 0 0 0 3px #fff}

/* Kalender */
.cal-wrap{display:grid;grid-template-columns:1.1fr 1fr;gap:clamp(1rem,2.5vw,2rem)}
@media (max-width:680px){.cal-wrap{grid-template-columns:1fr}}
.calendar{border:1px solid var(--line);border-radius:var(--radius-sm);padding:1rem}
.cal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:.8rem}
.cal-head .cal-title{font-family:var(--font-head);font-weight:700;font-size:1.05rem}
.cal-nav{width:36px;height:36px;border-radius:9px;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--ink);transition:all var(--t)}
.cal-nav:hover:not(:disabled){border-color:var(--red);color:var(--red)}
.cal-nav:disabled{opacity:.35;cursor:not-allowed}
.cal-nav svg{width:18px;height:18px}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}
.cal-dow{text-align:center;font-size:.72rem;font-weight:700;color:var(--slate-2);padding:.4rem 0;text-transform:uppercase;letter-spacing:.04em}
.cal-day{aspect-ratio:1;border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:.92rem;font-weight:500;border:1.5px solid transparent;transition:all var(--t);color:var(--ink)}
.cal-day:hover:not(:disabled):not(.empty){border-color:var(--red);color:var(--red)}
.cal-day:disabled,.cal-day.empty{color:var(--line);cursor:not-allowed}
.cal-day.today{font-weight:800;color:var(--red)}
.cal-day.selected{background:var(--red);color:#fff;border-color:var(--red)}

/* Zeit-Slots */
.slots-panel{min-height:120px}
.slots-date{font-family:var(--font-head);font-weight:700;margin-bottom:.9rem;font-size:1rem}
.slots{display:grid;grid-template-columns:repeat(auto-fill,minmax(86px,1fr));gap:.6rem}
.slot{padding:.7rem .4rem;border:1.5px solid var(--line);border-radius:9px;font-weight:600;font-size:.95rem;transition:all var(--t);color:var(--ink)}
.slot:hover:not(:disabled){border-color:var(--red);color:var(--red);transform:translateY(-2px)}
.slot.selected{background:var(--red);color:#fff;border-color:var(--red)}
.slot:disabled{opacity:.4;text-decoration:line-through;cursor:not-allowed}
.slots-empty,.slots-hint{color:var(--slate-2);font-size:.92rem;padding:1rem 0;text-align:center}
.spinner{width:30px;height:30px;border:3px solid var(--line);border-top-color:var(--red);border-radius:50%;animation:spin .7s linear infinite;margin:1.6rem auto}
@keyframes spin{to{transform:rotate(360deg)}}

/* Wizard-Navigation */
.wizard-nav{display:flex;justify-content:space-between;gap:1rem;margin-top:2rem;padding-top:1.6rem;border-top:1px solid var(--line-2)}
.wizard-nav .btn--back{visibility:hidden}
.wizard-nav .btn--back.show{visibility:visible}

/* Zusammenfassung (Sidebar) */
.summary{background:var(--bg-alt);border:1px solid var(--line);border-radius:var(--radius);padding:1.6rem;position:sticky;top:calc(var(--header-h) + 16px)}
.summary h3{font-size:1.1rem;margin-bottom:1.2rem;display:flex;align-items:center;gap:.5rem}
.summary h3 svg{width:20px;height:20px;color:var(--red)}
.summary-row{display:flex;justify-content:space-between;gap:1rem;padding:.7rem 0;border-bottom:1px dashed var(--line);font-size:.92rem}
.summary-row .sr-label{color:var(--slate-2)}
.summary-row .sr-val{font-weight:600;text-align:right;color:var(--ink)}
.summary-row .sr-val.empty{color:var(--slate-2);font-weight:400;font-style:italic}
.summary-foot{margin-top:1.3rem;font-size:.84rem;color:var(--slate);display:flex;gap:.6rem;align-items:flex-start}
.summary-foot svg{width:18px;height:18px;color:var(--red);flex-shrink:0;margin-top:.1rem}
.summary-trust{margin-top:1.2rem;display:grid;gap:.6rem}
.summary-trust li{display:flex;gap:.55rem;align-items:center;font-size:.86rem;color:var(--slate)}
.summary-trust svg{width:16px;height:16px;color:var(--red);flex-shrink:0}

/* Review-Liste (Schritt 4) */
.review-list{display:grid;gap:0;margin-bottom:1.5rem;border:1px solid var(--line);border-radius:var(--radius-sm);overflow:hidden}
.review-list .review-row{display:flex;justify-content:space-between;gap:1rem;padding:.9rem 1.1rem;font-size:.95rem;border-bottom:1px solid var(--line-2)}
.review-list .review-row:last-child{border-bottom:0}
.review-list .rr-label{color:var(--slate)}
.review-list .rr-val{font-weight:600;text-align:right}

/* Hinweis-Banner (Mock-/Fallback-Modus) */
.notice{display:flex;gap:.7rem;align-items:flex-start;background:#FFF7E6;border:1px solid #FCE3B0;color:#8A6100;border-radius:var(--radius-sm);padding:.9rem 1.1rem;font-size:.88rem;margin-bottom:1.4rem}
.notice svg{width:19px;height:19px;flex-shrink:0;margin-top:.1rem}

/* Erfolgs-Screen */
.booking-success{text-align:center;padding:clamp(1.5rem,4vw,3rem) 1rem;display:none}
.booking-success.show{display:block;animation:fadeUp .5s var(--ease-out)}
.success-check{width:84px;height:84px;border-radius:50%;background:var(--red-tint);color:var(--red);display:flex;align-items:center;justify-content:center;margin:0 auto 1.5rem}
.success-check svg{width:44px;height:44px}
.booking-success h2{margin-bottom:.8rem}
.booking-success p{max-width:46ch;margin:0 auto 1rem}

/* ===================== REFERENZ-KACHELN ===================== */
.ref-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.8rem;max-width:1000px;margin-inline:auto}
.ref-tile{position:relative;display:flex;flex-direction:column;text-align:center;align-items:center;background:var(--white);border:1px solid var(--line);border-radius:var(--radius-lg);padding:2.8rem 2.2rem;box-shadow:var(--shadow-sm);transition:transform .25s var(--ease-out),box-shadow .25s var(--ease-out)}
.ref-tile:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.ref-tile::before{content:"";position:absolute;inset:0 0 auto;height:4px;border-radius:var(--radius-lg) var(--radius-lg) 0 0;background:linear-gradient(90deg,var(--red),var(--red-500))}
.ref-media{width:96px;height:96px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:var(--red-tint);color:var(--red);margin-bottom:1.4rem}
.ref-media svg{width:46px;height:46px}
.ref-quote{font-family:var(--font-head);font-size:1.12rem;line-height:1.72;font-weight:500;color:var(--ink-2);margin:0 0 1.6rem;max-width:40ch;letter-spacing:.002em}
.ref-quote .rq-mark{color:var(--red);font-weight:700}
.ref-tile h3{font-size:1.05rem;margin:0 0 1rem}
.ref-meta{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;margin-top:auto}
.ref-meta span{font-size:.82rem;font-weight:600;color:var(--slate-2);background:var(--mist);border:1px solid var(--line);border-radius:100px;padding:.34rem .8rem}
@media(max-width:760px){.ref-grid{grid-template-columns:1fr}.ref-tile{padding:2.2rem 1.6rem}.ref-quote{font-size:1.1rem}}

/* ===================== VERBAND / INNUNG ===================== */
.footer-verband{display:flex;align-items:center;gap:.8rem;margin:1.2rem 0 .2rem}
.footer-verband .verband-logo{height:56px;width:auto;flex:none;background:#fff;border-radius:8px;padding:5px}
.footer-verband span{font-size:.8rem;color:var(--slate-2);line-height:1.45;max-width:34ch}
.verband-band{display:flex;align-items:center;gap:1.5rem;flex-wrap:wrap;background:var(--mist);border:1px solid var(--line);border-radius:var(--radius-lg);padding:1.5rem 1.8rem}
.verband-band .vb-logo{height:88px;width:auto;flex:none;background:#fff;border:1px solid var(--line);border-radius:10px;padding:8px}
.verband-band .vb-text{flex:1;min-width:240px}
.verband-band .vb-text h3{margin:0 0 .35rem}
.verband-band .vb-text p{margin:0;color:var(--slate-2)}

/* ===== Bild-Platzhalter vorübergehend ausgeblendet – echte Fotos folgen später ===== */
.hero-visual,.split-media,.hero-badge,.ba-slider{display:none!important}
.hero .container{grid-template-columns:1fr}
.hero-content{max-width:820px}
.split{grid-template-columns:1fr}
