/* =====================================================
   WEBBAUKASTEN VARIANTE 36 – main.css
   Design: Marquise / Luxus – Königsblau + Gold + Creme
   Enthält: Variante36-Basis + alle Vorlagen-Sektionen
   ===================================================== */

/* Schriften lokal (DSGVO-konform) */
@import url("playfair-display.css");
@import url("lato.css");
@import url("font-awesome.css");

/* ===========================================================
   CSS-VARIABLEN
   =========================================================== */
:root {
  --farbe-koenigsblau:       #1b2a5e;
  --farbe-koenigsblau-tief:  #142050;
  --farbe-koenigsblau-hell:  #243678;
  --farbe-gold:              #c8a84b;
  --farbe-gold-hell:         #dfc06e;
  --farbe-gold-dunkel:       #a8882f;
  --farbe-creme:             #f8f4e8;
  --farbe-creme-dunkel:      #ede8d5;
  --farbe-weiss:             #ffffff;
  --farbe-text:              #1a1f3a;
  --farbe-text-hell:         #4a5075;
  --farbe-grau-hell:         #f4f6fb;
  --farbe-grau-mittel:       #dde0eb;
  --farbe-linie:             #dde0eb;
  --farbe-fehler:            #c0392b;
  /* RGB-Kanäle für rgba()-Nutzung — Farbeditor-kompatibel */
  --farbe-koenigsblau-rgb:       27, 42, 94;
  --farbe-koenigsblau-tief-rgb:  20, 32, 80;
  --farbe-gold-rgb:              200, 168, 75;
  --farbe-creme-rgb:             248, 244, 232;
  --farbe-fehler-rgb:            192, 57, 43;

  --schrift-headline: 'Playfair Display', Georgia, 'Times New Roman', serif;
  --schrift-text:     'Lato', system-ui, -apple-system, sans-serif;

  --schatten-sanft:  0 2px 20px rgba(var(--farbe-koenigsblau-rgb), 0.10);
  --schatten-mittel: 0 4px 30px rgba(var(--farbe-koenigsblau-rgb), 0.18);
  --schatten-stark:  0 8px 40px rgba(var(--farbe-koenigsblau-rgb), 0.28);
  --radius-btn:      3px;
  --radius-karte:    6px;
  --transition:      0.3s ease;
  
  
  --farbe-autorenbox-akzent:       #1b2a5e;
  --farbe-autorenbox-hintergrund: #fdfbfb;
}

/* ===========================================================
   BASIS-RESET
   =========================================================== */
*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  scroll-behavior: smooth;
  font-size: 16px;
}

body {
  font-family: var(--schrift-text);
  color: var(--farbe-text);
  background-color: var(--farbe-weiss);
  line-height: 1.7;
  overflow-x: hidden;
  padding-top: 170px; /* Offset für fixierten Header (Topbar 40px + Logo ~94px + Nav ~42px) */
}

a {
  color: inherit;
  text-decoration: none;
  transition: color var(--transition);
}

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

ul { list-style: none; }

/* ===========================================================
   TYPOGRAFIE
   =========================================================== */
h1, h2, h3, h4, h5, h6 {
  font-family: var(--schrift-headline);
  line-height: 1.3;
  color: var(--farbe-koenigsblau);
}

h1 { font-size: clamp(2rem, 4vw, 3.2rem); }
h2 { font-size: clamp(1.6rem, 3vw, 2.4rem); }
h3 { font-size: clamp(1.2rem, 2vw, 1.6rem); }

p {
  font-size: 1rem;
  color: var(--farbe-text-hell);
  margin-bottom: 1rem;
}

p:last-child { margin-bottom: 0; }

strong { color: var(--farbe-koenigsblau); font-weight: 700; }

/* ===========================================================
   BUTTONS
   =========================================================== */
.btn {
  display: inline-block;
  padding: 0.65rem 1.8rem;
  border-radius: var(--radius-btn);
  font-family: var(--schrift-text);
  font-size: 0.88rem;
  font-weight: 700;
  cursor: pointer;
  border: 2px solid transparent;
  transition: all var(--transition);
  text-align: center;
  letter-spacing: 1px;
  text-transform: uppercase;
}

.btn-gold,
.btn-primaer {
  background-color: var(--farbe-gold);
  color: var(--farbe-koenigsblau-tief);
  border-color: var(--farbe-gold);
}

.btn-gold:hover,
.btn-primaer:hover {
  background-color: var(--farbe-gold-dunkel);
  border-color: var(--farbe-gold-dunkel);
  transform: translateY(-2px);
  box-shadow: var(--schatten-sanft);
  color: var(--farbe-weiss);
}

.btn-koenigsblau,
.btn-akzent,
.btn-dunkelblau {
  background-color: var(--farbe-koenigsblau);
  color: var(--farbe-weiss);
  border-color: var(--farbe-koenigsblau);
}

.btn-koenigsblau:hover,
.btn-akzent:hover,
.btn-dunkelblau:hover {
  background-color: var(--farbe-koenigsblau-tief);
  border-color: var(--farbe-koenigsblau-tief);
  transform: translateY(-2px);
  box-shadow: var(--schatten-sanft);
  color: var(--farbe-weiss);
}

.btn-outline-weiss,
.btn-hell {
  background-color: transparent;
  color: var(--farbe-weiss);
  border-color: rgba(255,255,255,0.7);
}

.btn-outline-weiss:hover,
.btn-hell:hover {
  background-color: rgba(255,255,255,0.15);
  border-color: var(--farbe-weiss);
  color: var(--farbe-weiss);
}

.btn[disabled] {
  opacity: 0.65;
  cursor: not-allowed;
  pointer-events: none;
}

/* ===========================================================
   SKIP-LINK
   =========================================================== */
.skip-link {
  position: absolute;
  top: -100px;
  left: 1rem;
  background-color: var(--farbe-koenigsblau);
  color: var(--farbe-weiss);
  padding: 0.7rem 1.2rem;
  border-radius: 0 0 4px 4px;
  z-index: 9999;
  transition: top 0.3s ease;
}

.skip-link:focus { top: 0; }

/* ===========================================================
   MOBILE OVERLAY (für Navigation)
   =========================================================== */
.mobile-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.55);
  z-index: 999;
}

.mobile-overlay.offen { display: block; }

/* ===========================================================
   HEADER – MARQUISE LUXUS (3-stufig)
   Zeile 1: Topbar (Kontaktdaten, dunkelblau)
   Zeile 2: Logo (zentriert, weiss)
   Zeile 3: Navigation (dunkelblau, zentriert)
   =========================================================== */
.site-header {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 1000;
  background-color: var(--farbe-weiss);
  transition: box-shadow var(--transition);
}

.site-header.scrolled {
  box-shadow: 0 4px 30px rgba(var(--farbe-koenigsblau-rgb), 0.2);
}

/* --- Zeile 1: Topbar --- */
.header-topbar {
  background-color: var(--farbe-koenigsblau);
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
}

.header-topbar::after {
  content: '';
  position: absolute;
  bottom: 0; left: 0; right: 0;
  height: 1px;
  background: linear-gradient(to right, transparent 0%, var(--farbe-gold) 20%, var(--farbe-gold) 80%, transparent 100%);
}

.topbar-inner {
  display: flex;
  align-items: center;
  gap: 2.5rem;
  font-size: 0.78rem;
  color: rgba(var(--farbe-creme-rgb), 0.85);
  font-family: var(--schrift-text);
  letter-spacing: 0.3px;
}

.topbar-inner a {
  color: rgba(var(--farbe-creme-rgb), 0.85);
  display: flex;
  align-items: center;
  gap: 0.4rem;
  transition: color var(--transition);
}

.topbar-inner a:hover { color: var(--farbe-gold); }

.topbar-inner span {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  color: rgba(var(--farbe-creme-rgb), 0.85);
}

.topbar-inner i {
  color: var(--farbe-gold);
  font-size: 0.75rem;
}

.topbar-trenner {
  width: 1px;
  height: 14px;
  background-color: rgba(var(--farbe-gold-rgb), 0.35);
  flex-shrink: 0;
}

/* --- Zeile 2: Logo-Bereich --- */
.header-logo-row {
  background-color: var(--farbe-weiss);
  padding: 2.5rem 2rem;
  display: flex;
  align-items: center;
  justify-content: center;
  border-bottom: 1px solid var(--farbe-grau-mittel);
  position: relative;
}

.header-logo-link {
  display: flex;
  align-items: center;
  gap: 1.2rem;
  position: relative;
  text-decoration: none;
}

/* Dekorative goldene Linien links/rechts */
.header-logo-link::before,
.header-logo-link::after {
  content: '';
  position: absolute;
  top: 50%;
  width: 80px;
  height: 1px;
  transform: translateY(-50%);
}

.header-logo-link::before {
  right: calc(100% + 1.5rem);
  background: linear-gradient(to right, transparent, var(--farbe-gold));
}

.header-logo-link::after {
  left: calc(100% + 1.5rem);
  background: linear-gradient(to left, transparent, var(--farbe-gold));
}

.header-logo-link img {
  height: 64px;
  width: auto;
  flex-shrink: 0;
}

.logo-text {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}

.logo-text .praxis-name {
  font-family: var(--schrift-headline);
  font-size: 1.7rem;
  font-weight: 700;
  color: var(--farbe-koenigsblau);
  line-height: 1.15;
  letter-spacing: -0.5px;
}

.logo-text .praxis-subtitle {
  font-family: var(--schrift-text);
  font-size: 0.68rem;
  color: var(--farbe-gold-dunkel);
  letter-spacing: 4px;
  text-transform: uppercase;
  margin-top: 2px;
}

/* --- Zeile 3: Navigation --- */
.header-nav-row {
  background-color: var(--farbe-koenigsblau);
  position: relative;
}

.header-nav-row::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(to right, transparent 0%, var(--farbe-gold) 15%, var(--farbe-gold) 85%, transparent 100%);
}

.header-nav-inner {
  max-width: 1400px;
  margin: 0 auto;
  padding: 0 2rem;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
}

/* Desktop-Nav */
.header-nav-desktop {
  width: 100%;
}

.header-nav-desktop > ul {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0;
  list-style: none;
}

.header-nav-desktop > ul > li {
  position: relative;
}

.header-nav-desktop > ul > li > a {
  display: block;
  padding: 0.8rem 0.85rem;
  font-size: 0.72rem;
  font-weight: 700;
  color: rgba(var(--farbe-creme-rgb), 0.88);
  letter-spacing: 0.8px;
  text-transform: uppercase;
  transition: color var(--transition);
  white-space: nowrap;
  font-family: var(--schrift-text);
}

