/* Booking-Wizard – 3D Lasersports. Arcade/HUD-Look: Sternenhimmel + Neon (Cyan/Magenta),
   Orbitron (Display) + Rajdhani (UI), Lock-on-Fokus, abgeschrägter Action-Button,
   Captcha als "Sicherheits-Check" mit Laser-Ziel-Kacheln. No-build, mobile-first. */
:root{
  --bw-bg:#05060d;
  --bw-surface:#0e1426;
  --bw-surface-2:#121a30;
  --bw-cal:#1c244f;            /* Kalender-Blau wie Original */
  --bw-border:#2b3566;
  --bw-text:#eaf2ff;
  --bw-muted:#8a93b8;
  --bw-cyan:#27e7ff;
  --bw-magenta:#ff3df0;
  --bw-danger:#ff7a7a;
  --bw-ok:#4ade80;
  --bw-gap:16px;
  --bw-maxw:720px;
  --bw-disp:'Orbitron',sans-serif;
  --bw-ui:'Rajdhani',system-ui,sans-serif;
}
*{box-sizing:border-box}
html,body{margin:0}
body{
  color:var(--bw-text);
  font:500 17px/1.5 var(--bw-ui);
  -webkit-text-size-adjust:100%;
  min-height:100dvh;
  background:
    linear-gradient(rgba(5,6,13,.72), rgba(5,6,13,.88)),
    url('../../images/space-new.jpg') repeat,
    #000;
}

/* Logo */
.bw-header{display:flex;justify-content:center;padding:24px 16px 4px}
.bw-logo{max-width:280px;width:64%;height:auto;filter:drop-shadow(0 0 22px rgba(255,61,240,.4))}

#bw-app{max-width:var(--bw-maxw);margin:0 auto;padding:8px 16px 104px}
h2{font:700 1.5rem/1.15 var(--bw-disp);letter-spacing:.5px;margin:.1em 0 .8em;text-align:center;
  text-shadow:0 0 22px rgba(39,231,255,.35)}
small{color:var(--bw-muted)}
a{color:var(--bw-cyan)}

/* Fortschrittsanzeige */
.bw-stepper{display:flex;gap:8px;margin:8px 0 24px}
.bw-stepper>div{flex:1;height:5px;border-radius:99px;background:#161d38;
  clip-path:polygon(4px 0,100% 0,calc(100% - 4px) 100%,0 100%)}
.bw-stepper>div[data-on]{background:linear-gradient(90deg,var(--bw-cyan),var(--bw-magenta));
  box-shadow:0 0 14px -2px var(--bw-magenta)}

/* Glass-Karten / Panels */
.bw-grid{display:grid;gap:var(--bw-gap);grid-template-columns:1fr}
@media(min-width:560px){.bw-grid{grid-template-columns:1fr 1fr}}
.bw-card{
  background:rgba(14,20,38,.55);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  border:1px solid var(--bw-border);border-radius:14px;padding:16px;display:grid;gap:6px;
  cursor:pointer;transition:border-color .15s, box-shadow .15s, transform .15s;
}
.bw-card:hover{transform:translateY(-1px)}
.bw-card:hover,.bw-card[aria-selected=true]{
  border-color:var(--bw-cyan);box-shadow:0 0 0 1px var(--bw-cyan),0 16px 44px -20px var(--bw-magenta);
}

/* Slot-Chips (Spielzeit) */
.bw-chip{
  position:relative;padding:14px 10px;background:var(--bw-cal);
  border:1px solid var(--bw-border);cursor:pointer;user-select:none;
  display:grid;gap:3px;text-align:center;transition:.12s;
  clip-path:polygon(8px 0,100% 0,100% calc(100% - 8px),calc(100% - 8px) 100%,0 100%,0 8px);
}
.bw-chip:hover{border-color:var(--bw-cyan);box-shadow:0 0 16px -6px var(--bw-cyan)}
.bw-chip[aria-selected=true]{background:rgba(39,231,255,.16);border-color:var(--bw-cyan);
  box-shadow:0 0 0 1px var(--bw-cyan),0 0 22px -8px var(--bw-magenta)}
