:root {

  /* —— AquaFit Corporate Identity —— */

  --aqua-green: #79a202;

  --aqua-green-rgb: 121, 162, 2;

  --aqua-blue: #0062b8;

  --aqua-blue-rgb: 0, 98, 184;

  --aqua-green-soft: #d0e1ad;

  --aqua-green-soft-rgb: 208, 225, 173;

  --aqua-blue-soft: #b3cfe7;

  --aqua-blue-soft-rgb: 179, 207, 231;

  --aqua-blue-mid: #659dd0;

  --aqua-blue-mid-rgb: 101, 157, 208;



  /* Theme: Primär = Grün (Buttons, Flächen, Swiper), Sekundär = Blau (Markierung, Akzente) */

  --primary-color: #79a202;

  --primary-color-rgb: 121, 162, 2;

  --secondary-color: #0062b8;

  --secondary-color-rgb: 0, 98, 184;



  /* Button-Hover: einheitliches AquaFit-Blau (CI-Sekundärfarbe) */

  --btn-hover-bg: var(--secondary-color);



  /* Verlauf: überwiegend weiches Grün, leichter Blau-Auszug */

  --bg-gradient-1: 125deg, rgba(var(--aqua-green-soft-rgb), 0.55) 0%, rgba(var(--aqua-blue-soft-rgb), 0.4) 100%;

  /* Querformat-Logo AquaFit im Header */
  --logo-width: 220px;

}



/* Markierung / Untertitel / Akzenttext: Blau (überschreibt .id-color aus style.css) */

.id-color {

  color: var(--secondary-color);

}



/* Sterne: gleiche Markierfarbe wie Untertitel */

.d-stars.id-color,

span.d-stars.id-color {

  color: var(--secondary-color);

}

.d-stars.id-color i {

  color: inherit;

}

/* —— Startseite: Header über Hero-Video (transparent, Nav/Logo weiß); nach Scroll heller Balken —— */

body.aquafit-home .aquafit-hero {
  margin-top: 0 !important;
  border-radius: 0 0 48px 48px !important;
  -webkit-border-radius: 0 0 48px 48px !important;
  -moz-border-radius: 0 0 48px 48px !important;
}

/* Hero-Text leicht nach unten, damit nicht unter dem Header liegt */
body.aquafit-home .aquafit-hero .abs.abs-centered {
  padding-top: clamp(56px, 10vh, 120px);
  box-sizing: border-box;
}

/* Hero: Titel etwas kleiner, Subclaim, Logo darunter */
body.aquafit-home .aquafit-hero__title {
  font-size: clamp(40px, 7vw, 84px);
  letter-spacing: 0.02em;
}

body.aquafit-home .aquafit-hero__subclaim {
  font-family: var(--heading-font, inherit);
  font-size: clamp(16px, 1.6vw, 22px);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  opacity: 0.92;
  margin-bottom: 1.5rem;
}

body.aquafit-home .aquafit-hero__logo {
  display: block;
  margin: 0 auto 1.5rem;
  width: clamp(60px, 6.75vw, 90px);
  height: auto;
  filter: brightness(0) invert(1);
}

body.aquafit-home header.header-light.transparent:not(.smaller):not(.header-mobile) {
  background: transparent !important;
  box-shadow: none !important;
  padding-top: 20px;
  padding-bottom: 20px;
}

body.aquafit-home header.header-light.transparent:not(.smaller):not(.header-mobile) #mainmenu > li > a,
body.aquafit-home header.header-light.transparent:not(.smaller):not(.header-mobile) #mainmenu li.has-child:after {
  color: #fff !important;
}

body.aquafit-home header.header-light.transparent:not(.smaller):not(.header-mobile) #mainmenu a:hover,
body.aquafit-home header.header-light.transparent:not(.smaller):not(.header-mobile) nav a:hover {
  color: rgba(255, 255, 255, 0.88) !important;
}

/* Startseite: schlanke Sprungmarken-Navigation */
body.aquafit-home #mainmenu.mainmenu--anchors > li {
  margin-right: 1.1rem;
}

body.aquafit-home #mainmenu.mainmenu--anchors > li:last-child {
  margin-right: 0;
}

body.aquafit-home #mainmenu.mainmenu--anchors > li > a.menu-item {
  padding-top: 14px;
  padding-bottom: 14px;
  text-transform: none;
  letter-spacing: 0.02em;
  font-weight: 500;
}

