/* =========================================================
   Terminmarktplatz – Neon Candy Playground (bunt & frisch)
   Look: bold colors, gradients, bubbly shapes, young & fun
========================================================= */

/* ---------- Tokens ---------- */
:root{
  /* Brand Rainbow */
  --c-pink:#ff6bcb;
  --c-purple:#7c3aed;
  --c-violet:#8b5cf6;
  --c-blue:#3b82f6;
  --c-cyan:#06b6d4;
  --c-mint:#10b981;
  --c-lime:#84cc16;
  --c-yellow:#facc15;
  --c-orange:#fb923c;
  --c-red:#ef4444;

  --bg:#0b0f1a;
  --bg-soft:#0f1524;
  --surface:#0f172a;
  --ink:#f8fafc;
  --ink-dim:#cbd5e1;
  --border:rgba(255,255,255,.12);

  --ab-border: var(--border);
  --fg:#0f172a;
  --text-2:#475569;

  --r-3xl:28px;
  --r-2xl:22px;
  --r-xl:18px;
  --r-lg:14px;

  --shadow-1: 0 8px 26px rgba(0,0,0,.25);
  --shadow-2: 0 16px 48px rgba(0,0,0,.35);

  --grad-brand: linear-gradient(135deg, var(--c-pink), var(--c-blue), var(--c-lime));
  --grad-soft: linear-gradient(135deg, rgba(124,58,237,.25), rgba(6,182,212,.25));
  --focus: 0 0 0 3px rgba(59,130,246,.45);

  /* Form Farben */
  --field-bg: rgba(255,255,255,.06);
  --field-border: rgba(255,255,255,.18);
  --field-bg-focus: rgba(255,255,255,.10);

  --field-bg-strong: rgba(255,255,255,.14);
  --field-border-strong: rgba(255,255,255,.32);
  --field-bg-focus-strong: rgba(255,255,255,.20);

  --error:#ef4444;
  --success:#10b981;
  --warn:#f59e0b;
}

/* ---------- Base ---------- */
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  font-weight: 400;
  letter-spacing: .1px;
  color:var(--ink);
  background:
    radial-gradient(900px 520px at 15% -10%, rgba(255,107,203,.25), transparent 60%),
    radial-gradient(900px 520px at 90% -20%, rgba(6,182,212,.25), transparent 55%),
    radial-gradient(1200px 600px at 50% 120%, rgba(132,204,22,.18), transparent 55%),
    var(--bg);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}

/* Auth-Elemente standardmäßig ausblenden, JS blendet bei Login ein */
.auth-in,
.admin-only{
  display:none;
}
a{color:inherit; text-decoration:none}
img{max-width:100%; height:auto; display:block}
.container{width:min(1160px, 92%); margin-inline:auto}
small, .muted{color:var(--ink-dim)}

/* Accessibility: Screen Reader Only */
.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border-width: 0;
}

/* Skip to content link */
.skip-link {
  position: absolute;
  top: -40px;
  left: 0;
  background: var(--c-blue);
  color: white;
  padding: 8px 16px;
  text-decoration: none;
  z-index: 1000;
}
.skip-link:focus {
  top: 0;
}

/* Fun Blobs (Deko) */
body::before,
body::after{
  content:"";
  position:fixed;
  inset:auto auto 8% -10%;
  width:42vw; height:42vw; z-index:-1;
  filter: blur(60px);
  background:
    radial-gradient(circle at 30% 30%, rgba(124,58,237,.45), transparent 60%),
    radial-gradient(circle at 70% 70%, rgba(6,182,212,.40), transparent 60%);
  opacity:.7;
  transform: rotate(12deg);
}
body::after{
  inset:-8% -10% auto auto;
  width:36vw; height:36vw;
  background:
    radial-gradient(circle at 30% 30%, rgba(250,204,21,.40), transparent 60%),
    radial-gradient(circle at 70% 70%, rgba(16,185,129,.40), transparent 60%);
  transform: rotate(-8deg);
}

/* ---------- Header ---------- */
header{
  position:sticky;
  top:0;
  z-index:50;
  background: rgba(15,23,42,.7);
  backdrop-filter:saturate(160%) blur(14px);
  border-bottom:1px solid var(--border);
}
.nav{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:14px 0;
}
.brand{
  display:flex;
  align-items:center;
  gap:12px;
}
.brand-logo{
  width:44px; height:44px;
  border-radius:16px;
  background: var(--grad-brand);
  display:grid;
  place-items:center;
  box-shadow:var(--shadow-1);
  overflow:hidden;
}
.brand-title{font-weight:900; letter-spacing:.2px}

.nav-links{
  display:flex;
  align-items:center;
  gap:16px;
}
.nav-links a{
  padding:10px 12px;
  color:var(--ink-dim);
  font-weight:700;
  opacity:.9;
}
.nav-links a:hover,
.nav-links a.active{
  color:#fff;
  opacity:1;
}

.cta-group{
  display:flex;
  align-items:center;
  gap:10px;
}

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  padding:12px 18px;
  border-radius:18px;
  border:1px solid var(--border);
  background:rgba(255,255,255,.04);
  color:#ffffff;
  cursor:pointer;
  transition:.18s;
  box-shadow: var(--shadow-1);
  font-weight:700;
}
.btn:hover{transform:translateY(-2px)}
.btn:focus-visible{outline:none; box-shadow:var(--focus)}
.btn.primary{
  background:linear-gradient(135deg, var(--c-purple), var(--c-cyan));
  border:none;
  font-weight:800;
}
.btn.secondary{background:rgba(255,255,255,.06)}
.btn.block{width:100%}

/* Button Loading-State */
button.loading{
  position: relative;
  pointer-events: none;
  opacity: .85;
}
button.loading::after{
  content: "";
  position: absolute;
  right: 12px;
  top: 50%;
  width: 18px;
  height: 18px;
  margin-top: -9px;
  border-radius: 50%;
  border: 2px solid rgba(0,0,0,.1);
  border-top-color: transparent;
  animation: spin .8s linear infinite;
}
@keyframes spin{to{transform:rotate(360deg)}}

