* { touch-action: manipulation; }
:root,[data-theme="light"]{
  --font-display:'Instrument Serif',Georgia,serif;
  --font-body:'DM Sans',system-ui,sans-serif;
  --text-xs:clamp(.75rem,.7rem + .25vw,.875rem);
  --text-sm:clamp(.875rem,.8rem + .35vw,1rem);
  --text-base:clamp(1rem,.95rem + .25vw,1.125rem);
  --text-lg:clamp(1.125rem,1rem + .75vw,1.5rem);
  --text-xl:clamp(1.5rem,1.2rem + 1.25vw,2.25rem);
  --sp1:.25rem;--sp2:.5rem;--sp3:.75rem;--sp4:1rem;--sp5:1.25rem;
  --sp6:1.5rem;--sp8:2rem;--sp10:2.5rem;--sp12:3rem;--sp16:4rem;
  --bg:#f4f6f8;--sur:#f8f9fb;--sur2:#fbfcfe;--suroff:#e0e4e9;--suroff2:#d8dce3;
  --div:#d0d4dc;--bor:#c4c8d0;
  --tx:#23262b;--txm:#636775;--txf:#9498a2;--txi:#f8f9fb;
  --pri:#1a6fb5;--prih:#0d5a9a;--pria:#084573;--prhl:#dce8f5;
  --suc:#3d8b40;--such:#2a6b2d;--suchl:#cde0ce;
  --war:#964219;--warhl:#ddcfc6;
  --err:#c4423e;--errh:#a33532;--errhl:#f0d6d6;
  --gld:#d9700c;--gldhl:#f5e0cc;
  --r-sm:.375rem;--r-md:.5rem;--r-lg:.75rem;--r-xl:1rem;--r-full:9999px;
  --tr:180ms cubic-bezier(.16,1,.3,1);
  --sh-sm:0 1px 2px oklch(.2 .01 80/.06);
  --sh-md:0 4px 12px oklch(.2 .01 80/.08);
  --sh-lg:0 12px 32px oklch(.2 .01 80/.12);
}
[data-theme="dark"]{
  --bg:#171614;--sur:#1c1b19;--sur2:#201f1d;--suroff:#1d1c1a;--suroff2:#22211f;
  --div:#262523;--bor:#393836;
  --tx:#cdccca;--txm:#797876;--txf:#5a5957;--txi:#2b2a28;
  --pri:#5ba3d9;--prih:#3d8cc4;--pria:#2a75b0;--prhl:#2a3b4a;
  --suc:#6daa45;--such:#4d8f25;--suchl:#3a4435;
  --war:#bb653b;--warhl:#564942;
  --err:#dc7a7a;--errh:#c96a6a;--errhl:#4a3a3a;
  --gld:#e8923a;--gldhl:#4a3d30;
  --sh-sm:0 1px 2px oklch(0 0 0/.2);--sh-md:0 4px 12px oklch(0 0 0/.3);--sh-lg:0 12px 32px oklch(0 0 0/.4);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
*{-webkit-tap-highlight-color:transparent}
html{-webkit-font-smoothing:antialiased;-webkit-text-size-adjust:100%;text-size-adjust:100%;scroll-behavior:smooth}
body{min-height:100dvh;line-height:1.6;font-family:var(--font-body);font-size:var(--text-base);color:var(--tx);background:var(--bg);overscroll-behavior-y:contain}
img,svg{display:block;max-width:100%}
input,button,select,textarea{font:inherit;color:inherit}
h1,h2,h3,h4{line-height:1.2}
p,li{line-height:1.4}
button{cursor:pointer;background:none;border:none}
:focus-visible{outline:2px solid var(--pri);outline-offset:3px;border-radius:var(--r-sm)}
a,button,[role="button"],input,select{transition:color var(--tr),background var(--tr),border-color var(--tr),box-shadow var(--tr)}
.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}