#preise,
#oeffnungszeiten,
#gastro,
#veranstaltungen,
#preise-oeffnungszeiten {
  scroll-margin-top: 6rem;
}

body.aquafit-home header.header-light.transparent:not(.smaller):not(.header-mobile) #logo img {
  filter: brightness(0) invert(1);
}

body.aquafit-home header.header-light.transparent:not(.smaller):not(.header-mobile) #menu-btn {
  color: #fff !important;
}

body.aquafit-home header.header-light.smaller,
body.aquafit-home header.header-light.header-mobile {
  padding-top: 16px;
  padding-bottom: 16px;
}

body.aquafit-home header.smaller #logo img,
body.aquafit-home header.header-mobile #logo img {
  filter: none;
}

/* Sticky-Header beim Runterscrollen sauber ausblenden.
   Das Template nutzt .scroll-down { margin-top: -90px }, was bei
   unserem Querformat-Logo (Header ca. 140px) zu klein ist – der untere
   Logorand bliebe oben am Bildschirm kleben. Mit translateY(-100%)
   verschwindet der Header unabhängig von seiner Höhe vollständig. */
body.aquafit-home header.header-light.smaller {
  transition: transform 0.4s ease, margin-top 0.4s ease, background 0.3s ease;
  will-change: transform;
}

body.aquafit-home header.header-light.smaller.scroll-down {
  margin-top: 0 !important;
  transform: translateY(-100%);
}

body.aquafit-home header.header-light.smaller.nav-up {
  margin-top: 0 !important;
  transform: translateY(0);
}

/* Footer: wieder Template-Dunkelton (var(--bg-dark-1)); AquaFit-Logos als Weißversion */
footer:not(.footer-light) img[src*="logo-aquafit"],
footer:not(.footer-light) img[src*="icon.png"] {
  filter: brightness(0) invert(1);
}

/* Footer: interne Verlinkung */
.aquafit-footer-nav a {
  color: inherit;
  text-decoration: none;
  opacity: 0.92;
}

.aquafit-footer-nav a:hover {
  opacity: 1;
  text-decoration: underline;
}

.aquafit-footer-nav__sep {
  display: inline-block;
  margin: 0 0.35rem;
  opacity: 0.45;
}

/* Footer: Mobile-Abstände */
@media (max-width: 991.98px) {
  footer {
    padding-top: 3rem;
  }

  footer .d-lg-flex > div {
    padding-top: 1.5rem;
    padding-bottom: 1.5rem;
    border-bottom: 1px solid rgba(255, 255, 255, 0.1);
  }

  footer .d-lg-flex > div:last-child {
    border-bottom: none;
  }

  .subfooter {
    margin-top: 1rem;
    padding: 1.25rem 0;
  }

  .aquafit-footer-nav {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 0.4rem 0;
    line-height: 2;
  }

  .subfooter .row {
    flex-direction: column;
    gap: 1rem;
  }

  .subfooter .col-lg-6 {
    width: 100%;
  }
}

/* Unterseiten: Abstand unter festem Header, Inhaltsbereich */
body.aquafit-subpage .aquafit-subpage-content {
  padding-top: 3.5rem;
  padding-bottom: 4.5rem;
}

body.aquafit-subpage .aquafit-subpage-content h2 {
  font-size: 1.35rem;
  margin-bottom: 0.75rem;
}

.aquafit-placeholder-outline {
  border: 2px dashed rgba(0, 0, 0, 0.12);
}

/* AquaStern – Kontaktliste in der Foto-Kachel-Reihe */
.aquastern-contact-list {
  list-style: none;
  padding: 0;
  margin: 0;
}
.aquastern-contact-list li {
  display: flex;
  align-items: baseline;
  gap: 4px;
  padding: 6px 0;
  font-size: 14px;
  word-break: break-word;
}
.aquastern-contact-list a {
  color: inherit;
  text-decoration: none;
  border-bottom: 1px dotted rgba(0, 0, 0, 0.2);
}
.aquastern-contact-list a:hover {
  border-bottom-style: solid;
  color: var(--secondary-color);
}

/* —— Veranstaltungen-Unterseite —— */

