.gameroom-root{min-height:100vh;color:#e8edf3;position:relative;background-color:#0c1118;background-image:radial-gradient(circle at 15% 15%,rgba(57,74,96,.35),transparent 45%),radial-gradient(circle at 85% 20%,rgba(39,58,82,.35),transparent 45%),linear-gradient(180deg,#0a0e14f2,#0a0e14eb),repeating-linear-gradient(90deg,rgba(255,255,255,.02),rgba(255,255,255,.02) 1px,transparent 1px,transparent 24px),repeating-linear-gradient(0deg,rgba(255,255,255,.02),rgba(255,255,255,.02) 1px,transparent 1px,transparent 24px);display:flex;align-items:center;justify-content:center}.gameroom-shell{position:relative;z-index:1;width:100%;max-width:600px;padding:24px}.gameroom-card{background:#0d141eb3;border:1px solid rgba(101,115,141,.25);border-radius:16px;padding:40px 32px;box-shadow:0 12px 40px #04080c73;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);text-align:center}.gameroom-title{font-size:48px;font-weight:800;letter-spacing:4px;text-transform:uppercase;color:#eef2f7;margin-bottom:4px}.gameroom-subtitle{font-size:14px;letter-spacing:1.2px;text-transform:uppercase;color:#e8edf380;margin-bottom:24px}.gameroom-chips{display:flex;justify-content:center;gap:12px;margin-bottom:20px}.gameroom-count{font-size:13px;font-weight:700;letter-spacing:1.4px;text-transform:uppercase;color:#e8edf3b3;margin-bottom:24px}.gameroom-slots{display:flex;justify-content:center;gap:20px;margin-bottom:28px;flex-wrap:wrap}.gameroom-slot{display:flex;flex-direction:column;align-items:center;gap:8px}.gameroom-avatar{width:48px;height:48px;border-radius:50%;position:relative;transition:background-color .3s ease,box-shadow .3s ease}.gameroom-avatar.filled{border:2px solid rgba(255,255,255,.2)}.gameroom-avatar.empty{border:2px dashed rgba(101,115,141,.4);background:#65738d1a;animation:pulse-empty 2s ease-in-out infinite}.gameroom-avatar.me{border:3px solid rgba(255,255,255,.7)}@keyframes pulse-empty{0%,to{opacity:.5}50%{opacity:1}}.gameroom-you-badge{position:absolute;bottom:-6px;left:50%;transform:translate(-50%);padding:1px 6px;border-radius:999px;background:#ffffffe6;color:#0c1118;font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}.gameroom-slot-label{font-size:12px;color:#e8edf399;max-width:64px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.gameroom-identity{font-size:15px;margin-bottom:16px;color:#e8edf3cc}.gameroom-status{font-size:13px;color:#f0c784;margin-bottom:20px}.gameroom-spinner-wrap{display:flex;justify-content:center;margin-bottom:24px}.gameroom-leave{margin:0 auto}.lobby-root{min-height:100vh;color:#e8edf3;position:relative;background-color:#0c1118;background-image:radial-gradient(circle at 15% 15%,rgba(57,74,96,.35),transparent 45%),radial-gradient(circle at 85% 20%,rgba(39,58,82,.35),transparent 45%),linear-gradient(180deg,#0a0e14f2,#0a0e14eb),repeating-linear-gradient(90deg,rgba(255,255,255,.02),rgba(255,255,255,.02) 1px,transparent 1px,transparent 24px),repeating-linear-gradient(0deg,rgba(255,255,255,.02),rgba(255,255,255,.02) 1px,transparent 1px,transparent 24px)}.lobby-root:before{content:"";position:absolute;inset:0;background-image:url(/maps/world5.svg);background-repeat:no-repeat;background-position:center 120px;background-size:1200px auto;opacity:.12;filter:saturate(0) brightness(1.35);pointer-events:none}.lobby-shell{max-width:1140px;margin:0 auto;padding:48px 24px 80px;position:relative;z-index:1}.lobby-header{display:flex;justify-content:space-between;align-items:flex-start;gap:24px;margin-bottom:32px}.lobby-brand{display:flex;flex-direction:column;gap:8px}.lobby-title{font-size:48px;font-weight:800;letter-spacing:4px;text-transform:uppercase;color:#eef2f7}.lobby-subtitle{font-size:14px;letter-spacing:.4px;color:#e8edf39e}.lobby-header-meta{display:flex;flex-wrap:wrap;gap:12px}.lobby-chip{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border-radius:999px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.8px;color:#e8edf3b3;background:#0c111acc;border:1px solid rgba(101,115,141,.25)}.lobby-main{display:grid;grid-template-columns:minmax(280px,320px) minmax(0,1fr);gap:24px;align-items:start}.lobby-panel,.lobby-card{background:#0d141eb3;border:1px solid rgba(101,115,141,.25);border-radius:16px;padding:22px;box-shadow:0 12px 40px #04080c73;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.panel-title{display:flex;align-items:center;gap:10px;font-size:14px;text-transform:uppercase;letter-spacing:1.2px;color:#e8edf3b3;margin-bottom:18px}.panel-section{display:flex;flex-direction:column;gap:12px;padding-top:16px;margin-top:16px;border-top:1px solid rgba(101,115,141,.2)}.profile-summary{display:flex;align-items:center;gap:12px}.profile-avatar{width:46px;height:46px;border-radius:12px;display:grid;place-items:center;background:linear-gradient(135deg,#577198e6,#2a3e58e6);color:#f3f6fb;font-weight:700;font-size:18px}.profile-name{font-size:16px;font-weight:600}.profile-meta{font-size:11px;color:#e8edf373;letter-spacing:.6px}.field-label{font-size:11px;letter-spacing:1px;text-transform:uppercase;color:#e8edf380}.input,.select{width:100%;padding:12px;border-radius:10px;border:1px solid rgba(101,115,141,.35);background:#0c121ccc;color:#e8edf3;font-size:14px;outline:none}.input:focus,.select:focus{border-color:#829cc9b3;box-shadow:0 0 0 3px #4e699733}.button-row{display:flex;gap:10px}.button{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 16px;border-radius:10px;border:1px solid transparent;font-size:13px;font-weight:600;letter-spacing:.4px;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease;color:#ecf2f8;background:#232e3ecc}.button:hover{transform:translateY(-1px);box-shadow:0 6px 16px #050a1073}.button.primary{background:linear-gradient(135deg,#415f8af2,#273d58f2);border-color:#7191be66}.button.accent{background:linear-gradient(135deg,#29725be6,#1c5446e6);border-color:#62a89266}.button.warn{background:linear-gradient(135deg,#78352ff2,#4c2220f2);border-color:#bd605a73}.button.ghost{background:transparent;border-color:#65738d59;color:#e8edf3b3}.button:disabled{opacity:.5;cursor:not-allowed;box-shadow:none;transform:none}.auth-grid{display:grid;grid-template-columns:1fr auto;gap:8px 12px;font-size:13px;color:#e8edf3b3}.auth-label{color:#e8edf380}.helper-text{font-size:12px;color:#e8edf373}.lobby-card-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:18px}.lobby-card-title{display:flex;align-items:center;gap:10px;font-size:18px;font-weight:600}.count-pill{display:inline-flex;align-items:center;padding:4px 10px;border-radius:999px;background:#4a5f7c59;border:1px solid rgba(120,150,189,.3);font-size:12px;font-weight:600}.status-message{border-radius:12px;padding:12px 14px;border:1px solid rgba(148,83,80,.4);background:#4a1e1e66;color:#f2b6b6;font-size:13px;margin-bottom:14px}.panel-empty{text-align:center;padding:48px 16px;color:#e8edf380;font-size:14px}.spinner{width:22px;height:22px;border-radius:50%;border:2px solid rgba(232,237,243,.2);border-top-color:#e8edf3cc;margin:0 auto 12px;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.games-list{display:flex;flex-direction:column;gap:12px}.game-card{display:flex;justify-content:space-between;align-items:center;gap:16px;padding:16px;border-radius:14px;background:#0f1722cc;border:1px solid rgba(101,115,141,.2);transition:border-color .15s ease,transform .15s ease}.game-card:hover{border-color:#7896bd80;transform:translateY(-1px)}.game-meta{display:flex;align-items:center;gap:14px}.game-index{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;font-weight:700;font-size:16px;background:#273447e6;border:1px solid rgba(120,150,189,.4)}.game-title{font-size:15px;font-weight:600;margin-bottom:6px}.game-info{display:flex;align-items:center;gap:14px;font-size:12px;color:#e8edf38c}.info-row{display:inline-flex;align-items:center;gap:6px}.player-dots{display:inline-flex;align-items:center;gap:4px}.player-dot{width:8px;height:8px;border-radius:50%;display:inline-block;box-shadow:0 0 0 1px #ffffff1a}.status-pill{padding:2px 8px;border-radius:999px;font-size:11px;font-weight:700;letter-spacing:.4px;text-transform:uppercase}.status-pill.live{background:#34927840;color:#7fe3c4;border:1px solid rgba(52,146,120,.4)}.status-pill.waiting{background:#a4844440;color:#f0c784;border:1px solid rgba(164,132,68,.4)}.game-actions{display:flex;align-items:center}@media(max-width:960px){.lobby-main{grid-template-columns:1fr}.lobby-header{flex-direction:column;align-items:flex-start}}@media(max-width:640px){.lobby-shell{padding:36px 16px 64px}.lobby-title{font-size:36px}.game-card{flex-direction:column;align-items:flex-start}.game-actions,.game-actions .button{width:100%}}*{box-sizing:border-box}html,body,#root{width:100%;height:100%;margin:0;padding:0;overscroll-behavior:none;overflow:hidden}body{font-family:Inter,Segoe UI,system-ui,-apple-system,sans-serif;background:#0c0f14;color:#e8edf3;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none}.app{width:100%;height:100%}.app.lobby-mode{overflow-y:auto;-webkit-overflow-scrolling:touch}.app.game-mode{overflow:hidden;position:relative}.map-container{width:100%;height:100%;overflow:hidden;position:relative;background:#0b1a2e;touch-action:none;cursor:default}.map-svg path:hover{cursor:pointer}.map-container:active,.map-container.is-panning{cursor:grabbing}.map-svg{position:absolute;top:0;left:0;transform-origin:0 0;-webkit-user-select:none;user-select:none}