/* Checkbox-Zelle */
.table td:first-child,
.table th:first-child{
  text-align:center;
}

/* ---------------------------------------------------------
   Tabellen-Buttons (Standard-Seiten, NICHT Portal)
--------------------------------------------------------- */
body:not(.page-portal) .table .btn{
  padding:8px 12px;
  border:none;
  border-radius:12px;
  font-weight:800;
  color:#fff;
  background: linear-gradient(135deg, var(--c-purple), var(--c-cyan));
  box-shadow: var(--shadow-1);
  transition: transform .15s, filter .15s;
}
body:not(.page-portal) .table .btn:hover{
  transform: translateY(-1px);
  filter: brightness(1.08);
}
body:not(.page-portal) .table .btn.action{
  background: linear-gradient(135deg, var(--c-blue), var(--c-mint));
}
body:not(.page-portal) .table .btn.danger{
  background: linear-gradient(135deg, var(--c-red), #ff7b7b);
}

/* Deaktivierte Bulk-Buttons */
.seg .btn[disabled]{
  background:linear-gradient(135deg, var(--c-purple), var(--c-cyan));
}

/* ---------- Hero ---------- */
.hero{padding:86px 0 34px}
.hero-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:20px;
  text-align:center;
}
.badge{
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-size:20px;
  font-weight:900;
  padding:8px 12px;
  border-radius:999px;
  color:#0b0f1a;
  background:#fff;
  box-shadow:0 2px 0 0 rgba(0,0,0,.1), 0 10px 24px rgba(0,0,0,.15);
}
h1,h2,h3{
  font-weight:800;
  letter-spacing:.2px;
}
.hero h1{
  font-size: clamp(28px, 4vw, 52px);
  line-height:1.04;
  margin:14px 0 10px;
  letter-spacing:-0.8px;
  background:linear-gradient(90deg, #fff, #dbeafe, #fff);
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
}
.hero p.lead{
  color:var(--ink-dim);
  font-size:clamp(16px, 2.2vw, 20px);
  max-width:900px;
  margin-inline:auto;
}

/* ---------- Suche ---------- */
.search-card{
  margin:24px auto 0;
  background:linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
  border:1px solid var(--border);
  border-radius:var(--r-3xl);
  box-shadow: var(--shadow-2), inset 0 1px 0 rgba(255,255,255,.08);
  padding:18px 18px 20px;
  max-width:980px;
}
.searchbar{
  display:grid;
  grid-template-columns:1.2fr 1fr .9fr .9fr auto;
  gap:12px;
}
.input{
  display:flex;
  gap:10px;
  align-items:center;
  background:var(--field-bg);
  border:1px solid var(--field-border);
  border-radius:16px;
  padding:12px 12px;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.08);
}
.input:focus-within{
  outline: none;
  background:var(--field-bg-focus);
  box-shadow: var(--focus);
}
.input input,
.input select{
  all:unset;
  color:#fff;
  width:100%;
}
.searchbar .input input::placeholder{
  color:rgba(255,255,255,.65);
}
.searchbar .input:nth-child(-n+2){
  background: var(--field-bg-strong);
  border-color: var(--field-border-strong);
}
.searchbar .input:nth-child(-n+2):focus-within{
  background: var(--field-bg-focus-strong);
  box-shadow: var(--focus);
}
.searchbar .input input[type="date"]{ color:#fff; }
.searchbar .input input[type="date"]::-webkit-calendar-picker-indicator{
  filter: invert(1) opacity(.9);
}
.searchbar .input input[type="date"]::-webkit-datetime-edit{
  color:#fff;
}
.searchbar .input select{
  -webkit-appearance:none;
  -moz-appearance:none;
  appearance:none;
  background-image:none;
}
.input input:-webkit-autofill{
  -webkit-text-fill-color:#fff;
  transition: background-color 5000s ease-in-out 0s;
}
.btn.primary[type="submit"]{
  background:linear-gradient(135deg, var(--c-pink), var(--c-blue));
  border:none;
  color:#0b0f1a;
  font-weight:900;
}
.btn.primary[type="submit"]:hover{filter: brightness(1.1)}
.trust{
  display:flex;
  gap:14px;
  align-items:center;
  margin-top:14px;
  color:rgba(255,255,255,.8);
  font-size:14px;
  justify-content:center;
}

/* Suche – Select-Felder dunkel */
.searchbar .input select{
  color:#fff;
  background-color: transparent;
  -webkit-appearance:none;
  -moz-appearance:none;
  appearance:none;
  background-image:none;
}
.searchbar .input select option{
  background:#0f172a;
  color:#fff;
}

/* ---------- Sections ---------- */
section{padding:56px 0}
h2{
  font-size: clamp(20px, 2.6vw, 30px);
  margin:0 0 12px;
  letter-spacing:-.3px;
  display:inline-flex;
  align-items:center;
  gap:10px;
}
h2::after{
  content:"";
  width:64px;
  height:6px;
  border-radius:6px;
  background:linear-gradient(90deg, var(--c-yellow), var(--c-pink), var(--c-blue));
  display:inline-block;
  margin-left:8px;
}

/* Portal: h2 Gradient-Balken innerhalb des Panels */
.page-portal .panel{
  position:relative;
  overflow:visible;
}

.page-portal .panel h2{
  position:relative;
  display:inline-flex;
  align-items:center;
  gap:8px;
}

.page-portal .panel h2::after{
  margin-left:0;
  vertical-align:middle;
  position:relative;
  flex-shrink:0;
}
.sub{color:var(--c-blue); margin:14px 0 20px}

/* ---------- Feature-Cards ---------- */
.features{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:22px;
}
.card{
  background:linear-gradient(180deg, rgba(255,255,255,.07), rgba(255,255,255,.03));
  border:1px solid var(--border);
  border-radius:var(--r-2xl);
  padding:22px;
  box-shadow:var(--shadow-1);
  position:relative;
  overflow:hidden;
  transition: transform .16s ease, box-shadow .16s ease, border-color .16s ease;
}
.card::before{
  content:"";
  position:absolute;
  inset:-30% -30% auto auto;
  width:60%; height:60%;
  background: var(--grad-soft);
  filter: blur(22px);
  opacity:.6;
  transform: rotate(8deg);
}
.card:hover{
  transform:translateY(-4px);
  box-shadow:var(--shadow-2);
  border-color:rgba(255,255,255,.18);
}
.card h3{
  margin:6px 0 8px;
  font-size:18px;
  color:#fff;
}
.card p{
  color:var(--ink-dim);
  font-size:15px;
}

/* ---------- Kategorien ---------- */
.categories{
  display:flex;
  flex-wrap:wrap;
  gap:12px 16px;
  align-items:center;
}
.chip{
  display:inline-flex;
  align-items:center;
  padding:8px 12px;
  border-radius:999px;
  font-weight:800;
  letter-spacing:.2px;
  cursor:default;
  color:#0b0f1a;
  background:#fff;
  box-shadow:0 8px 20px rgba(0,0,0,.15);
  border:0;
  transform: translateZ(0);
  transition: transform .12s ease;
}
.chip:hover{ transform: translateY(-2px) }
.chip:nth-child(6n+1){ background:linear-gradient(135deg,#fff,#ffe1f2); }
.chip:nth-child(6n+2){ background:linear-gradient(135deg,#fff,#e1f5ff); }
.chip:nth-child(6n+3){ background:linear-gradient(135deg,#fff,#e5ffef); }
.chip:nth-child(6n+4){ background:linear-gradient(135deg,#fff,#fff4db); }
.chip:nth-child(6n+5){ background:linear-gradient(135deg,#fff,#f1e7ff); }
.chip:nth-child(6n+6){ background:linear-gradient(135deg,#fff,#ffe9e1); }

/* ---------- How (Steps) ---------- */
.how{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:20px;
}
.step{
  padding:20px;
  border:1px solid var(--border);
  border-radius:var(--r-xl);
  background:linear-gradient(180deg, rgba(255,255,255,.07), rgba(255,255,255,.03));
  box-shadow:var(--shadow-1);
}
.step b{
  display:inline-flex;
  width:32px; height:32px;
  border-radius:50%;
  align-items:center;
  justify-content:center;
  margin-right:8px;
  background:linear-gradient(135deg, var(--c-blue), var(--c-pink));
  color:#0b0f1a;
  font-weight:900;
}

/* ---------- Lesbarkeit-Fix: Panels nach Hero hell ---------- */
.hero + section .panel{
  background:#fff;
  border:1px solid var(--border);
  box-shadow:var(--shadow-2);
  color:var(--fg);
  overflow:visible; /* Gradient-Balken soll sichtbar bleiben */
}
.hero + section .panel .muted{
  color:var(--text-2);
  opacity:.95;
}
.hero + section .panel,
.hero + section .panel *{
  opacity:1;
  filter:none;
}
.hero + section .panel::before,
.hero + section .panel::after{
  content:none;
}

/* ---------- CTA Provider ---------- */
.cta-provider{
  display:grid;
  grid-template-columns: 1.1fr .9fr;
  gap:22px;
  align-items:center;
}
.cta-provider .panel{
  background:linear-gradient(180deg, rgba(255,255,255,.07), rgba(255,255,255,.03));
  border:1px solid var(--border);
  border-radius:var(--r-3xl);
  padding:24px;
  box-shadow:var(--shadow-2);
}
.cta-provider .sub{
  color:var(--c-blue);
  margin-top:4px;
}
.cta-provider .grid-2 ul{
  list-style:none;
  margin:0;
  padding:0;
  display:grid;
  gap:8px;
}
.cta-provider li{line-height:1.35}
.cta-provider .card{
  background:#fff;
  border:1px solid var(--border);
  border-radius:12px;
  padding:12px 14px;
  box-shadow:var(--shadow-1);
}

/* ---------- Testimonials ---------- */
.testimonials{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:20px;
}

/* ---------- FAQ ---------- */
.faq{
  display:grid;
  grid-template-columns:1fr;
  gap:12px;
}
details{
  background:linear-gradient(180deg, rgba(255,255,255,.07), rgba(255,255,255,.03));
  border:1px solid var(--border);
  border-radius:16px;
  padding:14px;
  box-shadow:var(--shadow-1);
  transition:background .2s, border-color .2s;
}
details[open]{
  background:linear-gradient(180deg, rgba(255,255,255,.12), rgba(255,255,255,.05));
  border-color:rgba(255,255,255,.2);
}
summary{
  cursor:pointer;
  font-weight:900;
  color:#fff;
}

/* ---------- Footer ---------- */
footer{
  margin-top:40px;
  padding:36px 0 50px;
  border-top:1px solid var(--border);
  background: linear-gradient(180deg, rgba(255,255,255,.00), rgba(255,255,255,.06));
}
.foot-grid{
  display:grid;
  grid-template-columns:1.1fr .9fr .9fr .9fr;
  gap:22px;
}
.foot-col h4{
  margin:8px 0 10px;
}
.foot-link{
  display:block;
  padding:6px 0;
  color:var(--ink-dim);
}
.copyright{
  margin-top:18px;
  color:var(--ink-dim);
  font-size:13px;
}

/* ---------- Cookie ---------- */
.cookie{
  position:fixed;
  inset:auto 16px 16px 16px;
  z-index:200;
  display:none;
}
.cookie .wrap{
  background:#0b0f1a;
  border:2px solid rgba(255,255,255,.35);
  border-radius:18px;
  padding:18px;
  box-shadow:0 20px 60px rgba(0,0,0,.6), inset 0 1px 0 rgba(255,255,255,.08);
  color:#f8fafc;
  max-width:860px;
  margin:0 auto;
}
.cookie p{
  margin:0 0 14px;
  color:#f8fafc;
  font-size:clamp(15px, 2.2vw, 17px);
  line-height:1.5;
  font-weight:500;
}
.cookie a{
  color:#a5f3fc;
  text-decoration:underline;
  text-underline-offset:2px;
}
.cookie a:hover{ color:#e0f2fe; }
.cookie .btns{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}
.cookie .btn{
  background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.3);
  color:#f8fafc;
  box-shadow:none;
}
.cookie .btn.primary{
  background:linear-gradient(135deg, var(--c-pink), var(--c-blue));
  border:none;
  color:#0b0f1a;
  font-weight:900;
}
.cookie .btn:hover{ filter:brightness(1.05); }
@media (max-width:640px){
  .cookie{
    inset:auto 12px 12px 12px;
  }
  .cookie .btns{
    flex-direction:column;
  }
  .cookie .btns .btn{
    width:100%;
  }
}

/* =========================================================
   FORM & AUTH (Login/Registrieren/Portal)
========================================================= */
.form{display:grid; gap:14px}
.field{display:grid; gap:8px}
.label{font-weight:800; font-size:14px}
.control{
  display:flex;
  align-items:center;
  gap:10px;
  padding:12px 14px;
  background:var(--field-bg);
  border:1px solid var(--field-border);
  border-radius:14px;
  transition:.15s;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.08);
}
.control:focus-within{
  background:var(--field-bg-focus);
  box-shadow:var(--focus);
}
.control input,
.control select,
.control textarea{
  all:unset;
  color:#fff;
  width:100%;
  line-height:1.4;
}
.control textarea{min-height:96px}
.help{
  font-size:12px;
  color:var(--surface);
}
.error-text{
  color:var(--error);
  font-weight:700;
  font-size:13px;
}
.success-text{
  color:var(--success);
  font-weight:700;
  font-size:13px;
}

/* Inline Info/Fehler über Formular */
#form-info{
  margin-top:8px;
  padding:10px 12px;
  border-radius:12px;
  font-weight:700;
}
#form-info.error{
  background:rgba(239,68,68,.12);
  border:1px solid rgba(239,68,68,.35);
  color:#fecaca;
}
#form-info.success{
  background:rgba(16,185,129,.12);
  border:1px solid rgba(16,185,129,.35);
  color:#bbf7d0;
}
#form-info.warn{
  background:rgba(245,158,11,.12);
  border:1px solid rgba(245,158,11,.35);
  color:#fde68a;
}

/* Checkbox/Radio kompakt */
.check{
  display:flex;
  align-items:center;
  gap:10px;
  font-size:14px;
  color:var(--surface);
}
.check input{
  width:18px;
  height:18px;
}

/* Tabs/Login-Umschalter */
.tabs{
  display:flex;
  gap:8px;
  background:rgba(255,255,255,.04);
  border:1px solid var(--border);
  border-radius:12px;
  padding:6px;
}
.tab{
  padding:8px 12px;
  border-radius:10px;
  font-weight:800;
  color:var(--ink-dim);
  cursor:pointer;
}
.tab.active{
  color:#0b0f1a;
  background:#fff;
}

/* ---------- Badges / Pill ---------- */
.pill{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:6px 10px;
  border-radius:999px;
  background:rgba(255,255,255,.08);
  border:1px solid var(--border);
  font-weight:800;
}
.pill.success{
  background:rgba(16,185,129,.14);
  border-color:rgba(16,185,129,.35);
  color:#d1fae5;
}
.pill.warn{
  background:rgba(245,158,11,.14);
  border-color:rgba(245,158,11,.35);
  color:#fde68a;
}
.pill.error{
  background:rgba(239,68,68,.14);
  border-color:rgba(239,68,68,.35);
  color:#fecaca;
}

/* ---------- Tabellen (allgemein) ---------- */
.table{
  width:100%;
  border-collapse:separate;
  border-spacing:0;
  background:rgba(255,255,255,.03);
  border:1px solid var(--border);
  border-radius:14px;
  overflow:hidden;
}
.table th,
.table td{
  padding:12px 14px;
  text-align:left;
}
.table thead th{
  background:rgba(255,255,255,.06);
  font-weight:800;
  color:#fff;
}
.table tbody tr{
  border-top:1px solid var(--border);
}
.table tbody tr:hover{
  background:rgba(255,255,255,.04);
}

/* ---------- Toast / Alerts ---------- */
.toast{
  position:fixed;
  right:16px;
  bottom:16px;
  z-index:60;
  background:linear-gradient(180deg, rgba(255,255,255,.12), rgba(255,255,255,.06));
  border:1px solid var(--border);
  color:#fff;
  padding:12px 14px;
  border-radius:12px;
  box-shadow:var(--shadow-2);
}
.alert{
  display:block;
  padding:12px 14px;
  border-radius:12px;
  border:1px solid var(--border);
  background:linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.03));
}
.alert.error{
  background:rgba(239,68,68,.12);
  border-color:rgba(239,68,68,.35);
  color:#fecaca;
}
.alert.success{
  background:rgba(16,185,129,.12);
  border-color:rgba(16,185,129,.35);
  color:#bbf7d0;
}
.alert.warn{
  background:rgba(245,158,11,.12);
  border-color:rgba(245,158,11,.35);
  color:#fde68a;
}

/* =========================================================
   Vollbild-Ladeoverlay (für Registrierung/Login/Buchung)
========================================================= */
.loading-backdrop[hidden]{ display:none !important; }
.loading-backdrop{
  position: fixed;
  inset: 0;
  z-index: 9999;
  background: rgba(20,16,40,.55);
  backdrop-filter: blur(4px) saturate(130%);
  display: grid;
  place-items: center;
}
.loading-dialog{
  background: #fff;
  color: #111;
  width: min(520px, 92vw);
  border-radius: 18px;
  padding: 28px 24px;
  text-align: center;
  box-shadow: 0 10px 40px rgba(0,0,0,.25);
}
.spinner{
  width: 56px;
  height: 56px;
  margin: 4px auto 14px;
  border-radius: 50%;
  border: 6px solid #e9e6ff;
  border-top-color: #6f53ff;
  animation: spin 1s linear infinite;
}
.subtext{
  margin-top: 6px;
  font-size: .92rem;
  color: #555;
}

/* ---------- Utilities ---------- */
.center{display:grid; place-items:center}
.grid-2{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px;
}
.panel{
  background:linear-gradient(180deg, rgba(255,255,255,.07), rgba(255,255,255,.03));
  border:1px solid var(--border);
  border-radius:18px;
  padding:18px;
  box-shadow:var(--shadow-1);
}

/* ---------- Responsive ---------- */
@media (max-width:1080px){
  .features{grid-template-columns:1fr 1fr}
  .testimonials{grid-template-columns:1fr 1fr}
}
@media (max-width:960px){
  .cta-provider,
  .foot-grid{grid-template-columns:1fr}
  .how{grid-template-columns:1fr}
  .searchbar{grid-template-columns:1fr 1fr 1fr auto}
}
@media (max-width:760px){
  .features{grid-template-columns:1fr}
  .testimonials{grid-template-columns:1fr}
  .categories{gap:10px 12px}
  .searchbar{grid-template-columns:1fr 1fr auto}
  .grid-2{grid-template-columns:1fr}
}
@media (max-width:640px){
  .cta-provider .grid-2{grid-template-columns:1fr}
  .cta-provider .panel .btn{width:100%}
  .btn{padding:12px 16px}
}

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

/* Punkt vor der Trust-Zeile ausblenden */
.trust::before{
  content:none !important;
  display:none !important;
}

/* Submit-Button in der Suchleiste: eigene Reihe, volle Breite */
.searchbar .btn[type="submit"]{
  grid-column: 1 / -1;
  justify-self: center;
  padding-inline: 22px;
  margin-top: 4px;
}

/* =========================================================
   Kontaktseite (page-contact): helle Felder
========================================================= */
.page-contact .control{
  background:#fff;
  border:1px solid rgba(15,23,42,.28);
  border-radius:14px;
  box-shadow:none;
}
.page-contact .control:focus-within{
  background:#fff;
  border-color:#60a5fa;
  box-shadow:0 0 0 3px rgba(59,130,246,.35);
}
.page-contact .control input,
.page-contact .control select,
.page-contact .control textarea{
  color:#0f172a !important;
}
.page-contact .control input::placeholder,
.page-contact .control textarea::placeholder{
  color:#64748b;
}
.page-contact .help{ color:#475569; }

/* =========================================================
   PORTAL-FIX (Anbieter-Portal)
========================================================= */

/* Portal Buttons durchgehend hell */
.page-portal .btn,
.page-portal .btn.primary,
.page-portal .btn.secondary,
.page-portal .btn.action,
.page-portal .btn.danger,
.page-portal .seg .btn,
.page-portal .table .btn,
.page-portal .toolbar .btn{
  color:#0f172a !important;
  background:#ffffff !important;
  background-image:none !important;
  text-shadow:none !important;
  border:1px solid #cbd5e1 !important;
  box-shadow:var(--shadow-1) !important;
}
.page-portal .btn:hover,
.page-portal .seg .btn:hover,
.page-portal .table .btn:hover{
  filter:none !important;
  transform:translateY(-1px);
}
.page-portal .seg .btn[disabled],
.page-portal .toolbar .btn[disabled]{
  opacity:.55;
  pointer-events:none;
}
/* Dauer-Schnellwahl-Chips im Slot-Formular */
.page-portal #form-slot .seg .btn,
.page-portal #form-slot .seg .btn[data-min],
.page-portal #form-slot .seg .btn[data-hour]{
  color:#0f172a !important;
  background:#fff !important;
  border:1px solid #cbd5e1 !important;
}

/* Portal-Form-Felder */
.page-portal .field{
  display:flex;
  flex-direction:column;
  gap:6px;
  background:rgba(255,255,255,.04);
  border:1px solid var(--border);
  border-radius:12px;
  padding:10px;
}
.page-portal .field input,
.page-portal .field select,
.page-portal .field textarea{
  background:#fff;
  color:#0f172a;
  border:1px solid rgba(15,23,42,.28);
  border-radius:12px;
  padding:10px;
  box-shadow: inset 0 1px 0 rgba(0,0,0,.03);
}
.page-portal .field input::placeholder,
.page-portal .field textarea::placeholder{
  color:#64748b;
}
.page-portal .field input:focus,
.page-portal .field select:focus,
.page-portal .field textarea:focus{
  outline:none;
  border-color:#60a5fa;
  box-shadow:0 0 0 3px rgba(59,130,246,.25);
}

/* Portal: Slot-Hints / gebuchte / abgelaufene Slots */
.page-portal .table tr.slot-past td{
  background:#f9fafb;
  color:#94a3b8;
}
.page-portal .table tr.slot-booked td{
  background:#ecfdf5;
}
.page-portal .table tr.slot-booked.slot-past td{
  background:#e5e7eb;
}
.slot-hint{
  display:block;
  font-size:12px;
  margin-top:2px;
}
.slot-past .slot-hint{
  color:#64748b;
  font-style:italic;
}
.slot-booked .slot-hint{
  color:#15803d;
  font-weight:500;
}

/* Slot-Filter / Toolbar oben rechts im Portal */
.slot-filter{
  display:flex;
  gap:8px;
  align-items:center;
  flex-wrap:wrap;
}
.slot-filter input{
  background:#fff;
  color:#0f172a;
  border:1px solid rgba(15,23,42,.28);
  border-radius:12px;
  padding:8px 10px;
  min-width:220px;
}

/* Guard / Callout wenn Profil unvollständig */
.callout{
  display:none;
  border:1px dashed #f59e0b;
  background:#fffbeb;
  color:#7c2d12;
  padding:12px 14px;
  border-radius:12px;
  margin-bottom:10px;
}
.callout strong{ color:#92400e }
.lock-hint{ font-size:14px }
fieldset[disabled]{
  filter: grayscale(0.1);
  opacity: .75;
}

/* Hinweisbanner evtl. ausgeblendet */
#force-banner{ display:none !important; }

/* Checkbox-Label „Alle auswählen“ im Portal sichtbar */
.page-portal .check{ color:#0f172a !important; }

/* Portal: Slot-Hinweise deutlich einfärben */
.page-portal .slot-hint {
  display: block;
  font-size: 12px;
  margin-top: 2px;
  color: #0f172a;      /* dunkler Text, gut lesbar auf weiß */
}

.page-portal .slot-hint.slot-hint-canceled {
  color: #b91c1c;      /* rot für Storniert am */
  font-weight: 600;
}

/* Stornierte Slots rot hinterlegt */
.page-portal .table tr.slot-canceled td {
  background: #fee2e2;
}


/* =========================================================
   Pflichtfelder: genau EIN roter Stern
========================================================= */
/* vorhandene <span class="req">*</span> ausblenden */
.field label .req{ display:none !important; }
/* Stern automatisch anhängen, wenn das nächste Feld required ist */
.field label:has(+ input[required]),
.field label:has(+ select[required]),
.field label:has(+ textarea[required]){
  position:relative;
  padding-right:8px;
}
.field label:has(+ input[required])::after,
.field label:has(+ select[required])::after,
.field label:has(+ textarea[required])::after{
  content:" *";
  color:var(--error);
  font-weight:700;
}

/* =========================================================
   GLOBAL: User-Dropdown / Menü – IMMER SICHTBAR
========================================================= */

/* Container für das User-Menü (rechts im Header) */
.user-menu{
  margin-left:auto;
  position:relative;
  z-index:60;
  display:block; /* wichtig: nie per media-query verstecken */
}

/* Dropdown-Menü */
.user-menu .menu{
  position:absolute;
  right:0;
  top:calc(100% + 8px);
  min-width:220px;
  padding:6px;
  background:#ffffff;
  color:#0f172a;
  border:1px solid #cbd5e1;
  border-radius:12px;
  box-shadow: var(--shadow-2, 0 16px 48px rgba(0,0,0,.35));
}
.user-menu .menu[hidden]{ display:none !important; }

/* Button, der das Menü öffnet (☰ Menü) */
#userMenuBtn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:6px;
  padding:6px 12px;
  border-radius:999px;
  border:1px solid var(--border, #e5e7eb);
  background:rgba(255,255,255,0.08);
  color:var(--ink, #f8fafc);
  font-size:0.95rem;
  line-height:1;
  cursor:pointer;
  box-shadow:var(--shadow-1, 0 1px 2px rgba(15,23,42,0.08));
}
#userMenuBtn:hover{
  background:rgba(255,255,255,0.16);
}

/* Einträge im Dropdown */
.user-menu .item{
  display:flex;
  width:100%;
  gap:8px;
  padding:10px 12px;
  border-radius:10px;
  background:transparent;
  border:0;
  cursor:pointer;
  text-align:left;
  font-weight:800;
  color:#0f172a;
  box-sizing:border-box;
}
.user-menu .item:hover{ background:#f1f5f9; }
.user-menu .item.danger{ color:#b91c1c; }
.user-menu .item.danger:hover{ background:#fee2e2; }

/* =========================================================
   NAVIGATION: Mobile Layout – Links IMMER sichtbar
========================================================= */
@media (max-width:768px){
  .container.nav{
    display:flex;
    flex-wrap:wrap;
    align-items:flex-start;
    gap:8px;
  }

  .brand{
    margin-right:auto;
  }

  .nav-links{
    display:flex !important;
    width:100%;
    justify-content:center;
    flex-wrap:wrap;
    gap:8px;
    text-align:center;
    margin-top:4px;
  }

  .nav-links a{
    font-size:0.9rem;
    padding:6px 8px;
  }

  /* CTA-Gruppe darf umbrechen, wenn vorhanden */
  .cta-group{
    display:flex;
    flex-wrap:wrap;
    gap:8px;
  }

  /* Portal: kompakter auf Mobile */
  .page-portal{
    font-size:0.95rem;
  }
  .page-portal .grid-2{
    grid-template-columns:1fr;
  }
  .page-portal .grid{
    gap:12px;
  }
  .page-portal .panel{
    margin-bottom:10px;
    padding:12px 10px;
    border-radius:18px;
  }
  .page-portal .panel h2{
    font-size:1.1rem;
    margin-bottom:4px;
  }
  .page-portal #form-profile,
  .page-portal #form-slot{
    gap:10px;
  }
  .page-portal .field{
    padding:8px;
    gap:4px;
  }
  .page-portal .field label{
    font-size:0.9rem;
  }
  .page-portal .field input,
  .page-portal .field select,
  .page-portal .field textarea{
    padding:8px;
    font-size:0.9rem;
  }
  .page-portal .toolbar{
    flex-direction:column;
    align-items:stretch;
    gap:6px;
  }
  .page-portal .toolbar .btn{
    width:100%;
    justify-content:center;
  }
  .page-portal .toolbar .muted{
    font-size:0.85rem;
  }
  .page-portal #form-slot .seg{
    gap:6px;
  }
  .page-portal #form-slot .seg .btn{
    font-size:0.78rem;
    padding:5px 8px;
  }
  .page-portal .slot-filter{
    flex-direction:column;
    align-items:stretch;
    gap:6px;
  }
  .page-portal .slot-filter input{
    width:100%;
    min-width:0;
  }
  .page-portal .slot-filter .seg{
    width:100%;
    justify-content:flex-start;
    flex-wrap:wrap;
    gap:6px;
  }
  .page-portal .slot-filter .seg .btn{
    font-size:0.78rem;
    padding:5px 8px;
  }

  /* PORTAL: "Meine Slots" – mobile Layout
     Ein Slot = eine Zeile
     links: alle Infos, rechts: Buttons */
  .page-portal .table-wrap{
    width:100%;
    overflow-x:visible;
  }

  /* Desktop: Tabelle mit horizontalem Scrollen */
  @media (min-width: 769px) {
    .page-portal .table-wrap{
      overflow-x: auto;
      overflow-y: visible;
      -webkit-overflow-scrolling: touch;
    }
    
    .page-portal #tbl-slots{
      min-width: 1000px; /* Mindestbreite für alle Spalten */
      width: 100%;
    }
    
    .page-portal #tbl-slots thead{
      display: table-header-group; /* Header auf Desktop anzeigen */
    }
    
    .page-portal #tbl-slots tbody tr{
      display: table-row; /* Normale Tabellenzeilen auf Desktop */
    }
    
    .page-portal #tbl-slots tbody tr td{
      display: table-cell;
      padding: 10px 12px;
      white-space: nowrap;
      border: 0;
      border-bottom: 1px solid var(--border);
    }
    
    .page-portal #tbl-slots tbody tr td:nth-child(1) { width: 34px; } /* Checkbox */
    .page-portal #tbl-slots tbody tr td:nth-child(2) { width: 140px; } /* Start */
    .page-portal #tbl-slots tbody tr td:nth-child(3) { width: 140px; } /* Ende */
    .page-portal #tbl-slots tbody tr td:nth-child(4) { width: 180px; min-width: 150px; white-space: normal; } /* Titel */
    .page-portal #tbl-slots tbody tr td:nth-child(5) { width: 120px; } /* Kategorie */
    .page-portal #tbl-slots tbody tr td:nth-child(6) { width: 200px; min-width: 180px; white-space: normal; } /* Ort */
    .page-portal #tbl-slots tbody tr td:nth-child(7) { width: 60px; text-align: center; } /* Kapazität */
    .page-portal #tbl-slots tbody tr td:nth-child(8) { width: 100px; } /* Status */
    .page-portal #tbl-slots tbody tr td:nth-child(9) { 
      width: 120px; 
      display: flex;
      flex-direction: column;
      gap: 4px;
      align-items: flex-start;
      white-space: normal;
    } /* Aktionen */
    
    .page-portal #tbl-slots tbody tr td:nth-child(9) .btn {
      width: 100%;
      white-space: nowrap;
    }
  }

  .page-portal #tbl-slots{
    width:100%;
    border-collapse:separate;
    border-spacing:0;
    min-width:0;
  }

  /* Desktop: Tabelle mit horizontalem Scrollen */
  @media (min-width: 769px) {
    .page-portal .table-wrap{
      overflow-x: auto;
      overflow-y: visible;
      -webkit-overflow-scrolling: touch;
    }
    
    .page-portal #tbl-slots{
      min-width: 1000px; /* Mindestbreite für alle Spalten */
      width: 100%;
    }
    
    .page-portal #tbl-slots thead{
      display: table-header-group; /* Header auf Desktop anzeigen */
    }
    
    .page-portal #tbl-slots tbody tr{
      display: table-row; /* Normale Tabellenzeilen auf Desktop */
    }
    
    .page-portal #tbl-slots tbody tr td{
      display: table-cell;
      padding: 10px 12px;
      white-space: nowrap;
      border: 0;
      border-bottom: 1px solid var(--border);
    }
    
    .page-portal #tbl-slots tbody tr td:nth-child(1) { width: 34px; } /* Checkbox */
    .page-portal #tbl-slots tbody tr td:nth-child(2) { width: 140px; } /* Start */
    .page-portal #tbl-slots tbody tr td:nth-child(3) { width: 140px; } /* Ende */
    .page-portal #tbl-slots tbody tr td:nth-child(4) { width: 180px; min-width: 150px; white-space: normal; } /* Titel */
    .page-portal #tbl-slots tbody tr td:nth-child(5) { width: 120px; } /* Kategorie */
    .page-portal #tbl-slots tbody tr td:nth-child(6) { width: 200px; min-width: 180px; white-space: normal; } /* Ort */
    .page-portal #tbl-slots tbody tr td:nth-child(7) { width: 60px; text-align: center; } /* Kapazität */
    .page-portal #tbl-slots tbody tr td:nth-child(8) { width: 100px; } /* Status */
    .page-portal #tbl-slots tbody tr td:nth-child(9) { width: 120px; } /* Aktionen */
  }

  /* Mobile: Grid-Layout */
  @media (max-width: 768px) {
    .page-portal #tbl-slots thead{
      display:none;
    }

    .page-portal #tbl-slots tbody tr{
      display:grid;
      grid-template-columns:minmax(0,1.7fr) auto;
      align-items:flex-start;
      gap:4px;
      padding:6px 6px;
      border-bottom:1px solid var(--border);
      border-radius:10px;
      background:#ffffff;
      color:#0f172a;
      margin-bottom:6px;
    }
  }

  /* Past/booked Klassen sollen Hintergrund vom Row übernehmen */
  .page-portal #tbl-slots tbody tr.slot-past td,
  .page-portal #tbl-slots tbody tr.slot-booked td,
  .page-portal #tbl-slots tbody tr.slot-booked.slot-past td{
    background:transparent;
  }

  .page-portal #tbl-slots tbody tr td{
    border:0;
    padding:2px 4px;
    font-size:0.82rem;
    white-space:normal;
  }

  /* Alle Infos (Checkbox, Start, Ende, Titel, Kategorie, Ort, Kapazität, Status) links */
  .page-portal #tbl-slots tbody tr td:nth-child(-n+8){
    grid-column:1 / 2;
    text-align:left;
  }

  /* Aktionen rechts */
  .page-portal #tbl-slots tbody tr td:nth-child(9){
    grid-column:2 / 3;
    text-align:right;
  }

  .page-portal #tbl-slots tbody tr td:nth-child(9) .btn{
    display:block;
    width:100%;
    margin:2px 0;
    text-align:center;
  }

  /* Checkbox links kompakt */
  .page-portal #tbl-slots tbody tr td:first-child{
    display:flex;
    align-items:center;
    gap:4px;
  }

  .page-portal #tbl-slots .slot-hint{
    font-size:0.78rem;
  }

  /* Footer-Spalten untereinander */
  .foot-grid{
    grid-template-columns:1fr;
    gap:16px;
  }
  .foot-col{
    margin-top:4px;
  }
  /* page-portal: "Meine Slots" – kompakt auf Mobile */