/* Hero mit Foto + dunklem Overlay */
.aquafit-events-hero {
  position: relative;
  min-height: 320px;
  display: flex;
  align-items: center;
  padding: clamp(48px, 7vw, 96px) 0;
}

.aquafit-events-hero__img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  z-index: 1;
}

.aquafit-events-hero__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg,
    rgba(0, 0, 0, 0.35) 0%,
    rgba(0, 0, 0, 0.55) 100%);
  z-index: 1;
}

.aquafit-events-hero .container {
  position: relative;
  z-index: 2;
}

.aquafit-events-hero__title {
  font-size: clamp(36px, 5vw, 64px);
  line-height: 1.05;
}

/* Featured-Event */
.aquafit-event-featured {
  padding: clamp(40px, 6vw, 80px) 0 0;
}

.aquafit-event-featured__card {
  background: #fff;
}

.aquafit-event-featured__media {
  position: relative;
  height: 100%;
  min-height: 320px;
}

.aquafit-event-featured__img {
  width: 100%;
  height: 100%;
  min-height: 320px;
  object-fit: cover;
  object-position: center;
  display: block;
}

.aquafit-event-featured__body {
  padding: clamp(28px, 4vw, 48px);
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.badge-featured {
  display: inline-flex;
  align-items: center;
  background: var(--secondary-color);
  color: #fff;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  padding: 6px 12px;
  border-radius: 999px;
}

.aquafit-event-featured__date {
  color: #6b7280;
  font-size: 14px;
}

/* Grid */
.aquafit-events-grid {
  padding: clamp(48px, 7vw, 96px) 0;
}

/* Karten */
.aquafit-event-card {
  background: #fff;
  border-radius: 14px;
  overflow: hidden;
  height: 100%;
  box-shadow: 0 6px 18px -10px rgba(0, 0, 0, 0.18);
  transition: transform .25s ease, box-shadow .25s ease;
}

.aquafit-event-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 14px 28px -12px rgba(0, 0, 0, 0.25);
}

.aquafit-event-card.is-featured {
  outline: 2px solid var(--secondary-color);
  outline-offset: 0;
}

.aquafit-event-card__link {
  display: flex;
  flex-direction: column;
  height: 100%;
  color: inherit;
  text-decoration: none;
}

.aquafit-event-card__media {
  position: relative;
  aspect-ratio: 4 / 3;
  overflow: hidden;
}

.aquafit-event-card__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  transition: transform .35s ease;
}

.aquafit-event-card__link:hover .aquafit-event-card__img {
  transform: scale(1.05);
}

/* Datums-Badge oben links — auch im Featured-Hero verwendbar */
.aquafit-event-card__date {
  position: absolute;
  top: 16px;
  left: 16px;
  background: rgba(0, 0, 0, 0.55);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  color: #fff;
  border-radius: 12px;
  padding: 10px 14px;
  text-align: center;
  font-weight: 600;
  z-index: 2;
}

.aquafit-event-card__day {
  font-size: 28px;
  line-height: 1;
}

.aquafit-event-card__month {
  display: block;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  opacity: 0.95;
  margin-top: 2px;
}

.aquafit-event-card__time {
  display: block;
  font-size: 11px;
  margin-top: 6px;
  padding-top: 6px;
  border-top: 1px solid rgba(255, 255, 255, 0.3);
  color: #ffffff;
  font-weight: 600;
}

.aquafit-event-card__body {
  padding: 22px 22px 24px;
  display: flex;
  flex-direction: column;
  flex-grow: 1;
}

.aquafit-event-card__title {
  font-size: 20px;
  margin-bottom: 8px;
  line-height: 1.25;
}

.aquafit-event-card__excerpt {
  color: #4b5563;
  font-size: 14px;
  margin-bottom: 14px;
  flex-grow: 1;
}

.aquafit-event-card__more {
  color: var(--secondary-color);
  font-weight: 600;
  font-size: 14px;
  align-self: flex-start;
}

/* Mobile: Featured untereinander */
@media (max-width: 991.98px) {
  .aquafit-event-featured__media {
    min-height: 240px;
  }
  .aquafit-event-featured__img {
    min-height: 240px;
  }
}

