/* ================================================================
   TANZSCHULE YULIA AVDONINA — GLOBAL STYLESHEET
   Gültig für: index.html, raumvermietung.html, impressum.html,
               datenschutz.html und alle weiteren Unterseiten
   ================================================================ */

/* ================================================================
   1. DESIGN TOKENS
   ================================================================ */
:root {
  --offwhite:   #f8f7f5;
  --warmgrey:   #f2f1ef;
  --surface:    #ffffff;
  --surface2:   #f5f4f2;
  --border:     rgba(26,26,26,0.07);
  --border2:    rgba(26,26,26,0.12);

  --ink:        #1a1a1a;
  --ink-70:     rgba(26,26,26,0.70);
  --ink-40:     rgba(26,26,26,0.40);
  --ink-20:     rgba(26,26,26,0.20);
  --ink-08:     rgba(26,26,26,0.08);

  --gold:       #c9a84c;
  --gold-light: #e8d5a3;
  --gold-glow:  rgba(201,168,76,0.18);
  --rose:       #c9a0a8;
  --rose-light: #e8d0d4;

  --ff-sans:  'Montserrat', sans-serif;
  --ff-serif: 'Playfair Display', Georgia, serif;

  --ease:   cubic-bezier(0.25,0.46,0.45,0.94);
  --spring: cubic-bezier(0.22,1,0.36,1);
  --bounce: cubic-bezier(0.34,1.56,0.64,1);
}

/* ================================================================
   2. RESET & BASE
   ================================================================ */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; overflow-x:hidden; }
body {
  font-family: var(--ff-sans);
  background: var(--offwhite);
  color: var(--ink);
  line-height: 1.7;
  overflow-x: hidden;
}
img { display:block; max-width:100%; }
a { text-decoration:none; color:inherit; }
@media (hover:none) { body { cursor:auto; } }

::-webkit-scrollbar { width:4px; }
::-webkit-scrollbar-track { background:var(--warmgrey); }
::-webkit-scrollbar-thumb { background:var(--gold-light); border-radius:2px; }

/* ================================================================
   3. SILK CANVAS (Hintergrund-Wellen — alle Seiten)
   ================================================================ */
#silkCanvas {
  position:fixed; inset:0; z-index:0; pointer-events:none;
  opacity:0.30;
}

/* ================================================================
   4. INTRO OVERLAY (nur index.html — einmalig via sessionStorage)
   ================================================================ */
.intro-overlay {
  position:fixed; inset:0; z-index:9999;
  background:var(--offwhite);
  display:flex; align-items:center; justify-content:center;
  flex-direction:column; gap:20px;
  transition:opacity 0.5s var(--ease), visibility 0.5s;
}
.intro-overlay.done { opacity:0; visibility:hidden; pointer-events:none; }

.intro-tagline {
  font-size:.90rem; font-weight:300; letter-spacing:5px; text-transform:uppercase;
  color:var(--ink-40);
  opacity:0; animation:fadeUp 0.5s var(--ease) 1.0s forwards;
}

/* ================================================================
   5. KEYFRAMES
   ================================================================ */
@keyframes fadeUp {
  from { opacity:0; transform:translateY(16px); }
  to   { opacity:1; transform:translateY(0); }
}
@keyframes haloBreath {
  0%,100% { transform:scale(1);   opacity:.8; }
  50%     { transform:scale(1.06); opacity:1;  }
}
@keyframes rotateSlow { to { transform:rotate(360deg); } }
@keyframes dotPulse   { 0%,100%{opacity:1} 50%{opacity:.3} }
@keyframes beat {
  0%  { transform:scale(1);    }
  15% { transform:scale(1.35); }
  30% { transform:scale(1);    }
  45% { transform:scale(1.25); }
  70% { transform:scale(1);    }
}
@keyframes waPulse  { 0%{transform:scale(1);opacity:1}  100%{transform:scale(1.75);opacity:0} }
@keyframes modalIn  { from{transform:translateY(24px) scale(.97);opacity:0} to{transform:translateY(0) scale(1);opacity:1} }

/* ================================================================
   6. 

/* ================================================================
   NAVIGATION COMPONENT CSS
   Nur für die Navigation - einbinden: <link rel="stylesheet" href="components/nav.css">
   ================================================================ */

/* ================================================================
   1. NAVIGATION BAR
   ================================================================ */
.nav {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1000;
  height: 74px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 6%;
  background: rgba(248, 247, 245, 0.75);
  backdrop-filter: blur(24px) saturate(1.8);
  -webkit-backdrop-filter: blur(24px) saturate(1.8);
  border-bottom: 1px solid transparent;
  transition: border-color 0.4s ease, box-shadow 0.4s ease, background 0.4s ease;
}
.nav.scrolled {
  background: rgba(248, 247, 245, 0.96);
  border-color: rgba(26, 26, 26, 0.07);
  box-shadow: 0 1px 30px rgba(26, 26, 26, 0.06);
}

/* ================================================================
   2. LOGO
   ================================================================ */
.nav-logo {
  display: flex;
  align-items: center;
  gap: 14px;
  text-decoration: none;
}
.nav-logo.reveal-after-intro { opacity: 0; transition: opacity 0.6s; }
.nav-logo.reveal-after-intro.reveal { opacity: 1; }

.logo-mark {
  width: 42px;
  height: 42px;
  border-radius: 10px;
  border: 1px solid rgba(26, 26, 26, 0.12);
  overflow: hidden;
  flex-shrink: 0;
  background: #e0e0e0;
  box-shadow: 0 2px 12px rgba(26, 26, 26, 0.06);
}
.logo-mark img { width: 100%; height: 100%; object-fit: cover; }

.nav-logo-name {
  font-size: .92rem;
  font-weight: 700;
  color: #1a1a1a;
  letter-spacing: .3px;
  display: block;
  line-height: 1.2;
}
.nav-logo-sub {
  font-size: .58rem;
  font-weight: 300;
  letter-spacing: 3.5px;
  text-transform: uppercase;
  color: #c9a84c;
  display: block;
  margin-top: 2px;
}

/* ================================================================
   3. DESKTOP NAV LINKS
   ================================================================ */