/* ── LAYOUT ── */
.app-shell{display:flex;flex-direction:column;min-height:100dvh}
.topbar {
  position: sticky;
  top: 0;
  z-index: 100;
  height: 56px; /* Festgelegte Höhe für präzises Stacking */
  background: var(--sur);
  border-bottom: 1px solid var(--bor);
  padding: 0 var(--sp6); /* Nur seitliches Padding, Höhe wird über height geregelt */
  display: flex;
  align-items: center; /* Zentriert Logo und Menü vertikal in den 56px */
  gap: var(--sp3);
}
.topbar-logo{display:flex;align-items:center;gap:var(--sp3);text-decoration:none;color:var(--tx);flex-shrink:0;margin-top:2px}
.logo-icon{color:var(--pri);display:block}
.topbar-title{font-family:var(--font-display);font-size:var(--text-lg);font-weight:400}
.topbar-right{display:flex;align-items:center;gap:var(--sp2);margin-left:auto}
.nav-tabs{display:flex;gap:var(--sp1);align-items:center}
.nav-dropdown-wrap{display:flex;align-items:center;gap:var(--sp1)}
.nav-dropdown{position:relative}
.nav-dropdown-trigger{display:flex;align-items:center;gap:var(--sp2);padding:var(--sp2) var(--sp3);border-radius:var(--r-md);font-size:var(--text-sm);color:var(--txm);font-weight:600;background:none;border:none;cursor:pointer;white-space:nowrap;transition:background var(--tr),color var(--tr)}
.nav-dropdown-trigger:hover{background:var(--suroff);color:var(--tx)}
.nav-dropdown-trigger.active{background:var(--prhl);color:var(--pri)}
.nav-dd-menu{display:none;position:absolute;top:calc(100% + 6px);left:0;min-width:180px;background:var(--sur);border:1px solid var(--bor);border-radius:var(--r-lg);box-shadow:var(--sh-lg);padding:var(--sp2);z-index:200;animation:ddIn .15s ease}
.nav-dd-menu.open{display:flex;flex-direction:column;will-change:transform,opacity}
@keyframes ddIn{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:none}}
.nav-dd-item{display:flex;align-items:center;gap:var(--sp3);padding:var(--sp2) var(--sp3);border-radius:var(--r-md);font-size:var(--text-sm);font-weight:500;color:var(--tx);background:none;border:none;cursor:pointer;text-align:left;transition:background var(--tr),color var(--tr)}
.nav-dd-item:hover{background:var(--prhl);color:var(--pri)}
.nav-dd-item.active{background:var(--prhl);color:var(--pri);font-weight:700}
.nav-dd-item i, .nav-dd-item svg{width:16px;height:16px;flex-shrink:0}
.nav-dd-divider{height:1px;background:var(--div);margin:var(--sp1) 0}
.nav-btn{display:flex;align-items:center;gap:var(--sp2);padding:var(--sp2) var(--sp3);border-radius:var(--r-md);font-size:var(--text-sm);color:var(--txm);font-weight:500;white-space:nowrap}
.nav-btn:hover{background:var(--suroff);color:var(--tx)}
.nav-btn.active{background:var(--prhl);color:var(--pri)}
.nav-btn i, .nav-btn svg{width:16px;height:16px;flex-shrink:0}
.topbar-divider{width:1px;height:24px;background:var(--bor);margin:0 var(--sp2)}
.btn-login{display:flex;align-items:center;gap:var(--sp2);padding:var(--sp2) var(--sp3);border-radius:var(--r-md);font-size:var(--text-sm);font-weight:600;background:var(--suroff);border:1px solid var(--bor);color:var(--txm)}
.btn-login:hover{background:var(--prhl);color:var(--pri);border-color:var(--pri)}
.btn-login.is-admin{background:var(--gldhl);color:var(--gld);border-color:oklch(from var(--gld) l c h/.3)}
.btn-login i, .btn-login svg{width:16px;height:16px}
.topbar .nav-btn i, .topbar .nav-btn svg, .topbar .nav-dropdown-trigger i, .topbar .nav-dropdown-trigger svg{width:18px;height:18px}
.theme-btn{padding:var(--sp2);border-radius:var(--r-md);color:var(--txm)}
.theme-btn:hover{background:var(--suroff);color:var(--tx)}
.main{max-width:960px;margin:0 auto;padding:var(--sp4) var(--sp6);width:100%;flex:1;align-self:flex-start}
.view{display:none}.view.active{display:block}

/* ── SWIPE ── */
.swipe-wrap{overflow:hidden;position:relative;width:100%}
.swipe-track{display:flex;transition:transform .35s cubic-bezier(.16,1,.3,1);will-change:transform}
.swipe-track.dragging{transition:none}
.swipe-active .swipe-track>.view{display:block!important;flex:0 0 100%;min-width:0}
@media(min-width:641px){.swipe-wrap{touch-action:auto}}