/* Kurs-Karten – nutzen die Event-Card-Basis und ergänzen Badge + Audience */
.aquafit-course-card__badge {
  position: absolute;
  top: 16px;
  left: 16px;
  z-index: 3;
  background: var(--primary-color);
  color: #fff;
  font-size: 14px;
  font-weight: 600;
  letter-spacing: 0.02em;
  line-height: 1;
  padding: 8px 14px;
  border-radius: 999px;
  box-shadow: 0 6px 18px rgba(0, 0, 0, 0.18);
}

.aquafit-course-card__audience {
  font-size: 13px;
  color: var(--secondary-color);
  font-weight: 600;
  margin: 0 0 0.5rem;
  display: flex;
  align-items: center;
}

/* Featured-Card auf der Kurs-Unterseite: Badge auch im großen Hero-Card-Bild */
.aquafit-event-featured__media .aquafit-course-card__badge {
  top: 20px;
  left: 20px;
  font-size: 15px;
  padding: 10px 18px;
}

/* Hover-Effekt für die Kurs-Kacheln auf der Startseite */
.aquafit-course-tile {
  transition: transform 0.25s ease, box-shadow 0.25s ease;
}

.aquafit-course-tile:hover {
  transform: translateY(-4px);
  box-shadow: 0 16px 40px rgba(0, 0, 0, 0.12);
}

/* FAQ-Sprachumschalter (nur über dem FAQ-Accordion) */
.aquafit-faq-lang {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 18px;
}

.aquafit-faq-lang__label {
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--secondary-color);
  margin-right: 4px;
}

.aquafit-faq-lang__btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  background: transparent;
  border: none;
  border-radius: 6px;
  cursor: pointer;
  line-height: 0;
  opacity: 0.55;
  transform: translateY(0);
  transition: opacity 0.2s ease, transform 0.2s ease, box-shadow 0.2s ease, filter 0.2s ease;
}

.aquafit-faq-lang__btn:hover {
  opacity: 0.9;
  transform: translateY(-1px);
}

.aquafit-faq-lang__btn.is-active {
  opacity: 1;
  transform: translateY(-1px);
  box-shadow: 0 6px 14px rgba(0, 0, 0, 0.18);
}

.aquafit-faq-lang__btn:focus-visible {
  outline: 2px solid var(--primary-color);
  outline-offset: 3px;
}

.aquafit-faq-lang__flag {
  display: block;
  width: 36px;
  height: 24px;
  border-radius: 4px;
  overflow: hidden;
  box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.10);
}

/* Öffnungszeiten- und Preise-Akkordeon: linke Icons komplett entfernen
   (FAQ-Akkordeon behält seine Icons). */
#aqua-zeiten-accordion .accordion-icon,
#aqua-preise-accordion .accordion-icon {
  display: none !important;
}

#aqua-zeiten-accordion .accordion-section-title--with-icon,
#aqua-preise-accordion .accordion-section-title--with-icon {
  gap: 0;
}

/* Feiertage / Revisionen: Sub-Hinweis unter dem Datum,
   und sicherstellen, dass die rechts platzierte Pill nicht umbrochen wird. */
.info-list__sub {
  display: block;
  font-size: 12px;
  color: #6b7280;
  margin-top: 2px;
}

.info-list--feiertage li > .info-tag {
  white-space: nowrap;
}

/* CTA-Section „Virtueller Rundgang" — etwas Innenabstand, damit der Button atmet */
.aquafit-cta {
  padding-top: clamp(64px, 9vw, 130px);
  padding-bottom: clamp(64px, 9vw, 130px);
}

/* Claim-Section über dem Pool-Hintergrund */
.aquafit-claim {
  padding-top: clamp(80px, 12vw, 180px);
  padding-bottom: clamp(80px, 12vw, 180px);
}

.aquafit-claim__eyebrow {
  font-size: clamp(13px, 1.2vw, 16px);
  letter-spacing: 0.22em;
  text-transform: uppercase;
  font-weight: 600;
  margin-bottom: 0.75rem;
}

.aquafit-claim__title {
  font-size: clamp(48px, 8vw, 110px);
  line-height: 1;
  margin: 0 0 1.25rem;
  font-weight: 700;
  letter-spacing: -0.01em;
}

.aquafit-claim__sub {
  font-size: clamp(18px, 2.2vw, 26px);
  letter-spacing: 0.08em;
  font-weight: 300;
  opacity: 0.92;
}