.header-nav-desktop > ul > li > a:hover,
.header-nav-desktop > ul > li.aktiv > a {
  color: var(--farbe-gold);
}

/* Hover-Unterstrich golden */
.header-nav-desktop > ul > li > a::before {
  content: '';
  position: absolute;
  bottom: 0;
  left: 50%; right: 50%;
  height: 2px;
  background-color: var(--farbe-gold);
  transition: left 0.25s ease, right 0.25s ease;
}

.header-nav-desktop > ul > li:hover > a::before {
  left: 0.5rem;
  right: 0.5rem;
}

/* Dropdown-Indikator */
.header-nav-desktop > ul > li.hat-dropdown > a::after {
  content: ' ▾';
  font-size: 0.65rem;
  opacity: 0.7;
}

/* Termin-Button in Nav */
.btn-termin-header {
  display: inline-block;
  padding: 0.42rem 1.1rem;
  background-color: var(--farbe-gold);
  color: var(--farbe-koenigsblau-tief) !important;
  border-radius: var(--radius-btn);
  font-weight: 700 !important;
  font-size: 0.7rem !important;
  text-transform: uppercase !important;
  letter-spacing: 0.8px !important;
  transition: all var(--transition) !important;
  white-space: nowrap;
  margin-left: 0.5rem;
  border: 2px solid var(--farbe-gold);
}

.btn-termin-header:hover {
  background-color: transparent !important;
  color: var(--farbe-gold) !important;
  border-color: var(--farbe-gold) !important;
  transform: translateY(-1px);
}

/* Dropdown-Menü */
.header-nav-desktop > ul > li .dropdown {
  position: absolute;
  top: 100%;
  left: 50%;
  transform: translateX(-50%) translateY(-8px);
  min-width: 220px;
  background-color: var(--farbe-weiss);
  box-shadow: var(--schatten-stark);
  border-top: 2px solid var(--farbe-gold);
  border-radius: 0 0 var(--radius-karte) var(--radius-karte);
  opacity: 0;
  visibility: hidden;
  transition: all var(--transition);
  z-index: 200;
}

.header-nav-desktop > ul > li:hover .dropdown {
  opacity: 1;
  visibility: visible;
  transform: translateX(-50%) translateY(0);
}

.header-nav-desktop > ul > li .dropdown li {
  border-bottom: 1px solid var(--farbe-grau-mittel);
}

.header-nav-desktop > ul > li .dropdown li:last-child {
  border-bottom: none;
}

.header-nav-desktop > ul > li .dropdown li a {
  display: block;
  padding: 0.6rem 1.2rem;
  font-size: 0.83rem;
  text-transform: none;
  font-weight: 400;
  color: var(--farbe-text);
  letter-spacing: 0;
  transition: all var(--transition);
}

.header-nav-desktop > ul > li .dropdown li a:hover {
  background-color: var(--farbe-creme);
  color: var(--farbe-gold-dunkel);
  padding-left: 1.5rem;
}

/* Burger-Button (Mobile) */
.burger-btn {
  display: none;
  background: none;
  border: none;
  cursor: pointer;
  padding: 0.6rem;
  flex-direction: column;
  gap: 5px;
  z-index: 1100;
  position: absolute;
  right: 1.5rem;
  bottom:11px;
}

.burger-btn span {
  display: block;
  width: 24px;
  height: 2px;
  background-color: var(--farbe-creme);
  transition: all var(--transition);
  border-radius: 1px;
}

.burger-btn.aktiv span:nth-child(1) { transform: rotate(45deg) translate(5px, 5px); }
.burger-btn.aktiv span:nth-child(2) { opacity: 0; }
.burger-btn.aktiv span:nth-child(3) { transform: rotate(-45deg) translate(5px, -5px); }

/* Mobile Nav Overlay */

/* --------------------------------------------------------------------------
   GALERIE-SECTION
   Bento-Grid: 1. Bild groß (2×2), restliche Bilder kleiner rechts/unten
   -------------------------------------------------------------------------- */
.galerie {
  padding: var(--abstand-l, 4rem) 0;
  background: var(--farbe-creme-dunkel,
    var(--farbe-hintergrund-alt,
    var(--farbe-bg-light,
    var(--farbe-beige-dunkel,
    #f0ede8))));
}
.galerie-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  grid-template-rows: auto auto;
  gap: var(--abstand-s, 1rem);
  max-width: var(--max-breite, 1200px);
  margin: 0 auto;
  padding: 0 2rem;
}
.galerie-item {
  overflow: hidden;
  border-radius: var(--radius-l,
    var(--radius-karte,
    var(--radius-lg,
    12px)));
  position: relative;
  background: var(--farbe-dunkel-hell,
    var(--farbe-primaer-dunkel,
    var(--farbe-footer,
    #1a2a3a)));
}
.galerie-item:first-child {
  grid-column: span 2;
  grid-row: span 2;
}
.galerie-bild {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.5s ease;
  min-height: 180px;
}
.galerie-item:first-child .galerie-bild {
  min-height: 380px;
}
.galerie-overlay {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.0);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background var(--transition, 0.3s ease);
}
.galerie-item:hover .galerie-bild {
  transform: scale(1.06);
}
.galerie-item:hover .galerie-overlay {
  background: rgba(0, 0, 0, 0.30);
}
/* Galerie-Header zentriert (scoped — betrifft NUR section-header innerhalb .galerie) */
.galerie .section-header {
  text-align: center;
  margin-left: auto;
  margin-right: auto;
  max-width: 640px;
  padding: 0 2rem;
}
.galerie .section-label {
  justify-content: center;
}
/* section-beschreibung: Unterzeile unter section-titel */
.section-beschreibung {
  font-size: 1rem;
  font-weight: 300;
  color: var(--farbe-text-hell, var(--farbe-muted, #5a6a7a));
  line-height: 1.8;
  margin-top: 0.5rem;
}
@media (max-width: 1024px) {
  .galerie-grid { grid-template-columns: repeat(2, 1fr); }
  .galerie-item:first-child { grid-column: span 2; grid-row: span 1; }
  .galerie-item:first-child .galerie-bild { min-height: 280px; }
}
@media (max-width: 768px) {
  .galerie-grid { grid-template-columns: repeat(2, 1fr); padding: 0 1.25rem; }
  .galerie-item:first-child { grid-column: span 2; }
}
@media (max-width: 480px) {
  .galerie-grid { grid-template-columns: 1fr; padding: 0 1rem; }
  .galerie-item:first-child { grid-column: span 1; }
}
@media (max-width: 900px) {
  .header-nav-desktop.offen {
    display: flex !important;
    flex-direction: column;
    position: fixed;
    top: 0; left: 0;
    width: min(340px, 100vw);
    height: 100vh;
    background: var(--farbe-koenigsblau-tief);
    z-index: 1500;
    overflow-y: auto;
    padding: 3.5rem 1.5rem 2rem;
  }

  .header-nav-desktop.offen > ul {
    flex-direction: column;
    width: 100%;
    padding: 0;
  }

  .header-nav-desktop.offen > ul > li {
    display: block;
    border-bottom: 1px solid rgba(var(--farbe-gold-rgb), 0.15);
  }

  .header-nav-desktop.offen > ul > li > a {
    display: block;
    padding: 0.9rem 0;
    color: var(--farbe-creme);
    font-size: 1.05rem;
  }

  .header-nav-desktop.offen > ul > li .dropdown {
    position: static;
    display: none;
    background: none;
    box-shadow: none;
    opacity: 1;
    visibility: visible;
    transform: none;
    padding: 0 0 0 1rem;
  }

  .header-nav-desktop.offen > ul > li.offen .dropdown {
    display: block;
  }
}

/* ===========================================================
   HERO-SLIDER
   margin-top = topbar 40px + logo-row ~94px + nav-row ~42px
   =========================================================== */
.hero-slider {
  position: relative;
  width: 100%;
  height: 650px;
  max-height: 650px;
  overflow: hidden;
}

.slider-track {
  display: flex;
  width: 300%;
  height: 100%;
  transition: transform 0.9s cubic-bezier(0.77, 0, 0.175, 1);
}

.slide {
  width: calc(100% / 3);
  height: 100%;
  position: relative;
  flex-shrink: 0;
}

.slide img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
}

.slide-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(var(--farbe-koenigsblau-rgb), 0.82) 0%, rgba(var(--farbe-koenigsblau-rgb), 0.5) 45%, rgba(var(--farbe-koenigsblau-rgb), 0.15) 100%);
  display: flex;
  align-items: center;
}

.slide-content {
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 4rem;
  width: 100%;
}

.slide-content::before {
  content: '';
  display: block;
  width: 50px;
  height: 2px;
  background-color: var(--farbe-gold);
  margin-bottom: 1.2rem;
}

.slide-content h1 {
  color: var(--farbe-weiss);
  font-size: clamp(1.8rem, 3.5vw, 3.2rem);
  margin-bottom: 1rem;
  text-shadow: 0 2px 12px rgba(0,0,0,0.25);
  max-width: 580px;
  line-height: 1.2;
}

.slide-content p {
  color: rgba(var(--farbe-creme-rgb), 0.88);
  font-size: 1.05rem;
  margin-bottom: 2.2rem;
  max-width: 480px;
}

.slide-buttons {
  display: flex;
  gap: 1rem;
  flex-wrap: wrap;
}

/* Slider-Steuerung */
.slider-controls {
  position: absolute;
  bottom: 2rem;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  gap: 0.8rem;
  z-index: 10;
}

.slider-dot {
  width: 28px;
  height: 3px;
  border-radius: 2px;
  background-color: rgba(255,255,255,0.35);
  cursor: pointer;
  border: none;
  transition: all var(--transition);
  padding: 0;
}

.slider-dot.aktiv {
  background-color: var(--farbe-gold);
  width: 40px;
}

.slider-pfeil {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  background-color: rgba(var(--farbe-koenigsblau-rgb), 0.4);
  border: 1px solid rgba(var(--farbe-gold-rgb), 0.5);
  color: var(--farbe-weiss);
  width: 46px;
  height: 46px;
  border-radius: 0;
  cursor: pointer;
  font-size: 1rem;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all var(--transition);
  z-index: 10;
}

.slider-pfeil:hover {
  background-color: var(--farbe-gold);
  border-color: var(--farbe-gold);
  color: var(--farbe-koenigsblau);
}

.slider-pfeil-links { left: 2rem; }
.slider-pfeil-rechts { right: 2rem; }

/* ===========================================================
   NAV: has-dropdown (CMS-Standard-Klasse)
   li.has-dropdown > ul = direktes ul als Untermenü
   =========================================================== */
.header-nav-desktop > ul > li.has-dropdown > a::after {
  content: ' ▾';
  font-size: 0.65rem;
  opacity: 0.7;
}

.header-nav-desktop > ul > li.has-dropdown > ul {
  position: absolute;
  top: 100%;
  left: 50%;
  transform: translateX(-50%) translateY(-8px);
  min-width: 220px;
  background-color: var(--farbe-weiss);
  box-shadow: var(--schatten-stark);
  border-top: 2px solid var(--farbe-gold);
  border-radius: 0 0 var(--radius-karte) var(--radius-karte);
  opacity: 0;
  visibility: hidden;
  transition: all var(--transition);
  z-index: 200;
}

.header-nav-desktop > ul > li.has-dropdown:hover > ul {
  opacity: 1;
  visibility: visible;
  transform: translateX(-50%) translateY(0);
}

.header-nav-desktop > ul > li.has-dropdown > ul > li {
  border-bottom: 1px solid var(--farbe-grau-mittel);
}

.header-nav-desktop > ul > li.has-dropdown > ul > li:last-child {
  border-bottom: none;
}

.header-nav-desktop > ul > li.has-dropdown > ul > li > a {
  display: block;
  padding: 0.6rem 1.2rem;
  font-size: 0.83rem;
  text-transform: none;
  font-weight: 400;
  color: var(--farbe-text);
  letter-spacing: 0;
  transition: all var(--transition);
}

.header-nav-desktop > ul > li.has-dropdown > ul > li > a:hover {
  background-color: var(--farbe-creme);
  color: var(--farbe-gold-dunkel);
  padding-left: 1.5rem;
}

/* Mobile: has-dropdown */
@media (max-width: 900px) {
  .header-nav-desktop.offen > ul > li.has-dropdown > ul {
    position: static;
    display: none;
    background: none;
    box-shadow: none;
    opacity: 1;
    visibility: visible;
    transform: none;
    border-top: none;
    padding: 0 0 0 1rem;
  }

  .header-nav-desktop.offen > ul > li.has-dropdown > ul > li > a {
    color: rgba(var(--farbe-creme-rgb), 0.75);
    font-size: 0.9rem;
    padding: 0.5rem 0;
  }

  .header-nav-desktop.offen > ul > li.has-dropdown.offen > ul {
    display: block;
  }
}

/* mobile-only: Übersicht-Links nur im Burger-Menü sichtbar */
.mobile-only { display: none !important; }

@media (max-width: 900px) {
  .header-nav-desktop.offen .mobile-only { display: list-item !important; }
}

/* ===========================================================
   SLIDER (CMS-Standard-Klassen)
   .slider-bereich / .slider-container / .slider-folie
   Gleiche Optik wie .hero-slider, aber andere Klassen
   =========================================================== */
.slider-bereich {
  position: relative;
  width: 100%;
  height: 650px;
  max-height: 600px;
  overflow: hidden;
}

.slider-container {
  position: relative;
  width: 100%;
  height: 100%;
}

.slider-folie {
  display: none;
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
}

.slider-folie.aktiv {
  display: block;
}

.slider-folie > img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
}

/* Dunkler Overlay-Gradient */
.slider-folie::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(var(--farbe-koenigsblau-rgb), 0.82) 0%, rgba(var(--farbe-koenigsblau-rgb), 0.5) 45%, rgba(var(--farbe-koenigsblau-rgb), 0.15) 100%);
  pointer-events: none;
}

.slider-inhalt {
  position: absolute;
  inset: 0;
  z-index: 2;
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: 0 4rem;
  width: 100%;
  max-width: 1280px;
  margin: 0 auto;
  left: 0; right: 0;
}

.slider-inhalt::before {
  content: '';
  display: block;
  width: 50px;
  height: 2px;
  background-color: var(--farbe-gold);
  margin-bottom: 1.2rem;
}

.slider-label {
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--farbe-gold);
  margin-bottom: 0.8rem;
}