/* ── TYPE ── */
.page-title{font-family:var(--font-display);font-size:var(--text-xl);font-weight:400;margin-bottom:var(--sp6)}
.sec-title{font-size:var(--text-lg);font-weight:600;margin-bottom:var(--sp4)}
.label{font-size:var(--text-xs);font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--txm)}

/* ── CARD ── */
.card{background:var(--sur);border:1px solid oklch(from var(--tx) l c h/.08);border-radius:var(--r-xl);padding:var(--sp6);box-shadow:var(--sh-sm);contain:content}

/* ── KPI ── */
.kpi-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(190px,100%),1fr));gap:var(--sp4);margin-bottom:var(--sp8)}
.kpi{background:var(--sur);border:1px solid oklch(from var(--tx) l c h/.08);border-radius:var(--r-xl);padding:var(--sp5);box-shadow:var(--sh-sm)}
.kpi-lbl{font-size:var(--text-xs);font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--txm);margin-bottom:var(--sp2)}
.kpi-val{font-size:var(--text-xl);font-weight:700;font-variant-numeric:tabular-nums lining-nums;line-height:1;white-space:nowrap}
.kpi-sub{font-size:var(--text-xs);color:var(--txm);margin-top:var(--sp1)}
.kpi-val.pos{color:var(--suc)}.kpi-val.neg{color:var(--err)}.kpi-val.warn{color:var(--war)}