/* Video-Teaser: deutlich flacher als Bild-Eigenformat */
.aquafit-video-teaser__media {
  height: clamp(220px, 38vw, 520px);
}

.aquafit-video-teaser__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
}

/* —— AquaFit-Buttons: einheitlich Grün → Blau, sauberer Hover statt Klapp-Effekt —— */

/* Grundton (Grün) und sanfter Übergang */
a.btn-main,
.btn-main,
a.btn-main:active,
a.btn-main:focus,
a.btn-main:visited,
input[type=button].btn-main {
  background: var(--primary-color);
  color: #fff;
  transition: background-color .25s ease, color .25s ease,
              transform .25s ease, box-shadow .25s ease;
}

/* Hover: AquaFit-Blau (überschreibt eventuelle Varianten wie hover-white,
   damit alle Buttons gleich reagieren) */
a.btn-main:hover,
.btn-main:hover,
a.btn-main.btn-line:hover,
a.btn-main.hover-white:hover,
.btn-main.hover-white:hover {
  background: var(--secondary-color) !important;
  color: #fff !important;
  box-shadow: 0 10px 22px -12px rgba(var(--secondary-color-rgb), 0.55);
  transform: translateY(-2px);
}

a.btn-main:hover span,
.btn-main:hover span,
a.btn-main.hover-white:hover span,
.btn-main.hover-white:hover span {
  color: #fff !important;
}

/* fx-slide: Klapp-Animation deaktivieren – Schrift bleibt stehen */
a.btn-main.fx-slide,
.btn-main.fx-slide {
  overflow: visible;
  will-change: transform;
}

a.btn-main.fx-slide span,
.btn-main.fx-slide span {
  position: static;
  display: inline-block;
  transform: none !important;
  opacity: 1 !important;
  transition: color .25s ease;
}

a.btn-main.fx-slide:hover span,
.btn-main.fx-slide:hover span {
  transform: none !important;
  opacity: 1 !important;
}

a.btn-main.fx-slide:before,
a.btn-main.fx-slide:hover:before,
.btn-main.fx-slide:before,
.btn-main.fx-slide:hover:before {
  content: none !important;
  display: none !important;
}

/* =========================================================================
   Mobile-Navigation: schwebender Burger + Off-Canvas-Drawer
   ========================================================================= */

/* Burger und Drawer sind nur unterhalb von 992 px sichtbar.
   Auf größeren Screens bleibt das Template-Menü unverändert. */
.aquafit-burger,
.aquafit-mobile-backdrop,
.aquafit-mobile-drawer {
  display: none;
}

