
* { 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:#f7f6f2;--sur:#f9f8f5;--sur2:#fbfbf9;--suroff:#f0ede9;--suroff2:#edeae5;
  --div:#dcd9d5;--bor:#d4d1ca;
  --tx:#28251d;--txm:#7a7974;--txf:#bab9b4;--txi:#f9f8f4;
  --pri:#01696f;--prih:#0c4e54;--pria:#0f3638;--prhl:#cedcd8;
  --suc:#437a22;--such:#2e5c10;--suchl:#d4dfcc;
  --war:#964219;--warhl:#ddcfc6;
  --err:#a12c7b;--errh:#7d1e5e;--errhl:#e0ced7;
  --gld:#d19900;--gldhl:#e9e0c6;
  --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:#4f98a3;--prih:#227f8b;--pria:#1a626b;--prhl:#313b3b;
  --suc:#6daa45;--such:#4d8f25;--suchl:#3a4435;
  --war:#bb653b;--warhl:#564942;
  --err:#d163a7;--errh:#b9478f;--errhl:#4c3d46;
  --gld:#e8af34;--gldhl:#4d4332;
  --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}
html{-webkit-font-smoothing:antialiased;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)}
img,svg{display:block;max-width:100%}
input,button,select,textarea{font:inherit;color:inherit}
h1,h2,h3,h4{text-wrap:balance;line-height:1.2}
p,li{text-wrap:pretty}
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;background:var(--sur);border-bottom:1px solid var(--bor);padding:var(--sp3) var(--sp6);display:flex;align-items:center;gap:var(--sp3)}
.topbar-logo{display:flex;align-items:center;gap:var(--sp3);text-decoration:none;color:var(--tx);flex-shrink:0}
.logo-icon{color:var(--pri)}
.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}
@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}

/* ── 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)}

/* ── 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:all 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{filter:brightness(.95)}
.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)}

/* ── TABLE ── */
.tw{overflow-x:auto;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}
.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}
.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)}
.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:all 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}
.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:all 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(--suc) l c h/.4);background:var(--suchl)}
.admin-slot .slot-name{font-weight:600;font-size:var(--text-sm)}
.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);backdrop-filter:blur(6px);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}
.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:all 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:all 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);backdrop-filter:blur(4px);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}
.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{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);backdrop-filter:blur(8px);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}
.welcome-box{background:var(--sur);border-radius:var(--r-xl);padding:var(--sp8);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-logo{color:var(--pri);margin:0 auto var(--sp4)}
.welcome-title{font-family:var(--font-display);font-size:var(--text-xl);margin-bottom:var(--sp2)}
.welcome-sub{font-size:var(--text-sm);color:var(--txm);margin-bottom:var(--sp6)}
.player-pick-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp2);max-height:300px;overflow-y:auto;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:all var(--tr)}
.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}
.welcome-skip{margin-top:var(--sp4);font-size:var(--text-xs);color:var(--txm);cursor:pointer;background:none;border:none;text-decoration:underline}

@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}
}

/* Pull to Refresh */
#ptr-indicator {
  position: fixed;
  top: 0; left: 50%;
  transform: translateX(-50%) translateY(-60px);
  z-index: 999;
  background: var(--sur);
  border: 1px solid var(--bor);
  border-radius: var(--r-full);
  padding: var(--sp2) var(--sp4);
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--txm);
  display: flex;
  align-items: center;
  gap: var(--sp2);
  box-shadow: var(--sh-md);
  transition: transform 0.2s ease, opacity 0.2s ease;
  opacity: 0;
  pointer-events: none;
}
#ptr-indicator.visible {
  opacity: 1;
}
#ptr-indicator.releasing {
  transform: translateX(-50%) translateY(12px);
}
#ptr-indicator svg {
  transition: transform 0.3s ease;
}
#ptr-indicator.releasing svg {
  transform: rotate(180deg);
}
#ptr-indicator.loading svg {
  animation: spin 0.8s linear infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }