/* ===== Selbst-gehostete Schriften (DSGVO – kein Google-CDN) ===== */
@font-face{font-family:'Inter';font-style:normal;font-weight:400;font-display:swap;src:url(/static/fonts/inter-400.woff2) format('woff2')}
@font-face{font-family:'Inter';font-style:normal;font-weight:500;font-display:swap;src:url(/static/fonts/inter-500.woff2) format('woff2')}
@font-face{font-family:'Inter';font-style:normal;font-weight:600;font-display:swap;src:url(/static/fonts/inter-600.woff2) format('woff2')}
@font-face{font-family:'Inter';font-style:normal;font-weight:700;font-display:swap;src:url(/static/fonts/inter-700.woff2) format('woff2')}
@font-face{font-family:'Space Grotesk';font-style:normal;font-weight:500;font-display:swap;src:url(/static/fonts/spacegrotesk-500.woff2) format('woff2')}
@font-face{font-family:'Space Grotesk';font-style:normal;font-weight:600;font-display:swap;src:url(/static/fonts/spacegrotesk-600.woff2) format('woff2')}
@font-face{font-family:'Space Grotesk';font-style:normal;font-weight:700;font-display:swap;src:url(/static/fonts/spacegrotesk-700.woff2) format('woff2')}

:root{
  /* ============ DARK PREMIUM · Anthrazit + Orange ============ */
  --bg:#0a0d12; --bg-2:#0c1118; --surface:#121922; --surface-2:#19222e;
  --glass:rgba(255,255,255,.045); --glass-2:rgba(255,255,255,.07);
  --ink:#f4f7fb; --soft:#9fb0c2; --faint:#6c7c8e;
  --brand:#ff7a1a; --brand-2:#ff9a3d; --brand-3:#070a0e; --brand-d:#ff6a00;
  --accent:#ff7a1a; --accent-d:#ff6a00; --accent-soft:rgba(255,122,26,.13);
  --green:#34d27b; --green-soft:rgba(52,210,123,.13);
  --red:#ff5a5a; --red-soft:rgba(255,90,90,.12);
  --gold:#f0c454; --gold-soft:rgba(240,196,84,.12);
  --line:rgba(255,255,255,.09); --line-2:rgba(255,255,255,.06);
  --radius:18px; --radius-sm:12px;
  --shadow:0 1px 2px rgba(0,0,0,.4),0 12px 34px rgba(0,0,0,.35);
  --shadow-lg:0 30px 80px rgba(0,0,0,.55);
  --glow:0 0 0 1px rgba(255,122,26,.4),0 18px 50px rgba(255,122,26,.22);
  --ring:0 0 0 4px rgba(255,122,26,.18);
  --grad-brand:linear-gradient(135deg,#ff9a3d,#ff6a00);
  /* semantische Token (theme-abhaengig) */
  --field-bg:rgba(0,0,0,.25); --field-bg-2:rgba(0,0,0,.35); --fill-subtle:rgba(255,255,255,.04);
  --ok-text:#7fe6ad; --err-text:#ff9d9d; --header-bg:rgba(10,13,18,.72);
  --maxw:1200px;
}

/* ============ LIGHT THEME ============ */
:root[data-theme="light"]{
  --bg:#eef1f7; --bg-2:#e6eaf2; --surface:#ffffff; --surface-2:#f5f7fc;
  --glass:rgba(255,255,255,.74); --glass-2:rgba(255,255,255,.95);
  --ink:#14222f; --soft:#54636f; --faint:#84919e;
  --brand:#ff7a1a; --brand-2:#e8650a; --brand-3:#0c1018; --brand-d:#ff6a00;
  --accent:#ff7a1a; --accent-d:#ff6a00; --accent-soft:rgba(255,122,26,.12);
  --green:#1f9d57; --green-soft:rgba(31,157,87,.13);
  --red:#d83a3a; --red-soft:rgba(216,58,58,.10);
  --gold:#bd8c12; --gold-soft:rgba(189,140,18,.14);
  --line:rgba(15,30,45,.12); --line-2:rgba(15,30,45,.07);
  --shadow:0 1px 2px rgba(20,40,60,.06),0 12px 30px rgba(20,40,60,.10);
  --shadow-lg:0 30px 70px rgba(20,40,60,.18);
  --glow:0 0 0 1px rgba(255,122,26,.32),0 18px 50px rgba(255,122,26,.16);
  --ring:0 0 0 4px rgba(255,122,26,.18);
  --field-bg:#f2f5fa; --field-bg-2:#ffffff; --fill-subtle:rgba(15,30,45,.05);
  --ok-text:#15814a; --err-text:#bd2f24; --header-bg:rgba(255,255,255,.82);
}
/* Light: dezenterer Ambient-Hintergrund */
:root[data-theme="light"] body::before{
  background:
    radial-gradient(900px 600px at 80% -10%,rgba(255,122,26,.07),transparent 60%),
    radial-gradient(760px 560px at 4% 8%,rgba(60,110,190,.06),transparent 62%);
}
/* Light: Komponenten mit fest verdrahteten Dunkel-Farben angleichen */
:root[data-theme="light"] .btn-dark{background:var(--surface-2);color:var(--ink);border:1px solid var(--line)}
:root[data-theme="light"] .btn-dark:hover{background:#e9edf5;color:var(--ink);border-color:var(--line)}
:root[data-theme="light"] nav a:hover{color:var(--brand-2);background:var(--accent-soft)}
:root[data-theme="light"] .btn-ghost:hover{color:var(--brand-2);background:var(--accent-soft);border-color:rgba(255,122,26,.5)}
/* Hero bleibt in beiden Themes dunkel (Foto) – weiße Buttons dort wiederherstellen */
:root[data-theme="light"] .hero-photo .btn-ghost,:root[data-theme="light"] .hero-video .btn-ghost{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.28);color:#fff}
:root[data-theme="light"] .hero-photo .btn-ghost:hover,:root[data-theme="light"] .hero-video .btn-ghost:hover{background:rgba(255,255,255,.16);border-color:#fff;color:#fff}
/* Light: Glas-Cards bekommen weichen Rand für mehr Definition */
:root[data-theme="light"] .benefit,:root[data-theme="light"] .plan,:root[data-theme="light"] .amenity,
:root[data-theme="light"] .ws-block,:root[data-theme="light"] .howto .card,:root[data-theme="light"] .contact,
:root[data-theme="light"] .panel,:root[data-theme="light"] .order-card,:root[data-theme="light"] .form-card,
:root[data-theme="light"] .stat,:root[data-theme="light"] .kpi,:root[data-theme="light"] .table,
:root[data-theme="light"] .faq details{background:var(--surface)}
:root[data-theme="light"] .table th{background:#eef2f8}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:"Inter","Segoe UI",system-ui,sans-serif;background:var(--bg);color:var(--ink);line-height:1.65;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden}
/* Ambient glow im Hintergrund */
body::before{content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;
  background:
    radial-gradient(900px 600px at 78% -8%,rgba(255,122,26,.10),transparent 60%),
    radial-gradient(700px 520px at 8% 12%,rgba(40,90,160,.10),transparent 60%),
    radial-gradient(900px 700px at 50% 108%,rgba(255,122,26,.06),transparent 60%)}
a{color:var(--brand-2);text-decoration:none}a:hover{color:var(--brand);text-decoration:none}
h1,h2,h3,h4{font-family:"Space Grotesk","Inter",system-ui,sans-serif;line-height:1.05;color:var(--ink);margin:0 0 .4em;letter-spacing:-.02em;font-weight:700}
h1{font-size:clamp(2.4rem,6vw,4.4rem);font-weight:700}
h2{font-size:clamp(1.9rem,3.6vw,2.7rem)}
img{max-width:100%}
small{color:var(--soft)}
.muted{color:var(--soft)}.small{font-size:.85rem}.hidden{display:none}.center{text-align:center}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
::selection{background:rgba(255,122,26,.3);color:#fff}

/* ---------- Buttons ---------- */
.btn-primary,.btn-ghost,.btn-dark{
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  padding:13px 26px;border-radius:12px;font-weight:700;cursor:pointer;border:0;
  font-size:.92rem;letter-spacing:.3px;transition:transform .18s cubic-bezier(.2,.7,.2,1),box-shadow .18s,filter .18s,background .18s;line-height:1}
.btn-primary{background:var(--grad-brand);color:#10151c;box-shadow:0 10px 30px rgba(255,106,0,.32),inset 0 1px 0 rgba(255,255,255,.3);font-weight:800}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 16px 40px rgba(255,106,0,.45),inset 0 1px 0 rgba(255,255,255,.3);filter:brightness(1.04);color:#10151c}
.btn-primary:disabled{opacity:.4;cursor:not-allowed;box-shadow:none;transform:none;filter:none}
.btn-ghost{background:var(--glass);border:1px solid var(--line);color:var(--ink);backdrop-filter:blur(8px)}
.btn-ghost:hover{border-color:rgba(255,122,26,.6);color:#fff;background:var(--glass-2);transform:translateY(-2px)}
.btn-dark{background:var(--glass-2);color:#fff;border:1px solid var(--line)}
.btn-dark:hover{background:rgba(255,255,255,.12);border-color:var(--line);transform:translateY(-2px);color:#fff}
/* Theme-Umschalter (System/Hell/Dunkel) */
.theme-toggle{display:inline-flex;align-items:center;gap:8px;background:var(--glass);border:1px solid var(--line);
  color:var(--soft);font:inherit;font-size:.9rem;font-weight:600;letter-spacing:.2px;padding:8px 13px;border-radius:10px;
  cursor:pointer;transition:.15s;line-height:1}
.theme-toggle:hover{color:var(--ink);border-color:var(--brand)}
.theme-toggle .tt-ico{display:inline-flex;width:17px;height:17px;color:var(--brand-2)}
.theme-toggle .tt-ico svg{width:17px;height:17px;display:block}
.big{padding:17px 34px;font-size:1.02rem}.small{padding:7px 13px;font-size:.78rem}.block{width:100%}

main{min-height:60vh}

/* ---------- Header ---------- */
.topbar{position:sticky;top:0;z-index:60;background:var(--header-bg);
  backdrop-filter:blur(18px) saturate(160%);border-bottom:1px solid var(--line-2)}
.topbar-inner{max-width:var(--maxw);margin:0 auto;padding:14px 24px;
  display:flex;justify-content:space-between;align-items:center;gap:14px;flex-wrap:wrap}
.brand{display:flex;align-items:center;gap:13px;color:var(--ink);font-weight:800;font-size:1.18rem;letter-spacing:.2px}
.brand:hover{color:var(--ink)}
.brand-logo{display:grid;place-items:center;filter:drop-shadow(0 6px 16px rgba(255,106,0,.4))}
.brand .b2{color:var(--brand)}
.brand small{display:block;color:var(--soft);font-weight:500;font-size:.66rem;letter-spacing:.5px;text-transform:none;margin-top:1px}
nav{display:flex;align-items:center;gap:4px;flex-wrap:wrap}
nav a{color:var(--soft);font-size:.9rem;font-weight:600;padding:9px 14px;border-radius:10px;letter-spacing:.2px;transition:.15s}
nav a:hover{background:var(--glass);color:#fff}
nav .btn-primary,nav .btn-ghost{padding:10px 18px}
nav .btn-primary:hover{color:#10151c}
.nav-toggle{display:none;flex-direction:column;justify-content:center;gap:5px;width:46px;height:46px;
  background:var(--glass);border:1px solid var(--line);border-radius:12px;cursor:pointer;padding:0}
.nav-toggle span{display:block;width:20px;height:2px;background:var(--ink);margin:0 auto;transition:.22s;border-radius:2px}
.nav-toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle.open span:nth-child(2){opacity:0}
.nav-toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

.vip-badge-bar{max-width:var(--maxw);margin:18px auto 0;padding:12px 18px;
  background:var(--gold-soft);border:1px solid rgba(240,196,84,.35);color:var(--gold);
  border-radius:12px;font-weight:700;display:flex;align-items:center;gap:8px}

/* ---------- Hero (Vollbild-Video, dark premium) ---------- */
.hero{position:relative;overflow:hidden}
.hero-video,.hero-photo{min-height:80vh;display:flex;align-items:flex-end;overflow:hidden}
.hero-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;border:0;border-radius:0;filter:saturate(1.05) contrast(1.05)}
/* Foto-Hero: echtes Hallenfoto (ffmpeg-gegradet), dezent dunkler fuer Text-Kontrast */
.hero-photo .hero-bg{filter:brightness(.78) contrast(1.04) saturate(1.05)}
/* Gradient-Bars (Vanilla-Port der React-Komponente) – animierte Orange-Balken davor */
.hero-bars{position:absolute;inset:0;z-index:2;display:flex;width:100%;overflow:hidden;pointer-events:none;
  mix-blend-mode:screen;opacity:.4;transform:translateZ(0);backface-visibility:hidden}
.hero-bars .bar{height:100%;transform-origin:bottom;transition:transform .5s ease-in-out;
  animation:pulseBar var(--dur,2s) ease-in-out infinite alternate;outline:1px solid transparent;box-sizing:border-box}
@keyframes pulseBar{0%{transform:scaleY(var(--s))}100%{transform:scaleY(calc(var(--s) * .7))}}
@media(prefers-reduced-motion:reduce){.hero-bars .bar{animation:none}}
/* Hero zweispaltig: Text links, Glas-Schnell-Karte rechts */
.hero.hero-photo{align-items:center}
.hero.hero-photo .hero-inner{grid-template-columns:1fr;align-items:center;padding-top:104px;padding-bottom:84px}
.hero-quick{position:relative;align-self:center;border-radius:22px;padding:26px 26px 24px;
  background:rgba(16,22,30,.52);backdrop-filter:blur(18px) saturate(150%);border:1px solid var(--line);
  box-shadow:var(--shadow-lg);overflow:hidden}
.hero-quick::before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--brand),transparent)}
.hq-head{font-family:"Space Grotesk",sans-serif;text-transform:uppercase;letter-spacing:1.4px;font-size:.74rem;
  color:var(--brand-2);font-weight:800;margin-bottom:14px}
.hq-list{list-style:none;padding:0;margin:0 0 20px}
.hq-list li{display:flex;justify-content:space-between;align-items:center;gap:14px;padding:12px 0;
  border-bottom:1px solid var(--line-2);color:rgba(255,255,255,.78);font-size:.92rem}
.hq-list li:first-child{padding-top:0}
.hq-list li b{color:#fff;font-weight:800;white-space:nowrap;font-family:"Space Grotesk",sans-serif}
.hq-foot{margin-top:13px;text-align:center;color:rgba(255,255,255,.62);font-size:.8rem}
.hero-scrim{position:absolute;inset:0;z-index:1;pointer-events:none;
  background:
    linear-gradient(180deg,rgba(10,13,18,.78) 0%,rgba(10,13,18,.25) 30%,rgba(10,13,18,.55) 72%,var(--bg) 100%),
    linear-gradient(90deg,rgba(10,13,18,.85) 0%,rgba(10,13,18,.35) 55%,transparent 100%),
    radial-gradient(900px 500px at 80% 30%,rgba(255,122,26,.18),transparent 60%)}
.hero-video .hero-inner,.hero-photo .hero-inner{position:relative;z-index:2;max-width:var(--maxw);margin:0 auto;width:100%;
  display:grid;grid-template-columns:1fr;padding:120px 24px 88px}
.hero-text{max-width:760px}
.hero .eyebrow{display:inline-flex;align-items:center;gap:9px;background:var(--glass);
  border:1px solid var(--line);color:#fff;padding:8px 16px;border-radius:40px;
  font-size:.74rem;font-weight:700;letter-spacing:1px;text-transform:uppercase;margin-bottom:24px;backdrop-filter:blur(8px)}
.hero .eyebrow::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--brand);box-shadow:0 0 12px var(--brand)}
.hero h1{font-size:clamp(2.6rem,6.6vw,5rem);margin-bottom:20px;line-height:1.02;color:#fff}
.hero h1 .hl{background:var(--grad-brand);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
  text-shadow:0 0 50px rgba(255,122,26,.35)}
.hero p.lead{font-size:clamp(1.05rem,1.6vw,1.28rem);color:rgba(255,255,255,.82);max-width:54ch;margin:0 0 32px;font-weight:400}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap}
.hero-trust{margin-top:34px;display:flex;gap:14px 28px;flex-wrap:wrap;color:rgba(255,255,255,.78);font-size:.92rem}
.hero-trust span{display:flex;align-items:center;gap:8px}
.hero-trust span::before{content:"✓";color:var(--brand);font-weight:800}
.hero-video .btn-ghost,.hero-photo .btn-ghost{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.28);color:#fff}
.hero-video .btn-ghost:hover,.hero-photo .btn-ghost:hover{background:rgba(255,255,255,.16);border-color:#fff;color:#fff}
.hero-chip,.hero-chip--corner{position:absolute;right:24px;bottom:88px;left:auto;z-index:3;
  background:rgba(18,25,34,.7);backdrop-filter:blur(14px);border:1px solid var(--line);color:#fff;border-radius:18px;
  padding:16px 22px;box-shadow:var(--shadow-lg);font-family:"Space Grotesk",sans-serif;font-weight:700;font-size:1.7rem;line-height:1}
.hero-chip span{display:block;font-size:.6rem;letter-spacing:1.5px;text-transform:uppercase;color:var(--brand-2);font-family:"Inter",sans-serif;font-weight:700;margin-bottom:4px}
.hero-chip small{font-size:.76rem;color:var(--soft);font-weight:500}

/* ---------- Sections ---------- */
.sec{padding:96px 0;position:relative}
.sec.alt{background:linear-gradient(180deg,var(--bg-2),var(--bg));border-top:1px solid var(--line-2);border-bottom:1px solid var(--line-2)}
.sec-head{text-align:center;max-width:680px;margin:0 auto 56px}
.sec-head .kicker,.washbay-text .kicker{display:inline-flex;align-items:center;gap:9px;color:var(--brand-2);font-weight:700;
  text-transform:uppercase;letter-spacing:2px;font-size:.78rem;margin-bottom:14px;font-family:"Space Grotesk",sans-serif}
.sec-head .kicker::before,.sec-head .kicker::after{content:"";width:24px;height:1.5px;background:linear-gradient(90deg,transparent,var(--brand));display:inline-block}
.sec-head .kicker::after{background:linear-gradient(90deg,var(--brand),transparent)}
.sec-head p{color:var(--soft);font-size:1.08rem;margin:.6em 0 0}

/* ---------- Glas-Card-Basis ---------- */
.benefit,.plan,.amenity,.ws-block,.howto .card,.contact,.panel,.order-card,.form-card,.stat,.legal-body,.vip-hero{
  background:var(--glass);border:1px solid var(--line);backdrop-filter:blur(10px);
  box-shadow:0 1px 0 rgba(255,255,255,.05) inset,var(--shadow)}

/* ---------- Benefits ---------- */
.benefits{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.benefit{border-radius:var(--radius);padding:28px;transition:.2s;position:relative;overflow:hidden}
.benefit::after{content:"";position:absolute;inset:0;border-radius:var(--radius);padding:1px;
  background:linear-gradient(160deg,rgba(255,122,26,.5),transparent 40%);
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;opacity:0;transition:.2s}
.benefit:hover{transform:translateY(-4px);background:var(--glass-2);box-shadow:var(--shadow-lg)}
.benefit:hover::after{opacity:1}
.benefit .ic{width:54px;height:54px;border-radius:14px;background:linear-gradient(150deg,rgba(255,122,26,.22),rgba(255,122,26,.04));
  border:1px solid rgba(255,122,26,.28);color:var(--brand-2);display:grid;place-items:center;margin-bottom:16px}
.benefit h4{font-size:1.08rem;margin-bottom:6px}
.benefit p{margin:0;color:var(--soft);font-size:.93rem}

/* ---------- Pricing ---------- */
.pricing{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;align-items:stretch}
.plan{border-radius:var(--radius);padding:34px;position:relative;display:flex;flex-direction:column;transition:.2s}
.plan:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.plan.featured{border-color:rgba(255,122,26,.55);background:linear-gradient(180deg,rgba(255,122,26,.10),var(--glass));box-shadow:var(--glow)}
.plan .badge{position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:var(--grad-brand);
  color:#10151c;font-size:.7rem;font-weight:800;letter-spacing:.8px;padding:6px 16px;border-radius:8px;text-transform:uppercase;box-shadow:0 8px 20px rgba(255,106,0,.4)}
.plan.vip{border-color:rgba(240,196,84,.45);background:linear-gradient(180deg,rgba(240,196,84,.10),var(--glass))}
.plan.vip .badge{background:linear-gradient(135deg,#f6d57a,#e0ad33);color:#2a1f00;box-shadow:0 8px 20px rgba(240,196,84,.3)}
.plan h3{font-size:1.25rem}
.plan .ptype{color:var(--soft);font-size:.9rem;margin-bottom:18px}
.plan .pamt{font-size:3rem;font-weight:800;color:#fff;line-height:1;font-family:"Space Grotesk",sans-serif}
.plan .pamt span{font-size:.92rem;color:var(--soft);font-weight:500}
.plan.featured .pamt,.plan .pamt{background:var(--grad-brand);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.plan.featured .pamt span,.plan .pamt span{-webkit-text-fill-color:var(--soft)}
.plan.vip .pamt{background:linear-gradient(135deg,#f6d57a,#e0ad33);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.plan .pnote{color:var(--faint);font-size:.82rem;margin:6px 0 22px}
.plan ul{list-style:none;padding:0;margin:0 0 26px;flex:1}
.plan li{padding:10px 0;border-bottom:1px solid var(--line-2);font-size:.93rem;display:flex;gap:10px;align-items:flex-start;color:var(--soft)}
.plan li::before{content:"\2713";color:var(--brand);font-weight:800;margin-top:1px}
.plan li:last-child{border-bottom:0}

/* ---------- Amenities ---------- */
.amenities{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.amenity{align-items:center;border-radius:16px;padding:20px;display:flex;gap:14px;transition:.2s}
.amenity:hover{border-color:rgba(255,122,26,.4);background:var(--glass-2);transform:translateY(-3px);box-shadow:var(--shadow-lg)}
.amenity .ic{display:grid;place-items:center;flex:0 0 auto;width:46px;height:46px;border-radius:13px;
  background:linear-gradient(150deg,rgba(255,122,26,.22),rgba(255,122,26,.04));border:1px solid rgba(255,122,26,.28);color:var(--brand-2)}
.amenity .ic svg{width:24px;height:24px}
.amenity>div{min-width:0}
.amenity b{display:block;font-size:.95rem;color:var(--ink);margin-bottom:2px;line-height:1.2;overflow-wrap:break-word;hyphens:auto}
.amenity small{color:var(--soft);font-size:.82rem;line-height:1.4;display:block;overflow-wrap:break-word}

/* ---------- Waschhalle ---------- */
.washbay{display:grid;grid-template-columns:1fr 1fr;gap:44px;align-items:center}
.washbay-text h2{margin-bottom:14px}
.washbay-text .lead-text{color:var(--soft);font-size:1.08rem;margin:0 0 22px}
.washbay-list{list-style:none;padding:0;margin:0 0 26px}
.washbay-list li{position:relative;padding:12px 0 12px 28px;border-bottom:1px solid var(--line-2);font-size:1.02rem;font-weight:600;color:var(--ink)}
.washbay-list li:last-child{border-bottom:0}
.washbay-list li::before{content:"";position:absolute;left:0;top:1.35em;width:10px;height:10px;background:var(--grad-brand);border-radius:3px;transform:translateY(-50%) rotate(45deg);box-shadow:0 0 12px rgba(255,122,26,.5)}
.washbay-imgs{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.washbay-imgs img{display:block;width:100%;aspect-ratio:4/3;object-fit:cover;border-radius:var(--radius);
  border:1px solid var(--line);box-shadow:var(--shadow)}

/* ---------- Workshops / Lifts ---------- */
.ws-grid{display:grid;grid-template-columns:1fr 1fr;gap:22px}
.ws-block{border-radius:var(--radius);padding:30px;transition:.2s}
.ws-block:hover{box-shadow:var(--shadow-lg);transform:translateY(-3px)}
.ws-block h3{display:flex;align-items:center;gap:11px;margin-bottom:4px;font-size:1.3rem}
.ws-block .dot{width:10px;height:10px;border-radius:50%;background:var(--brand);box-shadow:0 0 14px var(--brand)}
.ws-imgs{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:18px 0}
.ws-imgs img{display:block;width:100%;aspect-ratio:4/3;object-fit:cover;border-radius:var(--radius-sm);border:1px solid var(--line)}
.lift-row{display:flex;flex-direction:column;gap:11px;margin-top:18px}
.lift-chip{background:var(--surface-2);border:1px solid var(--line);border-left:3px solid var(--brand);
  border-radius:var(--radius-sm);padding:14px 17px;display:flex;justify-content:space-between;align-items:center;
  gap:12px;cursor:pointer;transition:.15s;text-decoration:none}
.lift-chip:hover{border-color:rgba(255,122,26,.5);border-left-color:var(--brand);background:var(--glass-2);
  transform:translateX(2px);box-shadow:var(--shadow)}
.lift-chip strong{display:block;font-size:.96rem;color:var(--ink)}.lift-chip span{font-size:.8rem;color:var(--soft)}
.lift-chip em{font-style:normal;font-weight:800;color:var(--brand-2);white-space:nowrap;margin-left:auto}
.lift-chip-go{flex:0 0 auto;color:var(--brand-2);font-weight:800;font-size:1.1rem;opacity:.55;transition:.15s}
.lift-chip:hover .lift-chip-go{opacity:1;transform:translateX(2px)}

/* ---------- How-to ---------- */
.howto{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.howto .card{border-radius:var(--radius);padding:30px 26px;transition:.2s}
.howto .card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.howto .num{width:46px;height:46px;border-radius:13px;background:var(--grad-brand);
  color:#10151c;font-weight:800;display:grid;place-items:center;margin-bottom:16px;font-size:1.15rem;font-family:"Space Grotesk",sans-serif;
  box-shadow:0 10px 26px rgba(255,106,0,.35)}
.howto h4{font-size:1.05rem}.howto p{margin:0;color:var(--soft);font-size:.91rem}

/* ---------- Gallery ---------- */
.gallery{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.gallery .gimg{width:100%;aspect-ratio:16/10;object-fit:cover;border-radius:var(--radius);
  border:1px solid var(--line);box-shadow:var(--shadow);transition:.25s;cursor:pointer;filter:saturate(1.05)}
.gallery .gimg:hover{transform:scale(1.015);box-shadow:var(--shadow-lg);border-color:rgba(255,122,26,.4)}

/* ---------- Contact / CTA ---------- */
.contact{display:grid;grid-template-columns:1fr 1fr;gap:34px;border-radius:var(--radius);padding:38px}
.contact ul{list-style:none;padding:0;margin:0}
.contact li{padding:11px 0;border-bottom:1px solid var(--line-2);display:flex;gap:12px}
.contact li:last-child{border-bottom:0}
.contact li b{min-width:90px;color:var(--soft)}
.cta-band{position:relative;overflow:hidden;background:linear-gradient(120deg,#1a1207,#2a1a06);
  border:1px solid rgba(255,122,26,.3);color:#fff;border-radius:24px;padding:64px 46px;text-align:center;box-shadow:var(--shadow-lg)}
.cta-band::before{content:"";position:absolute;inset:0;background:radial-gradient(700px 400px at 50% -30%,rgba(255,122,26,.35),transparent 60%)}
.cta-band::after{content:"";position:absolute;inset:0;background:repeating-linear-gradient(115deg,rgba(255,255,255,.03) 0 2px,transparent 2px 26px)}
.cta-band>*{position:relative;z-index:1}
.cta-band h2{color:#fff;font-size:clamp(1.9rem,3.4vw,2.8rem)}.cta-band p{color:rgba(255,255,255,.82);margin-bottom:28px;font-size:1.1rem}
.cta-band .btn-primary{box-shadow:0 14px 40px rgba(255,106,0,.5)}
.contact li a{color:var(--brand-2)}.contact li a:hover{color:var(--brand)}

/* ---------- Google-Maps-Einbettung ---------- */
.map-embed{margin-top:20px;border-radius:14px;overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow)}
.map-embed iframe{display:block;width:100%;height:240px;border:0;filter:saturate(.92) contrast(1.02)}
/* Karten-Platzhalter (Klick-zum-Laden, DSGVO) */
.map-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;
  height:240px;text-align:center;padding:20px;background:var(--surface-2)}
.map-placeholder .map-pin{font-size:1.8rem}
.map-placeholder strong{color:var(--ink)}
.map-placeholder .small{max-width:30ch}
.map-placeholder button{margin-top:6px}

/* AGB-Zustimmung auf der Zahlungsseite */
.agb-check{display:flex;align-items:flex-start;gap:10px;margin:16px 0 14px;
  text-transform:none;letter-spacing:0;font-weight:500;color:var(--soft);font-size:.86rem;line-height:1.5}
.agb-check input{width:auto;margin:2px 0 0;flex:0 0 auto;accent-color:var(--brand)}
.agb-check a{color:var(--brand-2);text-decoration:underline}
.agb-check a:hover{color:var(--brand)}

/* Cookie-/Consent-Banner */
.cookie-banner{position:fixed;left:14px;right:14px;bottom:14px;z-index:200;margin:0 auto;max-width:760px;
  display:flex;align-items:center;gap:18px;flex-wrap:wrap;
  background:var(--surface-2);border:1px solid var(--line);border-radius:16px;padding:18px 20px;
  box-shadow:var(--shadow-lg);backdrop-filter:blur(12px)}
.cookie-banner .cookie-text{flex:1;min-width:240px}
.cookie-banner strong{display:block;color:var(--ink);margin-bottom:4px;font-size:.95rem}
.cookie-banner p{margin:0;color:var(--soft);font-size:.85rem;line-height:1.5}
.cookie-banner .cookie-actions{display:flex;gap:10px;flex-wrap:wrap}
.cookie-banner.hidden{display:none}
@media(max-width:560px){
  .cookie-banner{left:8px;right:8px;bottom:8px;padding:15px 16px;gap:12px}
  .cookie-banner .cookie-actions{width:100%}
  .cookie-banner .cookie-actions .btn-ghost,.cookie-banner .cookie-actions .btn-primary{flex:1}
}

/* ---------- FAQ-Accordion ---------- */
.faq details{border:1px solid var(--line);border-radius:12px;background:var(--glass);margin-bottom:10px;
  backdrop-filter:blur(8px);transition:border-color .2s,background .2s}
.faq details[open]{border-color:rgba(255,122,26,.4);background:var(--glass-2)}
.faq summary{cursor:pointer;list-style:none;padding:14px 16px;font-weight:700;color:var(--ink);font-size:.97rem;
  display:flex;justify-content:space-between;align-items:center;gap:14px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--brand-2);font-size:1.4rem;font-weight:700;line-height:1;transition:transform .2s;flex:0 0 auto}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq details p{margin:0;padding:0 16px 16px;color:var(--soft);font-size:.92rem;line-height:1.6}

/* ---------- WhatsApp Floating-Button (nur Mobile, scrollt mit) ---------- */
.wa-fab,.wa-label{display:none}
@media(max-width:768px){
  .wa-fab{display:flex;align-items:center;justify-content:center;position:fixed;z-index:130;
    right:16px;right:max(16px,env(safe-area-inset-right));
    bottom:18px;bottom:calc(18px + env(safe-area-inset-bottom));
    width:60px;height:60px;border-radius:50%;background:var(--grad-brand);color:#fff;
    box-shadow:0 10px 26px rgba(255,106,0,.5),0 2px 8px rgba(0,0,0,.4);animation:waPop .3s ease}
  .wa-fab svg{width:30px;height:30px}
  .wa-fab:hover,.wa-fab:active{color:#fff}
  @keyframes waPop{from{transform:scale(.6);opacity:0}to{transform:scale(1);opacity:1}}
  /* Preis-Chip in den Textfluss (kein Überlappen mit dem WhatsApp-Button) */
  .hero-chip,.hero-chip--corner{position:static;margin-top:22px;align-self:flex-start;display:inline-block}
}

/* ---------- Forms ---------- */
.page{max-width:960px;margin:0 auto;padding:64px 24px}
.page-narrow{max-width:780px}
.page h1{font-size:clamp(2rem,4vw,3rem)}
.form-card{max-width:460px;margin:64px auto;border-radius:var(--radius);padding:38px;position:relative;overflow:hidden}
.form-card::before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--brand),transparent)}
.form-card h1{font-size:1.7rem}
label{display:block;margin-bottom:16px;font-size:.82rem;font-weight:600;color:var(--soft);text-transform:uppercase;letter-spacing:.4px}
input,select,textarea{width:100%;margin-top:7px;padding:13px 14px;background:var(--field-bg);border:1px solid var(--line);
  border-radius:11px;color:var(--ink);font-size:1rem;font-family:inherit;text-transform:none;transition:.15s}
select{appearance:none;background-image:linear-gradient(45deg,transparent 50%,var(--soft) 50%),linear-gradient(135deg,var(--soft) 50%,transparent 50%);
  background-position:calc(100% - 20px) 1.25em,calc(100% - 14px) 1.25em;background-size:6px 6px;background-repeat:no-repeat}
option{background:var(--surface);color:var(--ink)}
textarea{resize:vertical}
input::placeholder,textarea::placeholder{color:var(--faint)}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--brand);box-shadow:var(--ring);background:var(--field-bg-2)}


.alert{background:var(--red-soft);border:1px solid rgba(255,90,90,.4);color:var(--err-text);padding:13px 16px;border-radius:11px;margin-bottom:20px}
.alert.success{background:var(--green-soft);border-color:rgba(52,210,123,.4);color:var(--ok-text)}
.alert.small{padding:8px 12px;margin:8px 0 0;font-size:.85rem}

/* ---------- Step indicator ---------- */
.steps{display:flex;align-items:center;justify-content:center;gap:0;margin:0 auto 40px;max-width:580px}
.steps .st{display:flex;align-items:center;gap:10px;color:var(--faint);font-weight:700;font-size:.85rem;text-transform:uppercase;letter-spacing:.3px}
.steps .st .n{width:36px;height:36px;border-radius:50%;border:1.5px solid var(--line);display:grid;place-items:center;background:var(--surface);font-size:.95rem}
.steps .st.active{color:var(--ink)}.steps .st.active .n{border-color:var(--brand);background:var(--grad-brand);color:#10151c;box-shadow:0 0 0 4px rgba(255,122,26,.18)}
.steps .st.done{color:var(--green)}.steps .st.done .n{border-color:var(--green);background:var(--green);color:#0a0d12}
.steps .bar{flex:1;height:2px;background:var(--line);margin:0 12px;min-width:24px}

/* ---------- Booking step 1 ---------- */
.booking-wrap{max-width:820px;margin:0 auto;padding:56px 24px}
.panel{border-radius:var(--radius);padding:32px}
.field-row{display:flex;gap:16px;flex-wrap:wrap}.field-row label{flex:1;min-width:220px}

/* ---------- Bühnen-Auswahl als kompakte Chips ---------- */
.field-block{margin-bottom:6px}
.field-title{display:block;font-size:.82rem;font-weight:600;color:var(--soft);text-transform:uppercase;letter-spacing:.4px;margin-bottom:4px}
.ws-group-label{display:flex;align-items:center;gap:7px;font-size:.74rem;font-weight:700;color:var(--soft);
  text-transform:uppercase;letter-spacing:.4px;margin:12px 0 7px}
.ws-group-label .dot{width:6px;height:6px;border-radius:50%;background:var(--brand);box-shadow:0 0 8px var(--brand)}
.ws-group-label:first-child{margin-top:0}
/* Aufklappbare Auswahl (Akkordeon) */
.lift-picker{position:relative}
.lift-picker-head{width:100%;display:flex;align-items:center;gap:10px;margin:0;
  background:var(--field-bg);border:1.5px solid var(--line);border-radius:11px;padding:13px 15px;color:var(--ink);
  font-size:1rem;font-weight:600;font-family:inherit;text-transform:none;letter-spacing:0;cursor:pointer;transition:.15s}
.lift-picker-head:hover{border-color:var(--brand)}
.lift-picker.open .lift-picker-head{border-color:var(--brand);box-shadow:var(--ring)}
.lph-text{flex:1;min-width:0;text-align:left;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.lph-text.placeholder{color:var(--faint);font-weight:500}
.lph-chevron{color:var(--brand-2);font-size:.9rem;transition:transform .2s;flex:0 0 auto}
.lift-picker.open .lph-chevron{transform:rotate(180deg)}
/* schwebendes Overlay – drueckt nichts weg */
.lift-picker-body{display:none;position:absolute;left:0;right:0;top:calc(100% + 8px);z-index:50;
  max-height:58vh;overflow:auto;-webkit-overflow-scrolling:touch;padding:8px 12px 12px;background:var(--surface-2);
  border:1px solid var(--line);border-radius:13px;box-shadow:var(--shadow-lg)}
.lift-picker.open .lift-picker-body{display:block;animation:pickerIn .16s ease}
@keyframes pickerIn{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:none}}
/* FAB ausblenden, solange die Auswahl offen ist (sonst ueberlagert er das Panel) */
html.picker-open .wa-fab{display:none !important}
.lift-opts{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.lift-opt{position:relative;display:flex;align-items:center;gap:9px;cursor:pointer;
  border:1.5px solid var(--line);border-radius:11px;padding:9px 11px;background:var(--field-bg);
  transition:.14s;margin:0;text-transform:none;letter-spacing:0}
.lift-opt input{position:absolute;opacity:0;width:0;height:0;margin:0;pointer-events:none}
.lift-opt:hover{border-color:var(--brand);background:var(--glass-2)}
.lift-opt .lo-ico{width:24px;height:24px;flex:0 0 auto;display:grid;place-items:center;border-radius:7px;
  background:linear-gradient(150deg,rgba(255,122,26,.22),rgba(255,122,26,.04));border:1px solid rgba(255,122,26,.28);
  color:var(--brand-2);font-size:.9rem;font-weight:800}
.lift-opt .lo-name{font-weight:700;color:var(--ink);font-size:.92rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.lift-opt .lo-price{margin-left:auto;font-weight:800;color:var(--brand-2);font-size:.9rem;white-space:nowrap;font-family:"Space Grotesk",sans-serif}
.lift-opt.is-sel,.lift-opt:has(input:checked){border-color:var(--brand);background:var(--accent-soft);box-shadow:var(--ring)}
.lift-opt.is-sel .lo-name,.lift-opt:has(input:checked) .lo-name{color:var(--brand-2)}
.slot-area{margin:24px 0}
.slot-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(82px,1fr));gap:10px}
.slot{padding:13px 0;border:1px solid var(--line);background:var(--field-bg);color:var(--ink);border-radius:11px;cursor:pointer;font-weight:700;transition:.14s}
.slot:hover:not(.booked){border-color:var(--brand);color:var(--brand-2);background:var(--glass-2)}
.slot.selected{background:var(--grad-brand);color:#10151c;border-color:transparent;box-shadow:0 8px 22px rgba(255,106,0,.4)}
.slot.booked{background:var(--fill-subtle);color:var(--faint);cursor:not-allowed;text-decoration:line-through;opacity:.6}
.legend{display:flex;align-items:center;gap:6px;color:var(--soft);font-size:.85rem;margin-top:16px;flex-wrap:wrap}
.lg{width:14px;height:14px;border-radius:4px;display:inline-block;margin-left:12px}
.lg.free{background:var(--field-bg);border:1px solid var(--line)}.lg.sel{background:var(--brand)}.lg.bk{background:var(--fill-subtle);border:1px solid var(--line)}
.summary{background:var(--accent-soft);border:1px solid rgba(255,122,26,.3);border-radius:var(--radius-sm);padding:18px;margin:20px 0}
.summary .total{font-size:1.7rem;font-weight:800;color:var(--brand-2);margin-top:8px;font-family:"Space Grotesk",sans-serif}
.summary .total small{font-size:.78rem;color:var(--soft);font-weight:500;display:block}
.summary .total.vip{color:var(--gold)}
.vip-note{color:var(--gold);font-weight:700}
.dur-ctrl{display:flex;align-items:center;gap:12px;margin:10px 0 4px}
.dur-val{font-weight:800}.dur-reset{margin-left:auto;font-size:.85rem;color:var(--soft)}

/* ---------- Add-ons ---------- */
.addon-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.addon-item{display:flex;align-items:center;gap:11px;border:1px solid var(--line);border-radius:12px;
  padding:12px 15px;cursor:pointer;background:var(--field-bg);margin:0;font-weight:700;transition:.14s;text-transform:none;color:var(--ink)}
.addon-item:hover{border-color:var(--brand);background:var(--glass-2)}
.addon-item input{width:auto;margin:0}.addon-item .addon-name{flex:1}
.addon-item .addon-price{color:var(--brand-2);font-weight:800;white-space:nowrap}

/* ---------- Modal ---------- */
.modal-overlay{position:fixed;inset:0;background:rgba(4,6,9,.7);backdrop-filter:blur(6px);display:grid;place-items:center;z-index:200;padding:20px}
.modal-overlay.hidden{display:none}
.modal-box{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-lg);max-width:440px;width:100%;padding:30px;animation:modalpop .18s cubic-bezier(.2,.7,.2,1)}
@keyframes modalpop{from{transform:scale(.94) translateY(8px);opacity:0}to{transform:scale(1);opacity:1}}
.modal-box h3{margin:0 0 12px;font-size:1.25rem}
.modal-box p{color:var(--soft);margin:0 0 26px;line-height:1.55}
.modal-actions{display:flex;gap:12px;justify-content:flex-end;flex-wrap:wrap}

/* ---------- Rechtstexte ---------- */
.legal-body{border-radius:var(--radius);padding:32px;line-height:1.75;color:var(--soft)}
.legal-body h3{margin:22px 0 8px;color:var(--ink)}.legal-body p{margin:0 0 14px}

/* ---------- Blog ---------- */
.wrap-narrow{max-width:760px;margin:0 auto;padding:0 24px}
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.blog-card{background:var(--glass);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;
  box-shadow:var(--shadow);transition:.2s;display:flex;flex-direction:column}
.blog-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:rgba(255,122,26,.4)}
.blog-cover{display:block;aspect-ratio:16/10;background:var(--surface-2);overflow:hidden}
.blog-cover img{width:100%;height:100%;object-fit:cover;transition:.3s}
.blog-card:hover .blog-cover img{transform:scale(1.04)}
.blog-body{padding:22px;display:flex;flex-direction:column;flex:1}
.blog-date{color:var(--brand-2);font-size:.76rem;font-weight:700;text-transform:uppercase;letter-spacing:.8px}
.blog-body h2{font-size:1.2rem;margin:.4em 0 .4em;line-height:1.2}
.blog-body h2 a{color:var(--ink)}.blog-body h2 a:hover{color:var(--brand-2)}
.blog-body p{color:var(--soft);font-size:.93rem;margin:0 0 16px;flex:1}
.blog-more{font-weight:700;color:var(--brand-2);font-size:.9rem}

/* Einzelner Artikel */
.post{padding:64px 0 80px}
.post-back{display:inline-block;color:var(--soft);font-weight:600;font-size:.88rem;margin-bottom:18px}
.post-back:hover{color:var(--brand-2)}
.post-kicker{color:var(--brand-2);font-weight:700;text-transform:uppercase;letter-spacing:2px;font-size:.78rem;font-family:"Space Grotesk",sans-serif}
.post h1{font-size:clamp(2rem,4.2vw,3.1rem);margin:.3em 0 .2em}
.post-date{color:var(--faint);font-size:.9rem}
.post-cover{width:100%;aspect-ratio:16/9;object-fit:cover;border-radius:var(--radius);border:1px solid var(--line);
  box-shadow:var(--shadow-lg);margin:26px 0 8px}
.post-content{font-size:1.06rem;line-height:1.75;color:var(--soft);margin-top:26px}
.post-content h2{color:var(--ink);font-size:1.5rem;margin:1.5em 0 .4em}
.post-content p{margin:0 0 1.1em}
.post-content ul{margin:0 0 1.2em;padding-left:1.2em}
.post-content li{margin:.4em 0}
.post-content a{color:var(--brand-2);font-weight:600;text-decoration:underline;text-underline-offset:2px}
.post-content strong{color:var(--ink)}
.post-cta{margin:42px 0 0;background:linear-gradient(135deg,rgba(255,122,26,.14),rgba(255,122,26,.04));
  border:1px solid rgba(255,122,26,.35);border-radius:var(--radius);padding:30px;text-align:center}
.post-cta h3{font-size:1.3rem;margin-bottom:6px}
.post-cta p{color:var(--soft);margin:0 0 18px}

/* ---------- Payment ---------- */
.pay-grid{display:grid;grid-template-columns:1.2fr .9fr;gap:24px;align-items:start}
.order-card{border-radius:var(--radius);padding:28px;position:sticky;top:96px}
.order-card h3{font-size:1.1rem;margin-bottom:18px}
.order-row{display:flex;justify-content:space-between;padding:10px 0;border-bottom:1px solid var(--line-2);font-size:.93rem;color:var(--soft)}
.order-row.tot{border-bottom:0;border-top:1px solid var(--line);margin-top:6px;padding-top:14px;font-size:1.45rem;font-weight:800;color:var(--brand-2);font-family:"Space Grotesk",sans-serif}
.order-row .lbl{color:var(--soft)}
.pay-methods{display:flex;gap:10px;margin:6px 0 22px;flex-wrap:wrap}
.pay-method{flex:1;min-width:120px;border:1px solid var(--line);border-radius:12px;padding:13px;text-align:center;cursor:pointer;font-weight:700;font-size:.9rem;background:var(--field-bg);color:var(--ink);transition:.14s}
.pay-method.sel{border-color:var(--brand);background:var(--accent-soft);color:var(--brand-2)}
.card-fields{display:grid;grid-template-columns:1fr 1fr;gap:12px}.card-fields .full{grid-column:1/-1}
.sim-note{background:var(--field-bg);border:1px dashed var(--line);border-radius:12px;padding:12px 15px;font-size:.85rem;color:var(--soft);margin:16px 0}
.pay-info{display:flex;gap:12px;align-items:flex-start;background:var(--accent-soft);border:1px solid rgba(255,122,26,.3);
  border-radius:12px;padding:14px 16px;font-size:.9rem;color:var(--ink);margin:16px 0;line-height:1.5}
.pay-info .pay-info-ico{font-size:1.2rem;flex:0 0 auto}
.voucher-box{display:flex;gap:8px;align-items:stretch}
.voucher-box input{margin-top:0}
.voucher-box .btn-dark{white-space:nowrap}
.firstbook-promo{display:flex;align-items:center;gap:14px;flex-wrap:wrap;justify-content:space-between;
  background:linear-gradient(135deg,rgba(255,122,26,.16),rgba(255,122,26,.05));
  border:1px solid rgba(255,122,26,.4);border-radius:12px;padding:12px 14px;margin-bottom:14px;font-size:.9rem;color:var(--ink)}
.firstbook-promo code{background:var(--field-bg);border:1px solid var(--line);border-radius:6px;
  padding:2px 8px;font-weight:800;letter-spacing:.5px;color:var(--brand-2)}
.firstbook-promo .btn-primary{white-space:nowrap}

/* ---------- Confirmation ---------- */
.confirm{max-width:640px;margin:64px auto;text-align:center;padding:0 24px}
.confirm .check{width:90px;height:90px;border-radius:50%;background:var(--green-soft);color:var(--green);display:grid;place-items:center;font-size:2.8rem;margin:0 auto 24px;border:2px solid rgba(52,210,123,.5);box-shadow:0 0 0 8px rgba(52,210,123,.08)}
.confirm .ticket{border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);text-align:left;margin:28px 0;overflow:hidden;background:var(--glass)}
.ticket .tk-head{background:var(--grad-brand);color:#10151c;padding:18px 24px;font-weight:800;text-transform:uppercase;letter-spacing:.5px}
.ticket .tk-body{padding:24px}
.ticket .tk-row{display:flex;justify-content:space-between;gap:18px;padding:9px 0;border-bottom:1px dashed var(--line);color:var(--soft)}
.ticket .tk-row:last-child{border-bottom:0}
.ticket .tk-row .l{color:var(--faint);flex:0 0 auto}
.ticket .tk-row span:last-child{flex:1 1 auto;text-align:right;min-width:0}

/* ---------- Tables ---------- */
.table{width:100%;border-collapse:collapse;margin:16px 0;background:var(--glass);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.table th,.table td{padding:13px 16px;text-align:left;border-bottom:1px solid var(--line-2);font-size:.9rem}
.table th{background:var(--fill-subtle);color:var(--soft);font-weight:700;text-transform:uppercase;letter-spacing:.5px;font-size:.76rem}
.table td{color:var(--ink)}
.table tr:last-child td{border-bottom:0}
.row-cancelled{opacity:.45}
/* Responsive Tabelle -> Karten auf Mobile (Meine Buchungen) */
@media(max-width:640px){
  .table-cards{border:0;background:transparent;box-shadow:none;overflow:visible}
  .table-cards thead{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0)}
  .table-cards,.table-cards tbody,.table-cards tr,.table-cards td{display:block;width:auto}
  .table-cards tr{background:var(--glass);border:1px solid var(--line);border-radius:14px;
    margin-bottom:14px;padding:4px 15px;box-shadow:var(--shadow)}
  .table-cards td{border-bottom:1px solid var(--line-2);padding:11px 0;display:flex;
    justify-content:space-between;align-items:center;gap:14px;text-align:right;font-size:.92rem}
  .table-cards td:last-child{border-bottom:0}
  .table-cards td::before{content:attr(data-label);color:var(--faint);font-weight:700;
    text-transform:uppercase;font-size:.7rem;letter-spacing:.4px;text-align:left}
  .table-cards td.td-actions{flex-direction:column;align-items:stretch;gap:8px;padding:12px 0}
  .table-cards td.td-actions::before{display:none}
  .table-cards td.td-actions form{display:block}
  .table-cards td.td-actions .btn-ghost,.table-cards td.td-actions button{width:100%;justify-content:center}
  /* Übrige (Admin-)Tabellen horizontal scrollbar statt überlaufend */
  .table:not(.table-cards){display:block;overflow-x:auto;-webkit-overflow-scrolling:touch;white-space:nowrap}
  .table:not(.table-cards) td,.table:not(.table-cards) th{white-space:nowrap}
}
.tag{padding:4px 11px;border-radius:7px;font-size:.72rem;font-weight:800;text-transform:uppercase;letter-spacing:.3px}
.tag.green{background:var(--green-soft);color:var(--ok-text)}.tag.grey{background:var(--fill-subtle);color:var(--soft)}.tag.vip{background:var(--gold-soft);color:var(--gold)}

/* ---------- Stats / Admin ---------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin:22px 0 38px}
.stat{border-radius:var(--radius);padding:22px}
.stat span{display:block;font-size:1.9rem;font-weight:800;color:var(--brand-2);margin-bottom:3px;font-family:"Space Grotesk",sans-serif}.stat small{color:var(--soft)}
.lift-form{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin:0}
.lift-form input{margin:0;padding:9px 11px}.lf-name{flex:1;min-width:180px}.lf-num{width:80px;text-align:right}

/* ---------- VIP page ---------- */
.vip-hero{background:linear-gradient(180deg,rgba(240,196,84,.12),var(--glass));border:1px solid rgba(240,196,84,.4);border-radius:var(--radius);padding:40px;max-width:580px;margin:0 auto;box-shadow:var(--shadow-lg)}
.vip-hero h1{background:linear-gradient(135deg,#f6d57a,#e0ad33);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.vip-price{font-size:3rem;font-weight:800;color:var(--gold);font-family:"Space Grotesk",sans-serif}
.vip-price span{display:block;font-size:.9rem;color:var(--soft);font-weight:500}
.vip-hero ul{list-style:none;padding:0;margin:20px 0}.vip-hero li{padding:10px 0;border-bottom:1px solid rgba(240,196,84,.18);color:var(--soft)}
.vip-slots{margin:18px 0;font-size:1.05rem}

/* ---------- Footer ---------- */
footer{background:var(--brand-3);color:#9aa6b2;margin-top:0;padding:64px 0 28px;border-top:1px solid rgba(255,255,255,.08)}
.footer-inner{max-width:var(--maxw);margin:0 auto;padding:0 24px;display:grid;grid-template-columns:2fr 1fr 1fr;gap:34px}
footer h4{color:#fff;font-size:.95rem;margin-bottom:14px;text-transform:uppercase;letter-spacing:.5px}
footer a{color:#9aa6b2;display:block;padding:5px 0}footer a:hover{color:var(--brand-2)}
.footer-bottom{max-width:var(--maxw);margin:34px auto 0;padding:20px 24px 0;border-top:1px solid rgba(255,255,255,.08);font-size:.85rem;color:#6b7480;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px}

/* ---------- SVG-Icons ---------- */
.ic svg{width:26px;height:26px;stroke:currentColor;fill:none;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round}
.eyebrow{font-family:"Space Grotesk","Inter",sans-serif}

/* ---------- Scroll-Reveal ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s cubic-bezier(.2,.7,.2,1),transform .7s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}

@media(max-width:920px){
  .nav-toggle{display:flex}
  #mainnav{position:absolute;top:100%;left:0;right:0;background:var(--surface);backdrop-filter:blur(18px);border-top:1px solid var(--line);
    border-bottom:1px solid var(--line);box-shadow:var(--shadow-lg);flex-direction:column;align-items:stretch;
    gap:0;padding:8px 20px 16px;display:none}
  #mainnav.open{display:flex}
  #mainnav a{padding:14px 6px;border-bottom:1px solid var(--line-2);border-radius:0;font-size:.98rem}
  #mainnav a:hover{background:transparent;color:var(--brand-2)}
  #mainnav .btn-primary,#mainnav .btn-ghost{margin-top:12px;justify-content:center;border-bottom:0}
  #mainnav .theme-toggle{width:100%;justify-content:center;margin-top:10px}
  .hero-video,.hero-photo{min-height:72vh}
  .hero.hero-photo .hero-inner,.hero-video .hero-inner{padding:84px 24px 52px}
  .hero.hero-photo .hero-inner{grid-template-columns:1fr;gap:30px}
  .hero-quick{max-width:420px}
  .hero-chip,.hero-chip--corner{padding:12px 16px;font-size:1.35rem}
  .sec{padding:68px 0}
  .benefits,.pricing,.amenities,.howto,.gallery,.blog-grid{grid-template-columns:1fr 1fr}
  .ws-grid,.contact,.pay-grid,.washbay{grid-template-columns:1fr}
  .stats{grid-template-columns:1fr 1fr}.order-card{position:static}
  .footer-inner{grid-template-columns:1fr 1fr}
}
/* --- Konto / Profil-Seite -------------------------------------------- */
.page-narrow{max-width:880px}
.account-grid{display:grid;grid-template-columns:1fr 1fr;gap:22px;margin-top:18px}
.account-grid .panel{padding:26px}
.account-grid h2{margin:0 0 14px;font-size:1.15rem}
.stack-form{display:flex;flex-direction:column;gap:14px}
.stack-form label{display:flex;flex-direction:column;gap:6px;font-weight:600;font-size:.86rem;color:var(--soft)}
.stack-form input{margin:0}
.stack-form .btn-primary{margin-top:4px;align-self:flex-start}

/* --- Admin: Navigation + Kennzahlen ---------------------------------- */
.admin-nav{display:flex;flex-wrap:wrap;gap:8px;margin:6px 0 26px}
.admin-nav a{background:var(--glass);border:1px solid var(--line);color:var(--soft);
  padding:7px 13px;border-radius:9px;font-size:.84rem;font-weight:600}
.admin-nav a:hover{color:var(--ink);border-color:var(--brand)}
.admin-nav .csv-link{margin-left:auto;color:var(--brand-2);border-color:rgba(255,122,26,.4)}
.export-bar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin:0 0 28px;
  background:var(--glass);border:1px solid var(--line);border-radius:12px;padding:12px 14px}
.export-bar select{width:auto;min-width:170px;margin:0;padding:9px 11px}
.export-bar button{margin:0}
.kpi-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:14px;margin:0 0 36px}
.kpi{background:var(--glass);border:1px solid var(--line);border-radius:14px;padding:18px 16px;box-shadow:var(--shadow)}
.kpi-val{display:block;font-size:1.35rem;font-weight:800;color:var(--brand-2);font-family:"Space Grotesk",sans-serif;margin-bottom:3px}
.kpi small{color:var(--soft);font-size:.78rem;line-height:1.3;display:block}

/* --- Admin: Belegungskalender ---------------------------------------- */
.cal-datebar{display:flex;align-items:center;gap:16px;flex-wrap:wrap;margin:0 0 14px}
.cal-datebar label{display:flex;align-items:center;gap:8px;font-weight:600;color:var(--soft)}
.cal-datebar input{margin:0}
.cal-scroll{overflow-x:auto;border:1px solid var(--line);border-radius:12px;background:var(--glass)}
.cal-grid{border-collapse:collapse;width:100%;min-width:760px;font-size:.8rem}
.cal-grid th{background:var(--fill-subtle);color:var(--soft);font-weight:700;padding:8px 4px;text-align:center;font-size:.72rem;border-bottom:1px solid var(--line-2)}
.cal-grid th.cal-corner{text-align:left;padding-left:14px;min-width:150px}
.cal-lift{padding:8px 10px 8px 14px;font-weight:600;color:var(--ink);border-bottom:1px solid var(--line-2);white-space:nowrap}
.cal-cell{border-left:1px solid var(--line-2);border-bottom:1px solid var(--line-2);text-align:center;height:38px;padding:2px;overflow:hidden}
.cal-cell.c-free{background:rgba(52,210,123,.10)}
.cal-cell.c-booked{background:rgba(255,122,26,.28);color:#fff;font-weight:600}
.cal-cell.c-block{background:repeating-linear-gradient(45deg,rgba(255,90,90,.25),rgba(255,90,90,.25) 5px,rgba(255,90,90,.12) 5px,rgba(255,90,90,.12) 10px);color:#ffb3b3}
.cal-cell.c-past{background:rgba(255,255,255,.03);color:var(--faint)}
.cal-who{display:block;font-size:.66rem;line-height:1.1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:64px;margin:0 auto}
.cal-util{text-align:center;font-weight:700;color:var(--brand-2);border-bottom:1px solid var(--line-2)}
.lg.blk{background:repeating-linear-gradient(45deg,rgba(255,90,90,.5),rgba(255,90,90,.5) 3px,rgba(255,90,90,.2) 3px,rgba(255,90,90,.2) 6px)}
.lg.pst{background:rgba(255,255,255,.06);border:1px solid var(--line)}

/* --- Admin: Formular-Raster (manuelle Buchung, Sperren, Schließtage) -- */
.grid-form{display:flex;flex-wrap:wrap;align-items:flex-end;gap:12px;margin:0 0 18px;
  background:var(--glass);border:1px solid var(--line);border-radius:14px;padding:18px}
.grid-form label{display:flex;flex-direction:column;gap:5px;font-size:.78rem;font-weight:600;color:var(--soft)}
.grid-form input,.grid-form select{margin:0;padding:9px 11px}
.grid-form input[type=text],.grid-form input[type=tel]{min-width:150px}
.grid-form button{margin-bottom:1px}

@media(max-width:900px){
  .kpi-grid{grid-template-columns:repeat(3,1fr)}
  .account-grid{grid-template-columns:1fr}
}

@media(max-width:560px){
  .kpi-grid{grid-template-columns:1fr 1fr}
  .grid-form label{flex:1 1 100%}
  .grid-form input[type=text],.grid-form input[type=tel]{min-width:0;width:100%}
  .brand{font-size:1rem;gap:10px}
  .brand-logo{width:40px;height:40px}
  .brand small{font-size:.58rem}
  .pricing,.howto,.stats,.blog-grid{grid-template-columns:1fr}
  /* Benefits + Galerie als 2er-Raster auf Mobile */
  .benefits,.gallery{grid-template-columns:1fr 1fr;gap:10px}
  .benefit{padding:16px}
  .benefit .ic{width:42px;height:42px;border-radius:11px;margin-bottom:10px}
  .benefit .ic svg{width:20px;height:20px}
  .benefit h4{font-size:.95rem;margin-bottom:4px}
  .benefit p{font-size:.8rem;line-height:1.45}
  .gallery .gimg{aspect-ratio:4/3;border-radius:14px}
  .amenities{grid-template-columns:1fr 1fr;gap:10px}     /* Ausstattung: 2er-Raster auf Mobile */
  .amenity{flex-direction:column;align-items:flex-start;gap:10px;padding:15px}
  .amenity .ic{width:42px;height:42px}
  .amenity b{font-size:.88rem}.amenity small{font-size:.78rem}
  .card-fields{grid-template-columns:1fr}.footer-inner{grid-template-columns:1fr}
  .cta-band{padding:44px 24px}
  .hero-trust{gap:10px 18px;font-size:.85rem}
  /* Hero kürzer + kompakter auf Mobile */
  .hero-video,.hero-photo{min-height:auto}
  .hero.hero-photo .hero-inner,.hero-video .hero-inner{padding:24px 16px 28px}
  .hero .eyebrow{margin-bottom:12px}
  .hero h1{font-size:1.95rem;margin-bottom:10px;line-height:1.08}
  .hero p.lead{font-size:.96rem;margin-bottom:18px}
  .hero-actions{gap:10px;width:100%}
  .hero-actions .btn-primary,.hero-actions .btn-ghost{flex:1 1 100%;justify-content:center}
  .hero-trust{margin-top:16px;font-size:.84rem;flex-direction:column;align-items:flex-start;gap:9px}
  /* Preis-Chip auf Mobile ausblenden – Preise stehen direkt darunter */
  .hero-chip,.hero-chip--corner{display:none}
  /* allgemein kompakter auf Mobile */
  .sec{padding:46px 0}
  .wrap{padding:0 16px}
  .page{padding:42px 16px}
  .sec-head{margin-bottom:26px}
  h1{font-size:1.7rem}
  h2{font-size:1.35rem}
  /* Buchungsseite kompakter + Bühnen-Chips */
  .booking-wrap{padding:22px 14px}
  .booking-wrap h1{font-size:1.45rem;margin-bottom:10px}
  .panel{padding:16px}
  .steps{margin-bottom:20px}
  .steps .st{font-size:.66rem;gap:5px}
  .steps .st .n{width:26px;height:26px;font-size:.8rem}
  .steps .bar{margin:0 5px}
  .lift-opts{grid-template-columns:1fr;gap:7px}
  .lift-opt{padding:11px 12px;gap:9px}
  .lift-opt .lo-ico{width:23px;height:23px;font-size:.85rem}
  .lift-opt .lo-name{font-size:.9rem}
  .lift-opt .lo-price{font-size:.9rem}
  .booking-wrap .field-row label{margin-bottom:0}
  .booking-wrap p.muted.small{font-size:.78rem;margin:10px 0}
  .slot-grid{grid-template-columns:repeat(auto-fill,minmax(58px,1fr));gap:7px}
  .slot{padding:10px 0;font-size:.92rem}
}