.slider-inhalt h1 {
  color: var(--farbe-weiss);
  font-size: clamp(1.8rem, 3.5vw, 3.2rem);
  margin-bottom: 1rem;
  text-shadow: 0 2px 12px rgba(0,0,0,0.25);
  max-width: 580px;
  line-height: 1.2;
}

.slider-inhalt p {
  color: rgba(var(--farbe-creme-rgb), 0.88);
  font-size: 1.05rem;
  margin-bottom: 2.2rem;
  max-width: 480px;
}

.slider-aktionen {
  display: flex;
  gap: 1rem;
  flex-wrap: wrap;
}

.slider-punkte {
  position: absolute;
  bottom: 2rem;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  gap: 0.8rem;
  z-index: 10;
}

.slider-punkt {
  width: 28px;
  height: 3px;
  border-radius: 2px;
  background-color: rgba(255,255,255,0.35);
  cursor: pointer;
  border: none;
  transition: all var(--transition);
  padding: 0;
}

.slider-punkt.aktiv {
  background-color: var(--farbe-gold);
  width: 40px;
}

@media (max-width: 900px) {
  .slider-bereich { height: 340px; }
  .slider-inhalt  { padding: 0 1.5rem; }
  .slider-inhalt h1 { font-size: 1.5rem; }
}

@media (max-width: 480px) {
  .slider-bereich { height: 280px; }
}

/* ===========================================================
   SEITENHEADER (Unterseite ohne Slider)
   =========================================================== */
.seite-header {
  background: linear-gradient(135deg, var(--farbe-koenigsblau-tief) 0%, var(--farbe-koenigsblau) 100%);
  padding: 4.5rem 0 3.5rem;
  position: relative;
  overflow: hidden;
  text-align: center;
}

/* Mit Hintergrundbild: kein Padding – Höhe kommt vom Bild */
.seite-header:has(.header-bg) {
  padding: 0;
}

.seite-header::before {
  content: '';
  position: absolute;
  bottom: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(to right, transparent, var(--farbe-gold) 20%, var(--farbe-gold) 80%, transparent);
  z-index: 12;
}

/* Dunkler Overlay */
.seite-header::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(var(--farbe-koenigsblau-rgb), 0.80) 0%, rgba(var(--farbe-koenigsblau-rgb), 0.55) 100%);
  z-index: 1;
}

/* Hintergrundbild (CMS: <img class="header-bg">)
   Im normalen Fluss – bestimmt die Höhe des Containers */
.seite-header .header-bg {
  display: block;
  width: 100%;
  max-height: 380px;
  object-fit: cover;
  object-position: center center;
}

/* Inhalt absolut über dem Bild zentriert */
.seite-header .container {
  position: absolute;
  inset: 0;
  z-index: 10;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 2rem 1rem;
}

/* Ohne Bild: .seite-header-inner im normalen Fluss */
.seite-header-inner {
  max-width: 800px;
  margin: 0 auto;
  padding: 0 2rem;
  position: relative;
  z-index: 10;
}

.seite-header h1 {
  color: var(--farbe-weiss);
  font-size: clamp(1.8rem, 3.5vw, 3rem);
  margin-bottom: 0.8rem;
}

.seite-header p {
  color: rgba(var(--farbe-creme-rgb), 0.85);
  font-size: 1.05rem;
  max-width: 600px;
  margin: 0 auto;
}

/* ===========================================================
   BREADCRUMB
   =========================================================== */
.breadcrumb {
  background-color: var(--farbe-creme);
  border-bottom: 1px solid var(--farbe-creme-dunkel);
  
  
  padding-top: 3.3rem;
  padding-bottom: 0.3rem;
  
}

.breadcrumb ol {
  display: flex;
  flex-wrap: wrap;
  gap: 0.3rem;
  list-style: none;
  padding: 0;
  margin: 0;
  font-size: 0.82rem;
  color: var(--farbe-text-hell);
  align-items: center;
}

.breadcrumb li + li::before {
  content: '›';
  margin-right: 0.3rem;
  color: var(--farbe-gold);
}

.breadcrumb a {
  color: var(--farbe-koenigsblau);
  transition: color var(--transition);
}

.breadcrumb a:hover { color: var(--farbe-gold-dunkel); }

/* Breadcrumb auf der Startseite (kein Slider-Kontext) ausblenden */
.breadcrumb:empty { display: none; }

/* ===========================================================
   UTILITIES: container, section-header, labels, etc.
   =========================================================== */
.container {
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 2rem;
}

/* Section-Überschriften (Vorlagen-Pattern) */
.section-header {
  text-align: center;
  margin-bottom: 3rem;
}

.section-header h2 {
  font-family: var(--schrift-headline);
  font-size: clamp(1.8rem, 3vw, 2.8rem);
  color: var(--farbe-koenigsblau);
  margin-bottom: 0.8rem;
  line-height: 1.25;
}

.section-header p {
  max-width: 640px;
  margin: 0 auto;
  color: var(--farbe-text-hell);
}

/* Auf dunklem Hintergrund */
.section-header-hell h2 { color: var(--farbe-weiss); }
.section-header-hell p { color: rgba(var(--farbe-creme-rgb), 0.82); }

/* Labels */
.section-label {
  display: inline-block;
  font-size: 0.7rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 4px;
  color: var(--farbe-gold-dunkel);
  margin-bottom: 0.8rem;
}

.section-label-hell {
  color: var(--farbe-gold);
}

/* Goldene Trennlinien */
.section-linie {
  width: 60px;
  height: 2px;
  background: linear-gradient(to right, var(--farbe-gold), var(--farbe-gold-hell));
  margin: 0.8rem auto 1.5rem;
}

.section-linie-links {
  margin-left: 0;
}

.textblock-linie {
  width: 50px;
  height: 2px;
  background: linear-gradient(to right, var(--farbe-gold), var(--farbe-gold-hell));
  margin: 0.8rem 0 1.5rem;
}

/* Goldene Trennlinie (from variante36) */
.trennlinie-gold {
  width: 60px;
  height: 2px;
  background: linear-gradient(to right, var(--farbe-gold), var(--farbe-gold-hell));
  margin: 1.2rem 0;
}

/* ===========================================================
   SCHNELLINFOS-SECTION
   Kontaktdaten auf einen Blick – dunkelblau Hintergrund
   =========================================================== */
.schnellinfos-section {
  background-color: var(--farbe-koenigsblau);
  padding: 1.8rem 0;
  position: relative;
}

.schnellinfos-section::before,
.schnellinfos-section::after {
  content: '';
  position: absolute;
  left: 0; right: 0;
  height: 2px;
  background: linear-gradient(to right, transparent, var(--farbe-gold) 20%, var(--farbe-gold) 80%, transparent);
}