.nav-links {
  list-style: none;
  display: flex;
  gap: 32px;
  align-items: center;
}
.nav-links a {
  font-size: .72rem;
  font-weight: 400;
  letter-spacing: 1.2px;
  text-transform: uppercase;
  color: rgba(26, 26, 26, 0.70);
  transition: color 0.25s, text-shadow 0.25s;
  position: relative;
  text-decoration: none;
}
.nav-links a::after {
  content: '';
  position: absolute;
  bottom: -4px;
  left: 0;
  width: 0;
  height: 1.5px;
  background: linear-gradient(90deg, #c9a84c, #e8d5a3);
  transition: width 0.35s cubic-bezier(0.16, 1, 0.3, 1);
  border-radius: 2px;
}
.nav-links a:hover {
  color: #1a1a1a;
  text-shadow: 0 0 20px rgba(201, 168, 76, 0.3);
}
.nav-links a:hover::after { width: 100%; }

.nav-cta {
  background:var(--ink) !important;
  color:var(--offwhite) !important;
  padding:10px 24px; border-radius:50px;
  font-weight:600 !important; letter-spacing:.6px !important;
  transition:transform .3s var(--spring), background .3s !important;
  box-shadow:0 4px 20px rgba(26,26,26,0.15);
}
.nav-cta::after { display:none !important; }
.nav-cta:hover { background:var(--gold) !important; color:var(--ink) !important; transform:translateY(-2px); }

/* ================================================================
   4. DROPDOWN MENU
   ================================================================ */
.nav-dropdown {
  position: relative;
  padding-bottom: 18px;
  margin-bottom: -18px;
}
.nav-dropdown-toggle {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  cursor: pointer;
}
.nav-arrow {
  transition: transform 0.3s ease;
  flex-shrink: 0;
}

@media (hover: hover) {
  .nav-dropdown:hover .nav-arrow { transform: rotate(180deg); }
  .nav-dropdown:hover .nav-dropdown-menu {
    opacity: 1;
    visibility: visible;
    transform: translateX(-50%) translateY(0);
    pointer-events: auto;
  }
}

.nav-dropdown-menu {
  position: absolute;
  top: calc(100% - 2px);
  left: 50%;
  transform: translateX(-50%) translateY(8px);
  list-style: none;
  background: rgba(255, 255, 255, 0.97);
  backdrop-filter: blur(24px);
  border: 1px solid rgba(26, 26, 26, 0.12);
  border-radius: 18px;
  padding: 10px;
  min-width: 260px;
  box-shadow: 0 8px 40px rgba(26, 26, 26, 0.10), 0 2px 8px rgba(26, 26, 26, 0.05);
  opacity: 0;
  visibility: hidden;
  transform: translateX(-50%) translateY(8px);
  transition: opacity 0.3s ease, transform 0.35s cubic-bezier(0.22, 1, 0.36, 1), visibility 0.3s;
  pointer-events: none;
  z-index: 500;
}

.nav-dropdown-menu::before {
  content: '';
  position: absolute;
  top: -7px;
  left: 50%;
  width: 12px;
  height: 12px;
  background: #fff;
  border-left: 1px solid rgba(26, 26, 26, 0.12);
  border-top: 1px solid rgba(26, 26, 26, 0.12);
  transform: translateX(-50%) rotate(45deg);
  border-radius: 2px 0 0 0;
}

.nav-dropdown-menu li a {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 14px;
  border-radius: 10px;
  font-size: .75rem;
  font-weight: 400;
  letter-spacing: .4px;
  color: rgba(26, 26, 26, 0.70);
  transition: background 0.2s, color 0.2s;
  text-decoration: none;
}
.nav-dropdown-menu li a::after { display: none; }
.nav-dropdown-menu li a:hover {
  background: #f2f1ef;
  color: #1a1a1a;
}

.drop-age {
  flex-shrink: 0;
  font-size: .6rem;
  font-weight: 600;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: #c9a84c;
  background: rgba(201, 168, 76, 0.18);
  border-radius: 50px;
  padding: 3px 9px;
  white-space: nowrap;
}

/* ================================================================
   5. BURGER BUTTON
   ================================================================ */
.burger {
  display: none;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: 44px;
  height: 44px;
  background: none;
  border: none;
  padding: 8px;
  cursor: pointer;
  z-index: 10001;
  position: relative;
}
.burger span {
  width: 24px;
  height: 2px;
  background: #1a1a1a;
  border-radius: 2px;
  transition: 0.35s cubic-bezier(0.68, -0.55, 0.265, 1.55);
  position: absolute;
}
.burger span:nth-child(1) { transform: translateY(-7px); }
.burger span:nth-child(2) { transform: translateY(0); }
.burger span:nth-child(3) { transform: translateY(7px); }
.burger.open span:nth-child(1) { transform: translateY(0) rotate(45deg); background: #c9a84c; }
.burger.open span:nth-child(2) { opacity: 0; transform: translateX(10px); }
.burger.open span:nth-child(3) { transform: translateY(0) rotate(-45deg); background: #c9a84c; }

/* ================================================================
   6. MOBILE MENU OVERLAY
   ================================================================ */
.menu-overlay {
  position: fixed;
  inset: 0;
  background: rgba(26, 26, 26, 0.6);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  z-index: 9995;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.4s ease, visibility 0.4s;
}
.menu-overlay.open {
  opacity: 1;
  visibility: visible;
}

/* ================================================================
   7. MOBILE MENU PANEL
   ================================================================ */
.menu-panel {
  position: fixed;
  top: 0;
  right: 0;
  width: min(85vw, 380px);
  height: 100vh;
  background: linear-gradient(135deg, #fdfcfb 0%, #f8f7f5 50%, #f5f4f2 100%);
  z-index: 10000;
  transform: translateX(100%);
  transition: transform 0.5s cubic-bezier(0.16, 1, 0.3, 1);
  display: flex;
  flex-direction: column;
  padding: 0;
  overflow: hidden;
  box-shadow: -20px 0 60px rgba(26, 26, 26, 0.15);
}
.menu-panel::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(201, 168, 76, 0.03) 0%, transparent 30%);
  pointer-events: none;
}
.menu-panel.open { transform: translateX(0); }

.menu-panel-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 20px 24px;
  border-bottom: 1px solid rgba(26, 26, 26, 0.07);
  background: rgba(255, 255, 255, 0.5);
}

.menu-panel-logo {
  display: flex;
  align-items: center;
  gap: 12px;
}
.menu-panel-logo img {
  width: 36px;
  height: 36px;
  border-radius: 8px;
  object-fit: cover;
  border: 1px solid rgba(26, 26, 26, 0.12);
}
.menu-panel-logo-text {
  font-size: .78rem;
  font-weight: 600;
  color: #1a1a1a;
  line-height: 1.2;
}

/* CLOSE BUTTON */
.menu-close {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: #f2f1ef;
  border: 1px solid rgba(26, 26, 26, 0.07);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: 0.3s;
  color: rgba(26, 26, 26, 0.40);
  padding: 0;
}
.menu-close:hover {
  background: rgba(201, 168, 76, 0.18);
  border-color: #c9a84c;
  color: #c9a84c;
  transform: rotate(90deg);
}
.close-icon {
  font-size: 16px;
  font-weight: 300;
  line-height: 1;
  color: inherit;
  pointer-events: none;
}
.menu-close:hover .close-icon {
  color: #c9a84c;
}

/* ================================================================
   8. MOBILE NAVIGATION LIST
   ================================================================ */
.menu-panel-content {
  flex: 1;
  overflow-y: auto;
  padding: 24px 0;
  scrollbar-width: thin;
  scrollbar-color: #e8d5a3 transparent;
}

.menu-nav-list {
  list-style: none;
}

.menu-nav-item {
  border-bottom: 1px solid rgba(26, 26, 26, 0.07);
}

.menu-nav-link {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 18px 28px;
  font-size: .85rem;
  font-weight: 500;
  letter-spacing: .5px;
  color: rgba(26, 26, 26, 0.70);
  text-transform: uppercase;
  transition: 0.3s;
  position: relative;
  overflow: hidden;
  text-decoration: none;
}
.menu-nav-link::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0;
  width: 3px;
  height: 100%;
  background: #c9a84c;
  transform: scaleY(0);
  transition: transform 0.3s cubic-bezier(0.16, 1, 0.3, 1);
}
.menu-nav-link:hover {
  color: #1a1a1a;
  background: rgba(201, 168, 76, 0.05);
  padding-left: 32px;
}
.menu-nav-link:hover::before { transform: scaleY(1); }
.menu-nav-link svg {
  width: 16px;
  height: 16px;
  transition: transform 0.3s;
}
.menu-nav-item.open .menu-nav-link svg {
  transform: rotate(180deg);
  color: #c9a84c;
}

/* ================================================================
   9. MOBILE SUBMENU
   ================================================================ */
.menu-submenu {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.4s cubic-bezier(0.16, 1, 0.3, 1);
  background: linear-gradient(180deg, rgba(201, 168, 76, 0.03) 0%, transparent 100%);
}
.menu-submenu.open { max-height: 500px; }

.menu-submenu-item {
  padding: 12px 28px 12px 40px;
  border-bottom: 1px solid rgba(26, 26, 26, 0.07);
  display: flex;
  align-items: center;
  gap: 12px;
  transition: 0.3s;
}
.menu-submenu-item:last-child { border-bottom: none; }
.menu-submenu-item:hover { background: rgba(201, 168, 76, 0.05); }
.menu-submenu-item a {
  font-size: .82rem;
  font-weight: 400;
  color: rgba(26, 26, 26, 0.40);
  transition: 0.3s;
  text-decoration: none;
}
.menu-submenu-item:hover a { color: #c9a84c; }

.menu-submenu-age {
  font-size: .58rem;
  font-weight: 600;
  letter-spacing: 1px;
  text-transform: uppercase;
  color: #c9a84c;
  background: rgba(201, 168, 76, 0.18);
  border-radius: 50px;
  padding: 3px 8px;
  white-space: nowrap;
}

/* ================================================================
   10. MOBILE CTA BUTTON
   ================================================================ */
.menu-cta-wrap {
  padding: 24px 28px;
  border-top: 1px solid rgba(26, 26, 26, 0.07);
  background: rgba(255, 255, 255, 0.5);
}
.menu-cta-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  width: 100%;
  padding: 16px 24px;
  background: #1a1a1a;
  color: #f8f7f5;
  border: none;
  border-radius: 14px;
  font-family: 'Montserrat', sans-serif;
  font-size: .78rem;
  font-weight: 600;
  letter-spacing: 1px;
  text-transform: uppercase;
  cursor: pointer;
  transition: 0.35s cubic-bezier(0.16, 1, 0.3, 1);
  box-shadow: 0 4px 20px rgba(26, 26, 26, 0.15);
  text-decoration: none;
}
.menu-cta-btn:hover {
  background: #c9a84c;
  color: #1a1a1a;
  transform: translateY(-2px);
  box-shadow: 0 8px 30px rgba(201, 168, 76, 0.3);
}

