@import url('https://fonts.googleapis.com/css2?family=Fredoka:wght@600;700&family=Outfit:wght@400;500;600&display=swap');

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
:root{
  --bg-0:#0d1117;--bg-1:#161b22;--bg-2:#1c2128;--bg-3:#22272e;--bg-4:#2d333b;
  --accent:#58a6ff;--accent-h:#79b8ff;
  --green:#56d364;--yellow:#e3b341;--red:#f85149;--orange:#d29922;--purple:#bc8cff;--pink:#f778ba;
  --text-1:#e6edf3;--text-2:#8b949e;--text-3:#484f58;
  --border:rgba(255,255,255,.07);--border-h:rgba(255,255,255,.13);
  --r-sm:8px;--r-md:14px;--r-lg:20px;
  --font-d:'Fredoka',sans-serif;--font-b:'Outfit',sans-serif;
}
html,body{height:100%;background:var(--bg-0);color:var(--text-1);font-family:var(--font-b);font-size:15px;line-height:1.5;-webkit-tap-highlight-color:transparent;}
a{color:var(--accent);text-decoration:none;}
.hidden{display:none!important;}

/* Buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:10px 20px;border:none;border-radius:var(--r-sm);font-family:var(--font-b);font-size:14px;font-weight:600;cursor:pointer;transition:all .18s;-webkit-tap-highlight-color:transparent;white-space:nowrap;min-height:42px;}
.btn:disabled{opacity:.45;cursor:not-allowed;}
.btn-primary{background:var(--accent);color:#0d1117;}
.btn-primary:hover:not(:disabled){background:var(--accent-h);}
.btn-secondary{background:var(--bg-3);color:var(--text-1);border:1px solid var(--border-h);}
.btn-secondary:hover:not(:disabled){background:var(--bg-4);}
.btn-ghost{background:transparent;color:var(--text-2);border:1px solid var(--border);}
.btn-ghost:hover:not(:disabled){color:var(--text-1);border-color:var(--border-h);}
.btn-danger{background:var(--red);color:#fff;}
.btn-danger:hover:not(:disabled){filter:brightness(1.1);}
.btn-sm{padding:7px 14px;font-size:13px;min-height:34px;}
.btn-lg{padding:14px 28px;font-size:16px;min-height:52px;font-family:var(--font-d);letter-spacing:.03em;}
.btn-full{width:100%;}

/* Cards */
.card{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--r-lg);padding:20px;}

/* Inputs */
.input{width:100%;padding:10px 14px;background:var(--bg-3);border:1px solid var(--border);border-radius:var(--r-sm);color:var(--text-1);font-family:var(--font-b);font-size:14px;outline:none;transition:border .18s;}
.input:focus{border-color:var(--accent);}
.input::placeholder{color:var(--text-3);}