@media (max-width:768px){

  /* Kopfzeile ausblenden */
  .page-portal #tbl-slots thead{
    display:none;
  }

  /* Jede Slot-Zeile als Card */
  .page-portal #tbl-slots tbody tr{
    display:block;
    padding:8px 10px;
    margin-bottom:8px;
    border-radius:12px;
    background:#ffffff;
    color:#0f172a;
    border:1px solid #e5e7eb;
  }

  .page-portal #tbl-slots tbody tr td{
    display:inline;
    border:0;
    padding:0;
    font-size:0.82rem;
    white-space:normal;
  }

  /* kleine Abstände zwischen Inline-Zellen */
  .page-portal #tbl-slots tbody tr td + td::before{
    content:" ";
  }

  /* Checkbox links ganz vorne */
  .page-portal #tbl-slots tbody tr td[data-label="✓"]{
    margin-right:6px;
  }

  /* Zeitbereich: Start – Ende */
  .page-portal #tbl-slots tbody tr td[data-label="Start"]::after{
    content:" –";
  }
  .page-portal #tbl-slots tbody tr td[data-label="Ende"]{
    margin-right:6px;
  }

  /* Titel etwas hervorgehoben */
  .page-portal #tbl-slots tbody tr td[data-label="Titel"]{
    font-weight:600;
  }

  /* Slot-Hinweis (gebucht/abgelaufen) kleiner */
  .page-portal #tbl-slots .slot-hint{
    display:inline-block;
    margin-left:4px;
    font-size:0.75rem;
  }

  /* --- 2. Zeile: Meta-Infos --- */

  /* Zeilenumbruch vor Kategorie erzwingen */
  .page-portal #tbl-slots tbody tr td[data-label="Kategorie"]::before{
    content:"\A";
    white-space:pre;
  }

  .page-portal #tbl-slots tbody tr td[data-label="Kategorie"],
  .page-portal #tbl-slots tbody tr td[data-label="Ort"],
  .page-portal #tbl-slots tbody tr td[data-label="Kapazität"],
  .page-portal #tbl-slots tbody tr td[data-label="Status"]{
    font-size:0.78rem;
    color:#64748b;
  }

  .page-portal #tbl-slots tbody tr td[data-label="Kapazität"]::before{
    content:" · Kap. ";
  }
  .page-portal #tbl-slots tbody tr td[data-label="Kapazität"]{
    /* Zahl alleine, Label kommt aus ::before */
  }

  .page-portal #tbl-slots tbody tr td[data-label="Status"] .badge-st{
    margin-left:4px;
  }

  /* --- Aktionen: eigene Zeile unten rechts --- */

  .page-portal #tbl-slots tbody tr td[data-label="Aktionen"]{
    display:block;
    margin-top:6px;
    text-align:right;
  }

  .page-portal #tbl-slots tbody tr td[data-label="Aktionen"] .btn{
    display:inline-block;
    width:auto;
    margin-left:4px;
    padding:4px 8px;
    font-size:0.75rem;
  }

  /* Past/Booked Hintergründe nicht mehr jede Zelle anfärben,
     sondern die Card leicht tönen, wenn du willst: */
  .page-portal #tbl-slots tbody tr.slot-past{
    background:#f9fafb;
  }
  .page-portal #tbl-slots tbody tr.slot-booked{
    background:#ecfdf5;
  }
  .page-portal #tbl-slots tbody tr.slot-booked.slot-past{
    background:#e5e7eb;
  }
}

    /* Hinweis-Banner oben unter dem Header */
.tm-hinweis {
  background: #eef2ff;              /* leichtes Lila, unaufdringlich */
  border-bottom: 1px solid #c7d2fe;
  font-family: 'Inter', system-ui, -apple-system, BlinkMacSystemFont, sans-serif;
}

.tm-hinweis-inner {
  max-width: 1100px;
  margin: 0 auto;
  padding: 10px 16px;
  display: flex;
  align-items: flex-start;
  gap: 12px;
}

.tm-hinweis-text {
  font-size: 0.95rem;
  color: #111827;
  line-height: 1.4;
}

/* Schließen-Button */
.tm-hinweis-close {
  margin-left: auto;
  border: none;
  background: transparent;
  font-size: 1.2rem;
  line-height: 1;
  cursor: pointer;
  color: #6b7280;
  padding: 0 4px;
}

.tm-hinweis-close:hover {
  color: #111827;
}

/* Mobile: Zeile umbrechen, Button rechts oben */
@media (max-width: 768px) {
  .tm-hinweis-inner {
    flex-direction: row;
    align-items: flex-start;
  }
}

}

/* ---------- Accessibility / Motion already handled oben ---------- */
