/* ──────────────────────────────────────────
   Design Tokens (Light + Dark)
   ────────────────────────────────────────── */
:root {
  --bg: #ffffff;
  --fg: #111111;
  --muted: #6b7280;
  --line: #e5e7eb;

  /* Primary / Accent (für Buttons etc.) */
  --accent-bg: #111111;
  --accent-fg: #ffffff;

  --surface: #ffffff;
  --surface-elev: #ffffff;
  --surface-a90: rgba(255,255,255,0.90);

  --radius: 14px;
  --radius-sm: 10px;
  --radius-lg: 18px;
  --shadow-1: 0 2px 10px rgba(0,0,0,0.05);
  --shadow-2: 0 6px 24px rgba(0,0,0,0.06);
  --shadow-3: 0 24px 64px rgba(0,0,0,0.10);

  --space-1: 4px;
  --space-2: 8px;
  --space-3: 12px;
  --space-4: 16px;
  --space-5: 20px;
  --space-6: 24px;
  --space-7: 32px;
  --space-8: 40px;

  --fs-200: clamp(12px, .85vw, 13px);
  --fs-300: 14px;
  --fs-400: 16px;
  --fs-500: clamp(17px, 1.1vw, 18px);
  --fs-600: clamp(18px, 1.25vw, 20px);
  --fs-700: clamp(22px, 2.5vw, 28px);
  --fs-800: clamp(28px, 4vw, 36px);

  /* Focus rings (light) */
  --ring: 0 0 0 3px rgba(17,17,17,0.10);
  --ring-strong: 0 0 0 3px rgba(17,17,17,0.18);

  color-scheme: light;
}

@media (prefers-color-scheme: dark) {
  :root {
    --bg: #0c0c0d;
    --fg: #f7f7f7;
    --muted: #9aa0a6;
    --line: #2a2b2e;

    /* In Dark Mode muss Button-Text dunkel sein,
       weil der Button-Hintergrund hell ist. */
    --accent-bg: #f7f7f7;
    --accent-fg: #0c0c0d;

    --surface: #0f1012;
    --surface-elev: #121316;
    --surface-a90: rgba(15,16,18,0.85);

    --shadow-1: 0 2px 10px rgba(0,0,0,0.35);
    --shadow-2: 0 6px 24px rgba(0,0,0,0.4);
    --shadow-3: 0 24px 64px rgba(0,0,0,0.5);

    /* Focus rings (dark) */
    --ring: 0 0 0 3px rgba(247,247,247,0.18);
    --ring-strong: 0 0 0 3px rgba(247,247,247,0.28);

    color-scheme: dark;
  }
}

/* ─────────── Base / Reset ─────────── */
* { box-sizing: border-box; }
html, body { height: 100%; }

/* WICHTIG gegen horizontales “Wackeln” */
html { overflow-x: hidden; -webkit-text-size-adjust: 100%; }
body { overflow-x: hidden; }