.bw-chip-arrival{font:700 .7rem var(--bw-ui);letter-spacing:1px;text-transform:uppercase;color:var(--bw-muted)}
.bw-chip-time{font:700 1.02rem var(--bw-disp);letter-spacing:.3px}
.bw-chip-free{font:600 .8rem var(--bw-ui);letter-spacing:1px;text-transform:uppercase;color:var(--bw-cyan)}
.bw-chip[aria-disabled=true]{cursor:not-allowed}
.bw-chip.is-full{opacity:.7;cursor:not-allowed;background:#1a1320;border-color:#5a2a3a}
.bw-chip.is-full:hover{border-color:#5a2a3a;box-shadow:none}
.bw-chip.is-full .bw-chip-time{color:var(--bw-muted)}
.bw-chip-free.is-full{color:var(--bw-danger);letter-spacing:1px}
.bw-chip-free.knapp{color:#ffb454}
.bw-price-info{text-align:center;color:var(--bw-muted);font:600 .88rem var(--bw-ui);margin:0 0 10px;letter-spacing:.3px}
.bw-note{text-align:center;color:#ffb454;font:600 .85rem var(--bw-ui);margin:0 0 16px;line-height:1.35}

/* HUD-Formularfelder – "Lock-on" */
.bw-field{display:grid;gap:7px;margin:14px 0}
.bw-field label{font:600 .8rem/1 var(--bw-ui);letter-spacing:1.5px;text-transform:uppercase;color:var(--bw-muted)}
.bw-field:focus-within label{color:var(--bw-cyan)}
.bw-field input,.bw-field textarea,.bw-field select{
  width:100%;padding:13px 14px;font:600 1rem var(--bw-ui);color:var(--bw-text);
  background:rgba(8,12,26,.65);border:1px solid var(--bw-border);
  border-left:2px solid var(--bw-cyan);border-radius:8px;transition:.15s;
}
.bw-field input::placeholder,.bw-field textarea::placeholder{color:#5b6488}
.bw-field input:focus,.bw-field textarea:focus,.bw-field select:focus{
  outline:none;border-color:var(--bw-cyan);
  box-shadow:0 0 0 2px rgba(39,231,255,.35),0 0 22px -6px var(--bw-cyan);
}

/* Navigation (fix unten) */
.bw-nav{position:fixed;left:0;right:0;bottom:0;display:flex;gap:12px;justify-content:space-between;
  padding:12px 16px;max-width:var(--bw-maxw);margin:0 auto;
  background:linear-gradient(0deg,var(--bw-bg) 74%,transparent)}
.bw-btn{
  padding:14px 20px;font:700 .95rem var(--bw-disp);letter-spacing:1px;text-transform:uppercase;
  color:var(--bw-text);background:rgba(18,26,48,.8);border:1px solid var(--bw-border);cursor:pointer;
  clip-path:polygon(9px 0,100% 0,100% calc(100% - 9px),calc(100% - 9px) 100%,0 100%,0 9px);
  transition:.15s;
}
.bw-btn:hover{border-color:var(--bw-cyan);color:var(--bw-cyan)}
.bw-btn--primary{
  flex:1;border:0;color:#06101a;
  background:linear-gradient(100deg,var(--bw-cyan),var(--bw-magenta));
  box-shadow:0 0 0 1px rgba(39,231,255,.6),0 10px 30px -10px var(--bw-magenta);
}
.bw-btn--primary:hover{filter:brightness(1.08);color:#06101a;
  box-shadow:0 0 0 1px var(--bw-cyan),0 0 30px -6px var(--bw-magenta)}
.bw-btn[disabled]{opacity:.4;cursor:not-allowed;box-shadow:none}

/* Hinweise / Zustände / Legende */
.bw-msg{color:var(--bw-muted);padding:10px 0;text-align:center}
.bw-msg--ok{color:var(--bw-ok)}
.bw-msg--err{color:var(--bw-danger)}
.bw-legend{display:flex;gap:18px;justify-content:center;flex-wrap:wrap;margin:2px 0 14px;
  font:600 .78rem var(--bw-ui);letter-spacing:.5px;text-transform:uppercase;color:var(--bw-muted)}
.bw-legend span{display:inline-flex;align-items:center;gap:7px}
.bw-legend i{width:12px;height:12px;border-radius:3px;display:inline-block}
.bw-legend .on{background:var(--bw-cal);box-shadow:0 0 0 1px var(--bw-cyan),0 0 10px -2px var(--bw-cyan)}
.bw-legend .off{background:var(--bw-cal);opacity:.4}

/* Paketauswahl (am Kalender) */
.bw-pkg{margin:0 0 16px}
.bw-pkg-label{font:700 .8rem var(--bw-ui);letter-spacing:1.5px;text-transform:uppercase;color:var(--bw-muted);margin-bottom:8px;text-align:center}
.bw-pkg-row{display:flex;gap:10px;flex-wrap:wrap;justify-content:center}
.bw-pkg-chip{flex:1;min-width:98px;text-align:center;padding:12px 10px;background:var(--bw-surface-2);
  border:1px solid var(--bw-border);color:var(--bw-text);cursor:pointer;font:700 .95rem var(--bw-disp);
  letter-spacing:.5px;transition:.12s;
  clip-path:polygon(8px 0,100% 0,100% calc(100% - 8px),calc(100% - 8px) 100%,0 100%,0 8px)}
.bw-pkg-chip:hover{border-color:var(--bw-cyan);color:var(--bw-cyan)}
.bw-pkg-chip[aria-selected=true]{background:rgba(39,231,255,.14);border-color:var(--bw-cyan);color:#fff;
  box-shadow:0 0 0 1px var(--bw-cyan),0 0 18px -8px var(--bw-magenta)}

/* Kalender */
.bw-cal-top{margin-bottom:10px}
.bw-cal-nav{display:flex;align-items:center;justify-content:space-between;margin:6px 0 12px}
.bw-cal-title{font:700 1.15rem var(--bw-disp);letter-spacing:1px;text-align:center;flex:1;text-transform:uppercase}
.bw-cal-arrow{width:48px;height:48px;border:1px solid var(--bw-border);background:rgba(18,26,48,.8);
  color:var(--bw-text);font-size:1.5rem;line-height:1;cursor:pointer;
  clip-path:polygon(8px 0,100% 0,100% calc(100% - 8px),calc(100% - 8px) 100%,0 100%,0 8px)}
.bw-cal-arrow:hover{border-color:var(--bw-cyan);color:var(--bw-cyan)}
.bw-cal{background:rgba(0,0,0,.4);border:1px solid var(--bw-border);border-radius:14px;padding:10px;
  backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}
.bw-cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}
.bw-cal-head{margin-bottom:6px}
.bw-cal-wd{text-align:center;color:var(--bw-muted);font:700 .78rem var(--bw-ui);
  letter-spacing:1px;padding:4px 0;text-transform:uppercase}
.bw-cal-cell{min-height:72px;background:var(--bw-cal);border:1px solid transparent;padding:7px;
  display:flex;flex-direction:column;gap:3px;color:#cfd6f0;
  clip-path:polygon(8px 0,100% 0,100% calc(100% - 8px),calc(100% - 8px) 100%,0 100%,0 8px)}
.bw-cal-empty{background:transparent;clip-path:none}
.bw-cal-day{font:700 1.3rem var(--bw-disp);line-height:1}
.bw-cal-info{font:600 .68rem var(--bw-ui);letter-spacing:.5px;text-transform:uppercase;color:var(--bw-cyan);margin-top:auto}
.bw-cal-cell.is-off,.bw-cal-cell.is-past{opacity:.34}
.bw-cal-cell.is-on{cursor:pointer;transition:.12s}
.bw-cal-cell.is-on:hover{border-color:var(--bw-cyan);box-shadow:0 0 20px -6px var(--bw-cyan)}
.bw-cal-cell.is-on[aria-selected=true]{border-color:var(--bw-cyan);background:rgba(39,231,255,.18);
  box-shadow:0 0 0 1px var(--bw-cyan),0 0 24px -6px var(--bw-magenta)}
@media(max-width:420px){
  .bw-cal-cell{min-height:56px;padding:5px}
  .bw-cal-day{font-size:1.05rem}
  .bw-cal-info{font-size:.58rem}
}

/* Captcha – "Sicherheits-Check" mit Laser-Ziel-Kacheln */
.bw-captcha{position:relative;margin:18px 0 4px;padding:16px;border:1px solid var(--bw-border);
  border-radius:12px;background:rgba(8,12,26,.55);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
  overflow:hidden}
.bw-captcha::before{content:"";position:absolute;inset:0;pointer-events:none;
  background:repeating-linear-gradient(0deg,rgba(39,231,255,.05) 0 1px,transparent 1px 3px)}
.bw-captcha-head{position:relative;font:700 .72rem var(--bw-disp);letter-spacing:2px;text-transform:uppercase;
  color:var(--bw-muted);display:flex;align-items:center;gap:8px}
.bw-captcha-head::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--bw-magenta);
  box-shadow:0 0 10px var(--bw-magenta)}
.bw-captcha-q{position:relative;display:flex;align-items:center;justify-content:center;gap:12px;margin-top:14px}
.bw-tile{width:50px;height:58px;display:grid;place-items:center;font:800 1.5rem var(--bw-disp);color:#fff;
  background:var(--bw-cal);border:1px solid var(--bw-cyan);border-radius:8px;
  box-shadow:0 0 20px -6px var(--bw-cyan),inset 0 0 18px -10px var(--bw-cyan)}
.bw-op,.bw-eq{font:700 1.4rem var(--bw-disp);color:var(--bw-magenta)}
.bw-captcha-in{width:84px;height:58px;text-align:center;font:800 1.5rem var(--bw-disp);color:var(--bw-text);
  background:rgba(8,12,26,.8);border:1px solid var(--bw-magenta);border-radius:8px;transition:.15s}
.bw-captcha-in:focus{outline:none;box-shadow:0 0 0 2px rgba(255,61,240,.35),0 0 22px -6px var(--bw-magenta)}

/* Dominanter Spieler-Stepper */
.bw-qty{display:grid;justify-items:center;gap:12px;margin:8px 0 22px}
.bw-qty-label{font:700 .85rem var(--bw-ui);letter-spacing:2px;text-transform:uppercase;color:var(--bw-muted)}
.bw-stepper-q{display:flex;align-items:center;gap:20px}
.bw-step-btn{
  width:60px;height:60px;font:700 2rem var(--bw-disp);line-height:1;color:var(--bw-text);
  background:rgba(18,26,48,.85);border:1px solid var(--bw-border);cursor:pointer;display:grid;place-items:center;
  clip-path:polygon(10px 0,100% 0,100% calc(100% - 10px),calc(100% - 10px) 100%,0 100%,0 10px);transition:.12s;
}
.bw-step-btn:hover{border-color:var(--bw-cyan);color:var(--bw-cyan);box-shadow:0 0 18px -6px var(--bw-cyan)}
.bw-step-btn:active{transform:scale(.93)}
.bw-step-num{
  min-width:90px;text-align:center;font:800 3.3rem var(--bw-disp);line-height:1;
  background:linear-gradient(180deg,var(--bw-cyan),var(--bw-magenta));
  -webkit-background-clip:text;background-clip:text;color:transparent;
  filter:drop-shadow(0 0 18px rgba(39,231,255,.4));
}
.bw-step-num.pop{animation:bw-pop .26s ease}
@keyframes bw-pop{0%{transform:scale(1)}40%{transform:scale(1.28)}100%{transform:scale(1)}}

/* Spielereien: Schritt-Einblendung, Button-Laser-Sweep, Auswahl-Pop */
.bw-step-in{animation:bw-in .3s ease both}
@keyframes bw-in{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
.bw-btn--primary{position:relative;overflow:hidden}
.bw-btn--primary::after{
  content:"";position:absolute;top:0;left:-60%;width:42%;height:100%;
  background:linear-gradient(100deg,transparent,rgba(255,255,255,.55),transparent);
  transform:skewX(-20deg);transition:left .55s ease;pointer-events:none;
}
.bw-btn--primary:hover::after{left:130%}
.bw-chip[aria-selected=true],.bw-cal-cell.is-on[aria-selected=true]{animation:bw-sel .32s ease}
@keyframes bw-sel{0%{transform:scale(1)}50%{transform:scale(1.06)}100%{transform:scale(1)}}

/* Hinweis (Mindestrunden) + Live-Zähler */
.bw-info{text-align:center;color:var(--bw-cyan);font:600 .92rem var(--bw-ui);letter-spacing:.5px;margin:2px 0 14px}
.bw-counter{text-align:center;color:var(--bw-muted);font:700 .82rem var(--bw-ui);letter-spacing:1px;text-transform:uppercase;margin:6px 0 12px}
.bw-counter.ok{color:var(--bw-ok)}
.bw-qty small{color:var(--bw-muted);font:600 .78rem var(--bw-ui)}

/* Live-Preis (Spielzeit) + Gesamtsumme (Übersicht) + Paketkarten-Texte */
.bw-price{text-align:center;min-height:1.5rem;margin:6px 0 14px;font:800 1.5rem var(--bw-disp);
  background:linear-gradient(180deg,var(--bw-cyan),var(--bw-magenta));-webkit-background-clip:text;
  background-clip:text;color:transparent;filter:drop-shadow(0 0 14px rgba(39,231,255,.3))}
.bw-total{margin-top:10px;font:700 1.15rem var(--bw-ui)}
.bw-total strong{font:800 1.35rem var(--bw-disp);color:var(--bw-cyan)}
.bw-card small{color:var(--bw-muted);font:600 .8rem var(--bw-ui)}

/* Kontextzeile (Arena · Preis) */
.bw-ctx{text-align:center;color:var(--bw-muted);margin:-4px 0 14px;font:600 .95rem var(--bw-ui);letter-spacing:.5px}
.bw-ctx strong{color:var(--bw-text);font-weight:700}

/* Honeypot */
.bw-hp{position:absolute!important;left:-9999px;width:1px;height:1px;overflow:hidden}

/* Responsive-Feinschliff (kleine Screens) */
@media(max-width:400px){
  #bw-app{padding:6px 12px 104px}
  h2{font-size:1.25rem}
  .bw-logo{width:72%}
  .bw-step-btn{width:52px;height:52px;font-size:1.7rem}
  .bw-step-num{font-size:2.7rem;min-width:74px}
  .bw-stepper-q{gap:14px}
  .bw-tile{width:42px;height:50px;font-size:1.25rem}
  .bw-op,.bw-eq{font-size:1.2rem}
  .bw-captcha-in{width:70px;height:50px;font-size:1.25rem}
  .bw-cal-grid{gap:4px}
  .bw-chip-time{font-size:.95rem}
  .bw-btn{padding:13px 14px;font-size:.85rem}
}

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