.schnellinfos-section::before { top: 0; }
.schnellinfos-section::after  { bottom: 0; }

.schnellinfos-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1rem;
  align-items: center;
}

.schnellinfo-item {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: 0.5rem 1rem;
  border-right: 1px solid rgba(var(--farbe-gold-rgb), 0.25);
}

.schnellinfo-item:last-child { border-right: none; }

.schnellinfo-icon {
  width: 44px;
  height: 44px;
  background-color: rgba(var(--farbe-gold-rgb), 0.15);
  border: 1px solid rgba(var(--farbe-gold-rgb), 0.3);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.schnellinfo-icon i {
  color: var(--farbe-gold);
  font-size: 1rem;
}

.schnellinfo-text {
  display: flex;
  flex-direction: column;
  gap: 0.15rem;
}

.schnellinfo-text strong {
  font-size: 0.7rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: var(--farbe-gold);
}

.schnellinfo-text a,
.schnellinfo-text span {
  font-size: 0.9rem;
  color: rgba(var(--farbe-creme-rgb), 0.9);
  transition: color var(--transition);
}

.schnellinfo-text a:hover { color: var(--farbe-gold); }

/* ===========================================================
   TEXTBLOCK-SECTION (einspaltig & zweispaltig)
   =========================================================== */
.textblock-section {
  background-color: var(--farbe-weiss);
  padding: 4.5rem 0;
}

/* Automatischer Farbwechsel zwischen aufeinanderfolgenden neutralen Sektionen
   Neutrale Sektionen: textblock, gruppen, float, bildspalten, willkommen, highlight
   Dunkle/Spezial-Sektionen (parallax, schnellinfos, natur-zitat, kontakt-cta, faq, anfahrt)
   behalten immer ihren eigenen Hintergrund und brechen die Kette. */

/* Stufe 1 – direkte Nachfolger → Creme
   Jede :is()-Gruppe hat Spezifität 0-1-0 → längste Kette gewinnt */
:is(.textblock-section,.float-section,.bildspalten-section,.gruppen-section) +
:is(.textblock-section,.float-section,.bildspalten-section,.gruppen-section) {
  background-color: var(--farbe-creme);
}
:is(.textblock-section,.float-section,.bildspalten-section,.gruppen-section) +
:is(.textblock-section,.float-section,.bildspalten-section,.gruppen-section) +
:is(.textblock-section,.float-section,.bildspalten-section,.gruppen-section) {
  background-color: var(--farbe-weiss);
}
:is(.textblock-section,.float-section,.bildspalten-section,.gruppen-section) +
:is(.textblock-section,.float-section,.bildspalten-section,.gruppen-section) +
:is(.textblock-section,.float-section,.bildspalten-section,.gruppen-section) +
:is(.textblock-section,.float-section,.bildspalten-section,.gruppen-section) {
  background-color: var(--farbe-creme);
}
:is(.textblock-section,.float-section,.bildspalten-section,.gruppen-section) +
:is(.textblock-section,.float-section,.bildspalten-section,.gruppen-section) +
:is(.textblock-section,.float-section,.bildspalten-section,.gruppen-section) +
:is(.textblock-section,.float-section,.bildspalten-section,.gruppen-section) +
:is(.textblock-section,.float-section,.bildspalten-section,.gruppen-section) {
  background-color: var(--farbe-weiss);
}
:is(.textblock-section,.float-section,.bildspalten-section,.gruppen-section) +
:is(.textblock-section,.float-section,.bildspalten-section,.gruppen-section) +
:is(.textblock-section,.float-section,.bildspalten-section,.gruppen-section) +
:is(.textblock-section,.float-section,.bildspalten-section,.gruppen-section) +
:is(.textblock-section,.float-section,.bildspalten-section,.gruppen-section) +
:is(.textblock-section,.float-section,.bildspalten-section,.gruppen-section) {
  background-color: var(--farbe-creme);
}
:is(.textblock-section,.float-section,.bildspalten-section,.gruppen-section) +
:is(.textblock-section,.float-section,.bildspalten-section,.gruppen-section) +
:is(.textblock-section,.float-section,.bildspalten-section,.gruppen-section) +
:is(.textblock-section,.float-section,.bildspalten-section,.gruppen-section) +
:is(.textblock-section,.float-section,.bildspalten-section,.gruppen-section) +
:is(.textblock-section,.float-section,.bildspalten-section,.gruppen-section) +
:is(.textblock-section,.float-section,.bildspalten-section,.gruppen-section) {
  background-color: var(--farbe-weiss);
}
:is(.textblock-section,.float-section,.bildspalten-section,.gruppen-section) +
:is(.textblock-section,.float-section,.bildspalten-section,.gruppen-section) +
:is(.textblock-section,.float-section,.bildspalten-section,.gruppen-section) +
:is(.textblock-section,.float-section,.bildspalten-section,.gruppen-section) +
:is(.textblock-section,.float-section,.bildspalten-section,.gruppen-section) +
:is(.textblock-section,.float-section,.bildspalten-section,.gruppen-section) +
:is(.textblock-section,.float-section,.bildspalten-section,.gruppen-section) +
:is(.textblock-section,.float-section,.bildspalten-section,.gruppen-section) {
  background-color: var(--farbe-creme);
}

.textblock-inhalt {
  max-width: 800px;
}

.textblock-inhalt h2 {
  font-size: clamp(1.6rem, 2.5vw, 2.4rem);
  color: var(--farbe-koenigsblau);
  margin-bottom: 0.5rem;
}

.textblock-spalten {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 3rem;
  margin-top: 1.5rem;
}

.textblock-spalte p { margin-bottom: 1rem; }

/* ===========================================================
   FLOAT-SECTION (Bild schwebt, Text umfließt)
   =========================================================== */
.float-section {
  background-color: var(--farbe-weiss);
  padding: 4.5rem 0;
  overflow: hidden;
}

.float-section h2 {
  font-size: clamp(1.6rem, 2.5vw, 2.4rem);
  color: var(--farbe-koenigsblau);
  margin-bottom: 0.5rem;
}

.float-img-links {
  float: left;
  width: 42%;
  margin: 0 2.5rem 1.5rem 0;
  border-radius: var(--radius-karte);
  box-shadow: var(--schatten-mittel);
}

.float-img-rechts {
  float: right;
  width: 42%;
  margin: 0 0 1.5rem 2.5rem;
  border-radius: var(--radius-karte);
  box-shadow: var(--schatten-mittel);
}

.float-section::after {
  content: '';
  display: table;
  clear: both;
}

/* Kontakt-Layout (Online-Termin Vorlage) */
.kontakt-layout {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: 4rem;
  align-items: start;
}

.kontakt-form {
  background-color: var(--farbe-weiss);
  border: 1px solid var(--farbe-grau-mittel);
  border-radius: var(--radius-karte, 12px);
  padding: 2rem;
  box-shadow: 0 2px 16px rgba(0,0,0,0.06);
}

.kontakt-info h2,
.kontakt-form h2 {
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  color: var(--farbe-koenigsblau);
  margin-bottom: 1.5rem;
}

.kontakt-info-item {
  display: flex;
  align-items: flex-start;
  gap: 1rem;
  padding: 1rem 0;
  border-bottom: 1px solid var(--farbe-grau-mittel);
}

.kontakt-info-item:last-child { border-bottom: none; }

.kontakt-info-icon {
  width: 40px;
  height: 40px;
  background-color: var(--farbe-creme);
  border: 1px solid var(--farbe-creme-dunkel);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.kontakt-info-icon i {
  color: var(--farbe-gold-dunkel);
  font-size: 1rem;
}

.kontakt-info-text {
  display: flex;
  flex-direction: column;
  gap: 0.3rem;
}

.kontakt-info-text strong {
  font-size: 0.85rem;
  color: var(--farbe-koenigsblau);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.kontakt-info-text a {
  color: var(--farbe-gold-dunkel);
  font-weight: 600;
  transition: color var(--transition);
}

.kontakt-info-text a:hover { color: var(--farbe-koenigsblau); }

/* Öffnungszeiten-Tabelle */
.oeffnungszeiten-tabelle {
  border-collapse: collapse;
  font-size: 0.88rem;
  color: var(--farbe-text-hell);
}

.oeffnungszeiten-tabelle td {
  padding: 0.25rem 0.8rem 0.25rem 0;
}

.oeffnungszeiten-tabelle td:first-child {
  font-weight: 700;
  color: var(--farbe-koenigsblau);
  min-width: 100px;
}

/* ===========================================================
   BILDSPALTEN-SECTION (2-spaltig, kein Umfluss)
   =========================================================== */
.bildspalten-section {
  background-color: var(--farbe-creme);
  padding: 4.5rem 0;
}

.bildspalten-section + .bildspalten-section {
  background-color: var(--farbe-weiss);
}

.bildspalten-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4rem;
  align-items: center;
}

.bildspalten-grid-reverse {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4rem;
  align-items: center;
}

.bildspalten-grid-reverse .bildspalten-bild { order: 2; }
.bildspalten-grid-reverse .bildspalten-text { order: 1; }

.bildspalten-bild img {
  width: 100%;
  border-radius: var(--radius-karte);
  box-shadow: var(--schatten-mittel);
}

.bildspalten-bild h3 {
  font-size: clamp(1.3rem, 2vw, 1.8rem);
  color: var(--farbe-koenigsblau);
  margin-bottom: 0.5rem;
}

.bildspalten-text h2 {
  font-size: clamp(1.6rem, 2.5vw, 2.4rem);
  color: var(--farbe-koenigsblau);
  margin-bottom: 0.5rem;
}

/* ===========================================================
   GRUPPEN-SECTION (3 oder 6 Boxen mit/ohne Bild)
   =========================================================== */
.gruppen-section {
  background-color: var(--farbe-weiss);
  padding: 5rem 0;
}

.gruppen-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2rem;
  margin-top: 2rem;
}

.gruppe-karte {
  background-color: var(--farbe-weiss);
  border-radius: var(--radius-karte);
  box-shadow: var(--schatten-sanft);
  border: 1px solid var(--farbe-grau-mittel);
  overflow: hidden;
  transition: all var(--transition);
  display: flex;
  flex-direction: column;
}

.gruppe-karte:hover {
  transform: translateY(-6px);
  box-shadow: var(--schatten-mittel);
}

.gruppe-bild {
  position: relative;
  overflow: hidden;
  aspect-ratio: 4/3;
}

.gruppe-bild img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.5s ease;
}

.gruppe-karte:hover .gruppe-bild img {
  transform: scale(1.06);
}