body {
  margin: 0;
  background: var(--bg);
  color: var(--fg);
  font: var(--fs-400)/1.55 system-ui, -apple-system, "Segoe UI", Roboto, Ubuntu, Cantarell, "Noto Sans", sans-serif;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

:where(button, input, select, textarea) { font: inherit; color: inherit; }

a { color: inherit; text-decoration: none; }
a:hover { text-decoration: underline; }

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

/* Utilities */
.visually-hidden { position:absolute!important; width:1px; height:1px; margin:-1px; padding:0; border:0; overflow:hidden; clip:rect(0 0 0 0); clip-path:inset(50%); }
[hidden] { display:none!important; }
.muted { color: var(--muted); }
.container { max-width: 1040px; margin: 0 auto; padding: var(--space-6); }
.section { padding-block: var(--space-7); }

/* min-width:0 ist wichtig, damit lange Inhalte nicht overflowen */
.row { display:flex; gap:var(--space-3); align-items:center; flex-wrap:wrap; }
.row > * { min-width: 0; }
.row.end { justify-content:flex-end; }
.row.gap { gap:var(--space-4); }

.grid-2 { display:grid; gap:1rem; grid-template-columns:1fr 1fr; }
.small { font-size:var(--fs-300); }

/* ─────────── Header / Navigation ─────────── */
.nav {
  position:sticky; top:0; z-index:50;
  display:flex; align-items:center; justify-content:space-between;
  gap: 10px;
  flex-wrap: wrap;              /* verhindert Überlauf auf Mobile */
  padding:12px var(--space-6);
  border-bottom:1px solid var(--line);
  backdrop-filter:saturate(180%) blur(6px);
  background:var(--surface-a90);
}

.brand { font-weight:700; letter-spacing:0.2px; font-size:var(--fs-500); }

.nav-right, .nav-main {
  display:flex;
  gap:var(--space-2);
  align-items:center;
  flex-wrap: wrap;              /* verhindert Überlauf auf Mobile */
  min-width: 0;
}

/* Top-Level Nav Links */
.nav a { padding:8px 10px; border-radius:8px; white-space: nowrap; }
.nav a:focus-visible { outline:none; box-shadow:var(--ring-strong); }

/* ─────────── Hero ─────────── */
.hero { padding:var(--space-8) 0 var(--space-4); }
.hero h1 { margin:0 0 var(--space-2); font-size:var(--fs-800); line-height:1.1; letter-spacing:-0.02em; }
.hero p { margin:0; color:var(--muted); font-size:var(--fs-500); }

/* ─────────── Forms ─────────── */
.field { display:flex; flex-direction:column; gap:6px; min-width: 0; }
.field label { font-size:var(--fs-300); color:var(--muted); }

.field input,
.field select,
.field textarea {
  border:1px solid var(--line);
  border-radius:var(--radius-sm);
  padding:10px 12px;
  background:var(--surface);
  color:inherit;

  /* wichtig gegen horizontales Scrollen */
  width: 100%;
  min-width: 0;

  transition:border-color .15s ease, box-shadow .15s ease, background .15s ease;
}

.field textarea { min-height:120px; resize:vertical; }

.field input::placeholder,
.field textarea::placeholder { color:color-mix(in oklab, var(--muted) 75%, transparent); }

.field input:focus,
.field select:focus,
.field textarea:focus { outline:none; border-color:var(--fg); box-shadow:var(--ring); }

.field .help { font-size:var(--fs-300); color:var(--muted); }

.field.is-invalid input,
.field.is-invalid select,
.field.is-invalid textarea,
.field.invalid input,
.field.invalid select,
.field.invalid textarea {
  border-color:#dc2626!important;
  box-shadow:0 0 0 3px rgba(220,38,38,.1);
}

.field .error-msg {
  color:#b91c1c;
  margin-top:.25rem;
  display:block;
  overflow-wrap:anywhere;
  word-break: break-word;
}

.check { display:inline-flex; align-items:center; gap:var(--space-2); min-width: 0; }
.filters { padding:12px 0 8px; border-bottom:1px solid var(--line); margin-bottom:var(--space-4); }

/* Fehlerzusammenfassung */
.error-summary {
  border:1px solid #dc2626;
  background:#fef2f2;
  color:#991b1b;
  padding:.75rem 1rem;
  border-radius:.5rem;
  margin-bottom:1rem;
  list-style:none;
}
.error-summary ul { margin:.25rem 0 0; padding-left:1.2rem; }
.error-summary:focus { outline:2px solid #dc2626; outline-offset:2px; }

/* ─────────── Buttons ─────────── */
.btn {
  appearance:none; cursor:pointer;
  border:1px solid var(--accent-bg);
  background:var(--accent-bg);
  color:var(--accent-fg);

  padding:10px 14px;
  border-radius:999px;
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  font-size:var(--fs-400); line-height:1;
  transition:transform .04s ease, box-shadow .2s ease, background .2s ease, color .2s ease, border-color .2s ease;
}

.btn:hover { transform:translateY(-1px); box-shadow:var(--shadow-2); }
.btn:active { transform:translateY(0); box-shadow:var(--shadow-1); }
.btn:focus-visible { outline:none; box-shadow:var(--ring-strong); }
.btn:disabled { opacity:.5; cursor:not-allowed; box-shadow:none; }

.btn-outline { background:transparent; color:var(--fg); border:1px solid var(--line); }
.btn-ghost  { background:transparent; color:var(--fg); border:1px solid transparent; }
.btn-link   { background:transparent; border:none; padding:8px 10px; color:var(--fg); }

/* Accent-Button bleibt gleich wie .btn, aber als semantische Klasse */
.btn-accent { background:var(--accent-bg); border-color:var(--accent-bg); color:var(--accent-fg); }

.btn-danger { background:#dc2626; border-color:#dc2626; color:#fff; }
.btn-danger:hover { background:#b91c1c; border-color:#b91c1c; }

.btn-sm { padding:6px 10px; font-size:var(--fs-300); }
.btn-lg { padding:14px 18px; font-size:var(--fs-500); }
.btn-block { width:100%; }

/* ─────────── Cards & Grid ─────────── */
.grid {
  list-style:none; margin:0; padding:0;
  display:grid; gap:var(--space-3);
  grid-template-columns:repeat(auto-fill,minmax(260px,1fr));
}

.card {
  border:1px solid var(--line);
  border-radius:24px;
  padding:var(--space-4);
  background:var(--surface-elev);
  box-shadow:var(--shadow-2);
  display:flex;
  flex-direction:column;
  gap:var(--space-3);
  transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease;
  overflow:hidden;
  min-width: 0;
}

.card:hover { transform:translateY(-2px); box-shadow:var(--shadow-3); }
.card h3 { margin:0; font-size:var(--fs-600); letter-spacing:-0.01em; }
.card .actions {
  margin-top:auto;
  display:flex;
  gap:var(--space-2);
  flex-wrap: wrap;            /* verhindert Overflow bei vielen Buttons */
}
.card .actions > * { min-width: 0; }

.meta { display:flex; gap:10px; flex-wrap:wrap; color:var(--muted); font-size:var(--fs-300); min-width: 0; }
.tag {
  display:inline-block;
  border:1px solid var(--line);
  border-radius:999px;
  padding:4px 10px;
  font-size:12px;
  background:var(--surface);
  color:inherit;
}

/* Club-Bild in Karten (Full-bleed, aber ohne 120% Breite) */
.card-media {
  position:relative;
  width: calc(100% + 2 * var(--space-4));
  aspect-ratio:16/9;
  margin: calc(-1 * var(--space-4)) calc(-1 * var(--space-4)) var(--space-3);
  border-radius:0;
  overflow:hidden;
}
.card-media img {
  width:100%;
  height:100%;
  object-fit:cover;
}

/* ─────────── Dialogs ─────────── */
.dialog {
  border:none; border-radius:var(--radius-lg); padding:0;
  box-shadow:var(--shadow-3);
  width:min(560px,92vw);
  max-width: calc(100vw - 24px);
  max-height:min(82vh,900px);
  overflow:hidden;
  background:var(--surface-elev); color:inherit;
}
.dialog::backdrop { background:rgba(0,0,0,0.28); backdrop-filter:blur(2px); }
.dialog header { padding:14px var(--space-4); border-bottom:1px solid var(--line); font-weight:600; }
.dialog .tabs { display:flex; gap:4px; border-bottom:1px solid var(--line); padding:12px; flex-wrap:wrap; }
.dialog .tabs button { border:none; background:transparent; padding:8px 12px; border-radius:999px; cursor:pointer; }
.dialog [aria-selected="true"] { background:var(--accent-bg); color:var(--accent-fg); }

.stack { display:flex; flex-direction:column; gap:var(--space-3); padding:var(--space-4); }
.stack > * { min-width: 0; }

/* Buchungs-/Payment-Dialoge */
.booking-dialog {
  width:min(640px,96vw);
  max-width: calc(100vw - 16px);
  max-height:min(86vh,900px);
  background:var(--surface-elev);
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow-3);
  border:1px solid var(--line);
  overflow:hidden;
}
.booking-dialog .dialog-header {
  padding:var(--space-4) var(--space-4) var(--space-3);
  border-bottom:1px solid var(--line);
}
.booking-dialog .dialog-header h2 {
  margin:0 0 4px 0;
  font-size:var(--fs-600);
  letter-spacing:-0.02em;
}
.booking-dialog .dialog-header p { margin:0; color:var(--muted); }
.booking-dialog .stack { padding:var(--space-4); }
.booking-dialog footer {
  padding:var(--space-3) var(--space-4);
  border-top:1px solid var(--line);
}
.booking-dialog footer .btn { min-width:140px; }

/* Buchungs-Zusammenfassung */
.booking-summary {
  display:flex;
  justify-content:space-between;
  gap:var(--space-4);
  padding:var(--space-4);
  border-radius:var(--radius-lg);
  background:linear-gradient(
          135deg,
          color-mix(in oklab, var(--surface-elev) 80%, #eff6ff 20%),
          color-mix(in oklab, var(--surface-elev) 80%, #e0f2fe 20%)
  );
  border:1px solid color-mix(in oklab, var(--line) 70%, #bfdbfe 30%);
  position:relative;
  overflow:hidden;
  min-width: 0;
}
.booking-summary::before {
  content:"";
  position:absolute;
  inset:-40px auto auto -40px;
  width:120px;
  height:120px;
  border-radius:999px;
  background:radial-gradient(circle at center, rgba(255,255,255,0.22), transparent 60%);
  opacity:.7;
  pointer-events:none;
}
.booking-summary-main {
  display:flex;
  gap:var(--space-3);
  align-items:flex-start;
  min-width: 0;
}
.booking-summary-main h3 { margin:0 0 4px 0; font-size:var(--fs-500); }
.booking-summary-main p { margin:0; }
.booking-summary-text { display:flex; flex-direction:column; gap:4px; min-width: 0; }
.booking-summary-media {
  flex:0 0 64px;
  height:64px;
  border-radius:20px;
  overflow:hidden;
  background:#e5e7eb;
  box-shadow:var(--shadow-1);
}
.booking-summary-media img { width:100%; height:100%; object-fit:cover; }

.booking-summary-side {
  text-align:right;
  display:flex;
  flex-direction:column;
  gap:4px;
  font-size:var(--fs-300);
  min-width: 0;
}
.booking-summary-side .label {
  text-transform:uppercase;
  letter-spacing:0.08em;
  font-weight:500;
  color:var(--muted);
  font-size:var(--fs-200);
}

/* Highlight-Boxen */
.highlight {
  border-radius:var(--radius);
  padding:var(--space-3);
  border:1px solid var(--line);
  background:color-mix(in oklab, var(--surface-elev) 80%, #f9fafb 20%);
  box-shadow:var(--shadow-1);
  font-size:var(--fs-400);
}
.highlight h3 { margin:0 0 4px 0; font-size:var(--fs-400); }
.highlight p  { margin:0; }
.highlight.success {
  border-color:#22c55e33;
  background:color-mix(in oklab, var(--surface-elev) 70%, #dcfce7 30%);
}
.highlight.warning {
  border-color:#f9731633;
  background:color-mix(in oklab, var(--surface-elev) 70%, #ffedd5 30%);
}
.highlight.info {
  border-color:#0ea5e933;
  background:color-mix(in oklab, var(--surface-elev) 70%, #e0f2fe 30%);
}

/* Verwendungszweck-Karte */
.reference-card {
  border-radius:var(--radius);
  padding:var(--space-3);
  border:1px dashed color-mix(in oklab, var(--line) 70%, #38bdf8 30%);
  background:color-mix(in oklab, var(--surface-elev) 80%, #ecfeff 20%);
  box-shadow:var(--shadow-1);
  display:flex;
  flex-direction:column;
  gap:6px;
  min-width: 0;
}
.reference-label {
  text-transform:uppercase;
  letter-spacing:0.12em;
  font-size:var(--fs-200);
  color:var(--muted);
}
.reference-value {
  display:inline-flex;
  align-items:center;
  padding:6px 12px;
  border-radius:999px;
  background:#0f172a;
  color:#e5e7eb;
  font-family:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
  font-size:var(--fs-300);
  letter-spacing:0.06em;
  overflow-wrap:anywhere;
  word-break: break-word;
  min-width: 0;
  max-width: 100%;
}

/* Zahlungsarten (Basis) */
.payment-grid {
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(230px,1fr));
  gap:var(--space-3);
  margin-top:var(--space-2);
}

/* ─────────────────────────────────────────────
   NEU: Zahlungsinfos kompakt + nicht-interaktiv
───────────────────────────────────────────── */
.payment-grid.payment-grid--compact {
  grid-template-columns:repeat(auto-fit, minmax(180px,1fr));
  gap:var(--space-2);
}

/* Kompakte Info-Karte (statt auswählbarer Karte) */
.payment-info-card {
  padding: var(--space-3);
  border-radius: var(--radius);
  border: 1px solid var(--line);
  background: var(--surface-elev);
  box-shadow: var(--shadow-1);

  cursor: default;
}

.payment-info-card:hover {
  transform: none !important;
  box-shadow: var(--shadow-1) !important;
  border-color: var(--line) !important;
}

.payment-info-card h4 {
  margin: 0 0 6px 0;
  font-size: var(--fs-400);
}

.payment-info-card p {
  margin: 6px 0 0 0;
}

.invoice-hint {
  margin-top: 6px;
  font-size: var(--fs-300);
  color: var(--muted);
}
.invoice-hint a { text-decoration: underline; }

/* ALT: falls irgendwo noch payment-card existiert -> neutralisieren */
.payment-card,
.payment-card:hover,
.payment-card:focus-visible,
.payment-card--selected {
  cursor: default !important;
  transform: none !important;
  box-shadow: var(--shadow-1) !important;
  border-color: var(--line) !important;
  outline: none !important;
  transition: none !important;
}

/* Status-Pills */
.status-pill {
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:3px 10px;
  border-radius:999px;
  font-size:var(--fs-200);
  font-weight:600;
  letter-spacing:0.08em;
  text-transform:uppercase;
  align-self:flex-end;
}
.status-pill.status-free {
  background:#22c55e1a;
  color:#16a34a;
  border:1px solid #22c55e40;
}
.status-pill.status-open {
  background:#f973161a;
  color:#c2410c;
  border:1px solid #f9731640;
}
.status-pill.status-paid {
  background:#0ea5e91a;
  color:#0369a1;
  border:1px solid #0ea5e940;
}
.status-pill.status-cancelled {
  background:#ef44441a;
  color:#b91c1c;
  border:1px solid #ef444440;
}

.booking-error {
  color:#b91c1c;
  font-size:var(--fs-300);
  margin-top:4px;
  overflow-wrap:anywhere;
  word-break: break-word;
}

/* ─────────── Toast ─────────── */
#toast {
  position:fixed;
  left:50%;
  bottom:1.25rem;
  transform:translateX(-50%);
  background:rgba(0,0,0,.85);
  color:#fff;
  padding:.6rem .9rem;
  border-radius:.6rem;
  opacity:0;
  transition:opacity .2s ease, transform .2s ease;
  pointer-events:none;
  z-index:1200;
  max-width: calc(100vw - 24px);
}
#toast.show { opacity:1; transform:translateX(-50%) translateY(-4px); }

/* ─────────── Footer ─────────── */
.site-footer {
  border-top:1px solid var(--line);
  background:var(--surface);
  padding:var(--space-6);
  color:#555;
}
.footer-grid {
  display:grid;
  grid-template-columns:repeat(2,minmax(140px,1fr));
  gap:16px 32px;
  align-items:start;
  margin-bottom:var(--space-4);
}
.footer-col h4 {
  margin:0 0 8px 0;
  font-size:var(--fs-300);
  font-weight:600;
  color:var(--fg);
}
.footer-col ul { list-style:none; padding:0; margin:0; }
.footer-col li+li { margin-top:6px; }
.footer-col a { color:#555; text-decoration:none; }
.footer-col a:hover,
.footer-col a:focus { color:var(--fg); text-decoration:underline; outline:none; }

.footer-social {
  display:flex; gap:16px; align-items:center; margin:8px 0 16px 0;
}
.footer-social a { display:inline-flex; align-items:center; gap:8px; color:#555; text-decoration:none; }
.footer-social a:hover { color:var(--fg); text-decoration:underline; }

.footer-bottom {
  border-top:1px dashed var(--line);
  padding-top:12px;
  font-size:var(--fs-300);
  color:#777;
}
.footer-bottom a { color:inherit; text-decoration:none; }
.footer-bottom a:hover { text-decoration:underline; }

/* ─────────── Menu / Dropdown ─────────── */
.menu { position:relative; }

/* ✅ Default: links ausrichten (perfekt für "Mein Konto" links) */
.dropdown {
  position:absolute;
  top:calc(100% + 8px);
  left:0;
  right:auto;
  z-index:10;

  min-width:200px;
  max-width: min(320px, calc(100vw - 24px)); /* safer */
  margin:0;
  padding:8px;
  list-style:none;

  background:var(--surface-elev);
  color:inherit;
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:var(--shadow-2);
}

/* Optional: explizit rechts ausrichten (nur wenn du es setzt) */
.menu.menu--right .dropdown,
.menu[data-align="right"] .dropdown {
  left:auto;
  right:0;
}

.dropdown-item {
  display:block;
  padding:8px 10px;
  border-radius:8px;
  text-decoration:none;
  overflow-wrap:anywhere;
}
.dropdown-item:hover,
.dropdown-item:focus {
  background:color-mix(in oklab, var(--fg) 4%, transparent);
  outline:none;
}
.dropdown .sep { border-top:1px solid var(--line); margin:.25rem 0; }

/* ─────────── Kontaktliste ─────────── */
.contact-list { list-style:none; margin:0; padding:0; }
.contact-list li {
  display:flex;
  align-items:center;
  gap:8px;
  padding:8px 0;
  border-bottom:1px solid var(--line);
  font-size:var(--fs-400);
  min-width: 0;
}
.contact-list li:last-child { border-bottom:none; }
.contact-list .label {
  min-width:90px;
  font-size:var(--fs-300);
  color:var(--muted);
}
.contact-list a { text-decoration:none; overflow-wrap:anywhere; }
.contact-list a:hover,
.contact-list a:focus-visible { text-decoration:underline; }

.contact-btn {
  margin-left:auto;
  text-decoration:none;
}
.contact-btn:hover,
.contact-btn:focus-visible { text-decoration:none; }

/* ─────────── FAQ ─────────── */
.faq-list { display:flex; flex-direction:column; gap:var(--space-2); }
.faq-item {
  border-bottom:1px solid var(--line);
  padding:8px 0;
}
.faq-item:last-of-type { border-bottom:none; }
.faq-item summary {
  list-style:none;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:var(--space-3);
  font-size:var(--fs-400);
  font-weight:500;
}
.faq-item summary::-webkit-details-marker { display:none; }

.faq-toggle-icon {
  width:16px;
  height:16px;
  position:relative;
  flex-shrink:0;
}
.faq-toggle-icon::before,
.faq-toggle-icon::after {
  content:"";
  position:absolute;
  inset:50% auto auto 50%;
  width:12px;
  height:1.5px;
  background:var(--muted);
  transform:translate(-50%,-50%);
  transition:transform .15s ease, opacity .15s ease;
}
.faq-toggle-icon::after { transform:translate(-50%,-50%) rotate(90deg); }
.faq-item[open] .faq-toggle-icon::after { opacity:0; }

.faq-body {
  margin-top:6px;
  font-size:var(--fs-400);
  color:var(--muted);
  max-width:62ch;
}
.faq-body p { margin:0; }

/* ─────────── Terminplan (Schedule) ─────────── */
.schedule { margin-bottom:var(--space-7); }

.schedule-header {
  display:flex;
  align-items:center;
  justify-content:space-between;
  border-radius:var(--radius);
  padding:var(--space-3) var(--space-4);
  background:color-mix(in oklab, var(--surface-elev) 70%, #e0f2fe 30%);
  border:1px solid var(--line);
  box-shadow:var(--shadow-1);
  gap: var(--space-3);
  flex-wrap: wrap;
}

.schedule-week-info {
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:2px;
}
.schedule-week-info strong { font-size:var(--fs-500); }
.schedule-hint { margin:var(--space-3) 0; }

.schedule-days {
  margin-top:var(--space-3);
  display:flex;
  flex-direction:column;
  gap:var(--space-2);
}

.schedule-day {
  border-radius:var(--radius);
  border:1px solid var(--line);
  overflow:hidden;
  background:var(--surface-elev);
}
.schedule-day summary {
  list-style:none;
  cursor:pointer;
  padding:10px 14px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:var(--space-2);
  font-weight:500;
}
.schedule-day summary::-webkit-details-marker { display:none; }
.schedule-day-label { display:flex; flex-direction:column; min-width: 0; }
.schedule-badge {
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:999px;
  padding:4px 10px;
  font-size:var(--fs-300);
  background:#ef4444;
  color:#fff;
}
.schedule-day-body {
  padding:var(--space-3) var(--space-4);
  border-top:1px solid var(--line);
}

.schedule-day-list {
  list-style:none;
  margin:0;
  padding:0;
  display:flex;
  flex-direction:column;
  gap:var(--space-2);
}
.schedule-item {
  display:flex;
  gap:var(--space-3);
  align-items:center;
  justify-content:space-between;
  min-width: 0;
}
.schedule-item-main {
  display:flex;
  gap:var(--space-3);
  align-items:flex-start;
  min-width: 0;
}
.schedule-item-content {
  display:flex;
  flex-direction:column;
  gap:4px;
  min-width: 0;
}
.schedule-item-time {
  font-weight:600;
  font-size:var(--fs-400);
}
.schedule-item-title { font-size:var(--fs-400); overflow-wrap:anywhere; }
.schedule-item-meta {
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  font-size:var(--fs-300);
  color:var(--muted);
}
.schedule-item .tag { font-size:var(--fs-300); }

.schedule-item-thumb {
  flex:0 0 56px;
  height:56px;
  border-radius:18px;
  overflow:hidden;
  background:#e5e7eb;
  box-shadow:var(--shadow-1);
}
.schedule-item-thumb img { width:100%; height:100%; object-fit:cover; }

/* ─────────── Detailbild im Dialog (full-bleed) ─────────── */
.details-dialog-body { gap: var(--space-4); }

.details-media {
  position: relative;
  width: calc(100% + 2 * var(--space-4));
  aspect-ratio: 16 / 9;
  margin: calc(-1 * var(--space-4)) calc(-1 * var(--space-4)) var(--space-3);
  border-radius: 0;
  overflow: hidden;
  box-shadow: var(--shadow-2);
  background: radial-gradient(circle at center, #e5e7eb, #d1d5db);
}
.details-media img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  object-position: center;
}

.tag-free {
  border-color: #22c55e55;
  background: #22c55e11;
  color: #15803d;
  font-weight: 500;
}

/* ─────────── Cookie Notice ─────────── */
.cookie-notice {
  position:fixed;
  left:0; right:0; bottom:0;
  z-index:1000;
  padding:1.25rem .75rem;
  background:rgba(10,10,10,0.92);
  backdrop-filter:blur(6px);
  box-shadow:0 -4px 16px rgba(0,0,0,0.45);
  color:#f5f5f5;
  font-family:system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  overflow-x: hidden;
}
.cookie-notice__inner {
  max-width:1080px;
  margin:0 auto;
  display:flex;
  gap:1.75rem;
  align-items:center;
  justify-content:space-between;
  flex-wrap:wrap;
}
.cookie-notice__content { flex:1 1 320px; min-width:0; }
.cookie-notice__title {
  margin:0 0 .5rem;
  font-size:1.25rem;
  font-weight:600;
}
.cookie-notice__text {
  margin:0 0 .4rem;
  font-size:.98rem;
  line-height:1.6;
  overflow-wrap:anywhere;
}
.cookie-notice__text--small { font-size:.9rem; opacity:.9; }
.cookie-notice__list {
  margin:.35rem 0 .6rem 1.1rem;
  padding:0;
  font-size:.95rem;
  line-height:1.5;
}
.cookie-notice__list li { margin-bottom:.15rem; }
.cookie-notice a { color:#ffd86b; text-decoration:underline; }
.cookie-notice a:hover { text-decoration:none; }
.cookie-notice__actions {
  flex:0 0 auto;
  display:flex;
  align-items:center;
  justify-content:flex-end;
  flex-wrap: wrap;
  gap: 10px;
}
.cookie-notice__btn {
  font-size:.95rem;
  padding:.55rem 1.4rem;
  border-radius:999px;
  white-space:nowrap;
}

/* ─────────── Responsive ─────────── */
@media (max-width: 720px) {
  .container { padding:20px; }

  /* ✅ Mobile Header: besseres Layout + Safe Areas */
  .nav {
    padding-block: 12px;
    padding-left: max(16px, env(safe-area-inset-left));
    padding-right: max(16px, env(safe-area-inset-right));
    gap: 10px;
  }

  .brand {
    font-size: 18px;
    letter-spacing: .2px;
  }

  /* Obere Reihe: Termine/Hilfe kompakter */
  .nav-main {
    gap: 8px;
  }

  /* Nur Top-Level Links in nav-main als „Pills“ (aber NICHT .btn überschreiben) */
  .nav-main > a:not(.btn) {
    border: 1px solid var(--line);
    border-radius: 999px;
    padding: 8px 12px;
    text-decoration: none;
    background: transparent;
  }
  .nav-main > a:not(.btn):hover,
  .nav-main > a:not(.btn):focus-visible {
    text-decoration: none;
    background: color-mix(in oklab, var(--fg) 6%, transparent);
  }

  /* ✅ Zweite Zeile: Konto links, Logout rechts (sauber!) */
  .nav-right {
    flex: 1 0 100%;
    width: 100%;
    justify-content: space-between;
    gap: 10px;
    padding-top: 2px;
  }

  /* Buttons im Header kleiner (touch-friendly, aber nicht riesig) */
  .nav-right .btn,
  .nav-right .btn-link {
    padding: 9px 12px;
    font-size: 14px;
    line-height: 1;
  }

  /* „Mein Konto“ Button als Pill statt „plain text“ */
  .nav-right .btn-link {
    border: 1px solid var(--line);
    border-radius: 999px;
    text-decoration: none;
  }
  .nav-right .btn-link:hover,
  .nav-right .btn-link:focus-visible {
    text-decoration: none;
    background: color-mix(in oklab, var(--fg) 6%, transparent);
  }

  /* Logout nicht zu breit */
  #logout-btn { min-width: 0; }

  /* ✅ FIX: Dropdown auf Mobile NICHT pauschal rechts -> sonst offscreen bei "Mein Konto" links */
  .dropdown {
    left: 0;
    right: auto;
    min-width: min(260px, calc(100vw - 24px));
    max-width: min(320px, calc(100vw - 24px));
  }

  /* optional: nur explizit rechts ausrichten */
  .menu.menu--right .dropdown,
  .menu[data-align="right"] .dropdown {
    left: auto;
    right: 0;
  }

  .dropdown-item { padding: 10px 12px; }

  .grid-2 { grid-template-columns: 1fr; } /* verhindert “Zweispaltig zu breit” */

  .cookie-notice { padding:1rem .75rem 1.1rem; }
  .cookie-notice__inner { align-items:flex-start; }
  .cookie-notice__title { font-size:1.1rem; }
  .cookie-notice__text { font-size:.94rem; }
  .cookie-notice__actions {
    width:100%;
    justify-content:flex-start;
    margin-top:.5rem;
  }
}

@media (max-width: 640px) {
  .schedule-item { flex-direction:column; align-items:flex-start; }
  .schedule-item-main { align-items:center; }

  .booking-summary { flex-direction:column; align-items:flex-start; }
  .booking-summary-side { text-align:left; align-items:flex-start; }

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

  /* Buttons im Footer des Dialogs sollen nicht überlaufen */
  .booking-dialog footer { display:flex; gap: var(--space-2); flex-wrap: wrap; }
  .booking-dialog footer .btn { flex:1 1 160px; min-width: 0; }

  .booking-summary-main { align-items:center; }
}

@media (max-width: 520px) {
  .footer-grid { grid-template-columns:1fr; }
}

/* Motion preferences */
@media (prefers-reduced-motion: reduce) {
  * { transition:none!important; animation:none!important; scroll-behavior:auto!important; }
}

/* ─────────────────────────────────────────────
   DIALOG MOBILE FIX (WICHTIG)
   - Dialoge sind NUR sichtbar, wenn sie [open] sind
   - Inhalt im Dialog scrollt, Footer bleibt erreichbar
───────────────────────────────────────────── */

/* Wichtig: verhindert “Dialog immer sichtbar” */
dialog:not([open]) { display: none !important; }

/* Flex nur wenn Dialog geöffnet ist */
dialog.dialog[open],
dialog.booking-dialog[open],
#auth[open],
#details[open],
#booking-dialog[open],
#booking-result[open] {
  width: min(640px, 96vw);
  max-width: calc(100vw - 16px);

  /* iOS / Mobile: dvh statt vh */
  max-height: calc(92dvh - env(safe-area-inset-bottom));
  overflow: hidden;

  display: flex;
  flex-direction: column;
}

/* Header + Tabs dürfen nicht schrumpfen */
dialog.dialog[open] > header,
dialog.dialog[open] > .tabs,
dialog.booking-dialog[open] > .dialog-header {
  flex: 0 0 auto;
}

/* Der Inhalt (stack / form panels) scrollt */
dialog.dialog[open] .stack,
dialog.booking-dialog[open] .stack,
#auth[open] #panel-login,
#auth[open] #panel-register {
  flex: 1 1 auto;
  min-height: 0;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  padding-bottom: max(16px, env(safe-area-inset-bottom));
}

/* Footer bleibt sichtbar */
dialog.booking-dialog[open] footer,
dialog.dialog[open] footer {
  flex: 0 0 auto;
  position: sticky;
  bottom: 0;
  background: var(--surface-elev);
  padding-bottom: max(var(--space-3), env(safe-area-inset-bottom));
  z-index: 2;
}

/* Buttons/Rows im Dialog dürfen umbrechen statt rauszuschieben */
dialog[open] .row.end,
dialog[open] .actions,
.schedule-actions {
  flex-wrap: wrap;
}

/* Optional: Dark-Mode Tabs/Dialoge */
@media (prefers-color-scheme: dark) {
  dialog.dialog[open],
  dialog.booking-dialog[open],
  #auth[open],
  #details[open],
  #booking-dialog[open],
  #booking-result[open] {
    background: var(--surface-elev);
    color: var(--fg);
  }
}

/* ─────────────────────────────────────────────
   ADD-ON: Utilities + Danger-Zone + Delete-Dialog Layout
   (Ganz unten an style.css anhängen)
───────────────────────────────────────────── */

.between { justify-content: space-between; }
.wrap { flex-wrap: wrap; }

/* Danger zone (Details) */
.danger-zone {
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  background: var(--surface-elev);
  box-shadow: var(--shadow-1);
  overflow: hidden;
}
.danger-zone__summary {
  list-style: none;
  cursor: pointer;
  padding: var(--space-3) var(--space-4);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
}
.danger-zone__summary::-webkit-details-marker { display: none; }
.danger-zone__title { font-weight: 600; }
.danger-zone__body {
  padding: var(--space-3) var(--space-4) var(--space-4);
  border-top: 1px solid var(--line);
}
.danger-zone[open] .danger-zone__summary {
  background: color-mix(in oklab, var(--fg) 3%, transparent);
}

/* Outline-danger button */
.btn-danger-outline {
  background: transparent;
  border-color: #dc2626;
  color: #dc2626;
}


/* ─────────────────────────────────────────────
   ADD-ON: Semantische Alias-Klassen + Page-Layouts
   - keine Logikänderung
   - entfernt Inline-Stile aus den Templates
   - ergänzt ungestylte Klassen aus den JS-/Web-Components
───────────────────────────────────────────── */

.logo { display:inline-block; }
.list-wrap { min-width:0; }

/* Semantische Button-Aliasse aus den Komponenten */
.btn-primary,
.btn-solid {
  background:var(--accent-bg);
  border-color:var(--accent-bg);
  color:var(--accent-fg);
}

/* Pagination */
.pager {
  display:flex;
  align-items:center;
  justify-content:center;
  gap:var(--space-3);
  flex-wrap:wrap;
  padding-top:var(--space-5);
}

/* Booking-Hinweis ohne Inline-Styles */
.payment-note__line {
  margin:6px 0 0 0;
}

/* Benutzerkonto: Karten für Buchungen / Rechnungen */
.booking-card,
.invoice-card {
  gap:var(--space-4);
}

.booking-card-main,
.invoice-card-main {
  display:flex;
  flex-direction:column;
  gap:var(--space-3);
  min-width:0;
}

.booking-card-header,
.invoice-card-header {
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:var(--space-3);
  flex-wrap:wrap;
}

.booking-title,
.invoice-title {
  margin:0;
  min-width:0;
}

.booking-desc {
  margin:0;
}

.booking-meta,
.invoice-meta {
  display:flex;
  flex-wrap:wrap;
  gap:8px 12px;
  color:var(--muted);
  font-size:var(--fs-300);
  min-width:0;
}

.booking-card-footer {
  display:flex;
  align-items:center;
  gap:var(--space-2);
  flex-wrap:wrap;
  padding-top:var(--space-2);
  border-top:1px solid var(--line);
  margin-top:auto;
}

.booking-extra,
.booking-ref {
  color:var(--muted);
  font-size:var(--fs-300);
}

.invoice-payment {
  border-top:1px solid var(--line);
  padding-top:var(--space-3);
}

.invoice-payment p {
  margin:0 0 8px 0;
}

.invoice-payment-list {
  list-style:none;
  margin:0;
  padding:0;
  display:grid;
  gap:6px;
  font-size:var(--fs-300);
}

.invoice-payment-list li,
.invoice-meta span,
.booking-meta span,
.booking-ref,
.reference-value {
  overflow-wrap:anywhere;
  word-break:break-word;
}

.invoice-actions {
  margin-top:var(--space-3);
  display:flex;
  gap:var(--space-2);
  flex-wrap:wrap;
}

.invoice-actions > * {
  min-width:0;
}

.invoice-actions--wrap {
  align-items:flex-start;
}

@media (max-width: 640px) {
  .pager { justify-content:flex-start; }
  .booking-card-footer { align-items:flex-start; }
  .booking-card-header,
  .invoice-card-header { align-items:flex-start; }
}


/* Semantische Hilfsklassen aus dem refaktorierten Markup */
.card--club {
  min-height: 100%;
}

.payment-note {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

/* Diese Klassen sind primär JS-Hooks. Die Regeln sind bewusst minimal,
   damit bestehendes Button-Verhalten unverändert bleibt. */
.close-auth,
.booking-cancel {
  touch-action: manipulation;
}


/* ─────────────────────────────────────────────
   Paket-Integration + Host-Admin
───────────────────────────────────────────── */
.section-head {
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:var(--space-3);
  flex-wrap:wrap;
  margin-bottom:var(--space-4);
}
.section-head h2 { margin:0; font-size:var(--fs-700); line-height:1.15; }
.section-head p { margin:0; }
.tag-kind {
  border-color: color-mix(in oklab, var(--line) 70%, #60a5fa 30%);
  background: color-mix(in oklab, var(--surface-elev) 75%, #eff6ff 25%);
}
.package-card { position:relative; }
.package-club-preview,
.package-club-list {
  list-style:none;
  margin:0;
  padding:0;
  display:flex;
  flex-direction:column;
  gap:8px;
}
.package-club-preview li,
.package-club-list li {
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:var(--space-3);
  padding:8px 0;
  border-top:1px dashed var(--line);
}
.package-club-preview li:first-child,
.package-club-list li:first-child { border-top:none; padding-top:0; }
.package-club-preview li:last-child,
.package-club-list li:last-child { padding-bottom:0; }
.package-club-preview small,
.package-club-list small { text-align:right; }
.package-detail-block {
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:var(--space-3);
  background:color-mix(in oklab, var(--surface-elev) 82%, #f8fafc 18%);
  box-shadow:var(--shadow-1);
}
.package-detail-block[hidden] { display:none !important; }

.host-admin-panel {
  display:flex;
  flex-direction:column;
  gap:var(--space-4);
}
.host-toolbar {
  display:flex;
  justify-content:space-between;
  align-items:flex-end;
  gap:var(--space-3);
  flex-wrap:wrap;
}
.host-toolbar__title h3 { margin:0; }
.host-toolbar__title p { margin:4px 0 0; }
.host-filters {
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(180px,1fr));
  gap:var(--space-3);
}
.host-grid {
  list-style:none;
  margin:0;
  padding:0;
  display:grid;
  gap:var(--space-3);
}
.host-card {
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  background:var(--surface-elev);
  box-shadow:var(--shadow-1);
  padding:var(--space-4);
  display:flex;
  flex-direction:column;
  gap:var(--space-3);
}
.host-card__header {
  display:flex;
  justify-content:space-between;
  gap:var(--space-3);
  flex-wrap:wrap;
}
.host-card__header h3 { margin:0; }
.host-card__meta {
  display:flex;
  flex-wrap:wrap;
  gap:8px 12px;
  color:var(--muted);
  font-size:var(--fs-300);
}
.host-card__footer {
  display:flex;
  flex-wrap:wrap;
  gap:var(--space-2);
  padding-top:var(--space-2);
  border-top:1px solid var(--line);
}
.host-hint {
  border:1px solid color-mix(in oklab, var(--line) 70%, #f59e0b 30%);
  background:color-mix(in oklab, var(--surface-elev) 78%, #fffbeb 22%);
  border-radius:var(--radius);
  padding:var(--space-3);
}
.host-selector-grid {
  list-style:none;
  margin:0;
  padding:0;
  display:grid;
  gap:var(--space-2);
  max-height:260px;
  overflow:auto;
}
.host-selector-item {
  display:flex;
  align-items:flex-start;
  gap:var(--space-2);
  padding:10px 12px;
  border:1px solid var(--line);
  border-radius:var(--radius);
  background:var(--surface);
}
.host-selector-item input { margin-top:3px; }
.host-selector-item__body {
  display:flex;
  flex-direction:column;
  gap:4px;
  min-width:0;
}
.host-panel-empty {
  border:1px dashed var(--line);
  border-radius:var(--radius-lg);
  padding:var(--space-5);
  text-align:center;
  color:var(--muted);
}
@media (max-width: 640px) {
  .host-card__header,
  .host-toolbar { align-items:flex-start; }
  .package-club-preview li,
  .package-club-list li { flex-direction:column; }
  .package-club-preview small,
  .package-club-list small { text-align:left; }
}


/* ─────────────────────────────────────────────
   Materialien / Zugang im Nutzerkonto
───────────────────────────────────────────── */
.materials-dialog {
  width: min(760px, 96vw);
  max-width: calc(100vw - 16px);
}
.materials-dialog__header h3 {
  margin: 0;
  font-size: var(--fs-600);
}
.materials-dialog__header p {
  margin: 6px 0 0;
}
.materials-content {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}
.materials-panel {
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  background: var(--surface-elev);
  box-shadow: var(--shadow-1);
}
.materials-panel__body {
  padding: var(--space-4);
}
.materials-panel__body h4 {
  margin: 0 0 8px 0;
}
.materials-panel__body p {
  margin: 0;
}
.materials-grid {
  display: grid;
  gap: var(--space-3);
}
.materials-club-card {
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  background: var(--surface-elev);
  box-shadow: var(--shadow-1);
  padding: var(--space-4);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}
.materials-club-card__header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: var(--space-3);
  flex-wrap: wrap;
}
.materials-club-card__header h4 {
  margin: 0;
}
.materials-club-card__header p {
  margin: 4px 0 0;
}
.materials-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
}
.materials-actions .btn {
  min-width: 0;
}
.booking-card-footer > a.btn {
  text-decoration: none;
}
@media (max-width: 640px) {
  .materials-club-card__header {
    align-items: flex-start;
  }
  .materials-actions {
    flex-direction: column;
    align-items: stretch;
  }
}