@media (max-width: 991.98px) {

  /* Template-Mobile-Burger und das ursprüngliche Mainmenu komplett ausblenden,
     damit sich nichts mit unserem neuen Drawer überlagert. */
  header #menu-btn,
  header .menu_side_area > .btn-main,
  header #mainmenu {
    display: none !important;
  }

  /* Header soll sich mobil zurücknehmen, kein weißer Balken mehr. */
  header.header-light {
    background: transparent !important;
    box-shadow: none !important;
    padding-top: 16px !important;
    padding-bottom: 0 !important;
  }

  /* Header auf Mobil fest am oberen Rand verankern (scrollt nicht mit). */
  header.header-light,
  header.header-light.header-mobile,
  header.header-light.smaller {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    width: 100% !important;
    z-index: 1002 !important;
  }

  /* Startseite: transparenter Header mit dunklem Verlauf oben
     – Logo bleibt in allen Scroll-Positionen lesbar. */
  body.aquafit-home header.header-light,
  body.aquafit-home header.header-light.header-mobile,
  body.aquafit-home header.header-light.smaller {
    background: linear-gradient(
      to bottom,
      rgba(0, 0, 0, 0.35) 0%,
      rgba(0, 0, 0, 0.0) 100%
    ) !important;
    box-shadow: none !important;
  }

  /* Unterseiten: milchig-weißer Frosted-Glass-Header für Lesbarkeit
     des dunklen Logos über hellem Content. */
  body.aquafit-subpage header.header-light {
    background: rgba(255, 255, 255, 0.88) !important;
    backdrop-filter: blur(12px) saturate(150%) !important;
    -webkit-backdrop-filter: blur(12px) saturate(150%) !important;
    box-shadow: 0 2px 16px rgba(0, 0, 0, 0.08) !important;
  }

  /* Logo mobil auf der Home immer in Weiß (auch bei smaller/header-mobile). */
  body.aquafit-home header.header-light #logo img,
  body.aquafit-home header.header-mobile #logo img,
  body.aquafit-home header.smaller #logo img {
    filter: brightness(0) invert(1) !important;
  }

  /* logo-mobile verstecken – logo-main wird stattdessen angezeigt. */
  header .logo-mobile {
    display: none !important;
  }
  header .logo-main {
    display: block !important;
    max-height: 56px;
    width: auto;
  }

  /* Logo sanft ausblenden sobald gescrollt wird. */
  header #logo {
    transition: opacity 0.2s ease, visibility 0.2s ease;
  }
  body.aq-scrolled header #logo {
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
  }

  /* --- Burger-Button: eigene fixed-Positionierung, unabhängig vom Header --- */
  .aquafit-burger {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    position: fixed;
    top: 16px;
    right: 16px;
    z-index: 1100;
    width: 48px;
    height: 48px;
    border: none;
    border-radius: 14px;
    cursor: pointer;
    color: #fff;
    background: rgba(20, 30, 50, 0.55);
    backdrop-filter: blur(10px) saturate(140%);
    -webkit-backdrop-filter: blur(10px) saturate(140%);
    box-shadow: 0 6px 20px rgba(0, 0, 0, 0.22);
    transition: background 0.25s ease, box-shadow 0.25s ease;
  }

  .aquafit-burger:hover,
  .aquafit-burger:focus-visible {
    background: rgba(20, 30, 50, 0.78);
    outline: none;
  }

  .aquafit-burger.is-open {
    background: var(--secondary-color, #1a73e8);
  }

  .aquafit-burger__bars {
    display: inline-flex;
    flex-direction: column;
    justify-content: center;
    gap: 6px;
    width: 24px;
    height: 18px;
    position: relative;
  }

  .aquafit-burger__bars span {
    display: block;
    height: 2.5px;
    width: 100%;
    background: currentColor;
    border-radius: 2px;
    transform-origin: center;
    transition: transform 0.25s ease, opacity 0.2s ease;
  }

  .aquafit-burger__bars span:nth-child(2) {
    width: 70%;
    align-self: flex-end;
  }

  .aquafit-burger.is-open .aquafit-burger__bars {
    gap: 0;
  }

  .aquafit-burger.is-open .aquafit-burger__bars span:nth-child(1) {
    transform: translateY(8px) rotate(45deg);
  }

  .aquafit-burger.is-open .aquafit-burger__bars span:nth-child(2) {
    opacity: 0;
  }

  .aquafit-burger.is-open .aquafit-burger__bars span:nth-child(3) {
    transform: translateY(-3px) rotate(-45deg);
    width: 100%;
  }

  /* --- Backdrop --------------------------------------------------------- */
  .aquafit-mobile-backdrop {
    display: block;
    position: fixed;
    inset: 0;
    background: rgba(8, 14, 28, 0.55);
    backdrop-filter: blur(2px);
    -webkit-backdrop-filter: blur(2px);
    z-index: 1050;
    opacity: 0;
    transition: opacity 0.25s ease;
  }

  .aquafit-mobile-backdrop.is-visible {
    opacity: 1;
  }

  /* --- Off-Canvas-Drawer ------------------------------------------------ */
  .aquafit-mobile-drawer {
    display: block;
    position: fixed;
    top: 0;
    right: 0;
    height: 100dvh;
    height: 100vh;
    width: min(420px, 88vw);
    z-index: 1080;
    background: linear-gradient(180deg, #0e1a36 0%, #0a1428 100%);
    color: #fff;
    transform: translateX(105%);
    transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    box-shadow: -20px 0 60px rgba(0, 0, 0, 0.35);
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
  }

  .aquafit-mobile-drawer.is-open {
    transform: translateX(0);
  }

  .aquafit-mobile-drawer__inner {
    display: flex;
    flex-direction: column;
    min-height: 100%;
    padding: 22px 26px 32px;
  }

  .aquafit-mobile-drawer__head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 26px;
  }

  .aquafit-mobile-drawer__logo img {
    height: 48px;
    width: auto;
    display: block;
    filter: brightness(0) invert(1);
  }

  .aquafit-mobile-drawer__close {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 44px;
    height: 44px;
    border-radius: 14px;
    border: 1px solid rgba(255, 255, 255, 0.18);
    background: rgba(255, 255, 255, 0.06);
    color: #fff;
    cursor: pointer;
    transition: background 0.2s ease, border-color 0.2s ease;
  }

  .aquafit-mobile-drawer__close:hover,
  .aquafit-mobile-drawer__close:focus-visible {
    background: rgba(255, 255, 255, 0.14);
    border-color: rgba(255, 255, 255, 0.32);
    outline: none;
  }

  /* --- Nav-Items: groß, generös, klar tappbar -------------------------- */
  .aquafit-mobile-drawer__nav {
    flex: 1 1 auto;
  }

  .aquafit-mobile-drawer__nav ul {
    list-style: none;
    padding: 0;
    margin: 0;
  }

  .aquafit-mobile-drawer__nav li + li {
    border-top: 1px solid rgba(255, 255, 255, 0.08);
  }

  .aquafit-mobile-drawer__nav a {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 18px 4px;
    color: #fff;
    text-decoration: none;
    font-size: 22px;
    font-weight: 500;
    letter-spacing: 0.01em;
    line-height: 1.2;
    transition: color 0.2s ease, transform 0.2s ease, padding 0.2s ease;
  }

  .aquafit-mobile-drawer__nav a i {
    color: rgba(255, 255, 255, 0.45);
    font-size: 16px;
    transition: transform 0.2s ease, color 0.2s ease;
  }

  .aquafit-mobile-drawer__nav a:hover,
  .aquafit-mobile-drawer__nav a:focus-visible {
    color: #fff;
    padding-left: 8px;
    outline: none;
  }

  .aquafit-mobile-drawer__nav a:hover i,
  .aquafit-mobile-drawer__nav a:focus-visible i {
    color: var(--primary-color, #94c12b);
    transform: translateX(4px);
  }

  /* --- CTA-Button + Kontaktblock --------------------------------------- */
  .aquafit-mobile-drawer__cta {
    margin-top: 24px;
  }

  .aquafit-mobile-drawer__cta .btn-main {
    width: 100%;
    text-align: center;
    padding: 16px 22px !important;
    font-size: 16px !important;
  }

  .aquafit-mobile-drawer__contact {
    margin-top: 28px;
    padding-top: 22px;
    border-top: 1px solid rgba(255, 255, 255, 0.10);
    display: flex;
    flex-direction: column;
    gap: 12px;
  }

  .aquafit-mobile-drawer__contact-line {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    color: rgba(255, 255, 255, 0.85);
    text-decoration: none;
    font-size: 14px;
    word-break: break-word;
  }

  .aquafit-mobile-drawer__contact-line i {
    width: 18px;
    text-align: center;
    color: var(--primary-color, #94c12b);
    flex: 0 0 auto;
  }

  .aquafit-mobile-drawer__contact-line:hover {
    color: #fff;
  }

  .aquafit-mobile-drawer__socials {
    display: flex;
    gap: 10px;
    margin-top: 6px;
  }

  .aquafit-mobile-drawer__socials a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    border-radius: 12px;
    background: rgba(255, 255, 255, 0.08);
    color: #fff;
    text-decoration: none;
    transition: background 0.2s ease, transform 0.2s ease;
  }

  .aquafit-mobile-drawer__socials a:hover {
    background: var(--primary-color, #94c12b);
    transform: translateY(-1px);
  }

  /* Body-Scroll sperren, solange das Drawer offen ist. */
  body.aquafit-mobile-nav-open {
    overflow: hidden;
  }

  /* Wenn das Drawer offen ist, Burger-Button als X zeigen – kein weiteres
     Ausblenden nötig, der Backdrop dimmt den Hintergrund. */
}

/* Sehr schmale Screens (≤ 380 px): Drawer-Innenpadding etwas kompakter. */
@media (max-width: 380px) {
  .aquafit-mobile-drawer__inner {
    padding: 18px 18px 26px;
  }
  .aquafit-mobile-drawer__nav a {
    font-size: 20px;
    padding: 16px 2px;
  }
  .aquafit-burger {
    width: 42px;
    height: 42px;
    border-radius: 11px;
    top: 12px;
    right: 12px;
  }
}

/* =========================================================================
   Live-Öffnungs-Status-Button (Header CTA) – im AquaFit-Button-Look
   ========================================================================= */
.aquafit-status-btn {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  padding: 10px 20px 10px 16px;
  border-radius: 999px;
  background: var(--primary-color);
  color: #ffffff;
  text-decoration: none;
  border: none;
  box-shadow: 0 6px 16px -8px rgba(var(--primary-color-rgb), 0.55);
  transition: background-color .25s ease, color .25s ease,
              transform .25s ease, box-shadow .25s ease;
  line-height: 1.1;
  white-space: nowrap;
}

.aquafit-status-btn:hover,
.aquafit-status-btn:focus-visible {
  background: var(--secondary-color);
  color: #ffffff;
  text-decoration: none;
  outline: none;
  transform: translateY(-2px);
  box-shadow: 0 10px 22px -12px rgba(var(--secondary-color-rgb), 0.55);
}

.aquafit-status-btn__dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  flex-shrink: 0;
  background: #ffffff;
  position: relative;
  box-shadow: 0 0 0 2px rgba(255, 255, 255, 0.25);
}

.aquafit-status-btn__text {
  display: inline-flex;
  flex-direction: column;
  gap: 1px;
}

.aquafit-status-btn__main {
  font-weight: 600;
  font-size: 14px;
  letter-spacing: 0.01em;
  color: #ffffff;
}

.aquafit-status-btn__sub {
  font-size: 11.5px;
  color: rgba(255, 255, 255, 0.82);
  letter-spacing: 0.01em;
}

/* ---- Variant: jetzt geöffnet (pulsierender weißer Dot) ---- */
.aquafit-status-btn--open .aquafit-status-btn__dot {
  background: #ffffff;
}
.aquafit-status-btn--open .aquafit-status-btn__dot::after {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: 50%;
  background: #ffffff;
  animation: aquafitStatusPulse 1.6s ease-out infinite;
}
@keyframes aquafitStatusPulse {
  0%   { transform: scale(1);   opacity: 0.65; }
  100% { transform: scale(2.4); opacity: 0;    }
}

/* ---- Variant: öffnet heute später (gelber Dot) ---- */
.aquafit-status-btn--opens_today .aquafit-status-btn__dot {
  background: #fbbf24;
  box-shadow: 0 0 0 2px rgba(255, 255, 255, 0.30);
}

/* ---- Variant: heute geschlossen (rot-akzentuierter Dot) ---- */
.aquafit-status-btn--closed_today .aquafit-status-btn__dot {
  background: #fca5a5;
  box-shadow: 0 0 0 2px rgba(255, 255, 255, 0.30);
}

/* Tablet/Desktop etwas kompakter */
@media (max-width: 1199.98px) {
  .aquafit-status-btn { padding: 9px 16px 9px 13px; gap: 10px; }
  .aquafit-status-btn__main { font-size: 13px; }
  .aquafit-status-btn__sub  { font-size: 11px;  }
}

/* Hero-Wrapper für den Status-Button: Standard ausgeblendet (Desktop hat
   den Button bereits im Header); auf Mobil wird er zur Anzeige aktiviert. */
.aquafit-hero__status {
  display: none;
}

/* Mobile: Header-Status-Button (im menu_side_area) verstecken; stattdessen
   wird er innerhalb der Hero-Sektion über "Jetzt eintauchen" gerendert. */
@media (max-width: 991.98px) {
  header .aquafit-status-btn {
    display: none !important;
  }

  .aquafit-hero__status {
    display: flex;
    justify-content: center;
    margin-bottom: 18px;
  }

  /* Status-Button in der Hero etwas kompakter, ohne fixe Positionierung. */
  .aquafit-hero__status .aquafit-status-btn {
    padding: 9px 16px 9px 13px;
    gap: 10px;
  }
  .aquafit-hero__status .aquafit-status-btn__main { font-size: 13px; }
  .aquafit-hero__status .aquafit-status-btn__sub  { font-size: 11px; }
}

@media (max-width: 380px) {
  .aquafit-hero__status .aquafit-status-btn {
    padding: 8px 14px 8px 11px;
    gap: 8px;
  }
  .aquafit-hero__status .aquafit-status-btn__main { font-size: 12.5px; }
  .aquafit-hero__status .aquafit-status-btn__sub  { font-size: 10.5px; }
}

