/* ==========================================================================
   5S Sicherheitstechnik KG – Design System v2
   Farben lt. Corporate Identity:
   Primär Blau   #00AEEF | Primär Schwarz #000000 | Weiß #FFFFFF
   Hellgrau      #F2F2F2 | Sehr Hellblau  #EAF6FF
   --------------------------------------------------------------------------
   v2: Animations-System (Stagger-Reveals, Hero-Entrance, Counter, Tilt),
   Dropdown-Navigation, Timeline, Spezifikations-Tabellen, Referenz-Galerie,
   Scroll-Progress, Page-Transitions, Back-to-Top.
   ========================================================================== */

:root {
  --blau: #00AEEF;
  --blau-dunkel: #0089bd;
  --schwarz: #0a0e12;
  --anthrazit: #14181d;
  --grau-text: #4a545e;
  --hellgrau: #F2F2F2;
  --hellblau: #EAF6FF;
  --weiss: #ffffff;
  --rand: #e3e8ec;

  --grad-blau: linear-gradient(120deg, #00AEEF 0%, #4cc9f0 50%, #0089bd 100%);

  --font: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;

  --fs-hero: clamp(2.1rem, 5vw, 3.6rem);
  --fs-h1: clamp(1.9rem, 4vw, 2.9rem);
  --fs-h2: clamp(1.5rem, 3vw, 2.2rem);
  --fs-h3: 1.2rem;
  --fs-body: 1.0625rem;

  --radius: 14px;
  --shadow-sm: 0 1px 3px rgba(10, 14, 18, .07);
  --shadow-md: 0 8px 30px rgba(10, 14, 18, .09);
  --shadow-lg: 0 20px 50px rgba(10, 14, 18, .14);
  --glow-blau: 0 8px 32px rgba(0, 174, 239, .35);

  /* Bewegungs-System */
  --ease-out: cubic-bezier(.22, 1, .36, 1);
  --ease-spring: cubic-bezier(.34, 1.56, .64, 1);
  --dauer-schnell: .25s;
  --dauer-normal: .45s;
  --dauer-langsam: .8s;

  --container: 1180px;
  --gap-section: clamp(4rem, 9vw, 7.5rem);
}

*, *::before, *::after { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  margin: 0;
  font-family: var(--font);
  font-size: var(--fs-body);
  line-height: 1.65;
  color: var(--schwarz);
  background: var(--weiss);
  -webkit-font-smoothing: antialiased;
}

/* Sanfter Seitenwechsel über die native View-Transition-API:
   kein künstliches Warten – Browser ohne Unterstützung wechseln einfach sofort. */
@view-transition { navigation: auto; }
::view-transition-old(root), ::view-transition-new(root) { animation-duration: .2s; }

::selection { background: rgba(0, 174, 239, .25); }

img { max-width: 100%; height: auto; display: block; }

h1, h2, h3, h4 { line-height: 1.2; margin: 0 0 1rem; font-weight: 700; letter-spacing: -0.015em; }
h1 { font-size: var(--fs-h1); }
h2 { font-size: var(--fs-h2); }
h3 { font-size: var(--fs-h3); }
p  { margin: 0 0 1rem; color: var(--grau-text); }

a { color: var(--blau-dunkel); text-decoration: none; }
a:hover { text-decoration: underline; }

:focus-visible {
  outline: 3px solid rgba(0, 174, 239, .55);
  outline-offset: 2px;
  border-radius: 4px;
}

.container {
  max-width: var(--container);
  margin-inline: auto;
  padding-inline: clamp(1.25rem, 4vw, 2.5rem);
}

section { padding-block: var(--gap-section); }

/* --------------------------------------------------------------------------
   Scroll-Progress-Leiste (wird per JS eingefügt)
   -------------------------------------------------------------------------- */
.scroll-progress {
  position: fixed;
  top: 0; left: 0;
  height: 3px;
  width: 100%;
  transform-origin: 0 50%;
  transform: scaleX(0);
  background: var(--grad-blau);
  z-index: 1000;
  pointer-events: none;
}

/* --------------------------------------------------------------------------
   Eyebrow / Kicker & Abschnittsköpfe
   -------------------------------------------------------------------------- */
.eyebrow {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  font-size: .8rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .14em;
  color: var(--blau-dunkel);
  margin-bottom: 1rem;
}
.eyebrow::before {
  content: "";
  width: 28px; height: 2px;
  background: var(--blau);
  transform-origin: left;
  transition: transform .6s var(--ease-out);
}
.reveal.visible .eyebrow::before { animation: linie-wachsen .7s var(--ease-out) both; }
@keyframes linie-wachsen {
  from { transform: scaleX(0); }
  to   { transform: scaleX(1); }
}

.section-head { max-width: 720px; margin-bottom: clamp(2rem, 5vw, 3.5rem); }
.section-head.center { margin-inline: auto; text-align: center; }
.section-head.center .eyebrow { justify-content: center; }
.section-head.center .eyebrow::before { display: none; }
.section-head p { font-size: 1.1rem; }

/* --------------------------------------------------------------------------
   Buttons – mit Glanz-Sweep, Press-Feedback & Glow
   -------------------------------------------------------------------------- */
.btn {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .55rem;
  padding: .85rem 1.7rem;
  border-radius: 999px;
  font-weight: 600;
  font-size: 1rem;
  text-decoration: none;
  transition: transform var(--dauer-schnell) var(--ease-spring),
              box-shadow var(--dauer-schnell) ease,
              background var(--dauer-schnell) ease,
              border-color var(--dauer-schnell) ease,
              color var(--dauer-schnell) ease;
  cursor: pointer;
  border: 0;
  overflow: hidden;
  isolation: isolate;
}
.btn:hover { text-decoration: none; transform: translateY(-2px); }
.btn:active { transform: translateY(0) scale(.97); }

/* Glanz-Sweep: läuft beim Hover einmal über den Button */
.btn::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  background: linear-gradient(105deg,
    transparent 35%,
    rgba(255, 255, 255, .35) 50%,
    transparent 65%);
  transform: translateX(-110%);
  transition: transform .6s var(--ease-out);
  pointer-events: none;
}
.btn:hover::before { transform: translateX(110%); }