/* Toast */
#toast-container{position:fixed;bottom:24px;right:24px;z-index:9999;display:flex;flex-direction:column;gap:8px;pointer-events:none;}
.toast{padding:10px 18px;border-radius:var(--r-sm);font-size:13px;font-weight:500;animation:toastIn .25s ease;pointer-events:none;max-width:320px;}
@keyframes toastIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
.toast-success{background:#1a4731;color:var(--green);border:1px solid rgba(86,211,100,.3);}
.toast-error{background:#3d1a1a;color:var(--red);border:1px solid rgba(248,81,73,.3);}
.toast-info{background:var(--bg-3);color:var(--text-2);border:1px solid var(--border);}

/* Conn status */
#conn-status{position:fixed;top:10px;left:50%;transform:translateX(-50%);z-index:888;background:var(--bg-3);border:1px solid var(--border);border-radius:99px;padding:5px 14px;font-size:12px;color:var(--text-3);display:flex;align-items:center;gap:6px;transition:opacity .5s;}
#conn-status.hidden{opacity:0;pointer-events:none;}
.dot{width:7px;height:7px;border-radius:50%;flex-shrink:0;}
.dot-on{background:var(--green);}
.dot-off{background:var(--red);}
.dot-wait{background:var(--yellow);}

/* Error msg */
.error-msg{color:var(--red);font-size:12px;min-height:18px;margin-top:4px;}

/* Scrollbar */
::-webkit-scrollbar{width:6px;height:6px;}
::-webkit-scrollbar-track{background:transparent;}
::-webkit-scrollbar-thumb{background:var(--bg-4);border-radius:3px;}

/* Mobile tabs */
.mobile-tabs{display:none;background:var(--bg-1);border-bottom:1px solid var(--border);flex-shrink:0;}
.mob-tab{flex:1;padding:10px 4px;background:none;border:none;color:var(--text-3);font-family:var(--font-b);font-size:12px;font-weight:600;cursor:pointer;border-bottom:2px solid transparent;transition:all .18s;}
.mob-tab.active{color:var(--accent);border-bottom-color:var(--accent);}

/* Avatar chip */
.avatar-chip{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:99px;font-size:12px;font-weight:600;}
.avatar-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;}

/* Player row */
.player-row{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:var(--r-sm);transition:background .15s;}
.player-row:hover{background:var(--bg-3);}
.player-row.active-player{background:rgba(88,166,255,.08);border:1px solid rgba(88,166,255,.2);}

/* Chat */
.chat-wrap{display:flex;flex-direction:column;flex:1;overflow:hidden;min-height:0;}
.chat-msgs{flex:1;overflow-y:auto;padding:8px 12px;display:flex;flex-direction:column;gap:4px;min-height:0;}
.chat-msg{font-size:12px;color:var(--text-2);line-height:1.4;word-break:break-word;}
.chat-msg.sys{color:var(--text-3);font-style:italic;}
.chat-msg .mu{color:var(--accent);font-weight:600;}
.chat-row{display:flex;gap:6px;padding:6px 10px;border-top:1px solid var(--border);flex-shrink:0;}
.chat-input{flex:1;padding:7px 10px;background:var(--bg-3);border:1px solid var(--border);border-radius:var(--r-sm);color:var(--text-1);font-size:13px;outline:none;}
.chat-input:focus{border-color:var(--accent);}
.chat-send-btn{padding:7px 12px;background:var(--accent);color:#0d1117;border:none;border-radius:var(--r-sm);font-weight:700;cursor:pointer;}

/* Select */
.select{padding:8px 12px;background:var(--bg-3);border:1px solid var(--border);border-radius:var(--r-sm);color:var(--text-1);font-family:var(--font-b);font-size:13px;outline:none;cursor:pointer;}
.select:focus{border-color:var(--accent);}
.select option{background:var(--bg-2);}

/* Highscore table */
.hs-table{width:100%;border-collapse:collapse;font-size:13px;}
.hs-table th{color:var(--text-3);font-size:10px;text-transform:uppercase;letter-spacing:.05em;padding:4px 8px;text-align:left;}
.hs-table td{padding:7px 8px;border-bottom:1px solid var(--border);}
.hs-rank{font-size:16px;width:36px;}
.hs-score{font-weight:700;color:var(--yellow);text-align:right;}

/* Stat pills */
.stats-row{display:flex;gap:12px;flex-wrap:wrap;}
.stat-pill{background:var(--bg-3);border:1px solid var(--border);border-radius:var(--r-md);padding:12px 16px;flex:1;min-width:80px;}
.stat-num{font-family:var(--font-d);font-size:22px;font-weight:700;color:var(--accent);}
.stat-lbl{font-size:11px;color:var(--text-3);margin-top:2px;}

/* Label */
.label{font-size:11px;color:var(--text-3);text-transform:uppercase;letter-spacing:.06em;font-weight:600;margin-bottom:6px;}

@media(max-width:768px){
  .btn-lg{padding:12px 20px;font-size:15px;}
  #toast-container{bottom:70px;right:12px;left:12px;}
  .toast{max-width:100%;}
}