/* Icon-Overlay auf dem Bild */
.gruppe-bild-icon {
  position: absolute;
  bottom: 1rem;
  right: 1rem;
  width: 44px;
  height: 44px;
  background-color: var(--farbe-koenigsblau);
  border: 2px solid var(--farbe-gold);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
}

.gruppe-bild-icon i {
  color: var(--farbe-gold);
  font-size: 1rem;
}

.gruppe-inhalt {
  padding: 1.5rem;
  flex: 1;
  display: flex;
  flex-direction: column;
}

.gruppe-inhalt h3 {
  font-size: 1.05rem;
  color: var(--farbe-koenigsblau);
  margin-bottom: 0.6rem;
}

.gruppe-inhalt p {
  font-size: 0.9rem;
  color: var(--farbe-text-hell);
  flex: 1;
  margin-bottom: 1rem;
}

.gruppe-mehr {
  font-size: 0.82rem;
  font-weight: 700;
  color: var(--farbe-gold-dunkel);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  display: flex;
  align-items: center;
  gap: 0.4rem;
  transition: gap var(--transition);
  margin-top: auto;
}

.gruppe-mehr:hover {
  color: var(--farbe-koenigsblau);
  gap: 0.7rem;
}

/* Karte ohne Bild (noimage) */
.gruppe-karte:not(:has(.gruppe-bild)) .gruppe-inhalt {
  padding: 2rem;
}

.gruppe-karte:not(:has(.gruppe-bild)) {
  position: relative;
  padding-top: 0;
}

.gruppe-karte:not(:has(.gruppe-bild))::before {
  content: '';
  display: block;
  height: 4px;
  background: linear-gradient(to right, var(--farbe-gold), var(--farbe-gold-hell));
}

/* ===========================================================
   WILLKOMMEN-SECTION (Bild links, Text rechts)
   =========================================================== */
.willkommen-section {
  background-color: var(--farbe-creme);
  padding: 5rem 0;
}

/* Grid aus variante36 wird wiederverwendet */
.willkommen-section .willkommen-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 5rem;
  align-items: center;
}

.willkommen-section .willkommen-bild {
  position: relative;
  border-radius: var(--radius-karte);
  overflow: visible;
}

/* Dekorativer Gold-Rahmen hinter dem Bild */
.willkommen-section .willkommen-bild::before {
  content: '';
  position: absolute;
  top: -20px; left: -20px;
  right: 20px; bottom: 20px;
  border: 2px solid var(--farbe-gold);
  border-radius: var(--radius-karte);
  z-index: 0;
  opacity: 0.4;
}

.willkommen-section .willkommen-bild img {
  position: relative;
  z-index: 1;
  width: 100%;
  height: 460px;
  object-fit: cover;
  border-radius: var(--radius-karte);
  box-shadow: var(--schatten-mittel);
}

/* Badge über dem Bild */
.willkommen-badge {
  position: absolute;
  bottom: -1.5rem;
  right: -1.5rem;
  background: linear-gradient(135deg, var(--farbe-koenigsblau), var(--farbe-koenigsblau-hell));
  color: var(--farbe-weiss);
  padding: 1.2rem 1.5rem;
  border-radius: var(--radius-karte);
  text-align: center;
  box-shadow: var(--schatten-mittel);
  font-family: var(--schrift-headline);
  border: 2px solid rgba(var(--farbe-gold-rgb), 0.4);
  z-index: 2;
  line-height: 1.3;
}

.willkommen-badge strong {
  display: block;
  font-size: 1.8rem;
  color: var(--farbe-gold);
}

.willkommen-badge span {
  display: block;
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 2px;
  color: rgba(var(--farbe-creme-rgb), 0.85);
  margin-top: 0.2rem;
}

.willkommen-inhalt {
  /* Inhalt rechts */
}

.willkommen-inhalt h2 {
  font-size: clamp(1.7rem, 3vw, 2.6rem);
  color: var(--farbe-koenigsblau);
  margin-bottom: 0.8rem;
}

.willkommen-stats {
  display: flex;
  gap: 2rem;
  margin: 1.8rem 0 2rem;
  padding: 1.2rem 0;
  border-top: 1px solid var(--farbe-grau-mittel);
  border-bottom: 1px solid var(--farbe-grau-mittel);
}

.stat-item {
  text-align: center;
}

.stat-item strong {
  display: block;
  font-family: var(--schrift-headline);
  font-size: 1.8rem;
  color: var(--farbe-gold-dunkel);
  line-height: 1;
}

.stat-item span {
  font-size: 0.78rem;
  color: var(--farbe-text-hell);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

/* ===========================================================
   HIGHLIGHT-SECTION (Vorteile / USPs – dunkelblau)
   =========================================================== */
.highlight-section {
  background-color: var(--farbe-koenigsblau);
  padding: 5rem 0;
  position: relative;
}

.highlight-section::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(to right, transparent, var(--farbe-gold) 20%, var(--farbe-gold) 80%, transparent);
}

.highlight-section .section-label { color: var(--farbe-gold); }

.highlight-section .section-header h2 { color: var(--farbe-weiss); }
.highlight-section .section-header p   { color: rgba(var(--farbe-creme-rgb), 0.8); }
.highlight-section .section-linie      { margin-left: auto; margin-right: auto; }

.vorteile-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 2rem;
  margin-top: 3rem;
}

.highlight-section .vorteil-item {
  text-align: center;
  padding: 2rem 1.5rem;
  background-color: rgba(255,255,255,0.05);
  border: 1px solid rgba(var(--farbe-gold-rgb), 0.2);
  border-radius: var(--radius-karte);
  transition: all var(--transition);
  display: flex;
  flex-direction: column;
  align-items: center;
}

.highlight-section .vorteil-item:hover {
  background-color: rgba(var(--farbe-gold-rgb), 0.1);
  border-color: rgba(var(--farbe-gold-rgb), 0.45);
  transform: translateY(-4px);
}

.highlight-section .vorteil-icon {
  width: 68px;
  height: 68px;
  background-color: rgba(var(--farbe-gold-rgb), 0.12);
  border: 1px solid rgba(var(--farbe-gold-rgb), 0.3);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 1.2rem;
  transition: background-color var(--transition);
}

.highlight-section .vorteil-item:hover .vorteil-icon {
  background-color: rgba(var(--farbe-gold-rgb), 0.22);
}

.highlight-section .vorteil-icon i {
  color: var(--farbe-gold);
  font-size: 1.5rem;
}

.highlight-section .vorteil-item h4 {
  color: var(--farbe-weiss);
  font-size: 1rem;
  margin-bottom: 0.6rem;
}

.highlight-section .vorteil-item p {
  color: rgba(var(--farbe-creme-rgb), 0.75);
  font-size: 0.88rem;
  text-align: center;
  margin-bottom: 0;
}

/* ===========================================================
   NATUR-ZITAT-SECTION (Zitat / Motto)
   =========================================================== */
.natur-zitat-section {
  background: linear-gradient(135deg, var(--farbe-koenigsblau-tief) 0%, var(--farbe-koenigsblau) 100%);
  padding: 5rem 0;
  position: relative;
  overflow: hidden;
}

.natur-zitat-section::before {
  content: '\201C';
  position: absolute;
  top: -3rem; left: 3rem;
  font-family: var(--schrift-headline);
  font-size: 18rem;
  color: rgba(var(--farbe-gold-rgb), 0.07);
  line-height: 1;
  pointer-events: none;
}

.natur-zitat-section::after {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(to right, transparent, var(--farbe-gold) 20%, var(--farbe-gold) 80%, transparent);
}

.zitat-inhalt {
  max-width: 820px;
  margin: 0 auto;
  text-align: center;
  padding: 0 2rem;
  position: relative;
  z-index: 1;
}

.zitat-anfuehrung {
  display: block;
  font-family: var(--schrift-headline);
  font-size: 5rem;
  color: var(--farbe-gold);
  line-height: 0.7;
  margin-bottom: 1rem;
  opacity: 0.6;
}

.zitat-text {
  font-family: var(--schrift-headline);
  font-size: clamp(1.4rem, 2.5vw, 2.1rem);
  color: var(--farbe-weiss);
  line-height: 1.7;
  font-style: italic;
  margin-bottom: 1.5rem;
}

.zitat-quelle {
  color: var(--farbe-gold);
  font-size: 0.82rem;
  letter-spacing: 3px;
  text-transform: uppercase;
  font-family: var(--schrift-text);
  margin-bottom: 0;
}

/* ===========================================================
   CTA-PARALLAX-SECTION (Vollbild-Hintergrund mit Text+Buttons)
   =========================================================== */
.cta-parallax-section {
  position: relative;
  padding: 7rem 0;
  overflow: hidden;
  background-size: cover;
  background-position: center;
  background-attachment: fixed;
}

.cta-parallax-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(var(--farbe-koenigsblau-tief-rgb), 0.91) 0%, rgba(var(--farbe-koenigsblau-rgb), 0.86) 100%);
  z-index: 0;
}

.cta-parallax-inhalt {
  position: relative;
  z-index: 1;
  text-align: center;
  max-width: 780px;
  margin: 0 auto;
}

.cta-parallax-inhalt h2 {
  color: var(--farbe-weiss);
  font-size: clamp(1.8rem, 3vw, 2.8rem);
  margin-bottom: 1.2rem;
}

.cta-parallax-inhalt p {
  color: rgba(var(--farbe-creme-rgb), 0.85);
  font-size: 1.05rem;
  margin-bottom: 0;
}

.cta-aktionen {
  display: flex;
  gap: 1rem;
  justify-content: center;
  flex-wrap: wrap;
  margin-top: 2.5rem;
}

/* Parallax-Hilfs-Bild (versteckt) */
.parallax-helper-img {
  display: none;
}

/* ===========================================================
   REINE-PARALLAX-SECTION (nur Hintergrundbild, kein Inhalt)
   =========================================================== */
.reine-parallax-section {
  height: 300px;
  background-size: cover;
  background-position: center;
  background-attachment: fixed;
  position: relative;
  overflow: hidden;
}

.reine-parallax-overlay {
  position: absolute;
  inset: 0;
  background: rgba(var(--farbe-koenigsblau-rgb), 0.35);
}

/* ===========================================================
   PRAXIS-SECTION (Kennzahlen / Stats mit Parallax-Hintergrund)
   =========================================================== */
.praxis-section {
  position: relative;
  padding: 6rem 0;
  overflow: hidden;
  background-size: cover;
  background-position: center;
  background-attachment: fixed;
}

.praxis-section::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(var(--farbe-koenigsblau-tief-rgb), 0.93) 0%, rgba(var(--farbe-koenigsblau-rgb), 0.88) 100%);
  z-index: 0;
}

.praxis-inhalt {
  position: relative;
  z-index: 1;
  text-align: center;
}

.praxis-inhalt h2 {
  color: var(--farbe-weiss);
  font-size: clamp(1.8rem, 3vw, 2.8rem);
  margin-bottom: 1rem;
}

.praxis-inhalt > p {
  color: rgba(var(--farbe-creme-rgb), 0.82);
  max-width: 640px;
  margin: 0 auto 2.5rem;
}

.praxis-inhalt .btn-hell {
  margin-bottom: 3.5rem;
}

.praxis-fakten {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 2rem;
  margin-top: 3rem;
}

.praxis-fakt {
  background-color: rgba(255,255,255,0.07);
  border: 1px solid rgba(var(--farbe-gold-rgb), 0.25);
  border-radius: var(--radius-karte);
  padding: 2rem 1rem;
  text-align: center;
  transition: all var(--transition);
}

.praxis-fakt:hover {
  background-color: rgba(var(--farbe-gold-rgb), 0.12);
  border-color: rgba(var(--farbe-gold-rgb), 0.5);
}

.praxis-fakt-zahl {
  font-family: var(--schrift-headline);
  font-size: 2.8rem;
  font-weight: 700;
  color: var(--farbe-gold);
  display: block;
  line-height: 1;
  margin-bottom: 0.5rem;
}

.praxis-fakt-text {
  color: rgba(255,255,255,0.8);
  font-size: 0.85rem;
  line-height: 1.4;
}

/* ===========================================================
   FAQ-SECTION
   =========================================================== */
.faq-section {
  background-color: var(--farbe-creme);
  padding: 5rem 0;
}
/* Farbwechsel-Verlängerung: faq-section kontrastiert immer zur vorherigen Section */
:is(.textblock-section,.float-section,.bildspalten-section,.gruppen-section) + :is(.textblock-section,.float-section,.bildspalten-section,.gruppen-section) + .faq-section { background-color: var(--farbe-weiss); }
:is(.textblock-section,.float-section,.bildspalten-section,.gruppen-section) + :is(.textblock-section,.float-section,.bildspalten-section,.gruppen-section) + :is(.textblock-section,.float-section,.bildspalten-section,.gruppen-section) + .faq-section { background-color: var(--farbe-creme); }
:is(.textblock-section,.float-section,.bildspalten-section,.gruppen-section) + :is(.textblock-section,.float-section,.bildspalten-section,.gruppen-section) + :is(.textblock-section,.float-section,.bildspalten-section,.gruppen-section) + :is(.textblock-section,.float-section,.bildspalten-section,.gruppen-section) + .faq-section { background-color: var(--farbe-weiss); }
:is(.textblock-section,.float-section,.bildspalten-section,.gruppen-section) + :is(.textblock-section,.float-section,.bildspalten-section,.gruppen-section) + :is(.textblock-section,.float-section,.bildspalten-section,.gruppen-section) + :is(.textblock-section,.float-section,.bildspalten-section,.gruppen-section) + :is(.textblock-section,.float-section,.bildspalten-section,.gruppen-section) + .faq-section { background-color: var(--farbe-creme); }
:is(.textblock-section,.float-section,.bildspalten-section,.gruppen-section) + :is(.textblock-section,.float-section,.bildspalten-section,.gruppen-section) + :is(.textblock-section,.float-section,.bildspalten-section,.gruppen-section) + :is(.textblock-section,.float-section,.bildspalten-section,.gruppen-section) + :is(.textblock-section,.float-section,.bildspalten-section,.gruppen-section) + :is(.textblock-section,.float-section,.bildspalten-section,.gruppen-section) + .faq-section { background-color: var(--farbe-weiss); }
:is(.textblock-section,.float-section,.bildspalten-section,.gruppen-section) + :is(.textblock-section,.float-section,.bildspalten-section,.gruppen-section) + :is(.textblock-section,.float-section,.bildspalten-section,.gruppen-section) + :is(.textblock-section,.float-section,.bildspalten-section,.gruppen-section) + :is(.textblock-section,.float-section,.bildspalten-section,.gruppen-section) + :is(.textblock-section,.float-section,.bildspalten-section,.gruppen-section) + :is(.textblock-section,.float-section,.bildspalten-section,.gruppen-section) + .faq-section { background-color: var(--farbe-creme); }
:is(.textblock-section,.float-section,.bildspalten-section,.gruppen-section) + :is(.textblock-section,.float-section,.bildspalten-section,.gruppen-section) + :is(.textblock-section,.float-section,.bildspalten-section,.gruppen-section) + :is(.textblock-section,.float-section,.bildspalten-section,.gruppen-section) + :is(.textblock-section,.float-section,.bildspalten-section,.gruppen-section) + :is(.textblock-section,.float-section,.bildspalten-section,.gruppen-section) + :is(.textblock-section,.float-section,.bildspalten-section,.gruppen-section) + :is(.textblock-section,.float-section,.bildspalten-section,.gruppen-section) + .faq-section { background-color: var(--farbe-weiss); }

.faq-liste {
  margin-top: 2rem;
  display: flex;
  flex-direction: column;
  gap: 0.8rem;
}

.faq-item {
  background-color: var(--farbe-weiss);
  border: 1px solid var(--farbe-grau-mittel);
  border-radius: var(--radius-karte);
  overflow: hidden;
  transition: box-shadow var(--transition);
}

.faq-item:hover {
  box-shadow: var(--schatten-sanft);
}

.faq-frage {
  padding: 1.2rem 1.5rem;
  font-family: var(--schrift-headline);
  font-size: 1rem;
  font-weight: 700;
  color: var(--farbe-koenigsblau);
  cursor: pointer;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1rem;
  user-select: none;
  transition: background-color var(--transition);
}

.faq-frage:hover {
  background-color: var(--farbe-creme);
}

.faq-frage::after {
  content: '+';
  font-size: 1.3rem;
  font-weight: 400;
  color: var(--farbe-gold);
  flex-shrink: 0;
  line-height: 1;
}

.faq-item.offen .faq-frage {
  background-color: var(--farbe-koenigsblau);
  color: var(--farbe-weiss);
}

.faq-item.offen .faq-frage::after {
  content: '−';
  color: var(--farbe-gold);
}

.faq-antwort {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.4s ease, padding 0.35s ease;
  font-size: 0.95rem;
  color: var(--farbe-text-hell);
  padding: 0 1.5rem;
}

.faq-item.offen .faq-antwort {
  max-height: 600px;
  padding: 1.2rem 1.5rem;
  border-top: 1px solid var(--farbe-grau-mittel);
}

/* ===========================================================
   KONTAKT-CTA-SECTION (3 Kontaktpunkte – dunkelblau Streifen)
   =========================================================== */
.kontakt-cta-section {
  background-color: var(--farbe-koenigsblau);
  padding: 3rem 0;
  position: relative;
}

.kontakt-cta-section::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(to right, transparent, var(--farbe-gold) 20%, var(--farbe-gold) 80%, transparent);
}

.kontakt-cta-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1rem;
}

.kontakt-cta-item {
  display: flex;
  align-items: center;
  gap: 1.2rem;
  padding: 1.2rem 2rem;
  border-right: 1px solid rgba(var(--farbe-gold-rgb), 0.2);
  justify-content: center;
}

.kontakt-cta-item:last-child { border-right: none; }