/* ── BUTTONS ── */
.btn{display:inline-flex;align-items:center;gap:var(--sp2);padding:var(--sp2) var(--sp4);border-radius:var(--r-md);font-size:var(--text-sm);font-weight:600;cursor:pointer;transition:background var(--tr),color var(--tr),border-color var(--tr);white-space:nowrap}
.btn i, .btn svg{width:16px;height:16px;flex-shrink:0}
.btn-pri{background:var(--pri);color:var(--txi);border:none}.btn-pri:hover{background:var(--prih)}
.btn-sec{background:transparent;color:var(--tx);border:1px solid var(--bor)}.btn-sec:hover{background:var(--suroff)}
.btn-dan{background:transparent;color:var(--err);border:1px solid oklch(from var(--err) l c h/.3)}.btn-dan:hover{background:var(--errhl)}
.btn-ok{background:var(--suc);color:var(--txi);border:none}.btn-ok:hover{background:var(--such)}
.btn-gld{background:var(--gldhl);color:var(--gld);border:1px solid oklch(from var(--gld) l c h/.3)}.btn-gld:hover{background:color-mix(in srgb,var(--gldhl),black 5%)}
.btn-me{background:#f0ddd0;color:#b8713c;border:1px solid #dba87a}.btn-me:hover{background:#e8d0c0}
[data-theme="dark"] .btn-me{background:#2f241d;color:#c89560;border-color:#7a5a40}[data-theme="dark"] .btn-me:hover{background:#3d2e24}
.btn-sm{padding:var(--sp1) var(--sp3);font-size:var(--text-xs)}
.btn-xs{padding:2px var(--sp2);font-size:var(--text-xs)}
.btn-icon{padding:var(--sp2)}
.btn-full{width:100%;justify-content:center}

/* ── BUTTON - Touch manipulation ── */
.nav-btn,
.nav-dd-item,
.pkey,
.btn-identity,
.welcome-skip,
.btn,
button {
  touch-action: manipulation;
}

/* ── FORM ── */
.fg{margin-bottom:var(--sp4)}
.fl{display:block;font-size:var(--text-sm);font-weight:500;margin-bottom:var(--sp2)}
.fi{width:100%;padding:var(--sp2) var(--sp3);border:1px solid var(--bor);border-radius:var(--r-md);background:var(--sur2);color:var(--tx);font-size:var(--text-sm)}
.fi:focus{outline:none;border-color:var(--pri);box-shadow:0 0 0 3px oklch(from var(--pri) l c h/.15)}
.fi::placeholder{color:var(--txf)}
select.fi{cursor:pointer}

/* ── BADGE ── */
.badge{display:inline-flex;align-items:center;gap:4px;padding:2px var(--sp2);border-radius:var(--r-full);font-size:var(--text-xs);font-weight:600}
.bg-ok{background:var(--suchl);color:var(--suc)}
.bg-war{background:var(--warhl);color:var(--war)}
.bg-err{background:var(--errhl);color:var(--err)}
.bg-pri{background:var(--prhl);color:var(--pri)}
.bg-neu{background:var(--suroff2);color:var(--txm)}
.bg-gld{background:var(--gldhl);color:var(--gld)}
.bg-me{background:#f0ddd0;color:#b8713c}
[data-theme="dark"] .bg-me{background:#2f241d;color:#c89560}

/* ── TABLE ── */
.tw{overflow:hidden;border-radius:var(--r-xl);border:1px solid oklch(from var(--tx) l c h/.08)}
.dt{width:100%;border-collapse:collapse;font-size:var(--text-sm)}
.dt th{background:var(--suroff);padding:var(--sp3) var(--sp4);text-align:left;font-size:var(--text-xs);font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--txm)}
.dt td{padding:var(--sp3) var(--sp4);border-top:1px solid var(--div);font-variant-numeric:tabular-nums lining-nums;vertical-align:middle;overflow-wrap:break-word}
.dt tbody tr:hover td{background:var(--suroff)}

/* ── PLAYER CARD ── */
.pg{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(270px,100%),1fr));gap:var(--sp4)}
.pc{background:var(--sur);border:1px solid oklch(from var(--tx) l c h/.08);border-radius:var(--r-xl);padding:var(--sp5);box-shadow:var(--sh-sm);display:flex;flex-direction:column;gap:var(--sp3);transition:box-shadow var(--tr),transform var(--tr)}
.pc:hover{box-shadow:var(--sh-md);transform:translateY(-1px)}
.pc-head{display:flex;align-items:center;gap:var(--sp3)}
.av{width:44px;height:44px;border-radius:var(--r-full);background:var(--prhl);display:flex;align-items:center;justify-content:center;font-size:var(--text-lg);font-weight:700;font-family:var(--font-display);color:var(--pri);flex-shrink:0;line-height:1}
.pc-name{font-weight:600;font-size:var(--text-base)}
.pc-meta{font-size:var(--text-xs);color:var(--txm)}
.pc-bal-row{display:flex;align-items:center;justify-content:space-between}
.pc-bal{font-size:var(--text-xl);font-weight:700;font-variant-numeric:tabular-nums}
.pc-bal.pos{color:var(--suc)}.pc-bal.neg{color:var(--err)}.pc-bal.zero{color:var(--txm)}
.pc-acts{display:flex;gap:var(--sp2);flex-wrap:wrap}

/* ── SESSION CARD (overview) ── */
.sc{background:var(--sur);border:1px solid oklch(from var(--tx) l c h/.08);border-radius:var(--r-xl);overflow:hidden;box-shadow:var(--sh-sm);margin-bottom:var(--sp4);content-visibility:auto;contain-intrinsic-size:200px}
.sc-head{padding:var(--sp4) var(--sp5);display:flex;align-items:center;justify-content:space-between;gap:var(--sp3);flex-wrap:wrap;border-bottom:1px solid var(--div);background:var(--suroff)}
.sc-date{font-weight:700;font-size:var(--text-base)}
.sc-meta{font-size:var(--text-xs);color:var(--txm);margin-top:2px}
.sc-body{padding:var(--sp5)}

/* ── PLAYER SLOTS GRID (unified, no court grouping) ── */
.slots-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(160px,100%),1fr));gap:var(--sp3);margin-bottom:var(--sp4)}
.slot-chip{display:flex;align-items:center;gap:var(--sp2);padding:var(--sp3);border-radius:var(--r-lg);font-size:var(--text-sm);border:1px solid oklch(from var(--tx) l c h/.08);background:var(--suroff);transition:background var(--tr),border-color var(--tr),color var(--tr)}
.slot-chip.filled{background:var(--suchl);border-color:oklch(from var(--suc) l c h/.3)}
.slot-chip.me{background:var(--prhl);border-color:oklch(from var(--pri) l c h/.4);font-weight:700;color:var(--pri)}
.slot-chip.wl{background:var(--gldhl);border-color:oklch(from var(--gld) l c h/.3);color:var(--gld)}
.slot-chip.open{background:var(--sur2);border:1px dashed var(--bor);color:var(--txm);cursor:pointer}
.slot-chip.open:hover{background:var(--prhl);border-color:var(--pri);color:var(--pri)}
.slot-av{width:28px;height:28px;border-radius:var(--r-full);background:var(--prhl);display:flex;align-items:center;justify-content:center;font-size:var(--text-xs);font-weight:700;color:var(--pri);flex-shrink:0;line-height:1}
.slot-av.suc{background:var(--suchl);color:var(--suc)}
.slot-av.gld{background:var(--gldhl);color:var(--gld)}
.wl-section{padding-top:var(--sp4);border-top:1px solid var(--div);margin-top:var(--sp2)}
.wl-title{font-size:var(--text-xs);font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--txm);margin-bottom:var(--sp3)}
.wl-list{display:flex;flex-wrap:wrap;gap:var(--sp2)}