/* ================================================================
   11. RESPONSIVE - MOBILE ONLY
   ================================================================ */
@media (max-width: 768px) {
  body { padding-top: 35px; }
  .nav { padding: 0 5%; height: 70px; }

  .nav-logo-name { font-size: .72rem; letter-spacing: 0; }
  .nav-logo-sub { font-size: .50rem; letter-spacing: 2px; }
  .logo-mark { width: 34px; height: 34px; border-radius: 8px; }

  /* Burger Sichtbar */
  .burger { display: flex; }

  /* Desktop Nav verstecken */
  .nav-links { display: none !important; }
}

/* ================================================================
   12. SCROLL PROGRESS BAR (gehört auch zur Nav)
   ================================================================ */
.scroll-progress {
  position: fixed;
  top: 0;
  left: 0;
  width: 0%;
  height: 3px;
  background: linear-gradient(90deg, #c9a84c, #e8d5a3, #c9a84c);
  z-index: 9999;
  transition: width 0.1s linear;
  box-shadow: 0 0 10px rgba(201, 168, 76, 0.5);
}



/* ================================================================
   8. BUTTONS
   ================================================================ */
.btn {
  display:inline-flex; align-items:center; gap:9px;
  padding:14px 34px; border-radius:50px;
  font-family:var(--ff-sans); font-weight:600;
  font-size:.75rem; letter-spacing:1px; text-transform:uppercase; border:none;
  cursor:pointer;
  transition:transform .35s var(--spring), box-shadow .35s var(--ease);
  text-decoration:none;
}
.btn-gold {
  background:var(--gold); color:var(--surface);
  box-shadow:0 6px 28px var(--gold-glow);
}
.btn-gold:hover { transform:translateY(-3px); box-shadow:0 12px 40px rgba(201,168,76,0.35); }
.btn-outline {
  background:transparent; color:var(--ink);
  border:1.5px solid var(--border2);
}
.btn-outline:hover { border-color:var(--ink); transform:translateY(-3px); }
.btn-dark { background:var(--ink); color:var(--offwhite); box-shadow:0 6px 24px rgba(26,26,26,0.14); }
.btn-dark:hover { transform:translateY(-3px); box-shadow:0 12px 36px rgba(26,26,26,0.2); }
.btn-sm { padding:10px 24px; font-size:.72rem; }
.btn-wa {
  background:#25d366; color:#fff;
  box-shadow:0 6px 28px rgba(37,211,102,.3);
}
.btn-wa:hover { transform:translateY(-3px); box-shadow:0 12px 40px rgba(37,211,102,.45); }

/* Magnetic wrapper */
.mag { display:inline-block; will-change:transform; }

/* ================================================================
   9. SECTION UTILITIES
   ================================================================ */
.section { padding:110px 7%; max-width:1360px; margin:0 auto; position:relative; z-index:2; }
.section-shade { background:var(--warmgrey); position:relative; z-index:2; }
.section-shade-inner { max-width:1360px; margin:0 auto; padding:110px 7%; }
.section-white { background:var(--surface); position:relative; z-index:2; }
.section-white-inner { max-width:1360px; margin:0 auto; padding:110px 7%; }

.sec-eyebrow {
  display:flex; align-items:center; gap:14px;
  font-size:.62rem; font-weight:400; letter-spacing:4px; text-transform:uppercase;
  color:var(--gold); margin-bottom:20px;
}
.sec-eyebrow-line { display:inline-block; width:32px; height:1px; background:var(--gold); }
.sec-title {
  font-family:var(--ff-sans); font-size:clamp(2rem,4vw,3.2rem);
  font-weight:200; line-height:1.1; letter-spacing:-1px; color:var(--ink); margin-bottom:16px;
}
.sec-title em { font-family:var(--ff-serif); font-style:italic; font-weight:400; color:var(--gold); }
.sec-sub { font-size:.88rem; font-weight:300; color:var(--ink-40); max-width:480px; line-height:1.9; }

/* Scroll-Reveal (alle Seiten) */
[data-reveal] { opacity:0; transform:translateY(28px); transition:opacity .8s var(--ease), transform .8s var(--spring); }
[data-reveal].vis { opacity:1; transform:translateY(0); }
[data-reveal][data-d="1"] { transition-delay:.08s; }
[data-reveal][data-d="2"] { transition-delay:.17s; }
[data-reveal][data-d="3"] { transition-delay:.26s; }
[data-reveal][data-d="4"] { transition-delay:.35s; }

/* Section-Divider */
.sec-divider { display:flex; align-items:center; gap:20px; max-width:1200px; margin:0 auto; padding:0 7%; }
.sec-divider-line { flex:1; height:1px; background:var(--border); }
.sec-divider-icon { color:var(--gold); font-size:.9rem; }

/* ================================================================
   10. HERO — INDEX
   ================================================================ */
.hero {
  min-height:100vh;
  display:flex; align-items:center; justify-content:center;
  gap:100px; padding:110px 8% 90px;
  max-width:1360px; margin:0 auto;
  position:relative; z-index:2;
}
.hero-left { flex:1; max-width:580px; }

.hero-eyebrow {
  display:inline-flex; align-items:center; gap:10px;
  font-size:.8rem; font-weight:400; letter-spacing:4px; text-transform:uppercase;
  color:var(--ink-40); margin-bottom:32px;
  opacity:0; animation:fadeUp 0.6s var(--ease) 1.5s forwards;
}
.eyebrow-dash { display:inline-block; width:28px; height:1px; background:var(--gold); }

.hero-title {
  font-family:var(--ff-sans);
  font-size:clamp(3rem,6vw,5.5rem);
  font-weight:200; line-height:1; letter-spacing:-2px; color:var(--ink); margin-bottom:10px;
  opacity:0; animation:fadeUp 0.7s var(--ease) 1.6s forwards;
}
.hero-title-italic {
  font-family:var(--ff-serif);
  font-size:clamp(3.4rem,6.5vw,6rem);
  font-weight:400; font-style:italic; line-height:1;
  letter-spacing:-1.5px; color:var(--gold); display:block; margin-bottom:10px;
  opacity:0; animation:fadeUp 0.7s var(--ease) 1.72s forwards;
}
.hero-title-name {
  font-family:var(--ff-sans);
  font-size:clamp(1.3rem,2vw,1.8rem);
  font-weight:700; line-height:1.1; letter-spacing:-1px; color:var(--ink); display:block;
  opacity:0; animation:fadeUp 0.7s var(--ease) 1.84s forwards;
}

.hero-divider {
  display:flex; align-items:center; gap:16px; margin:32px 0;
  opacity:0; animation:fadeUp 0.6s var(--ease) 1.96s forwards;
}
.hero-divider-line { flex:1; height:1px; background:linear-gradient(to right, var(--border2), transparent); max-width:80px; }
.hero-divider-icon { font-size:1rem; color:var(--gold); }

.hero-desc {
  font-size:.92rem; font-weight:300; color:var(--ink-70);
  line-height:1.9; margin-bottom:12px; max-width:500px;
  opacity:0; animation:fadeUp 0.6s var(--ease) 2.06s forwards;
}
.hero-actions {
  display:flex; gap:14px; margin:36px 0 46px; flex-wrap:wrap;
  opacity:0; animation:fadeUp 0.6s var(--ease) 2.16s forwards;
}

/* Hero Stats */
.hero-stats {
  display:flex; gap:40px; padding-top:40px;
  border-top:1px solid var(--border);
  opacity:0; animation:fadeUp 0.6s var(--ease) 2.26s forwards;
}
.stat-n { font-family:var(--ff-serif); font-style:italic; font-size:2.4rem; font-weight:400; color:var(--ink); line-height:1; }
.stat-u { font-size:.7rem; font-weight:400; letter-spacing:1px; text-transform:uppercase; color:var(--gold); margin:0 0 2px; }
.stat-l { font-size:.78rem; font-weight:300; color:var(--ink-40); margin-top:4px; }

/* Hero Right — Portrait */
.hero-right {
  flex-shrink:0; display:flex; align-items:center; justify-content:center;
  opacity:0; animation:fadeUp 0.9s var(--ease) 1.65s forwards;
}
.portrait-wrap { position:relative; }
.portrait-halo {
  position:absolute; inset:-50px; border-radius:50%;
  background:radial-gradient(circle, rgba(201,168,76,0.12) 0%, transparent 70%);
  filter:blur(40px);
  animation:haloBreath 7s ease-in-out infinite;
}
.portrait-ring {
  position:absolute; inset:-6px; border-radius:50%;
  border:1px solid transparent;
  background:linear-gradient(var(--offwhite),var(--offwhite)) padding-box,
             conic-gradient(from 0deg, var(--gold) 0deg, rgba(201,168,76,0.1) 120deg, var(--gold-light) 240deg, var(--gold) 360deg) border-box;
  animation:rotateSlow 20s linear infinite;
}
.portrait-img {
  width:340px; height:340px; object-fit:cover; border-radius:50%;
  position:relative; z-index:1;
  box-shadow:0 30px 70px rgba(26,26,26,0.12), 0 6px 20px rgba(26,26,26,0.06);
}
/* Badge */
.portrait-badge {
  position:absolute; bottom:16px; left:-38px; z-index:3;
  background:rgba(255,255,255,0.78);
  backdrop-filter:blur(24px) saturate(1.6);
  -webkit-backdrop-filter:blur(24px) saturate(1.6);
  border:1px solid rgba(255,255,255,0.9);
  border-radius:18px; padding:13px 20px;
  box-shadow:0 12px 40px rgba(26,26,26,0.08), 0 2px 8px rgba(26,26,26,0.04);
  animation:badgeFloat 5s ease-in-out infinite;
  white-space:nowrap;
}
.badge-num { font-family:var(--ff-serif); font-style:italic; font-size:1.8rem; font-weight:400; color:var(--gold); line-height:1; }
.badge-txt { font-size:.62rem; font-weight:400; letter-spacing:.08em; color:var(--ink-40); margin-top:3px; }
@keyframes badgeFloat { 0%,100%{transform:translateY(0)}50%{transform:translateY(-9px)} }

/* Mobile badge override */
@media (max-width:768px) {
  .portrait-badge {
    transform:scale(0.78);
    transform-origin:left bottom;
    left:-8px; bottom:-4px;
    padding:14px 20px;
    background:rgba(255,255,255,0.85);
    backdrop-filter:blur(28px) saturate(2);
    -webkit-backdrop-filter:blur(28px) saturate(2);
    animation:badgeFloatMobile 5s ease-in-out infinite;
  }
  .badge-num { font-size:1.6rem; }
  .badge-txt { font-size:.68rem; }
  @keyframes badgeFloatMobile {
    0%,100%{transform:scale(0.78) translateY(0)}
    50%{transform:scale(0.78) translateY(-8px)}
  }
}

/* Hero SEO-only headings */
.hero-h1-seo, .hero-h2-seo {
  position:absolute; width:1px; height:1px;
  padding:0; margin:-1px; overflow:hidden;
  clip:rect(0,0,0,0); white-space:nowrap; border:0;
}
.seo-text-block { text-align:center; }
.nav-impressum-link { color:var(--ink-70) !important; }

/* ================================================================
   11. COURSES GRID
   ================================================================ */
.courses-grid {
  display:grid; grid-template-columns:repeat(3,1fr); gap:24px; margin-top:64px;
}
.course-card {
  background:var(--surface); border-radius:24px; overflow:hidden;
  border:1px solid var(--border);
  box-shadow:0 2px 8px rgba(26,26,26,0.03), 0 12px 32px rgba(26,26,26,0.05);
  transition:transform .4s var(--spring), box-shadow .4s var(--ease), border-color .3s;
  /* <a> Fix */
  display:block;
  text-decoration:none;
  color:inherit;
}
.course-card:not(.card--feat) {
  display: flex !important;
  flex-direction: column !important;
}
.course-card:not(.card--feat) .card-body {
  display: flex !important;
  flex-direction: column !important;
  flex: 1 !important;
}
.course-card:not(.card--feat) .card-body p {
  flex: 1 !important;
}
.course-card:not(.card--feat) .card-schnupper {
  margin-top: auto !important;
}

.course-card:hover { transform:translateY(-6px); box-shadow:0 4px 16px rgba(26,26,26,0.06), 0 24px 56px rgba(26,26,26,0.09); }

.card-img { height:220px; overflow:hidden; position:relative; }
.card-img img { width:100%; height:100%; object-fit:cover; transition:transform .6s var(--ease); display:block; }
.course-card:hover .card-img img { transform:scale(1.04); }

/* Mask-slide container for images */
.img-mask {
  position:relative; overflow:hidden;
}
.img-mask::after {
  content:''; position:absolute; inset:0;
  background:var(--warmgrey);
  transform:translateX(0);
  transition:transform 0s; /* activated by JS */
}
.img-mask.revealed::after {
  transform:translateX(101%);
  transition:transform 1s cubic-bezier(0.76,0,0.24,1) 0.1s;
}
.card-age {
  position:absolute; top:14px; left:14px;
  background:rgba(248,247,245,0.88); backdrop-filter:blur(16px);
  border-radius:50px; padding:5px 14px;
  font-size:.65rem; font-weight:600; letter-spacing:1px; text-transform:uppercase;
  color:var(--ink); border:1px solid var(--border);
}
.card-body { padding:24px 26px 28px; }
.card-body h3 { font-family:var(--ff-sans); font-size:1.05rem; font-weight:600; color:var(--ink); margin-bottom:9px; line-height:1.35; }
.card-body p  { font-size:.87rem; font-weight:300; color:var(--ink-70); line-height:1.75; }
.card-times { font-size:.8rem; font-weight:300; color:var(--ink-40); margin-top:12px; max-height:0; opacity:0; overflow:hidden; transition:max-height .4s, opacity .4s; }
.course-card:hover .card-times { max-height:80px; opacity:1; }

/* Featured Card */
.card--feat {
  grid-column: span 3;
  display: grid;
  grid-template-columns: 1fr 1fr;
  border-radius: 28px;
  text-decoration: none;
  color: inherit;
}
.card--feat .card-img { height:auto; min-height:300px; order:2; border-radius:0 24px 24px 0; }
.card--feat .card-img.img-mask { height:auto; min-height:300px; }
.card--feat .card-body { padding:50px; order:1; display:flex; flex-direction:column; justify-content:center; }
.card--feat .card-body h3 { font-family:var(--ff-serif); font-size:1.9rem; font-weight:400; font-style:italic; margin-bottom:14px; }
.card--feat .card-body p { max-width:400px; font-size:.9rem; }
.card--feat .card-times { max-height:80px; opacity:1; margin-bottom:24px; }
.feat-badge {
  display:inline-flex; align-items:center; gap:7px;
  background:var(--gold-glow); border:1px solid rgba(201,168,76,0.25);
  border-radius:50px; padding:5px 14px; margin-bottom:22px;
  font-size:.62rem; font-weight:600; letter-spacing:2px; text-transform:uppercase;
  color:var(--gold); width:fit-content;
}
.feat-badge-dot { width:5px; height:5px; border-radius:50%; background:var(--gold); animation:dotPulse 2s ease-in-out infinite; }

/* ================================================================
   12. RENTAL / GALLERY SLIDER
   ================================================================ */
.rental-layout { display:grid; grid-template-columns:1.25fr 1fr; gap:72px; align-items:center; margin-top:64px; }

.slider-wrap {
  border-radius:28px; overflow:hidden; height:520px; position:relative; cursor:pointer;
  box-shadow:0 4px 20px rgba(26,26,26,0.04), 0 30px 70px rgba(26,26,26,0.08);
}
/* Raumvermietungs-Seite: aspect-ratio statt feste Höhe */
.slider-wrap.ratio { height:auto; aspect-ratio:4/3; }

.slider-track { display:flex; height:100%; transition:transform .60s var(--spring); }
.slider-track img { min-width:100%; width:100%; height:100%; object-fit:cover; flex-shrink:0; }

.sl-btn {
  position:absolute; top:50%; transform:translateY(-50%); z-index:10;
  background:rgba(255,255,255,0.88); backdrop-filter:blur(12px);
  border:none; border-radius:50%;
  width:44px; height:44px;
  display:flex; align-items:center; justify-content:center;
  color:var(--ink); font-size:1.4rem;
  box-shadow:0 4px 16px rgba(26,26,26,0.08);
  cursor:pointer;
  transition:.3s var(--spring);
}
.sl-btn:hover { background:var(--gold); color:#fff; transform:translateY(-50%) scale(1.05); }
.sl-prev { left:16px; }
.sl-next { right:16px; }
.sl-dots { position:absolute; bottom:18px; left:50%; transform:translateX(-50%); display:flex; gap:8px; z-index:5; }
.sl-dot { width:6px; height:6px; border-radius:50%; background:rgba(255,255,255,0.5); cursor:pointer; transition:.3s; }
.sl-dot.on { background:var(--gold); width:20px; border-radius:3px; }
.slider-wrap.zoomed { position:fixed; inset:0; z-index:9999; border-radius:0; aspect-ratio:auto; height:100%; }
.slider-wrap.zoomed .slider-track img { object-fit:contain; background:#000; }

/* Rental Features Liste */
.rental-feat { list-style:none; margin:28px 0 32px; display:flex; flex-direction:column; gap:20px; }
.rental-feat li { display:flex; gap:16px; align-items:flex-start; font-size:.9rem; font-weight:300; color:var(--ink-70); line-height:1.65; }
.rf-ico {
  width:42px; height:42px; border-radius:14px; flex-shrink:0;
  background:var(--warmgrey); border:1px solid var(--border);
  display:flex; align-items:center; justify-content:center;
  transition:background .3s;
}
.rental-feat li:hover .rf-ico { background:var(--gold-glow); border-color:rgba(201,168,76,0.2); }
.rental-feat strong { display:block; color:var(--ink); font-weight:600; font-size:.87rem; margin-bottom:2px; }
.rental-note { font-size:1.0rem; font-weight:900; letter-spacing:.05em; color:#1a1a1a; font-style:italic; margin-bottom:28px; }

/* ================================================================
   13. RAUMVERMIETUNG — SEITENSPEZIFISCH
   ================================================================ */

/* Hero (Unterseite) */
.page-hero {
  min-height: auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 140px 7% 80px;
  position: relative;
  z-index: 2;
  max-width: 960px;
  margin: 0 auto;
}
@media (max-width: 640px) {
  .page-hero {
    padding: 75px 5% 60px;
  }
}
.hero-badge {
  display:inline-flex; align-items:center; gap:9px;
  background:var(--gold-glow); border:1px solid rgba(201,168,76,0.3);
  border-radius:50px; padding:7px 18px; margin-bottom:36px;
  font-size:.68rem; font-weight:600; letter-spacing:2.5px; text-transform:uppercase;
  color:var(--gold);
  opacity:0; animation:fadeUp .7s var(--ease) .3s forwards;
}
.badge-dot { width:5px; height:5px; border-radius:50%; background:var(--gold); animation:dotPulse 2s ease-in-out infinite; }
.page-hero .hero-title {
  font-size:clamp(2.6rem,6vw,5.2rem);
  font-weight:200; line-height:1; letter-spacing:-2px; margin-bottom:10px;
  opacity:0; animation:fadeUp .8s var(--ease) .45s forwards;
  /* Reset Index-Animationen */
  animation-fill-mode:forwards;
}
.page-hero .hero-title em {
  font-family:var(--ff-serif); font-style:italic; font-weight:400;
  color:var(--gold); display:block; font-size:1.08em; letter-spacing:-1.5px;
}
.page-hero .hero-sub {
  font-size:clamp(.9rem,1.5vw,1.05rem); font-weight:300;
  color:var(--ink-70); line-height:1.85; max-width:560px; margin:28px auto 0;
  opacity:0; animation:fadeUp .7s var(--ease) .6s forwards;
}
.page-hero .hero-stats {
  display:flex; gap:0; margin-top:60px;
  border:1px solid var(--border2); border-radius:20px;
  overflow:hidden; background:var(--surface);
  box-shadow:0 4px 40px rgba(26,26,26,0.06);
  opacity:0; animation:fadeUp .7s var(--ease) .75s forwards;
}
.h-stat { flex:1; padding:28px 24px; text-align:center; border-right:1px solid var(--border); }
.h-stat:last-child { border-right:none; }
.h-stat-n { font-family:var(--ff-serif); font-style:italic; font-size:2.2rem; font-weight:400; color:var(--ink); line-height:1; }
.h-stat-l { font-size:.68rem; font-weight:300; letter-spacing:.05em; color:var(--ink-40); margin-top:6px; }
.page-hero .hero-cta {
  display:flex; gap:14px; margin-top:52px; justify-content:center; flex-wrap:wrap;
  opacity:0; animation:fadeUp .7s var(--ease) .9s forwards;
}

/* Features Grid (Raumvermietung) */
.feat-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:20px; margin-top:52px; }
.feat-card {
  background:var(--surface); border-radius:20px; padding:32px 28px;
  border:1px solid var(--border);
  box-shadow:0 2px 8px rgba(26,26,26,0.03), 0 12px 32px rgba(26,26,26,0.04);
  transition:transform .35s var(--spring), box-shadow .35s var(--ease);
}
.feat-card:hover { transform:translateY(-5px); box-shadow:0 4px 16px rgba(26,26,26,0.05), 0 24px 48px rgba(26,26,26,0.07); }
.feat-ico { font-size:2rem; margin-bottom:16px; }
.feat-card h3 { font-size:.95rem; font-weight:600; color:var(--ink); margin-bottom:8px; }
.feat-card p { font-size:.84rem; font-weight:300; color:var(--ink-70); line-height:1.75; }

/* Usecases Tags */
.usecases { display:flex; flex-wrap:wrap; gap:12px; margin-top:44px; }
.usecase-tag {
  display:inline-flex; align-items:center; gap:8px;
  background:var(--gold-glow); border:1px solid rgba(201,168,76,0.22);
  border-radius:50px; padding:10px 20px;
  font-size:.78rem; font-weight:500; color:var(--gold);
  transition:background .25s, transform .3s var(--spring);
}
.usecase-tag:hover { background:rgba(201,168,76,0.28); transform:translateY(-2px); }

/* Pricing */
.pricing-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; margin-top:52px; }
.price-card {
  background:var(--surface); border-radius:22px; padding:36px 28px;
  border:1px solid var(--border);
  box-shadow:0 2px 8px rgba(26,26,26,0.03);
  text-align:center; position:relative;
  transition:transform .35s var(--spring), box-shadow .35s var(--ease);
}
.price-card:hover { transform:translateY(-6px); box-shadow:0 6px 30px rgba(26,26,26,0.08); }
.price-card.featured { background:var(--ink); color:#fff; box-shadow:0 20px 60px rgba(26,26,26,0.2); border-color:transparent; }
.price-card.featured .price-label,
.price-card.featured .price-desc { color:rgba(255,255,255,0.55); }
.price-card.featured .price-amount { color:#fff; }
.price-card.featured .price-unit { color:rgba(255,255,255,0.45); }
.popular-badge {
  position:absolute; top:-14px; left:50%; transform:translateX(-50%);
  background:var(--gold); color:#fff;
  font-size:.6rem; font-weight:700; letter-spacing:2px; text-transform:uppercase;
  padding:5px 16px; border-radius:50px;
}
.price-label { font-size:.65rem; font-weight:400; letter-spacing:3px; text-transform:uppercase; color:var(--gold); margin-bottom:16px; }
.price-amount { font-family:var(--ff-serif); font-style:italic; font-size:3rem; font-weight:400; color:var(--ink); line-height:1; }
.price-unit { font-size:.75rem; font-weight:300; color:var(--ink-40); margin-top:4px; margin-bottom:20px; }
.price-divider { height:1px; background:var(--border); margin:20px 0; }
.price-card.featured .price-divider { background:rgba(255,255,255,0.1); }
.price-features { list-style:none; text-align:left; }
.price-features li { font-size:.83rem; font-weight:300; color:var(--ink-70); padding:7px 0; border-bottom:1px solid var(--border); display:flex; align-items:center; gap:8px; }
.price-features li:last-child { border:none; }
.price-card.featured .price-features li { color:rgba(255,255,255,0.65); border-color:rgba(255,255,255,0.08); }
.price-check { color:var(--gold); font-size:.9rem; flex-shrink:0; }
.price-desc { font-size:.75rem; color:var(--ink-40); margin-top:20px; line-height:1.7; }

/* Contact-Box (CTA Raumvermietung) */
.contact-box {
  background:var(--ink); border-radius:28px; padding:70px;
  text-align:center; color:#fff;
  box-shadow:0 30px 80px rgba(26,26,26,0.12);
}
.contact-box h2 { font-family:var(--ff-serif); font-style:italic; font-size:clamp(1.8rem,4vw,3rem); font-weight:400; margin-bottom:18px; }
.contact-box p { font-size:.92rem; font-weight:300; color:rgba(255,255,255,0.55); line-height:1.85; max-width:560px; margin:0 auto 44px; }
.contact-actions { display:flex; justify-content:center; gap:14px; flex-wrap:wrap; }
.contact-chips { display:flex; gap:12px; flex-wrap:wrap; justify-content:center; margin-top:32px; }
.chip {
  display:inline-flex; align-items:center; gap:7px;
  background:rgba(255,255,255,0.05); border:1px solid rgba(255,255,255,0.1);
  border-radius:50px; padding:8px 18px;
  font-size:.74rem; font-weight:300; color:rgba(255,255,255,0.45);
}

/* Location Grid (Raumvermietung) */
.loc-grid {
  display:grid; grid-template-columns:1.6fr 1fr; gap:32px; margin-top:64px; align-items:start;
}
.map-frame {
  border-radius:24px; overflow:hidden; height:460px;
  box-shadow:0 4px 20px rgba(26,26,26,0.04), 0 20px 60px rgba(26,26,26,0.07);
}
.map-frame iframe { width:100%; height:100%; display:block; border:0; }

/* ================================================================
   14. LOCATION (Index)
   ================================================================ */
.loc-layout { display:grid; grid-template-columns:1.6fr 1fr; gap:32px; align-items:start; margin-top:64px; }
.loc-cards { display:flex; flex-direction:column; gap:16px; }
.loc-card {
  background:var(--surface); border-radius:20px; padding:26px;
  box-shadow:0 2px 8px rgba(26,26,26,0.03), 0 12px 28px rgba(26,26,26,0.05);
  transition:transform .3s var(--spring), box-shadow .3s;
  border:1px solid var(--border);
}
.loc-card:hover { transform:translateY(-3px); box-shadow:0 4px 16px rgba(26,26,26,0.05),0 20px 40px rgba(26,26,26,0.08); }
.loc-card-hd { display:flex; gap:12px; align-items:flex-start; margin-bottom:16px; }
.loc-card-ico { width:40px; height:40px; border-radius:12px; background:var(--warmgrey); border:1px solid var(--border); display:flex; align-items:center; justify-content:center; font-size:1.1rem; flex-shrink:0; }
.loc-card-hd strong { display:block; font-weight:600; font-size:.92rem; color:var(--ink); margin-bottom:2px; }
.loc-card-hd p { font-size:.82rem; font-weight:300; color:var(--ink-70); line-height:1.55; }
.hrs-row { display:flex; justify-content:space-between; padding:9px 0; border-bottom:1px solid var(--border); font-size:.83rem; }
.hrs-row:last-child { border:none; }
.hrs-row span:first-child { font-weight:500; color:var(--ink); font-size:.8rem; }
.hrs-row span:last-child  { font-weight:300; color:var(--ink-40); }
.hrs-row.dim span { color:var(--ink-20); }

/* ================================================================
   15. FOOTER — INDEX (großer 3-Spalten-Footer)
   ================================================================ */
footer.footer-index {
  background:var(--ink);
  color:rgba(255,255,255,0.65);
  position:relative; z-index:2;
}
.footer-main {
  max-width:1360px; margin:0 auto; padding:80px 7% 60px;
  display:grid; grid-template-columns:1.5fr 1fr 1fr; gap:56px;
}
.footer-brand { display:flex; gap:14px; align-items:center; margin-bottom:20px; }
.footer-logo-img { width:48px; height:48px; border-radius:10px; object-fit:cover; border:1px solid rgba(255,255,255,0.1); }
.footer-brand-name { font-family:var(--ff-sans); font-size:.96rem; font-weight:600; color:#fff; display:block; line-height:1.2; }
.footer-brand-sub  { font-size:.58rem; font-weight:300; letter-spacing:2.5px; text-transform:uppercase; color:rgba(201,168,76,0.7); display:block; margin-top:2px; }
.footer-tagline { font-size:.84rem; font-weight:300; color:rgba(255,255,255,0.35); line-height:1.85; max-width:280px; }

.footer-col h4 { font-size:.62rem; font-weight:400; letter-spacing:3.5px; text-transform:uppercase; color:rgba(201,168,76,0.65); margin-bottom:22px; }
.footer-link { display:flex; align-items:center; gap:10px; color:rgba(255,255,255,0.42); font-size:.86rem; font-weight:300; margin-bottom:12px; transition:color .2s; }
.footer-link:hover { color:rgba(255,255,255,0.85); }
.footer-link-dim { color:rgba(255,255,255,0.22) !important; font-size:.8rem !important; }
.footer-link-dim:hover { color:rgba(255,255,255,0.65) !important; }

.footer-socials { display:flex; flex-direction:column; gap:12px; margin-top:16px; }
.footer-social {
  display:inline-flex; align-items:center; gap:12px;
  padding:10px 16px; border-radius:12px;
  background:rgba(255,255,255,0.04); border:1px solid rgba(255,255,255,0.08);
  color:rgba(255,255,255,0.45); font-size:.83rem; font-weight:300;
  transition:.3s var(--ease);
}
.footer-social:hover { background:rgba(201,168,76,0.12); border-color:rgba(201,168,76,0.25); color:rgba(255,255,255,0.85); }
.footer-social svg { opacity:.7; flex-shrink:0; }
.footer-social:hover svg { opacity:1; }

.footer-bottom {
  max-width:1360px; margin:0 auto; padding:22px 7%;
  border-top:1px solid rgba(255,255,255,0.06);
  display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:12px;
}
.footer-copy { font-size:.75rem; font-weight:300; color:rgba(255,255,255,0.2); }
.footer-made { font-size:.8rem; font-weight:300; color:rgba(255,255,255,0.32); display:flex; align-items:center; gap:6px; flex-wrap:wrap; }
.heart { display:inline-block; animation:beat 1.3s infinite; color:var(--rose); }
.sascha-a { color:rgba(201,168,76,0.75); font-weight:500; transition:.2s; }
.sascha-a:hover { color:var(--gold); }
.sascha-handle { font-size:.72rem; color:rgba(255,255,255,0.18); }

/* ================================================================
   16. FOOTER — UNTERSEITEN (schlanker 1-Zeilen-Footer)
   ================================================================ */
footer.footer-sub {
  background:var(--ink); color:rgba(255,255,255,0.35);
  padding:36px 7%; text-align:center;
  font-size:.78rem; font-weight:300;
  position:relative; z-index:2;
}
footer.footer-sub a { color:rgba(255,255,255,0.5); text-decoration:underline; transition:color .2s; }
footer.footer-sub a:hover { color:var(--gold); }
footer.footer-sub .footer-dot { margin:0 10px; }

/* ================================================================
   17. WA FAB
   ================================================================ */
.wa-fab {
  position:fixed; bottom:28px; right:28px; z-index:4000;
  width:56px; height:56px; border-radius:50%; background:#25d366;
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 4px 20px rgba(37,211,102,.35);
  transition:.35s var(--spring);
}
.wa-fab:hover { transform:scale(1.08) translateY(-3px); box-shadow:0 8px 32px rgba(37,211,102,.5); }
.wa-ring { position:absolute; width:100%; height:100%; border-radius:50%; background:rgba(37,211,102,.25); animation:waPulse 2.2s ease-out infinite; }

/* ================================================================
   18. MODALS
   ================================================================ */
.modal-veil {
  display:none; position:fixed; inset:0; z-index:9000;
  background:rgba(26,26,26,0.5);
  backdrop-filter:blur(24px) saturate(0.8);
  align-items:center; justify-content:center;
}
.modal-veil.show { display:flex; }
.modal-box {
  background:var(--surface); border:1px solid var(--border);
  border-radius:28px; padding:52px; width:90%; max-width:660px; position:relative;
  box-shadow:0 40px 100px rgba(26,26,26,0.15);
  animation:modalIn .45s var(--spring);
  overflow-y:auto; max-height:88vh;
}
.modal-close {
  position:absolute; right:22px; top:20px; font-size:22px;
  background:none; border:none; color:var(--ink-20); transition:.25s; line-height:1; cursor:pointer;
}
.modal-close:hover { color:var(--ink); transform:rotate(90deg); }
.modal-txt p { margin-bottom:14px; font-size:.87rem; font-weight:300; line-height:1.8; color:var(--ink-70); }
.modal-txt strong { color:var(--ink); font-weight:600; }
.impressum-txt p { margin-bottom:14px; font-size:.87rem; font-weight:300; line-height:1.8; color:var(--ink-70); }
.impressum-txt strong { color:var(--ink); font-weight:600; }

/* Timetable */
.timetable { width:100%; border-collapse:separate; border-spacing:0 10px; }
.timetable thead th { text-align:left; padding:0 16px 8px; color:var(--ink-20); font-size:.62rem; text-transform:uppercase; letter-spacing:2.5px; font-weight:400; }
.timetable tbody tr { transition:transform .2s; }
.timetable tbody tr:hover { transform:translateX(4px); }
.timetable tbody td { padding:13px 16px; background:var(--warmgrey); font-size:.86rem; font-weight:300; color:var(--ink-70); border:1px solid transparent; border-top:1px solid var(--border); border-bottom:1px solid var(--border); }
.timetable tbody td:first-child { border-left:1px solid var(--border); border-radius:12px 0 0 12px; font-weight:700; font-size:.95rem; width:50px; }
.timetable tbody td:last-child  { border-right:1px solid var(--border); border-radius:0 12px 12px 0; }
.tt-chip { display:inline-block; padding:4px 12px; border-radius:50px; font-size:.73rem; font-weight:500; }
.r-mo td:first-child { color:var(--gold); }  .r-mo .tt-chip { background:var(--gold-glow); color:var(--gold); } .r-mo:hover td { background:#ede9e0; }
.r-di td:first-child { color:var(--rose); }  .r-di .tt-chip { background:rgba(201,160,168,0.14); color:var(--rose); } .r-di:hover td { background:#ede9e3; }
.r-mi td:first-child { color:#78a8a0; }       .r-mi .tt-chip { background:rgba(120,168,160,0.12); color:#78a8a0; } .r-mi:hover td { background:#eaeae8; }

/* ================================================================
   19. IMPRESSUM / DATENSCHUTZ — SEITENSPEZIFISCH
   ================================================================ */
.legal-main { max-width:780px; margin:0 auto; padding:80px 6% 120px; }

.legal-eyebrow {
  display:flex; align-items:center; gap:14px;
  font-size:.62rem; font-weight:400; letter-spacing:4px; text-transform:uppercase;
  color:var(--gold); margin-bottom:18px;
}
.legal-eyebrow-line { display:inline-block; width:32px; height:1px; background:var(--gold); }

.legal-h1 {
  font-family:var(--ff-serif); font-style:italic;
  font-size:clamp(2.2rem,5vw,3.4rem); font-weight:400;
  color:var(--ink); line-height:1.1; margin-bottom:56px;
}
.legal-card {
  background:var(--surface); border-radius:18px; padding:32px 36px;
  border:1px solid var(--border);
  box-shadow:0 2px 8px rgba(26,26,26,0.03), 0 8px 24px rgba(26,26,26,0.04);
  margin-bottom:16px;
}
.legal-card-label {
  font-size:.58rem; font-weight:600; letter-spacing:3.5px; text-transform:uppercase;
  color:var(--gold); margin-bottom:12px;
}
.legal-card p { font-size:.88rem; font-weight:300; color:var(--ink-70); line-height:1.85; }
.legal-card p + p { margin-top:10px; }
.legal-card strong { color:var(--ink); font-weight:600; }
.legal-card a { color:var(--gold); text-decoration:underline; }
.legal-card .meta { font-size:.78rem; color:var(--ink-40); margin-top:16px; }
.legal-divider { height:1px; background:var(--border2); margin:24px 0; }

/* ================================================================
   20. RESPONSIVE
   ================================================================ */
@media (max-width:1100px) {
  .courses-grid { grid-template-columns:repeat(2,1fr); }
  .card--feat { grid-column:span 2; }
  .rental-layout { grid-template-columns:1fr; gap:44px; }
  .slider-wrap { height:400px; }
  .loc-layout, .loc-grid { grid-template-columns:1fr; }
  .map-frame { height:300px; }
  .footer-main { grid-template-columns:1fr 1fr; }
  .pricing-grid { grid-template-columns:repeat(2,1fr); }
}

@media (max-width:768px) {
  body { padding-top:35px; }
  .nav { padding:0 5%; height:70px; }

  /* Mobile Logo verkleinern */
  .nav-logo-name { font-size:.72rem; letter-spacing:0; }
  .nav-logo-sub  { font-size:.50rem; letter-spacing:2px; }
  .logo-mark     { width:34px; height:34px; border-radius:8px; }

  /* Burger */
  .burger { display:flex; }
  .nav-links {
    position:absolute; top:70px; left:0; width:100%;
    background:rgba(248,247,245,.98); backdrop-filter:blur(20px);
    flex-direction:column; align-items:center; gap:0;
    max-height:0; overflow:hidden; opacity:0;
    transition:max-height .4s var(--ease), opacity .3s;
    border-bottom:1px solid var(--border);
  }
.nav-links.open { max-height:700px; opacity:1; padding:20px 0 28px; border-radius:0 0 20px 20px; box-shadow:0 12px 40px rgba(26,26,26,0.08); }
.nav-links li { padding:12px 0; width:100%; text-align:center; border-bottom:1px solid var(--border); }
  .nav-cta { padding:8px 20px !important; }

  /* Hero index */
  .hero { flex-direction:column; padding:90px 6% 70px; gap:36px; min-height:auto; }
  .hero-right { order:-1; }
  .portrait-img { width:240px; height:240px; }
  .hero-actions { flex-direction:column; }
  .btn { width:100%; justify-content:center; }
  .mag { width:100%; }
  .hero-stats { gap:24px; flex-wrap:wrap; }

  /* Sections */
  .section { padding:80px 5%; }
  .section-shade-inner, .section-white-inner { padding:80px 5%; }

  /* Courses */
  .courses-grid { grid-template-columns:1fr; gap:20px; }
  .card--feat { grid-column:span 1; grid-template-columns:1fr; }
  .card--feat .card-img   { height:220px; order:0; border-radius:22px 22px 0 0; min-height:unset; }
  .card--feat .card-body  { order:1; padding:28px; }
  .card-times { max-height:80px !important; opacity:1 !important; }

  /* Slider */
  .slider-wrap { height:280px; border-radius:20px; }
  .slider-wrap.ratio { height:auto; }

  /* Map */
  .map-frame { height:260px; }

  /* Pricing */
  .pricing-grid { grid-template-columns:1fr; }

  /* Feat Grid */
  .feat-grid { grid-template-columns:1fr; }

  /* Contact Box */
  .contact-box { padding:36px 24px; }
  .contact-actions { flex-direction:column; align-items:center; }

  /* Footer index */
  .footer-main { grid-template-columns:1fr; gap:36px; padding:56px 5% 40px; }
  .footer-bottom { flex-direction:column; align-items:flex-start; padding:18px 5%; }

  /* Modals */
  .modal-box { padding:28px 20px; border-radius:22px; }
  .timetable thead { display:none; }
  .timetable tbody tr { display:flex; align-items:center; }
  .timetable tbody td {
    padding:10px 8px; font-size:.78rem;
    border-top:1px solid var(--border); border-bottom:1px solid var(--border);
    border-left:none !important; border-right:none !important;
    border-radius:0 !important; flex:1; min-width:0;
  }
  .timetable tbody td:first-child {
    flex:0 0 38px; font-size:.85rem; font-weight:700;
    border-left:1px solid var(--border) !important;
    border-radius:12px 0 0 12px !important; padding-left:10px;
  }
  .timetable tbody td:last-child {
    flex:2; border-right:1px solid var(--border) !important;
    border-radius:0 12px 12px 0 !important;
  }
  .tt-chip { font-size:.68rem; padding:3px 8px; white-space:nowrap; }

  /* Legal pages */
  .legal-main { padding:60px 5% 80px; }
  .legal-card { padding:24px 20px; }

  /* Subpage nav */
  .nav-back span { display:none; }

  a, button { cursor:auto; }
}

@media (max-width:480px) {
  .hero-title { font-size:2.6rem; }
  .hero-title-italic { font-size:3rem; }
  .hero-title-name { font-size:1.5rem; }
.page-hero .hero-stats { flex-direction:row; border-radius:14px; }
.h-stat { border-bottom:none; border-right:1px solid var(--border); }
.h-stat:last-child { border-right:none; }
  .logo-mark { width:30px; height:30px; }
  .nav-logo-name { font-size:.63rem; }
  .nav-logo-sub { font-size:.48rem; letter-spacing:1.5px; }
}


/* ================================================================
   NAV DROPDOWN — Kurse
   ================================================================ */
.nav-dropdown {
  position: relative;
  padding-bottom: 18px;
  margin-bottom: -18px;
}

.nav-dropdown-toggle {
  display: inline-flex;
  align-items: center;
  gap: 5px;
}

.nav-arrow {
  transition: transform 0.3s var(--ease);
  flex-shrink: 0;
}

/* Desktop: Hover öffnet */
@media (hover: hover) {
  .nav-dropdown:hover .nav-arrow {
    transform: rotate(180deg);
  }
  .nav-dropdown:hover .nav-dropdown-menu {
    opacity: 1;
    visibility: visible;
    transform: translateX(-50%) translateY(0);
    pointer-events: auto;
  }
}

/* Dropdown-Panel */
.nav-dropdown-menu {
  position: absolute;
  top: calc(100% - 2px);
  left: 50%;
  transform: translateX(-50%) translateY(8px);
  list-style: none;
  background: rgba(255,255,255,0.97);
  backdrop-filter: blur(24px);
  border: 1px solid var(--border2);
  border-radius: 18px;
  padding: 10px;
  min-width: 260px;
  box-shadow: 0 8px 40px rgba(26,26,26,0.10), 0 2px 8px rgba(26,26,26,0.05);
  opacity: 0;
  visibility: hidden;
  transform: translateX(-50%) translateY(8px);
  transition: opacity 0.3s var(--ease), transform 0.35s var(--spring), visibility 0.3s;
  pointer-events: none;
  z-index: 500;
}

/* Kleines Dreieck oben */
.nav-dropdown-menu::before {
  content: '';
  position: absolute;
  top: -7px;
  left: 50%;
  width: 12px;
  height: 12px;
  background: #fff;
  border-left: 1px solid var(--border2);
  border-top: 1px solid var(--border2);
  transform: translateX(-50%) rotate(45deg);
  border-radius: 2px 0 0 0;
}

.nav-dropdown-menu li a {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 14px;
  border-radius: 10px;
  font-size: .75rem;
  font-weight: 400;
  letter-spacing: .4px;
  color: var(--ink-70);
  transition: background .2s, color .2s;
}
.nav-dropdown-menu li a::after { display: none; } /* Underline-Effekt deaktivieren */
.nav-dropdown-menu li a:hover {
  background: var(--warmgrey);
  color: var(--ink);
}

.drop-age {
  flex-shrink: 0;
  font-size: .6rem;
  font-weight: 600;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: var(--gold);
  background: var(--gold-glow);
  border-radius: 50px;
  padding: 3px 9px;
  white-space: nowrap;
}


/* Mobile: Dropdown klappt inline auf */
@media (max-width: 768px) {
  .nav-dropdown-menu {
    position: static;
    opacity: 1;
    visibility: hidden;
    transform: none;
    box-shadow: none;
    border: none;
    border-radius: 0;
    background: transparent;
    padding: 0;
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.4s var(--ease), visibility 0.4s;
    pointer-events: none;
    min-width: unset;
    width: 100%;
  }
  .nav-dropdown-menu::before { display: none; }

  .nav-dropdown-menu.open {
    max-height: 500px;
    visibility: visible;
    pointer-events: auto;
  }

  /* Items zentrieren wie die anderen Nav-Links */
  .nav-dropdown-menu li {
    padding: 4px 0;
    text-align: center;
  }

  .nav-dropdown-menu li a {
    justify-content: center;
    padding: 8px 20px;
    gap: 10px;
    font-size: .72rem;
    color: var(--ink-70);
    border-radius: 10px;
    display: inline-flex;
  }

  .nav-dropdown-menu li a:hover {
    background: var(--warmgrey);
  }

  .drop-age {
    font-size: .58rem;
    padding: 2px 8px;
  }

  /* Pfeil-Animation auf Mobile */
  .nav-arrow {
    transition: transform 0.3s var(--ease);
  }
  .nav-arrow.open {
    transform: rotate(180deg);
  }

  /* "KURSE ↓" selbst auch zentrieren */
.nav-dropdown {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 10px 0;
    margin-bottom: 0;
    padding-bottom: 0;
  }
}




/* Gold-Ring Klick-Animation */
.course-card:active {
  transform: scale(0.98);
}

@keyframes goldRing {
  0%   { box-shadow: 0 0 0 0px rgba(201,168,76,0.6); }
  50%  { box-shadow: 0 0 0 8px rgba(201,168,76,0.25); }
  100% { box-shadow: 0 0 0 14px rgba(201,168,76,0); }
}

.course-card.clicked {
  animation: goldRing 0.6s var(--ease) forwards;
  border-color: var(--gold);
}




/*Schnupperkurs buchen Calling Card */
.card-schnupper {
  display: inline-block;
  margin-top: auto;
  padding: 8px 18px;
  font-size: .75rem;
  font-weight: 600;
  letter-spacing: .5px;
  color: var(--gold);
  border: 1.5px solid rgba(201,168,76,0.5);
  border-radius: 999px;
  transition: background .2s, border-color .2s;
}
.course-card:hover .card-schnupper {
  background: var(--gold-glow);
  border-color: var(--gold);
}
.card-body {
  display: flex;
  flex-direction: column;
  flex: 1;
}
.card-body p {
  flex: 1;
}









/* Video Gallery – Carousel */
.video-gallery {
  margin-top:64px;
}

.video-carousel {
  position:relative;
  margin-top:32px;
  padding-bottom:48px;
}

.video-track {
  display:flex;
  gap:20px;
  transition:transform .52s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  will-change:transform;
}

.video-track-viewport {
  overflow:hidden;
  margin-left:-60px;
  margin-right:-60px;
  padding-left:60px;
  padding-right:60px;
}
@media (max-width:640px){
  .video-track-viewport {
    margin-left:-32px;
    margin-right:-32px;
    padding-left:32px;
    padding-right:32px;
  }
}

.video-card {
  flex:0 0 260px;
  aspect-ratio:9/16;
  border-radius:20px;
  overflow:hidden;
  position:relative;
  cursor:pointer;
  background:#1a1a1a;
  box-shadow:0 8px 32px rgba(26,26,26,0.12);
  transition:
    filter .45s ease,
    transform .45s cubic-bezier(0.25, 0.46, 0.45, 0.94),
    opacity .45s ease,
    box-shadow .45s ease;
  filter:blur(4px);
  transform:scale(0.86);
  opacity:0.55;
  user-select:none;
}
@media (max-width:640px){
  .video-card { flex:0 0 200px; }
}
@media (max-width:400px){
  .video-card { flex:0 0 172px; }
}

.video-card.vc-active {
  filter:blur(0px);
  transform:scale(1);
  opacity:1;
  box-shadow:0 16px 56px rgba(26,26,26,0.22);
}
.video-card.vc-active:hover {
  transform:scale(1.02);
  box-shadow:0 20px 64px rgba(26,26,26,0.28);
}

.video-card video {
  width:100%; height:100%; object-fit:cover; display:block;
  pointer-events:none;
}
.video-overlay {
  position:absolute; inset:0;
  background:linear-gradient(to top, rgba(26,26,26,0.82) 0%, rgba(26,26,26,0.28) 50%, transparent 80%);
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  transition:opacity .3s ease;
}
.video-card:not(.vc-active) .video-overlay {
  opacity:0.4;
}
.video-play-btn {
  width:64px; height:64px; border-radius:50%;
  background:rgba(201,168,76,0.95);
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 6px 28px rgba(201,168,76,0.5);
  transition:transform .4s cubic-bezier(0.34, 1.56, 0.64, 1), background .3s, opacity .3s;
}
.video-card:not(.vc-active) .video-play-btn {
  opacity:0;
  transform:scale(0.6);
}
.video-card.vc-active:hover .video-play-btn {
  transform:scale(1.15);
  background:rgba(201,168,76,1);
  box-shadow:0 8px 36px rgba(201,168,76,0.7);
}
.video-label {
  color:rgba(255,255,255,0.95);
  font-size:.72rem;
  letter-spacing:1.4px;
  text-transform:uppercase;
  margin-top:16px;
  font-weight:500;
  text-shadow:0 2px 8px rgba(0,0,0,0.3);
  transition:opacity .3s;
}
.video-card:not(.vc-active) .video-label { opacity:0; }

/* Arrow buttons */
.vc-arrows {
  display:flex; gap:12px; justify-content:center; margin-top:24px;
}
.vc-btn {
  width:44px; height:44px; border-radius:50%;
  background:var(--surface); border:1px solid var(--border);
  display:flex; align-items:center; justify-content:center;
  cursor:pointer; transition:background .25s, transform .25s, box-shadow .25s;
  box-shadow:0 2px 10px rgba(26,26,26,0.07);
}
.vc-btn:hover { background:var(--gold-glow); transform:scale(1.08); box-shadow:0 4px 16px rgba(201,168,76,0.2); }
.vc-btn:disabled { opacity:0.3; cursor:default; transform:none; }
.vc-btn svg { pointer-events:none; }

/* Dots */
.vc-dots {
  display:flex; gap:7px; justify-content:center; margin-top:16px;
}
.vc-dot {
  width:7px; height:7px; border-radius:50%;
  background:var(--border); border:none; padding:0; cursor:pointer;
  transition:background .3s, transform .3s, width .3s;
}
.vc-dot.active {
  background:var(--gold);
  width:22px; border-radius:4px;
}