.kontakt-cta-icon {
  width: 52px;
  height: 52px;
  background-color: rgba(var(--farbe-gold-rgb), 0.12);
  border: 1px solid rgba(var(--farbe-gold-rgb), 0.3);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.kontakt-cta-icon i {
  color: var(--farbe-gold);
  font-size: 1.2rem;
}

.kontakt-cta-text {
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
}

.kontakt-cta-text strong {
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: var(--farbe-gold);
  font-weight: 700;
}

.kontakt-cta-text a {
  color: rgba(var(--farbe-creme-rgb), 0.9);
  font-size: 1rem;
  font-weight: 600;
  transition: color var(--transition);
}

.kontakt-cta-text a:hover { color: var(--farbe-gold); }

/* ===========================================================
   ANFAHRT-SECTION (2-spaltig: Info + Karte)
   =========================================================== */
.anfahrt-a {
  background-color: var(--farbe-creme);
  padding: 5rem 0;
}

.anfahrt-a-grid {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: 4rem;
  align-items: start;
}

.anfahrt-a-info {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}

.anfahrt-a-info h2 {
  font-size: clamp(1.6rem, 2.5vw, 2.4rem);
  color: var(--farbe-koenigsblau);
}

.anfahrt-a-linie {
  width: 50px;
  height: 2px;
  background: linear-gradient(to right, var(--farbe-gold), var(--farbe-gold-hell));
  margin: 0.5rem 0;
}

.anfahrt-a-kontakt-liste {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.anfahrt-a-kontakt-liste li {
  display: flex;
  align-items: flex-start;
  gap: 1rem;
  font-size: 0.92rem;
  color: var(--farbe-text-hell);
}

.anfahrt-a-kontakt-liste .ico {
  width: 38px;
  height: 38px;
  background-color: var(--farbe-creme);
  border: 1px solid var(--farbe-creme-dunkel);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.anfahrt-a-kontakt-liste .ico i {
  color: var(--farbe-gold-dunkel);
  font-size: 0.9rem;
}

.anfahrt-a-kontakt-liste a {
  color: var(--farbe-gold-dunkel);
  font-weight: 600;
  transition: color var(--transition);
}

.anfahrt-a-kontakt-liste a:hover { color: var(--farbe-koenigsblau); }

.btn-routenplaner {
  display: inline-flex;
  align-items: center;
  gap: 0.6rem;
  padding: 0.7rem 1.6rem;
  background-color: var(--farbe-koenigsblau);
  color: var(--farbe-weiss);
  border-radius: var(--radius-btn);
  font-size: 0.85rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.8px;
  border: 2px solid var(--farbe-koenigsblau);
  transition: all var(--transition);
}

.btn-routenplaner:hover {
  background-color: transparent;
  color: var(--farbe-koenigsblau);
}

/* Leaflet-Karte */
#map-zzam {
  width: 100%;
  height: 420px;
  border-radius: var(--radius-karte);
  box-shadow: var(--schatten-mittel);
  background-color: var(--farbe-grau-hell);
}

/* ===========================================================
   FORMULAR-STYLES
   =========================================================== */
.form-gruppe {
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
  margin-bottom: 1.2rem;
}

.form-gruppe label {
  font-size: 0.85rem;
  font-weight: 700;
  color: var(--farbe-koenigsblau);
  letter-spacing: 0.3px;
}

.form-gruppe input,
.form-gruppe select,
.form-gruppe textarea {
  padding: 0.65rem 1rem;
  border: 1px solid var(--farbe-grau-mittel);
  border-radius: var(--radius-btn);
  font-family: var(--schrift-text);
  font-size: 0.92rem;
  color: var(--farbe-text);
  background-color: var(--farbe-weiss);
  transition: border-color var(--transition);
  width: 100%;
}

.form-gruppe input:focus,
.form-gruppe select:focus,
.form-gruppe textarea:focus {
  outline: none;
  border-color: var(--farbe-gold);
  box-shadow: 0 0 0 3px rgba(var(--farbe-gold-rgb), 0.15);
}

.form-gruppe textarea {
  min-height: 130px;
  resize: vertical;
}

.form-datenschutz {
  display: flex;
  align-items: flex-start;
  gap: 0.7rem;
  margin-bottom: 1.5rem;
}

.form-datenschutz input[type="checkbox"] {
  width: 18px;
  height: 18px;
  flex-shrink: 0;
  margin-top: 2px;
  accent-color: var(--farbe-gold-dunkel);
}

.form-datenschutz label {
  font-size: 0.84rem;
  color: var(--farbe-text-hell);
  line-height: 1.5;
}

.form-datenschutz a {
  color: var(--farbe-gold-dunkel);
  text-decoration: underline;
}

/* Form-Feedback */
.form-feld-fehler {
  border-color: var(--farbe-fehler) !important;
  background-color: rgba(var(--farbe-fehler-rgb), 0.04) !important;
}

.form-feld-fehler-text {
  font-size: 0.8rem;
  color: var(--farbe-fehler);
  margin-top: 0.25rem;
}

.form-meldung {
  padding: 1rem 1.5rem;
  border-radius: var(--radius-btn);
  font-size: 0.92rem;
  font-weight: 600;
  margin-bottom: 1.2rem;
}

.form-meldung--erfolg {
  background-color: rgba(var(--farbe-gold-rgb), 0.12);
  border: 1px solid var(--farbe-gold);
  color: var(--farbe-gold-dunkel);
}

.form-meldung--fehler {
  background-color: rgba(var(--farbe-fehler-rgb), 0.08);
  border: 1px solid var(--farbe-fehler);
  color: var(--farbe-fehler);
}

/* ===========================================================
   FOOTER
   =========================================================== */
.site-footer {
  background-color: var(--farbe-koenigsblau-tief);
  color: rgba(var(--farbe-creme-rgb), 0.82);
  padding: 4rem 0 0;
}

.footer-grid {
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 2rem 3rem;
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 2fr;
  gap: 3rem;
}

.footer-col h4 {
  font-family: var(--schrift-headline);
  color: var(--farbe-gold);
  font-size: 1rem;
  margin-bottom: 1.2rem;
  padding-bottom: 0.6rem;
  border-bottom: 1px solid rgba(var(--farbe-gold-rgb), 0.25);
}

.footer-col p {
  color: rgba(var(--farbe-creme-rgb), 0.72);
  font-size: 0.9rem;
  line-height: 1.8;
}

.footer-col a {
  display: block;
  color: rgba(var(--farbe-creme-rgb), 0.72);
  font-size: 0.88rem;
  padding: 0.3rem 0;
  transition: all var(--transition);
}

.footer-col a:hover {
  color: var(--farbe-gold);
  padding-left: 0.5rem;
}

.footer-col ul { list-style: none; }

.footer-logo-text {
  font-family: var(--schrift-headline);
  font-size: 1.3rem;
  color: var(--farbe-weiss);
  margin-bottom: 0.5rem;
}

.footer-kontakt-item {
  display: flex;
  align-items: center;
  gap: 0.8rem;
  padding: 0.4rem 0;
  color: rgba(var(--farbe-creme-rgb), 0.72);
  font-size: 0.88rem;
}

.footer-kontakt-item i {
  color: var(--farbe-gold);
  width: 16px;
  flex-shrink: 0;
}

.footer-kontakt-item a {
  color: rgba(var(--farbe-creme-rgb), 0.72);
  transition: color var(--transition);
  display: inline;
  padding: 0;
}

.footer-kontakt-item a:hover {
  color: var(--farbe-gold);
  padding-left: 0;
}

.footer-social {
  display: flex;
  gap: 0.8rem;
  margin-top: 1rem;
}

.footer-social a {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  background-color: rgba(var(--farbe-gold-rgb), 0.12);
  border: 1px solid rgba(var(--farbe-gold-rgb), 0.25);
  border-radius: 50%;
  color: rgba(var(--farbe-creme-rgb), 0.7);
  font-size: 0.9rem;
  transition: all var(--transition);
  padding: 0;
}

.footer-social a:hover {
  background-color: var(--farbe-gold);
  border-color: var(--farbe-gold);
  color: var(--farbe-koenigsblau-tief);
  padding-left: 0;
}

.footer-bottom {
  background-color: rgba(0,0,0,0.3);
  padding: 1.2rem 2rem;
}

.footer-bottom-inner {
  max-width: 1280px;
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 0.5rem;
  font-size: 0.8rem;
  color: rgba(var(--farbe-creme-rgb), 0.55);
}

.footer-bottom-inner a {
  color: rgba(var(--farbe-creme-rgb), 0.55);
  transition: color var(--transition);
  display: inline;
  padding: 0;
}

.footer-bottom-inner a:hover {
  color: var(--farbe-gold);
  padding-left: 0;
}

/* Öffnungszeiten-Tabelle im Footer */
.site-footer .oeffnungszeiten-tabelle td {
  color: rgba(var(--farbe-creme-rgb), 0.72);
}

.site-footer .oeffnungszeiten-tabelle td:first-child {
  color: var(--farbe-gold);
}

/* ===========================================================
   SCROLL-TO-TOP
   =========================================================== */
.scroll-top {
  position: fixed;
  bottom: 2rem;
  right: 2rem;
  width: 44px;
  height: 44px;
  background-color: var(--farbe-koenigsblau);
  color: var(--farbe-weiss);
  border: 2px solid rgba(var(--farbe-gold-rgb), 0.4);
  border-radius: 0;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1rem;
  box-shadow: var(--schatten-mittel);
  opacity: 0;
  visibility: hidden;
  transition: all var(--transition);
  z-index: 500;
}

.scroll-top.sichtbar {
  opacity: 1;
  visibility: visible;
}

.scroll-top:hover {
  background-color: var(--farbe-gold);
  border-color: var(--farbe-gold);
  color: var(--farbe-koenigsblau);
  transform: translateY(-4px);
}

/* ===========================================================
   BARRIEREFREIHEIT / FOKUS
   =========================================================== */
:focus-visible {
  outline: 3px solid var(--farbe-gold);
  outline-offset: 3px;
}

button:focus-visible,
a:focus-visible {
  outline: 3px solid var(--farbe-gold);
  outline-offset: 3px;
  border-radius: 2px;
}

/* ===========================================================
   ANIMATIONEN
   =========================================================== */
.scroll-animate {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 0.7s ease, transform 0.7s ease;
}

.scroll-animate.sichtbar {
  opacity: 1;
  transform: translateY(0);
}

/* ===========================================================
   LEISTUNGEN-GRID (Design2 Boxen – Bild oben, Text unten)
   =========================================================== */
.leistungen-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2rem;
  margin-top: 2rem;
}

.leistung-bild-karte {
  background-color: var(--farbe-weiss);
  border-radius: var(--radius-karte);
  box-shadow: var(--schatten-sanft);
  border: 1px solid var(--farbe-grau-mittel);
  overflow: hidden;
  transition: all var(--transition);
}

.leistung-bild-karte:hover {
  transform: translateY(-5px);
  box-shadow: var(--schatten-mittel);
}

.leistung-bild {
  overflow: hidden;
  aspect-ratio: 16/9;
}

.leistung-bild img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.5s ease;
}

.leistung-bild-karte:hover .leistung-bild img {
  transform: scale(1.06);
}

.leistung-bild-karte-inhalt {
  padding: 1.5rem;
  border-top: 3px solid var(--farbe-gold);
}

.leistung-bild-karte-inhalt h3 {
  font-size: 1.05rem;
  color: var(--farbe-koenigsblau);
  margin-bottom: 0.6rem;
}

.leistung-bild-karte-inhalt p {
  font-size: 0.9rem;
  color: var(--farbe-text-hell);
  margin-bottom: 0;
}

/* Zwei Bilder rechts schwimmend (vorlage_zweibildrechts) */
.img-group-right {
  float: right;
  display: flex;
  flex-direction: column;
  gap: 1rem;
  width: 38%;
  margin: 0 0 1.5rem 2rem;
}

.img-group-right img {
  width: 100%;
  border-radius: var(--radius-karte);
  box-shadow: var(--schatten-sanft);
}

/* ===========================================================
   RESPONSIVE – Tablet bis 1200px
   =========================================================== */
@media (max-width: 1200px) {
  .header-nav-desktop > ul > li > a {
    padding: 0.8rem 0.65rem;
    font-size: 0.68rem;
  }

  .gruppen-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .vorteile-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .praxis-fakten {
    grid-template-columns: repeat(2, 1fr);
  }

  .schnellinfos-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .schnellinfo-item:nth-child(2) { border-right: none; }

  .footer-grid {
    grid-template-columns: 1fr 1fr;
    gap: 2rem;
  }
}

/* ===========================================================
   RESPONSIVE – Tablet bis 960px
   =========================================================== */
@media (max-width: 960px) {
  .willkommen-section .willkommen-grid,
  .bildspalten-grid,
  .bildspalten-grid-reverse,
  .anfahrt-a-grid,
  .kontakt-layout {
    grid-template-columns: 1fr;
    gap: 2.5rem;
  }

  .bildspalten-grid-reverse .bildspalten-bild,
  .bildspalten-grid-reverse .bildspalten-text {
    order: unset;
  }

  .kontakt-cta-grid {
    grid-template-columns: 1fr;
    gap: 0;
  }

  .kontakt-cta-item {
    border-right: none;
    border-bottom: 1px solid rgba(var(--farbe-gold-rgb), 0.2);
    justify-content: flex-start;
  }

  .kontakt-cta-item:last-child { border-bottom: none; }

  .willkommen-badge {
    right: 1rem;
    bottom: 1rem;
  }
}

/* ===========================================================
   RESPONSIVE – Mobile bis 768px
   =========================================================== */