/* ── ADMIN SLOT EDITOR ── */
.admin-slots-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(200px,100%),1fr));gap:var(--sp3);margin-bottom:var(--sp4)}
.admin-slot{display:flex;align-items:center;gap:var(--sp2);padding:var(--sp3);border-radius:var(--r-lg);border:1px dashed var(--bor);background:var(--sur2);cursor:pointer;transition:background var(--tr),border-color var(--tr);min-height:58px}
.admin-slot:hover{border-color:var(--pri);background:var(--prhl)}
.admin-slot.filled{border-style:solid;border-color:oklch(from var(--pri) l c h/.15);background:var(--prhl)}
.admin-slot.me{border-style:solid;border-color:#dba87a;background:#f0ddd0;font-weight:700;color:#b8713c}
.admin-slot .slot-name{font-weight:600;font-size:var(--text-sm)}
.admin-slot.filled .av{background:color-mix(in srgb, var(--pri) 40%, var(--sur));color:var(--txi)}
.admin-slot.me .av{background:#b8713c;color:#fff}
[data-theme="dark"] .admin-slot.me{border-color:#7a5a40;background:#2f241d;color:#c89560}
[data-theme="dark"] .admin-slot.me .av{background:#c89560;color:#1c1b19}
.admin-slot .slot-ph{color:var(--txf);font-size:var(--text-sm)}
.court-sep{font-size:var(--text-xs);font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--txm);margin-bottom:var(--sp2);margin-top:var(--sp4);display:flex;align-items:center;gap:var(--sp2)}
.court-sep:first-child{margin-top:0}

/* ── HISTORY ── */
.hl{display:flex;flex-direction:column;gap:var(--sp3)}
.hi{background:var(--sur);border:1px solid oklch(from var(--tx) l c h/.08);border-radius:var(--r-lg);padding:var(--sp4);display:flex;align-items:center;justify-content:space-between;gap:var(--sp3);box-shadow:var(--sh-sm)}
.hi-amt{font-size:var(--text-base);font-weight:700;font-variant-numeric:tabular-nums}
.hi-amt.cr{color:var(--suc)}.hi-amt.db{color:var(--err)}
.hi-meta{flex:1;min-width:0}
.hi-desc{font-weight:500;font-size:var(--text-sm);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.hi-date{font-size:var(--text-xs);color:var(--txm)}

/* ── PIN MODAL ── */
.pin-modal-overlay{position:fixed;inset:0;z-index:300;background:oklch(.1 0 0/.5);display:flex;align-items:center;justify-content:center;padding:var(--sp4);opacity:0;pointer-events:none;transition:opacity var(--tr)}
.pin-modal-overlay.open{opacity:1;pointer-events:all;backdrop-filter:blur(6px);will-change:opacity}
.pin-box{background:var(--sur);border-radius:var(--r-xl);padding:var(--sp8);max-width:340px;width:100%;box-shadow:var(--sh-lg);text-align:center;transform:translateY(12px) scale(.97);transition:transform var(--tr)}
.pin-modal-overlay.open .pin-box{transform:none}
.pin-logo{color:var(--pri);margin:0 auto var(--sp4)}
.pin-title{font-family:var(--font-display);font-size:var(--text-xl);margin-bottom:var(--sp2)}
.pin-subtitle{font-size:var(--text-sm);color:var(--txm);margin-bottom:var(--sp6)}
.pin-dots{display:flex;gap:var(--sp3);justify-content:center;margin-bottom:var(--sp5)}
.pdot{width:16px;height:16px;border-radius:var(--r-full);border:2px solid var(--bor);background:transparent;transition:background var(--tr),border-color var(--tr)}
.pdot.on{background:var(--pri);border-color:var(--pri)}
.pdot.err{background:var(--err);border-color:var(--err)}
.pin-err{color:var(--err);font-size:var(--text-sm);min-height:1.2em;margin-bottom:var(--sp3)}
.pin-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--sp3)}
.pkey{height:56px;border-radius:var(--r-lg);font-size:var(--text-lg);font-weight:600;background:var(--suroff);border:1px solid var(--bor);transition:background var(--tr),border-color var(--tr),color var(--tr)}
.pkey:hover{background:var(--prhl);border-color:var(--pri);color:var(--pri)}
.pkey:active{transform:scale(.93)}
.pkey.del{font-size:var(--text-sm);color:var(--txm);display:flex;align-items:center;justify-content:center}
.pin-close{margin-top:var(--sp4);font-size:var(--text-sm);color:var(--txm);cursor:pointer;background:none;border:none;text-decoration:underline}

/* ── MODAL ── */
.mo{position:fixed;inset:0;z-index:200;background:oklch(.1 0 0/.5);display:flex;align-items:center;justify-content:center;padding:var(--sp4);opacity:0;pointer-events:none;transition:opacity var(--tr)}
.mo.open{opacity:1;pointer-events:all;backdrop-filter:blur(4px);will-change:opacity}
.mo-box{background:var(--sur);border-radius:var(--r-xl);padding:var(--sp6);width:100%;max-width:480px;box-shadow:var(--sh-lg);transform:translateY(10px) scale(.97);transition:transform var(--tr)}
.mo.open .mo-box{transform:none}
.mo-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--sp5)}
.mo-title{font-size:var(--text-lg);font-weight:600}
.mo-close{padding:var(--sp2);border-radius:var(--r-md);color:var(--txm)}.mo-close:hover{background:var(--suroff);color:var(--tx)}
.mo-foot{display:flex;gap:var(--sp3);justify-content:flex-end;margin-top:var(--sp5)}