.btn-primary {
  background: var(--blau);
  color: #fff;
  box-shadow: 0 6px 20px rgba(0, 174, 239, .35);
}
.btn-primary:hover { background: var(--blau-dunkel); box-shadow: 0 12px 30px rgba(0, 174, 239, .5); color: #fff; }

.btn-dark { background: var(--schwarz); color: #fff; }
.btn-dark:hover { background: #1d242b; color: #fff; box-shadow: 0 12px 28px rgba(10, 14, 18, .35); }

.btn-ghost {
  background: transparent;
  color: var(--schwarz);
  border: 1.5px solid var(--rand);
}
.btn-ghost:hover { border-color: var(--blau); color: var(--blau-dunkel); box-shadow: 0 8px 22px rgba(0, 174, 239, .18); }

.btn-light { background: #fff; color: var(--schwarz); }
.btn-light:hover { background: var(--hellblau); box-shadow: 0 10px 26px rgba(10, 14, 18, .2); }

/* --------------------------------------------------------------------------
   Topbar
   -------------------------------------------------------------------------- */
.topbar {
  background: var(--schwarz);
  color: #cfd6dc;
  font-size: .85rem;
  padding: .45rem 0;
}
.topbar .container {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1rem;
  flex-wrap: wrap;
}
.topbar a { color: #fff; font-weight: 600; transition: color .2s ease; }
.topbar a:hover { color: var(--blau); }
.topbar .claim { letter-spacing: .02em; }
.topbar .claim strong { color: var(--blau); font-weight: 700; }
/* Mobil: nur die Telefonzeile zeigen, damit die Leiste einzeilig bleibt */
@media (max-width: 700px) {
  .topbar .claim { display: none; }
  .topbar .container { justify-content: center; text-align: center; }
}

/* --------------------------------------------------------------------------
   Header – sticky, blendet beim Runterscrollen sanft aus
   -------------------------------------------------------------------------- */
.site-header {
  position: sticky;
  top: 0;
  z-index: 100;
  background: rgba(255, 255, 255, .9);
  backdrop-filter: blur(14px) saturate(1.4);
  -webkit-backdrop-filter: blur(14px) saturate(1.4);
  border-bottom: 1px solid var(--rand);
  transition: box-shadow .25s ease, transform .35s var(--ease-out);
}
.site-header.scrolled { box-shadow: var(--shadow-md); }
.site-header.versteckt { transform: translateY(-100%); }

/* WordPress: Platz für die Admin-Leiste (nur für eingeloggte Benutzer) */
.admin-bar .site-header { top: 32px; }
@media (max-width: 782px) {
  .admin-bar .site-header { top: 46px; }
}

.nav-wrap {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1.5rem;
  padding-block: .7rem;
}

.logo { flex: 0 0 auto; display: inline-flex; align-items: center; }
.logo img { height: 56px; width: auto; max-width: none; object-fit: contain; transition: transform .3s var(--ease-spring); }
.logo:hover img { transform: scale(1.03); }
@media (max-width: 480px) {
  .logo img { height: 44px; }
}

.main-nav { display: flex; align-items: center; gap: .1rem; }
.main-nav > a, .nav-drop-trigger {
  position: relative;
  padding: .55rem .8rem;
  border-radius: 8px;
  color: var(--schwarz);
  font-weight: 500;
  font-size: .95rem;
  white-space: nowrap;
  transition: color .2s ease, background .2s ease;
}
.main-nav > a:hover, .nav-drop-trigger:hover { background: var(--hellblau); color: var(--blau-dunkel); text-decoration: none; }

/* Animierter Unterstrich für aktive/gehoverte Links */
.main-nav > a:not(.btn)::after, .nav-drop-trigger::after {
  content: "";
  position: absolute;
  left: .8rem; right: .8rem; bottom: .25rem;
  height: 2px;
  background: var(--blau);
  border-radius: 2px;
  transform: scaleX(0);
  transform-origin: left;
  transition: transform .3s var(--ease-out);
}
.main-nav > a:not(.btn):hover::after, .nav-drop-trigger:hover::after { transform: scaleX(1); }
.main-nav > a.active, .nav-drop-trigger.active { color: var(--blau-dunkel); font-weight: 700; }
.main-nav > a.active::after, .nav-drop-trigger.active::after { transform: scaleX(1); }

.main-nav .btn { margin-left: .6rem; padding: .6rem 1.25rem; font-size: .92rem; }
.main-nav .btn::after { display: none; }

/* Dropdown „Leistungen" */
.nav-drop { position: relative; }
.nav-drop-trigger { display: inline-flex; align-items: center; gap: .3rem; }
.nav-drop-trigger .chev {
  width: 14px; height: 14px;
  transition: transform .3s var(--ease-out);
}
.nav-drop:hover .chev, .nav-drop:focus-within .chev { transform: rotate(180deg); }

.nav-drop-menu {
  position: absolute;
  top: calc(100% + .5rem);
  left: 0;
  min-width: 250px;
  background: #fff;
  border: 1px solid var(--rand);
  border-radius: 14px;
  box-shadow: var(--shadow-lg);
  padding: .55rem;
  display: grid;
  gap: .15rem;
  opacity: 0;
  visibility: hidden;
  transform: translateY(10px) scale(.98);
  transform-origin: top left;
  transition: opacity .25s var(--ease-out), transform .25s var(--ease-out), visibility 0s linear .25s;
  z-index: 50;
}
/* Unsichtbare Brücke, damit das Menü beim Bewegen der Maus nicht zuklappt */
.nav-drop-menu::before {
  content: "";
  position: absolute;
  top: -.6rem; left: 0; right: 0;
  height: .6rem;
}
.nav-drop:hover .nav-drop-menu,
.nav-drop:focus-within .nav-drop-menu {
  opacity: 1;
  visibility: visible;
  transform: translateY(0) scale(1);
  transition: opacity .25s var(--ease-out), transform .25s var(--ease-out), visibility 0s;
}
.nav-drop-menu a {
  display: block;
  padding: .6rem .9rem;
  border-radius: 9px;
  color: var(--schwarz);
  font-size: .93rem;
  font-weight: 500;
  transition: background .18s ease, color .18s ease, transform .18s ease, padding-left .18s ease;
}
.nav-drop-menu a:hover {
  background: var(--hellblau);
  color: var(--blau-dunkel);
  text-decoration: none;
  padding-left: 1.15rem;
}
.nav-drop-menu a.active { color: var(--blau-dunkel); font-weight: 700; background: var(--hellblau); }

.nav-toggle {
  display: none;
  flex-direction: column;
  gap: 5px;
  background: none;
  border: 0;
  padding: .6rem;
  cursor: pointer;
}
.nav-toggle span {
  width: 26px; height: 2.5px;
  background: var(--schwarz);
  border-radius: 2px;
  transition: transform .25s ease, opacity .25s ease;
}
.nav-toggle[aria-expanded="true"] span:nth-child(1) { transform: translateY(7.5px) rotate(45deg); }
.nav-toggle[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
.nav-toggle[aria-expanded="true"] span:nth-child(3) { transform: translateY(-7.5px) rotate(-45deg); }

@media (max-width: 1100px) {
  .main-nav > a, .nav-drop-trigger { padding-inline: .6rem; font-size: .9rem; }
}

@media (max-width: 980px) {
  .nav-toggle { display: flex; }
  .main-nav {
    position: absolute;
    top: 100%; left: 0; right: 0;
    flex-direction: column;
    align-items: stretch;
    background: #fff;
    border-bottom: 1px solid var(--rand);
    box-shadow: var(--shadow-lg);
    padding: 1rem clamp(1.25rem, 4vw, 2.5rem) 1.5rem;
    display: none;
    max-height: calc(100vh - 120px);
    overflow-y: auto;
  }
  .main-nav.open { display: flex; animation: nav-rein .3s var(--ease-out) both; }
  @keyframes nav-rein {
    from { opacity: 0; transform: translateY(-8px); }
    to   { opacity: 1; transform: none; }
  }
  .main-nav > a, .nav-drop-trigger { padding: .85rem 1rem; font-size: 1.05rem; }
  .main-nav .btn { margin: .75rem 0 0; }

  /* Dropdown mobil: immer ausgeklappt, eingerückt */
  .nav-drop-trigger .chev { display: none; }
  .nav-drop-menu {
    position: static;
    opacity: 1;
    visibility: visible;
    transform: none;
    box-shadow: none;
    border: 0;
    border-left: 2px solid var(--hellblau);
    border-radius: 0;
    margin-left: 1rem;
    padding: 0 0 .4rem .4rem;
    min-width: 0;
  }
}

/* --------------------------------------------------------------------------
   Hero – Entrance-Animation, Gradient-Shimmer, Parallax
   -------------------------------------------------------------------------- */
.hero {
  position: relative;
  color: #fff;
  padding-block: clamp(5rem, 12vw, 9.5rem);
  background: var(--schwarz);
  overflow: hidden;
}
.hero::before {
  content: "";
  position: absolute;
  inset: -8% 0;
  background-size: cover;
  background-position: center;
  opacity: .55;
  animation: hero-zoom 22s ease-in-out infinite alternate;
  transform: translateY(calc(var(--parallax, 0) * 1px));
  will-change: transform;
}

/* Hero-Hintergrundbilder pro Seite (Pfade relativ zu dieser CSS-Datei) */
.hero--start::before            { background-image: url('../img/Vorarlberg-Landschaft.jpg'); }
.hero--dienstleistungen::before { background-image: url('../img/hero-dienstleistungen.jpg'); }
.hero--produkte::before         { background-image: url('../img/hero-produkte.jpg'); }
.hero--ueber::before            { background-image: url('../img/IMG_2641-scaled.jpg'); }
.hero--notdienst::before        { background-image: url('../img/hero-notdienst.jpg'); }
.hero--ratgeber::before         { background-image: url('../img/hero-ratgeber.jpg'); }
.hero--kontakt::before          { background-image: url('../img/hero-kontakt.jpg'); }
.hero--schliessanlagen::before  { background-image: url('../img/hero-schliessanlagen.jpg'); }
.hero--alarm::before            { background-image: url('../img/hero-alarm-video.jpg'); }
.hero--tresore::before          { background-image: url('../img/hero-tresore.jpg'); }
.hero--referenzen::before       { background-image: url('../img/hero-referenzen.jpg'); }

/* Ken-Burns-Effekt: sehr langsamer, ruhiger Zoom */
@keyframes hero-zoom {
  from { transform: scale(1)    translateY(calc(var(--parallax, 0) * 1px)); }
  to   { transform: scale(1.09) translateY(calc(var(--parallax, 0) * 1px)); }
}
.hero::after {
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(100deg, rgba(5, 10, 16, .88) 18%, rgba(5, 10, 16, .45) 60%, rgba(0, 174, 239, .18));
}
.hero .container { position: relative; z-index: 2; }
.hero-inner { max-width: 680px; }

/* Gestaffelte Entrance-Animation der Hero-Elemente
   (zweite Selektor-Variante: WordPress-Gruppen mit Inner-Container) */
.hero-inner > *,
.hero-inner > .wp-block-group__inner-container > * {
  animation: hero-element .9s var(--ease-out) both;
}
.hero-inner > *:nth-child(1), .hero-inner > .wp-block-group__inner-container > *:nth-child(1) { animation-delay: .05s; }
.hero-inner > *:nth-child(2), .hero-inner > .wp-block-group__inner-container > *:nth-child(2) { animation-delay: .18s; }
.hero-inner > *:nth-child(3), .hero-inner > .wp-block-group__inner-container > *:nth-child(3) { animation-delay: .34s; }
.hero-inner > *:nth-child(4), .hero-inner > .wp-block-group__inner-container > *:nth-child(4) { animation-delay: .5s; }
@keyframes hero-element {
  from { opacity: 0; transform: translateY(28px); }
  to   { opacity: 1; transform: none; }
}

.hero .badge {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  background: rgba(0, 174, 239, .16);
  border: 1px solid rgba(0, 174, 239, .45);
  color: #aee6fb;
  font-size: .85rem;
  font-weight: 600;
  padding: .4rem 1rem;
  border-radius: 999px;
  margin-bottom: 1.5rem;
  backdrop-filter: blur(4px);
}
/* Pulsierender Punkt im Badge */
.hero .badge::before {
  content: "";
  width: 7px; height: 7px;
  border-radius: 50%;
  background: var(--blau);
  box-shadow: 0 0 0 0 rgba(0, 174, 239, .6);
  animation: puls 2.4s ease-out infinite;
}
@keyframes puls {
  0%   { box-shadow: 0 0 0 0 rgba(0, 174, 239, .55); }
  70%  { box-shadow: 0 0 0 9px rgba(0, 174, 239, 0); }
  100% { box-shadow: 0 0 0 0 rgba(0, 174, 239, 0); }
}

.hero h1 {
  font-size: var(--fs-hero);
  font-weight: 800;
  color: #fff;
  margin-bottom: 1.25rem;
}

/* Akzent mit lebendigem Gradient-Shimmer */
.hero h1 .accent {
  background: linear-gradient(110deg, #00AEEF 20%, #8fe3ff 40%, #00AEEF 60%, #4cc9f0 80%);
  background-size: 220% 100%;
  -webkit-background-clip: text;
          background-clip: text;
  -webkit-text-fill-color: transparent;
  color: var(--blau); /* Fallback */
  animation: shimmer 6s linear infinite;
}
@keyframes shimmer {
  from { background-position: 220% 0; }
  to   { background-position: -220% 0; }
}

.hero p.lead {
  font-size: clamp(1.05rem, 2vw, 1.25rem);
  color: #d6dee5;
  max-width: 560px;
  margin-bottom: 2.25rem;
}

.hero-ctas { display: flex; gap: 1rem; flex-wrap: wrap; }

/* Scroll-Indikator (Start-Hero) */
.scroll-hinweis {
  position: absolute;
  left: 50%;
  bottom: 1.6rem;
  transform: translateX(-50%);
  z-index: 3;
  width: 26px; height: 42px;
  border: 2px solid rgba(255, 255, 255, .45);
  border-radius: 999px;
  display: flex;
  justify-content: center;
  padding-top: 7px;
  opacity: 0;
  animation: hero-element 1s var(--ease-out) .9s both;
}
.scroll-hinweis::before {
  content: "";
  width: 4px; height: 9px;
  border-radius: 4px;
  background: var(--blau);
  animation: scroll-punkt 2s var(--ease-out) infinite;
}
@keyframes scroll-punkt {
  0%   { transform: translateY(0); opacity: 1; }
  70%  { transform: translateY(13px); opacity: 0; }
  100% { transform: translateY(0); opacity: 0; }
}
@media (max-width: 700px) { .scroll-hinweis { display: none; } }

/* Unterseiten-Hero (kompakter) */
.hero.sub { padding-block: clamp(3.5rem, 8vw, 6rem); }

/* 5S-Leiste unter dem Hero */
.saeulen-strip {
  background: var(--schwarz);
  border-top: 1px solid rgba(255, 255, 255, .08);
  padding-block: 1.1rem;
}
.saeulen-strip .container {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  flex-wrap: wrap;
}
.saeulen-strip span {
  color: #9aa6b0;
  font-size: .92rem;
  font-weight: 600;
  letter-spacing: .12em;
  text-transform: uppercase;
  display: inline-flex;
  align-items: center;
  gap: .6rem;
  transition: color .25s ease;
}
.saeulen-strip span:hover { color: #fff; }
.saeulen-strip span strong { color: var(--blau); font-size: 1.15rem; }

/* --------------------------------------------------------------------------
   Karten & Raster – Glow-Border, Bild-Sheen, 3D-Tilt (per JS)
   -------------------------------------------------------------------------- */
.grid { display: grid; gap: 1.5rem; }
.grid-2 { grid-template-columns: repeat(2, 1fr); }
.grid-3 { grid-template-columns: repeat(3, 1fr); }
@media (max-width: 900px)  { .grid-3 { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 620px)  { .grid-2, .grid-3 { grid-template-columns: 1fr; } }

.card {
  position: relative;
  background: #fff;
  border: 1px solid var(--rand);
  border-radius: var(--radius);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
  transition: transform var(--dauer-normal) var(--ease-out),
              box-shadow var(--dauer-normal) ease,
              border-color var(--dauer-normal) ease;
  display: flex;
  flex-direction: column;
  transform-style: preserve-3d;
}
.card:hover {
  transform: translateY(-6px);
  box-shadow: var(--shadow-lg), 0 0 0 1px rgba(0, 174, 239, .25);
  border-color: rgba(0, 174, 239, .45);
}

.card-img { position: relative; aspect-ratio: 16 / 10; overflow: hidden; background: var(--hellblau); }
.card-img img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform .8s var(--ease-out), filter .8s ease;
}
.card:hover .card-img img { transform: scale(1.07); filter: saturate(1.1); }

/* Licht-Sheen, der beim Hover diagonal über das Bild läuft */
.card-img::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(115deg, transparent 40%, rgba(255, 255, 255, .35) 50%, transparent 60%);
  transform: translateX(-130%);
  transition: transform .9s var(--ease-out);
  pointer-events: none;
}
.card:hover .card-img::after { transform: translateX(130%); }

.card-body { padding: 1.6rem 1.6rem 1.8rem; flex: 1; display: flex; flex-direction: column; }
.card-body h3 { transition: color .25s ease; }
.card:hover .card-body h3 { color: var(--blau-dunkel); }
.card-body p { flex: 1; font-size: .98rem; }
.card-link {
  font-weight: 700;
  font-size: .95rem;
  color: var(--blau-dunkel);
  display: inline-flex;
  align-items: center;
  gap: .4rem;
}
.card-link::after { content: "→"; transition: transform .3s var(--ease-spring); }
.card:hover .card-link::after, .card-link:hover::after { transform: translateX(5px); }

/* Icon-Karten (Leistungen) */
.icon-card {
  position: relative;
  background: #fff;
  border: 1px solid var(--rand);
  border-radius: var(--radius);
  padding: 1.8rem 1.6rem;
  box-shadow: var(--shadow-sm);
  overflow: hidden;
  transition: transform var(--dauer-normal) var(--ease-out),
              box-shadow var(--dauer-normal) ease,
              border-color var(--dauer-normal) ease;
}
/* Akzentlinie, die beim Hover von links nach rechts wächst */
.icon-card::before {
  content: "";
  position: absolute;
  top: 0; left: 0;
  width: 100%; height: 3px;
  background: var(--grad-blau);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform .45s var(--ease-out);
}
.icon-card:hover::before { transform: scaleX(1); }
.icon-card:hover {
  transform: translateY(-5px);
  box-shadow: var(--shadow-md);
  border-color: rgba(0, 174, 239, .4);
}
.icon-card .icon {
  width: 54px; height: 54px;
  border-radius: 12px;
  background: var(--hellblau);
  color: var(--blau-dunkel);
  display: grid;
  place-items: center;
  margin-bottom: 1.1rem;
  transition: background .35s ease, color .35s ease, transform .45s var(--ease-spring), box-shadow .35s ease;
}
.icon-card:hover .icon {
  background: var(--blau);
  color: #fff;
  transform: scale(1.08) rotate(-4deg);
  box-shadow: var(--glow-blau);
}
.icon-card .icon svg { width: 26px; height: 26px; }
.icon-card h3 { margin-bottom: .5rem; transition: color .25s ease; }
.icon-card:hover h3 { color: var(--blau-dunkel); }
.icon-card p { font-size: .96rem; margin: 0; }
.icon-card .card-link { margin-top: .9rem; display: inline-flex; }

/* --------------------------------------------------------------------------
   Abschnitt-Hintergründe
   -------------------------------------------------------------------------- */
.bg-grau { background: var(--hellgrau); }
.bg-blauhell { background: var(--hellblau); }
.bg-dunkel {
  position: relative;
  background: var(--schwarz);
  color: #d6dee5;
  overflow: hidden;
}
.bg-dunkel h2, .bg-dunkel h3 { color: #fff; }
.bg-dunkel p { color: #aeb8c1; }
/* Dezent wanderndes Licht im dunklen Abschnitt */
.bg-dunkel::before {
  content: "";
  position: absolute;
  width: 60vw; height: 60vw;
  max-width: 700px; max-height: 700px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(0, 174, 239, .14), transparent 65%);
  top: -30%; left: -10%;
  animation: licht-wandern 18s ease-in-out infinite alternate;
  pointer-events: none;
}
@keyframes licht-wandern {
  from { transform: translate(0, 0); }
  to   { transform: translate(60vw, 30%); }
}
.bg-dunkel .container { position: relative; }

/* --------------------------------------------------------------------------
   Split-Layout (Bild + Text)
   -------------------------------------------------------------------------- */
.split {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(2rem, 6vw, 5rem);
  align-items: center;
}
@media (max-width: 860px) { .split { grid-template-columns: 1fr; } }

.split-img {
  border-radius: var(--radius);
  overflow: hidden;
  box-shadow: var(--shadow-lg);
  position: relative;
}
.split-img img {
  width: 100%;
  object-fit: cover;
  transition: transform 1.2s var(--ease-out);
}
.split-img:hover img { transform: scale(1.04); }

.split-img .img-tag {
  position: absolute;
  left: 1.2rem; bottom: 1.2rem;
  background: rgba(10, 14, 18, .82);
  color: #fff;
  font-size: .85rem;
  font-weight: 600;
  padding: .5rem 1rem;
  border-radius: 999px;
  backdrop-filter: blur(4px);
  transition: background .3s ease, transform .3s var(--ease-spring);
}
.split-img:hover .img-tag { background: rgba(0, 138, 189, .92); transform: translateY(-3px); }

/* Checkliste */
.checklist { list-style: none; padding: 0; margin: 0 0 1.5rem; display: grid; gap: .7rem; }
.checklist li {
  position: relative;
  padding-left: 2rem;
  color: var(--grau-text);
}
.checklist li strong { color: var(--schwarz); }
.checklist li::before {
  content: "";
  position: absolute;
  left: 0; top: .32em;
  width: 18px; height: 18px;
  border-radius: 50%;
  background: var(--blau);
  -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M22 11.08V12a10 10 0 1 1-5.93-9.14'/%3E%3Cpolyline points='22 4 12 14.01 9 11.01'/%3E%3C/svg%3E") center / contain no-repeat;
          mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M22 11.08V12a10 10 0 1 1-5.93-9.14'/%3E%3Cpolyline points='22 4 12 14.01 9 11.01'/%3E%3C/svg%3E") center / contain no-repeat;
}
/* Häkchen springen nacheinander rein, sobald sichtbar */
.reveal.visible .checklist li::before { animation: check-pop .5s var(--ease-spring) both; }
.reveal.visible .checklist li:nth-child(1)::before { animation-delay: .1s; }
.reveal.visible .checklist li:nth-child(2)::before { animation-delay: .22s; }
.reveal.visible .checklist li:nth-child(3)::before { animation-delay: .34s; }
.reveal.visible .checklist li:nth-child(4)::before { animation-delay: .46s; }
.reveal.visible .checklist li:nth-child(5)::before { animation-delay: .58s; }
.reveal.visible .checklist li:nth-child(6)::before { animation-delay: .7s; }
@keyframes check-pop {
  from { transform: scale(0); }
  to   { transform: scale(1); }
}

/* --------------------------------------------------------------------------
   Zahlen / Fakten (Counter per JS)
   -------------------------------------------------------------------------- */
.stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1.5rem;
  text-align: center;
}
@media (max-width: 760px) { .stats { grid-template-columns: repeat(2, 1fr); } }
.stat { transition: transform .35s var(--ease-spring); }
.stat:hover { transform: translateY(-4px); }
.stat .zahl {
  font-size: clamp(2rem, 4vw, 2.8rem);
  font-weight: 800;
  color: var(--blau);
  letter-spacing: -.02em;
  font-variant-numeric: tabular-nums;
}
.stat .label { font-size: .95rem; color: #aeb8c1; font-weight: 500; }

/* --------------------------------------------------------------------------
   Die 5 Säulen (Detail)
   -------------------------------------------------------------------------- */
.saeulen-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 1.25rem;
}
@media (max-width: 1020px) { .saeulen-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 640px)  { .saeulen-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 440px)  { .saeulen-grid { grid-template-columns: 1fr; } }

.saeule {
  background: #fff;
  border: 1px solid var(--rand);
  border-radius: var(--radius);
  padding: 1.6rem 1.3rem;
  text-align: center;
  transition: transform var(--dauer-normal) var(--ease-out),
              box-shadow var(--dauer-normal) ease,
              border-color var(--dauer-normal) ease;
}
.saeule:hover {
  transform: translateY(-6px);
  box-shadow: var(--shadow-md);
  border-color: rgba(0, 174, 239, .4);
}
.saeule .s {
  width: 52px; height: 52px;
  margin: 0 auto 1rem;
  border-radius: 50%;
  background: var(--blau);
  color: #fff;
  font-weight: 800;
  font-size: 1.4rem;
  display: grid;
  place-items: center;
  box-shadow: 0 6px 16px rgba(0, 174, 239, .35);
  transition: transform .5s var(--ease-spring), box-shadow .4s ease;
}
.saeule:hover .s {
  transform: scale(1.12) rotate(8deg);
  box-shadow: 0 0 0 6px rgba(0, 174, 239, .18), var(--glow-blau);
}
.saeule h3 { font-size: 1.05rem; margin-bottom: .4rem; }
.saeule p { font-size: .88rem; margin: 0; }

/* --------------------------------------------------------------------------
   Zielgruppen
   -------------------------------------------------------------------------- */
.ziel-card {
  background: #fff;
  border-radius: var(--radius);
  border: 1px solid var(--rand);
  padding: 2rem 1.8rem;
  box-shadow: var(--shadow-sm);
  border-top: 4px solid var(--blau);
  transition: transform var(--dauer-normal) var(--ease-out), box-shadow var(--dauer-normal) ease;
}
.ziel-card:hover { transform: translateY(-5px); box-shadow: var(--shadow-md); }
.ziel-card h3 { margin-bottom: .75rem; }
.ziel-card ul { padding-left: 1.1rem; margin: 0 0 1rem; color: var(--grau-text); font-size: .95rem; display: grid; gap: .3rem; }
.ziel-card blockquote {
  margin: 1rem 0 0;
  padding: .9rem 1.1rem;
  background: var(--hellblau);
  border-radius: 10px;
  font-size: .92rem;
  color: var(--schwarz);
  font-style: italic;
}

/* --------------------------------------------------------------------------
   Referenzen (Kundenlogos, laufendes Band)
   -------------------------------------------------------------------------- */
.referenzen { padding-block: clamp(3rem, 6vw, 4.5rem); }

.ref-band {
  --ref-gap: clamp(2rem, 5vw, 4rem);
  overflow: hidden;
  position: relative;
  display: flex;
  -webkit-mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent);
          mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent);
}
.ref-gruppe {
  flex: 0 0 auto;
  display: flex;
  align-items: center;
  gap: var(--ref-gap);
  padding-right: var(--ref-gap);
  animation: ref-lauf 35s linear infinite;
}
.ref-band:hover .ref-gruppe { animation-play-state: paused; }

@keyframes ref-lauf {
  from { transform: translateX(0); }
  to   { transform: translateX(-100%); }
}

.ref-logo {
  flex: 0 0 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: .55rem;
  text-decoration: none;
}
.ref-logo:hover { text-decoration: none; }
.ref-logo img {
  height: 74px;
  width: auto;
  max-width: 170px;
  object-fit: contain;
  border-radius: 10px;
  filter: grayscale(1);
  opacity: .75;
  transition: filter .35s ease, opacity .35s ease, transform .35s var(--ease-spring);
}
.ref-logo:hover img { filter: grayscale(0); opacity: 1; transform: scale(1.08); }
.ref-logo span { font-size: .8rem; font-weight: 600; color: var(--grau-text); }

@media (prefers-reduced-motion: reduce) {
  .ref-band { display: block; }
  .ref-gruppe { animation: none; flex-wrap: wrap; justify-content: center; padding-right: 0; }
  .ref-gruppe[aria-hidden="true"] { display: none; }
}

/* --------------------------------------------------------------------------
   Referenz-Galerie (Unterseite)
   -------------------------------------------------------------------------- */
.ref-galerie {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem;
}
@media (max-width: 900px) { .ref-galerie { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .ref-galerie { grid-template-columns: 1fr; } }

.ref-karte {
  position: relative;
  border-radius: var(--radius);
  overflow: hidden;
  aspect-ratio: 4 / 3;
  background: var(--hellblau);
  box-shadow: var(--shadow-sm);
  transition: transform var(--dauer-normal) var(--ease-out), box-shadow var(--dauer-normal) ease;
  display: block;
}
.ref-karte:hover { transform: translateY(-6px); box-shadow: var(--shadow-lg); text-decoration: none; }
.ref-karte img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform .9s var(--ease-out), filter .5s ease;
}
.ref-karte:hover img { transform: scale(1.07); }

/* Overlay gleitet beim Hover von unten hoch */
.ref-karte .ref-overlay {
  position: absolute;
  inset: auto 0 0 0;
  padding: 2.2rem 1.4rem 1.2rem;
  background: linear-gradient(to top, rgba(5, 10, 16, .92) 30%, transparent);
  color: #fff;
  transform: translateY(35%);
  opacity: .92;
  transition: transform .45s var(--ease-out), opacity .45s ease;
}
.ref-karte:hover .ref-overlay { transform: translateY(0); opacity: 1; }
.ref-overlay strong { display: block; font-size: 1.05rem; margin-bottom: .15rem; }
.ref-overlay span {
  display: block;
  font-size: .85rem;
  color: #aee6fb;
  opacity: 0;
  transform: translateY(8px);
  transition: opacity .4s ease .08s, transform .4s var(--ease-out) .08s;
}
.ref-karte:hover .ref-overlay span { opacity: 1; transform: none; }

/* --------------------------------------------------------------------------
   Google Rezensionen
   -------------------------------------------------------------------------- */
.rezension-summary {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1.2rem;
  flex-wrap: wrap;
  margin-bottom: clamp(2rem, 5vw, 3rem);
}
.rezension-summary .g-logo {
  width: 52px; height: 52px;
  background: #fff;
  border: 1px solid var(--rand);
  border-radius: 50%;
  display: grid;
  place-items: center;
  box-shadow: var(--shadow-sm);
}
.rezension-summary .g-logo svg { width: 28px; height: 28px; }
.rezension-summary .note { font-size: 2.2rem; font-weight: 800; color: var(--schwarz); line-height: 1; }
.rezension-summary .meta { font-size: .9rem; color: var(--grau-text); }

.sterne {
  display: inline-flex;
  gap: .15rem;
  color: #fbbc04;
}
.sterne svg { width: 20px; height: 20px; fill: currentColor; }
.sterne.klein svg { width: 16px; height: 16px; }
/* Sterne funkeln nacheinander, sobald sichtbar */
.reveal.visible .sterne svg { animation: stern-pop .45s var(--ease-spring) both; }
.reveal.visible .sterne svg:nth-child(1) { animation-delay: .05s; }
.reveal.visible .sterne svg:nth-child(2) { animation-delay: .15s; }
.reveal.visible .sterne svg:nth-child(3) { animation-delay: .25s; }
.reveal.visible .sterne svg:nth-child(4) { animation-delay: .35s; }
.reveal.visible .sterne svg:nth-child(5) { animation-delay: .45s; }
@keyframes stern-pop {
  0%   { transform: scale(0) rotate(-30deg); }
  100% { transform: scale(1) rotate(0); }
}

.rezension-card {
  background: #fff;
  border: 1px solid var(--rand);
  border-radius: var(--radius);
  padding: 1.7rem 1.6rem;
  box-shadow: var(--shadow-sm);
  display: flex;
  flex-direction: column;
  gap: .9rem;
  transition: transform var(--dauer-normal) var(--ease-out), box-shadow var(--dauer-normal) ease, border-color var(--dauer-normal) ease;
}
.rezension-card:hover { transform: translateY(-5px); box-shadow: var(--shadow-md); border-color: rgba(0, 174, 239, .35); }

.rezension-kopf { display: flex; align-items: center; gap: .9rem; }
.rezension-kopf .avatar {
  width: 44px; height: 44px;
  border-radius: 50%;
  background: var(--blau);
  color: #fff;
  font-weight: 700;
  font-size: 1.1rem;
  display: grid;
  place-items: center;
  flex-shrink: 0;
  transition: transform .4s var(--ease-spring), box-shadow .3s ease;
}
.rezension-card:hover .avatar { transform: scale(1.1); box-shadow: var(--glow-blau); }
.rezension-kopf strong { display: block; color: var(--schwarz); font-size: .98rem; }
.rezension-kopf span { font-size: .82rem; color: #8a949d; }

.rezension-card p {
  margin: 0;
  font-size: .95rem;
  flex: 1;
}
.rezension-card .g-badge {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  font-size: .78rem;
  color: #8a949d;
}
.rezension-card .g-badge svg { width: 14px; height: 14px; }

.rezension-ctas {
  display: flex;
  justify-content: center;
  gap: 1rem;
  flex-wrap: wrap;
  margin-top: clamp(2rem, 4vw, 2.8rem);
}

/* --------------------------------------------------------------------------
   CTA-Banner
   -------------------------------------------------------------------------- */
.cta-banner {
  position: relative;
  border-radius: calc(var(--radius) + 6px);
  overflow: hidden;
  color: #fff;
  padding: clamp(2.5rem, 6vw, 4.5rem);
  background: var(--schwarz);
  transition: box-shadow .4s ease;
}
.cta-banner:hover { box-shadow: var(--shadow-lg), 0 0 60px rgba(0, 174, 239, .2); }
.cta-banner::before {
  content: "";
  position: absolute; inset: 0;
  background-image: url('../img/hoch-hinaus-scaled.jpg');
  background-size: cover;
  background-position: center 30%;
  opacity: .4;
  transition: transform 8s var(--ease-out);
}
.cta-banner:hover::before { transform: scale(1.06); }
.cta-banner::after {
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(95deg, rgba(5, 10, 16, .92) 25%, rgba(0, 138, 189, .55));
}
/* Inhalt über die Überblendung heben
   (zweite Variante: WordPress-Gruppen mit Inner-Container) */
.cta-banner > *,
.cta-banner > .wp-block-group__inner-container > * { position: relative; z-index: 2; }
.cta-banner h2 { color: #fff; max-width: 560px; }
.cta-banner p { color: #cfd9e1; max-width: 520px; }

/* --------------------------------------------------------------------------
   FAQ / Akkordeon – mit sanftem Auf-/Zuklappen (per JS animiert)
   -------------------------------------------------------------------------- */
.faq-group { max-width: 820px; margin-inline: auto; }
.faq-group + .faq-group { margin-top: 3rem; }
.faq-group > h2 { margin-bottom: 1.25rem; }

details.faq {
  background: #fff;
  border: 1px solid var(--rand);
  border-radius: 12px;
  margin-bottom: .8rem;
  box-shadow: var(--shadow-sm);
  overflow: hidden;
  transition: border-color .25s ease, box-shadow .25s ease;
}
details.faq:hover { border-color: rgba(0, 174, 239, .35); }
details.faq[open] { border-color: rgba(0, 174, 239, .5); box-shadow: var(--shadow-md); }

details.faq summary {
  cursor: pointer;
  list-style: none;
  padding: 1.1rem 3.2rem 1.1rem 1.4rem;
  font-weight: 600;
  position: relative;
  color: var(--schwarz);
  transition: color .2s ease;
}
details.faq summary:hover { color: var(--blau-dunkel); }
details.faq summary::-webkit-details-marker { display: none; }
details.faq summary::after {
  content: "+";
  position: absolute;
  right: 1.3rem; top: 50%;
  transform: translateY(-50%);
  width: 28px; height: 28px;
  border-radius: 50%;
  background: var(--hellblau);
  color: var(--blau-dunkel);
  font-weight: 700;
  display: grid;
  place-items: center;
  transition: transform .35s var(--ease-spring), background .25s ease, color .25s ease;
}
details.faq[open] summary::after {
  content: "–";
  background: var(--blau);
  color: #fff;
  transform: translateY(-50%) rotate(180deg);
}
details.faq .faq-body { padding: 0 1.4rem 1.3rem; }
details.faq .faq-body p { margin-bottom: .5rem; font-size: .98rem; }
details.faq[open] .faq-body { animation: faq-rein .4s var(--ease-out) both; }
@keyframes faq-rein {
  from { opacity: 0; transform: translateY(-6px); }
  to   { opacity: 1; transform: none; }
}

/* --------------------------------------------------------------------------
   Kontakt
   -------------------------------------------------------------------------- */
.kontakt-grid {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: clamp(2rem, 5vw, 4rem);
  align-items: start;
}
@media (max-width: 860px) { .kontakt-grid { grid-template-columns: 1fr; } }

.kontakt-info-card {
  background: var(--schwarz);
  color: #d6dee5;
  border-radius: var(--radius);
  padding: 2.2rem 2rem;
}
.kontakt-info-card h3 { color: #fff; }
.kontakt-zeile {
  display: flex;
  gap: 1rem;
  align-items: flex-start;
  padding-block: 1rem;
  border-bottom: 1px solid rgba(255, 255, 255, .09);
  transition: transform .3s var(--ease-out);
}
.kontakt-zeile:hover { transform: translateX(4px); }
.kontakt-zeile:last-of-type { border-bottom: 0; }
.kontakt-zeile .icon {
  flex: 0 0 42px;
  width: 42px; height: 42px;
  border-radius: 10px;
  background: rgba(0, 174, 239, .15);
  color: var(--blau);
  display: grid;
  place-items: center;
  transition: background .3s ease, color .3s ease, transform .35s var(--ease-spring);
}
.kontakt-zeile:hover .icon { background: var(--blau); color: #fff; transform: scale(1.08); }
.kontakt-zeile .icon svg { width: 20px; height: 20px; }
.kontakt-zeile strong { display: block; color: #fff; font-size: .92rem; margin-bottom: .15rem; }
.kontakt-zeile a, .kontakt-zeile span { color: #c2ccd4; font-size: 1rem; }
.kontakt-zeile a:hover { color: var(--blau); }

.form-card {
  background: #fff;
  border: 1px solid var(--rand);
  border-radius: var(--radius);
  padding: 2.2rem 2rem;
  box-shadow: var(--shadow-md);
}
.form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1.1rem; }
@media (max-width: 560px) { .form-grid { grid-template-columns: 1fr; } }
.form-feld { display: flex; flex-direction: column; gap: .35rem; }
.form-feld.full { grid-column: 1 / -1; }
.form-feld label { font-size: .88rem; font-weight: 600; }
.form-feld input, .form-feld select, .form-feld textarea {
  font-family: var(--font);
  font-size: 1rem;
  padding: .8rem 1rem;
  border: 1.5px solid var(--rand);
  border-radius: 10px;
  background: #fbfcfd;
  transition: border-color .25s ease, box-shadow .25s ease, background .25s ease;
}
.form-feld input:hover, .form-feld select:hover, .form-feld textarea:hover { border-color: #c5d3dc; }
.form-feld input:focus, .form-feld select:focus, .form-feld textarea:focus {
  outline: none;
  border-color: var(--blau);
  background: #fff;
  box-shadow: 0 0 0 4px rgba(0, 174, 239, .15);
}
.form-hinweis { font-size: .82rem; color: #8a949d; margin-top: .9rem; }

/* Status-Meldung nach dem Absenden */
.form-status {
  margin-top: 1rem;
  padding: .9rem 1.1rem;
  border-radius: 10px;
  font-size: .95rem;
  font-weight: 500;
  animation: faq-rein .4s var(--ease-out) both;
}
.form-status.ok { background: #e7f7ee; color: #176b3a; border: 1px solid #b5e3c8; }
.form-status.fehler { background: #fdeeee; color: #9b2226; border: 1px solid #f3c2c4; }
.form-status.fehler a { color: #9b2226; font-weight: 700; }

/* --------------------------------------------------------------------------
   Notdienst-Hinweisleiste
   -------------------------------------------------------------------------- */
.notdienst-leiste {
  background: linear-gradient(90deg, var(--blau-dunkel), var(--blau));
  background-size: 180% 100%;
  color: #fff;
  border-radius: var(--radius);
  padding: 1.4rem 1.8rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1.5rem;
  flex-wrap: wrap;
  box-shadow: 0 12px 30px rgba(0, 174, 239, .3);
  animation: gradient-wandern 8s ease-in-out infinite alternate;
}
@keyframes gradient-wandern {
  from { background-position: 0% 50%; }
  to   { background-position: 100% 50%; }
}
.notdienst-leiste strong { font-size: 1.15rem; }
.notdienst-leiste p { color: rgba(255, 255, 255, .85); margin: 0; font-size: .95rem; }

/* --------------------------------------------------------------------------
   Timeline (Ablauf / Prozess) – Linie zeichnet sich beim Scrollen
   -------------------------------------------------------------------------- */
.timeline {
  position: relative;
  max-width: 760px;
  margin-inline: auto;
  padding-left: 2.6rem;
}
.timeline::before {
  content: "";
  position: absolute;
  left: 17px; top: 6px; bottom: 6px;
  width: 2px;
  background: linear-gradient(to bottom, var(--blau), rgba(0, 174, 239, .15));
  transform: scaleY(0);
  transform-origin: top;
  transition: transform 1.4s var(--ease-out) .2s;
}
.timeline.visible::before { transform: scaleY(1); }

.timeline-schritt {
  position: relative;
  padding-bottom: 2.2rem;
  opacity: 0;
  transform: translateY(20px);
  transition: opacity .6s var(--ease-out), transform .6s var(--ease-out);
}
.timeline.visible .timeline-schritt { opacity: 1; transform: none; }
.timeline.visible .timeline-schritt:nth-child(1) { transition-delay: .15s; }
.timeline.visible .timeline-schritt:nth-child(2) { transition-delay: .35s; }
.timeline.visible .timeline-schritt:nth-child(3) { transition-delay: .55s; }
.timeline.visible .timeline-schritt:nth-child(4) { transition-delay: .75s; }
.timeline.visible .timeline-schritt:nth-child(5) { transition-delay: .95s; }
.timeline-schritt:last-child { padding-bottom: 0; }

.timeline-schritt .punkt {
  position: absolute;
  left: -2.6rem; top: 0;
  width: 36px; height: 36px;
  border-radius: 50%;
  background: #fff;
  border: 2px solid var(--blau);
  color: var(--blau-dunkel);
  font-weight: 800;
  font-size: .95rem;
  display: grid;
  place-items: center;
  box-shadow: 0 0 0 5px rgba(0, 174, 239, .12);
  transition: background .3s ease, color .3s ease, transform .35s var(--ease-spring);
}
.timeline-schritt:hover .punkt { background: var(--blau); color: #fff; transform: scale(1.12); }
.timeline-schritt h3 { font-size: 1.1rem; margin-bottom: .35rem; }
.timeline-schritt p { font-size: .98rem; margin: 0; }

/* --------------------------------------------------------------------------
   Spezifikations-Tabelle (z. B. Tresor-Widerstandsgrade)
   -------------------------------------------------------------------------- */
.spec-tabelle-wrap { overflow-x: auto; border-radius: var(--radius); box-shadow: var(--shadow-sm); border: 1px solid var(--rand); }
.spec-tabelle {
  width: 100%;
  border-collapse: collapse;
  background: #fff;
  font-size: .95rem;
  min-width: 560px;
}
.spec-tabelle th, .spec-tabelle td { padding: .95rem 1.2rem; text-align: left; }
.spec-tabelle thead th {
  background: var(--schwarz);
  color: #fff;
  font-size: .82rem;
  text-transform: uppercase;
  letter-spacing: .08em;
  white-space: nowrap;
}
.spec-tabelle tbody tr { border-top: 1px solid var(--rand); transition: background .2s ease; }
.spec-tabelle tbody tr:hover { background: var(--hellblau); }
.spec-tabelle td strong { color: var(--blau-dunkel); }
.spec-tabelle td { color: var(--grau-text); }

/* Chips / Tags */
.chip-reihe { display: flex; flex-wrap: wrap; gap: .6rem; margin: 1.2rem 0; }
.chip {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  background: var(--hellblau);
  color: var(--blau-dunkel);
  border: 1px solid rgba(0, 174, 239, .3);
  font-size: .85rem;
  font-weight: 600;
  padding: .35rem .9rem;
  border-radius: 999px;
  transition: background .25s ease, color .25s ease, transform .25s var(--ease-spring), box-shadow .25s ease;
}
.chip:hover { background: var(--blau); color: #fff; transform: translateY(-2px); box-shadow: var(--glow-blau); }

/* --------------------------------------------------------------------------
   Inhaltsseiten (Recht)
   -------------------------------------------------------------------------- */
.prose { max-width: 820px; }
.prose h2 { font-size: 1.45rem; margin-top: 2.5rem; }
.prose h3 { margin-top: 1.8rem; }

/* --------------------------------------------------------------------------
   Footer
   -------------------------------------------------------------------------- */
.site-footer {
  background: var(--hellblau);
  border-top: 1px solid var(--rand);
  color: var(--grau-text);
  padding-top: clamp(3rem, 6vw, 4.5rem);
  font-size: .95rem;
}
.footer-grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr 1.2fr;
  gap: 2.5rem;
  padding-bottom: 3rem;
}
@media (max-width: 980px) { .footer-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 560px) { .footer-grid { grid-template-columns: 1fr; } }

.footer-logo {
  display: inline-block;
  margin-bottom: 1.2rem;
}
.footer-logo img { height: 52px; width: auto; max-width: none; object-fit: contain; }

.site-footer h4 {
  color: var(--schwarz);
  font-size: .85rem;
  text-transform: uppercase;
  letter-spacing: .12em;
  margin-bottom: 1.1rem;
}
.site-footer ul { list-style: none; padding: 0; margin: 0; display: grid; gap: .55rem; }
.site-footer a { color: var(--grau-text); transition: color .2s ease, padding-left .25s var(--ease-out); }
.site-footer ul a:hover { color: var(--blau-dunkel); text-decoration: none; padding-left: 4px; }

.footer-claim { color: var(--schwarz); font-style: italic; margin-top: .5rem; }
.footer-saeulen { color: var(--blau-dunkel); font-weight: 600; letter-spacing: .04em; font-size: .9rem; }

.social-links { display: flex; gap: .7rem; margin-top: 1rem; }
.social-links a {
  width: 40px; height: 40px;
  border-radius: 10px;
  background: #fff;
  border: 1px solid var(--rand);
  display: grid;
  place-items: center;
  color: var(--grau-text);
  transition: background .25s ease, color .25s ease, transform .3s var(--ease-spring), box-shadow .25s ease;
}
.social-links a:hover {
  background: var(--blau);
  border-color: var(--blau);
  color: #fff;
  transform: translateY(-3px) scale(1.05);
  box-shadow: var(--glow-blau);
  padding-left: 0;
}
.social-links svg { width: 18px; height: 18px; }

.footer-bottom {
  border-top: 1px solid rgba(10, 14, 18, .1);
  padding-block: 1.4rem;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1rem;
  flex-wrap: wrap;
  font-size: .85rem;
}
.footer-bottom nav { display: flex; gap: 1.4rem; }

/* --------------------------------------------------------------------------
   Back-to-Top (per JS eingefügt)
   -------------------------------------------------------------------------- */
.to-top {
  position: fixed;
  right: 1.4rem;
  bottom: 1.4rem;
  width: 48px; height: 48px;
  border-radius: 50%;
  background: var(--schwarz);
  color: #fff;
  border: 0;
  cursor: pointer;
  display: grid;
  place-items: center;
  box-shadow: var(--shadow-lg);
  opacity: 0;
  visibility: hidden;
  transform: translateY(14px);
  transition: opacity .35s ease, transform .35s var(--ease-out), background .25s ease, visibility 0s linear .35s;
  z-index: 90;
}
.to-top.sichtbar {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
  transition: opacity .35s ease, transform .35s var(--ease-out), background .25s ease, visibility 0s;
}
.to-top:hover { background: var(--blau); transform: translateY(-3px); }
.to-top svg { width: 20px; height: 20px; }

/* --------------------------------------------------------------------------
   Gutenberg-Feinschliff (WordPress: Inhalte als native Blöcke)
   -------------------------------------------------------------------------- */
/* WordPress schiebt bei klassischen Themes in jede Gruppe einen
   zusätzlichen Wrapper (__inner-container). display:contents macht ihn
   layout-neutral, damit Grid- und Flex-Raster (Säulen, Karten, Statistiken,
   Split-Layouts) wieder ihre direkten Kinder in Spalten anordnen. */
.wp-block-group__inner-container { display: contents; }

/* Zahlen/Labels der Statistik sind im Block-Editor Absätze */
.stat p { margin: 0; }
/* FAQ als wp:details-Block: Absätze liegen direkt im <details> (ohne .faq-body) */
details.faq > *:not(summary):not(.faq-body) {
  padding: 0 1.4rem;
  margin: 0 0 .5rem;
  font-size: .98rem;
}
details.faq > *:not(summary):not(.faq-body):last-child { padding-bottom: 1.3rem; margin-bottom: 0; }
details.faq[open] > *:not(summary) { animation: faq-rein .4s var(--ease-out) both; }

/* --------------------------------------------------------------------------
   Cookie-Banner (Einwilligung für Google Analytics)
   -------------------------------------------------------------------------- */
.cookie-banner {
  position: fixed;
  left: 1rem; right: 1rem; bottom: 1rem;
  max-width: 560px;
  margin-inline: auto;
  background: var(--schwarz);
  color: #d6dee5;
  border: 1px solid rgba(255, 255, 255, .12);
  border-radius: var(--radius);
  padding: 1.3rem 1.4rem;
  box-shadow: var(--shadow-lg);
  z-index: 200;
  opacity: 0;
  transform: translateY(20px);
  transition: opacity .4s var(--ease-out), transform .4s var(--ease-out);
}
.cookie-banner.sichtbar { opacity: 1; transform: none; }
.cookie-banner p { color: #c2ccd4; font-size: .92rem; margin-bottom: 1rem; }
.cookie-banner a { color: var(--blau); }
.cookie-knoepfe { display: flex; gap: .7rem; flex-wrap: wrap; }
.cookie-knoepfe .btn { padding: .6rem 1.3rem; font-size: .92rem; }
.cookie-knoepfe .btn-ghost { color: #d6dee5; border-color: rgba(255, 255, 255, .3); }
.cookie-knoepfe .btn-ghost:hover { color: var(--blau); border-color: var(--blau); }

/* --------------------------------------------------------------------------
   Scroll-Reveal-System
   .reveal               – Standard: nach oben einblenden
   data-reveal="links"   – von links
   data-reveal="rechts"  – von rechts
   data-reveal="zoom"    – aufzoomen
   --d wird per JS als Stagger-Verzögerung gesetzt
   -------------------------------------------------------------------------- */
.reveal {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity .6s var(--ease-out), transform .6s var(--ease-out);
  transition-delay: var(--d, 0s);
}
.reveal[data-reveal="links"]  { transform: translateX(-36px); }
.reveal[data-reveal="rechts"] { transform: translateX(36px); }
.reveal[data-reveal="zoom"]   { transform: scale(.92); }
.reveal.visible {
  opacity: 1;
  transform: none;
}

/* --------------------------------------------------------------------------
   Reduzierte Bewegung – alles Wesentliche bleibt nutzbar
   -------------------------------------------------------------------------- */
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  @view-transition { navigation: none; }
  *, *::before, *::after {
    animation-duration: .01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: .01ms !important;
  }
  .reveal { opacity: 1; transform: none; }
  .timeline::before { transform: scaleY(1); }
  .timeline-schritt { opacity: 1; transform: none; }
  .hero::before { animation: none; }
  .hero-inner > *, .scroll-hinweis { animation: none; opacity: 1; }
  .hero h1 .accent {
    animation: none;
    background: none;
    -webkit-text-fill-color: currentColor;
    color: var(--blau);
  }
}