@media (max-width: 768px) {
  .team-kacheln-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 1.2rem;
  }

  /* Topbar ausblenden */
  .header-topbar { display: none; }

  /* Logo-Zeile: links + Burger rechts */
  .header-logo-row {
    padding: 0.7rem 1.2rem;
    justify-content: space-between;
  }

  .header-logo-link::before,
  .header-logo-link::after { display: none; }

  .header-logo-link img { height: 48px; }

  .logo-text .praxis-name { font-size: 1.3rem; }

  .header-nav-inner {
    justify-content: flex-end;
    padding: 0.4rem 1.2rem;
    min-height: 44px;
	 display: block;
  }
  
  
  .breadcrumb {

  padding-top: 0rem;
  margin-top: -6px;
  
  
}
  


  .header-nav-desktop { display: none; }

  .burger-btn { display: flex; }

  /* Header-Offset für Mobilgeräte (Topbar fällt weg) */
  body { padding-top: 124px; }

  /* Slider kleiner */
  .hero-slider {
    height: 420px;
  }

  .slide-content { padding: 0 1.5rem; }
  .slide-content h1 { font-size: 1.6rem; }
  .slide-content p  { font-size: 0.92rem; }
  .slider-pfeil { display: none; }

  /* Sections */
  .textblock-section,
  .float-section,
  .bildspalten-section,
  .willkommen-section,
  .highlight-section,
  .natur-zitat-section,
  .gruppen-section,
  .faq-section,
  .praxis-section,
  .anfahrt-a,
  .kontakt-cta-section {
    padding: 3.5rem 0;
  }

  .float-img-links,
  .float-img-rechts {
    float: none;
    width: 100%;
    margin: 0 0 1.5rem;
  }

  .gruppen-grid {
    grid-template-columns: 1fr;
  }

  .vorteile-grid {
    grid-template-columns: 1fr 1fr;
  }

  .textblock-spalten {
    grid-template-columns: 1fr;
    gap: 1.5rem;
  }

  .willkommen-section .willkommen-grid {
    grid-template-columns: 1fr;
    gap: 3rem;
  }

  .willkommen-stats {
    flex-wrap: wrap;
    gap: 1rem;
  }

  .praxis-fakten {
    grid-template-columns: 1fr 1fr;
    gap: 1rem;
  }

  .schnellinfos-grid {
    grid-template-columns: 1fr;
    gap: 0;
  }

  .schnellinfo-item {
    border-right: none;
    border-bottom: 1px solid rgba(var(--farbe-gold-rgb), 0.2);
    padding: 0.8rem 0;
  }

  .schnellinfo-item:last-child { border-bottom: none; }

  .footer-grid {
    grid-template-columns: 1fr;
    gap: 2rem;
  }

  .footer-bottom-inner {
    flex-direction: column;
    text-align: center;
  }

  .cta-aktionen {
    flex-direction: column;
    align-items: center;
  }

  .reine-parallax-section { height: 180px; }

  #map-zzam { height: 280px; }

  .slide-buttons { flex-direction: column; align-items: flex-start; }
}

/* ===========================================================
   RESPONSIVE – sehr klein bis 480px
   =========================================================== */

/* ==========================================================================
   TEAM / BEHANDLER
   ========================================================================== */
.team-section { padding: 5rem 0; }
.team-section:nth-of-type(even) { background: var(--farbe-creme); }
.team-grid { display: flex; flex-direction: column; gap: 2.5rem; }
.team-foto-karte { display: flex; flex-direction: row; align-items: flex-start; gap: 2.5rem; margin-bottom: 2.5rem; }
.team-foto-karte:last-child { margin-bottom: 0; }
.team-foto-karte .team-bild { flex-shrink: 0; width: 240px; height: 280px; border-radius: var(--radius-karte); overflow: hidden; box-shadow: var(--schatten-sanft); outline: 2px solid var(--farbe-koenigsblau); outline-offset: 3px; }
.team-foto-karte .team-bild img { width: 100%; height: 100%; object-fit: cover; object-position: center top; transition: transform 0.4s ease; display: block; }
.team-foto-karte:hover .team-bild img { transform: scale(1.05); }
.team-foto-karte .team-info { flex: 1; background: var(--farbe-weiss); border-radius: var(--radius-karte); box-shadow: var(--schatten-sanft); border: 1px solid var(--farbe-linie); padding: 2rem 2.5rem; }
.team-foto-karte .team-name { font-size: 1.3rem; font-weight: 700; color: var(--farbe-koenigsblau-tief); margin-bottom: 0.3rem; }
.team-foto-karte .team-titel { font-size: 0.82rem; color: var(--farbe-gold); font-weight: 700; letter-spacing: 0.06em; text-transform: uppercase; margin-bottom: 1rem; display: block; }
.team-vita { font-size: 0.88rem; color: var(--farbe-text-hell); line-height: 1.7; }
.team-vita ul { list-style: none; margin-top: 0.8rem; }
.team-vita ul li { position: relative; padding-left: 1rem; margin-bottom: 0.35rem; }
.team-vita ul li::before { content: '›'; position: absolute; left: 0; color: var(--farbe-gold); }
.team-bild { height: 260px; overflow: hidden; flex-shrink: 0; }
.team-bild img { width: 100%; height: 100%; object-fit: cover; object-position: center top; transition: transform 0.5s ease; }
.team-karte { background: var(--farbe-weiss); border: 1px solid var(--farbe-linie); border-radius: var(--radius-karte); overflow: hidden; box-shadow: var(--schatten-sanft); transition: box-shadow var(--transition); }
.team-karte:hover { box-shadow: var(--schatten-mittel); }
.team-info { padding: 1.5rem; }
.team-name { font-family: var(--schrift-headline); font-size: 1.05rem; color: var(--farbe-koenigsblau); margin-bottom: 0.2rem; font-weight: 600; }
.team-titel { font-size: 0.82rem; color: var(--farbe-gold-dunkel); margin-bottom: 0.8rem; }
.team-rolle { background: var(--farbe-koenigsblau); color: var(--farbe-weiss); font-size: 0.7rem; font-weight: 700; letter-spacing: 0.15em; text-transform: uppercase; padding: 0.4rem 1.2rem; }
@media (max-width: 768px) {
  .team-foto-karte { flex-direction: column; }
  .team-foto-karte .team-bild { width: 100%; height: auto; }
  .team-foto-karte .team-bild img { height: auto; min-height: unset; }
}

/* --------------------------------------------------------------------------
   TEAM-KACHELN — Karten-Grid für team.html
   Max. 4 Spalten, auto-wrap, optimiert für 1:1 und 4:5 Portraits
   -------------------------------------------------------------------------- */
.team-kacheln-section {
  padding: var(--abstand-l, 5rem) 0;
}

.team-kacheln-section:nth-of-type(even) {
  background: var(--farbe-hintergrund-alt);
}

.team-kacheln-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1.75rem;
}

.team-kachel {
  background: var(--farbe-weiss);
  border-radius: 14px;
  overflow: hidden;
  box-shadow: 0 2px 14px rgba(0, 0, 0, 0.07);
  transition: transform 0.28s ease, box-shadow 0.28s ease;
  display: flex;
  flex-direction: column;
}

.team-kachel:hover {
  transform: translateY(-6px);
  box-shadow: 0 10px 36px rgba(var(--farbe-koenigsblau-rgb), 0.16);
}

/* Optimiert für quadratische (1:1) und Hochformat-Fotos (4:5) */
.team-kachel-bild {
  position: relative;
  aspect-ratio: 1 / 1;
  overflow: hidden;
  background: var(--farbe-hintergrund-alt);
}

.team-kachel-bild img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 20%;
  display: block;
  transition: transform 0.45s ease;
}

.team-kachel:hover .team-kachel-bild img {
  transform: scale(1.06);
}

.team-kachel-bild-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to bottom, transparent 55%, rgba(var(--farbe-koenigsblau-rgb), 0.35) 100%);
  pointer-events: none;
}

.team-kachel-info {
  padding: 1.25rem 1.2rem 1.5rem;
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
}

.team-kachel-abteilung {
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--farbe-primaer);
  margin: 0;
}

.team-kachel-name {
  font-family: var(--font-serif, var(--schrift-headline, Georgia, serif));
  font-size: 1.08rem;
  color: var(--farbe-primaer-dunkel);
  margin: 0.1rem 0 0;
  line-height: 1.3;
}

.team-kachel-rolle {
  font-size: 0.82rem;
  color: var(--farbe-text-hell);
  margin: 0;
}

.team-kachel-beschreibung {
  font-size: 0.82rem;
  color: var(--farbe-text-hell);
  line-height: 1.55;
  margin: 0.6rem 0 0;
  padding-top: 0.6rem;
  border-top: 1px solid var(--farbe-linie);
}

@media (max-width: 1100px) {
  .team-kacheln-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

@media (max-width: 480px) {
  .team-kacheln-grid {
    grid-template-columns: 1fr;
  }

  .hero-slider { height: 340px; }

  .vorteile-grid {
    grid-template-columns: 1fr;
  }

  .praxis-fakten {
    grid-template-columns: 1fr;
  }

  .kontakt-cta-grid {
    grid-template-columns: 1fr;
  }
  
  	/* Zwei Bilder rechts schwimmend (vorlage_zweibildrechts) */
.img-group-right {
  float: left;
  display: flex;
  flex-direction: row;
  
 
  
}


}

@media (max-width: 400px) {

	
	
	
	.seite-header .container h1 {
			font-size: clamp(1.4rem, 2vw, 1.8rem) !important; 
			 
			 line-height: 100%;
	}
	
	.seite-header .container p {
			line-height: 100% !important; ;
			font-size: 0.9rem !important; ;
	}
	
	
	.slider-inhalt h1 {
		line-height: 100% !important; ;
			font-size: 1.4rem !important; ;
	}
	
	.slider-inhalt p {
		line-height: 100% !important; ;
			font-size: 0.9rem !important; ;
			margin-bottom: 0.5rem !important; ;
	}
	
	.slider-aktionen {
		gap: 0.5 rem !important; ;
	}
	.slider-aktionen  .btn {
		padding: 0.3rem 0.5rem !important; ;
	}
	
	



}

@media (max-width: 357px) {

  .breadcrumb {

	padding-top: 0rem;
	margin-top: 15px;
	}
	
	

}


.only_display_desktop {
	display: inline;
}
.only_display_mobile {
	display:none;
}

@media (max-width: 768px) {
	
	.only_display_desktop {
	     display:none;
    }
	.only_display_mobile {
	   display: inline;
	}
}