/* ── TOAST ── */
#toast{position:fixed;bottom:var(--sp6);left:50%;transform:translateX(-50%) translateY(20px);background:var(--tx);color:var(--bg);padding:var(--sp3) var(--sp5);border-radius:var(--r-full);font-size:var(--text-sm);font-weight:500;opacity:0;pointer-events:none;transition:opacity 300ms ease,transform 300ms ease;z-index:999;white-space:nowrap}
#toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* ── UTILS ── */
.flex{display:flex}.items-c{align-items:center}.just-b{justify-content:space-between}
.g2{gap:var(--sp2)}.g3{gap:var(--sp3)}.g4{gap:var(--sp4)}
.mb2{margin-bottom:var(--sp2)}.mb4{margin-bottom:var(--sp4)}.mb6{margin-bottom:var(--sp6)}.mb8{margin-bottom:var(--sp8)}
.mt4{margin-top:var(--sp4)}.mt6{margin-top:var(--sp6)}
.txm{color:var(--txm)}.txsm{font-size:var(--text-sm)}.txxs{font-size:var(--text-xs)}
.fw6{font-weight:600}.fw7{font-weight:700}
.wrap{flex-wrap:wrap}
.divider{height:1px;background:var(--div);margin:var(--sp5) 0}
.empty{display:flex;flex-direction:column;align-items:center;text-align:center;padding:var(--sp16) var(--sp8);color:var(--txm)}
.empty i, .empty svg{width:48px;height:48px;color:var(--txf);margin-bottom:var(--sp4)}
.empty h3{color:var(--tx);margin-bottom:var(--sp2)}
.empty p{max-width:36ch;margin-bottom:var(--sp6);font-size:var(--text-sm)}

.btn-identity{display:flex;align-items:center;gap:var(--sp2);padding:var(--sp2) var(--sp3);border-radius:var(--r-md);font-size:var(--text-sm);font-weight:600;background:var(--suroff);border:1px solid var(--bor);color:var(--txm);cursor:pointer;white-space:nowrap;max-width:160px;overflow:hidden;text-overflow:ellipsis}
.btn-identity:hover{background:var(--prhl);color:var(--pri);border-color:var(--pri)}
.btn-identity.selected{background:var(--prhl);color:var(--pri);border-color:oklch(from var(--pri) l c h/.4)}
.btn-identity svg{flex-shrink:0}
#identity-label{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100px}

/* Guest balance bar */
.guest-bal-bar {
  position: sticky;
  top: 56px; /* Exakt die Höhe der Topbar */
  z-index: 90;
  background: var(--suroff);
  border-bottom: 1px solid var(--bor);
  padding: 0 var(--sp4);
  display: flex;
  align-items: center;
  gap: var(--sp3);
  font-size: var(--text-sm);
  height: 40px;
  box-sizing: border-box;
}
.guest-bal-bar.hidden{display:none}
.gbb-name{font-weight:600}
.gbb-amount{font-weight:700;font-variant-numeric:tabular-nums}
.gbb-amount.pos{color:var(--suc)}.gbb-amount.neg{color:var(--err)}.gbb-amount.zero{color:var(--txm)}

/* Welcome overlay */
.welcome-overlay{position:fixed;inset:0;z-index:400;background:oklch(.1 0 0/.6);display:flex;align-items:center;justify-content:center;padding:var(--sp4);opacity:0;pointer-events:none;transition:opacity .25s ease}
.welcome-overlay.open{opacity:1;pointer-events:all;backdrop-filter:blur(8px);will-change:opacity}
.welcome-box{background:var(--sur);border-radius:var(--r-xl);padding:var(--sp8);padding-bottom:30px;width:100%;max-width:420px;box-shadow:var(--sh-lg);text-align:center;transform:translateY(16px) scale(.96);transition:transform .25s ease}
.welcome-overlay.open .welcome-box{transform:none}
.welcome-branding{display:flex;flex-direction:column;align-items:center;margin-bottom:14px}
.welcome-logo{color:var(--pri);margin:0 auto 2px;transform:scale(0.85);transform-origin:center top}
.welcome-brand-text{font-size:11.5px;font-weight:600;letter-spacing:0.45em;text-transform:uppercase;opacity:0.75;color:var(--pri);line-height:1.2;width:100%;text-align:center;font-family:inherit}
.welcome-hero{font-size:22px;font-weight:800;text-transform:uppercase;letter-spacing:0.02em;color:var(--tx);text-align:center;margin-top:14px;font-family:inherit}
.welcome-sub{font-size:11px;letter-spacing:0.05em;color:var(--tx);margin-bottom:var(--sp4);text-align:center;font-family:inherit}
.player-pick-grid-wrap{max-height:400px;overflow-y:auto;-webkit-overflow-scrolling:touch;touch-action:auto;mask-image:linear-gradient(to bottom,black 0%,black 70%,transparent 100%);-webkit-mask-image:linear-gradient(to bottom,black 0%,black 70%,transparent 100%);padding-bottom:60px;scrollbar-width:none}
.player-pick-grid-wrap::-webkit-scrollbar{display:none}
.player-pick-grid{position:relative;display:grid;grid-template-columns:1fr 1fr;gap:var(--sp2);text-align:left}
.player-pick-btn{display:flex;align-items:center;gap:var(--sp3);padding:var(--sp3);border-radius:var(--r-lg);background:var(--suroff);border:1px solid oklch(from var(--tx) l c h/.08);cursor:pointer;font-size:var(--text-sm);font-weight:500;transition:background var(--tr),border-color var(--tr),color var(--tr);-webkit-tap-highlight-color:transparent;user-select:none;font-family:inherit}
.player-pick-btn:hover{background:var(--prhl);border-color:oklch(from var(--pri) l c h/.4);color:var(--pri)}
.player-pick-btn.active{background:var(--prhl);border-color:var(--pri);color:var(--pri);font-weight:700}
.player-pick-btn:active{transform:scale(0.97);opacity:.94}
.player-pick-btn .av.initials-long{font-size:0.7rem}
.welcome-skip{opacity:1;font-weight:700;font-size:11px;text-transform:uppercase;letter-spacing:0.15em;border-top:1px solid oklch(from var(--pri) l c h/.15);padding-top:20px;margin-top:10px;width:100%;color:var(--pri);cursor:pointer;background:none;border-left:none;border-right:none;border-bottom:none;font-family:inherit}

@media(max-width:640px){
  .main{padding:var(--sp4)}
  .topbar{padding:var(--sp3) var(--sp4)}
  .topbar-title{display:none}
  .nav-btn span{display:none}
  .mo-box{padding:var(--sp5)}
  .kpi-grid{grid-template-columns:1fr 1fr}
  .pg{grid-template-columns:1fr}
  .admin-slots-grid{grid-template-columns:1fr 1fr}
  .slots-grid{grid-template-columns:1fr 1fr}
  .dt td{padding:var(--sp2) var(--sp2)}
  .dt th{padding:var(--sp2) var(--sp2)}
  .fi,input,select,textarea{font-size:16px}
}