@keyframes countdown-pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.05);opacity:.9}}*,::after,::before{box-sizing:border-box;margin:0;padding:0}#app,body{height:100vh}body{font-family:"Segoe UI",system-ui,-apple-system,sans-serif;background:#0b0e14;color:#d0d4dc;overflow:hidden}#app{display:flex;flex-direction:column}#topbar{display:flex;align-items:center;gap:20px;padding:12px 24px;background:#141820;border-bottom:1px solid #1e2636;flex-shrink:0}#topbar h1{font-size:18px;font-weight:600}#topbar h1 a{color:#8ba4c4;text-decoration:none}#btn-login,#topbar nav a{font-size:13px;transition:all .15s}#topbar nav a{color:#607090;text-decoration:none;padding:4px 8px;border-radius:4px}#topbar nav a:hover{color:#c4d0e4;background:#1a2030}.spacer,main{flex:1}.user-area{display:flex;align-items:center;gap:8px}#btn-login{background:#2a5090;border:1px solid #3a6abf;color:#e0eaff;padding:7px 18px;border-radius:5px;cursor:pointer}#btn-login:hover{background:#3060a8;border-color:#4a7acf}#user-display{display:flex;align-items:center;gap:10px;font-size:13px;color:#c4d0e4}#user-display.hidden{display:none}.user-dot{width:8px;height:8px;border-radius:50%;background:#5bc470;box-shadow:0 0 6px #5bc47055}.tier-badge{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;padding:2px 8px;border-radius:3px;background:linear-gradient(135deg,#d4a020,#f0c848);color:#1a1200}.tier-badge.tier-guest{background:#2a3448;color:#607090}.join-code-group.hidden,.tier-badge.hidden{display:none}#username{font-weight:600;color:#e0eaff}#btn-logout{background:0 0;border:1px solid #2a3448;color:#607090;padding:5px 10px;border-radius:4px;font-size:11px;cursor:pointer;transition:all .15s}#btn-logout:hover{border-color:#4a2535;color:#e06c5e}main{overflow-y:auto;padding:24px;max-width:1000px;margin:0 auto;width:100%}.lobby-header{justify-content:space-between;margin-bottom:16px;flex-wrap:wrap}.join-code-group,.lobby-actions,.lobby-header{display:flex;align-items:center;gap:10px}.join-code-group{gap:4px}#join-code-input{background:#0e1218;border:1px solid #2a3448;color:#d0d4dc;padding:7px 10px;border-radius:5px;font-size:13px;font-family:"SF Mono","Consolas",monospace;letter-spacing:2px;width:100px;text-transform:uppercase;outline:0;transition:border-color .15s}#join-code-input:focus{border-color:#3a6abf}#join-code-input::placeholder{letter-spacing:0;font-family:inherit}#btn-join-code{background:#1a2030;border:1px solid #2a3448;color:#9aa8c0;padding:7px 12px;font-size:13px}#btn-join-code:hover{background:#2a5090;border-color:#3a6abf;color:#e0eaff}#lobby-section h2{font-size:16px;font-weight:600;color:#8ba4c4;text-transform:uppercase;letter-spacing:.5px}#btn-create,#btn-join-code,.filter-group summary{cursor:pointer;border-radius:5px;transition:all .15s}#btn-create{background:#2a5090;border:1px solid #3a6abf;color:#e0eaff;padding:7px 14px;font-size:13px}#btn-create:hover{background:#3060a8}#btn-create.hidden,.lobby-filters.hidden{display:none}.lobby-filters{display:flex;flex-wrap:wrap;gap:8px;align-items:flex-start;padding:12px 14px;margin-bottom:16px;background:#141820;border:1px solid #1e2636;border-radius:6px}.filter-group{position:relative}.filter-group summary{list-style:none;padding:6px 14px;background:#0e1218;border:1px solid #2a3448;font-size:12px;color:#9aa8c0;user-select:none;white-space:nowrap}.filter-group summary::-webkit-details-marker{display:none}.filter-group summary::after{content:" ▾";margin-left:6px;opacity:.6;font-size:9px}.filter-group summary:hover{background:#1a2030;border-color:#3a4a64;color:#c4d0e4}.filter-group[open] summary{background:#2a5090;border-color:#3a6abf;color:#e0eaff}#game-room.hidden,.filter-options{display:none}.filter-group[open] .filter-options{display:flex;flex-direction:column;gap:2px;position:absolute;top:calc(100% + 4px);left:0;z-index:10;background:#141820;border:1px solid #2a3448;border-radius:5px;padding:8px 4px;min-width:220px;box-shadow:0 4px 12px rgba(0,0,0,.5)}.filter-options label{display:flex;align-items:center;padding:6px 10px;font-size:13px;color:#c4d0e4;cursor:pointer;border-radius:3px;white-space:nowrap;user-select:none;transition:background .12s}.btn-filter-reset,.filter-options label:hover{background:#1a2030}.filter-options label input{margin-right:10px;cursor:pointer;accent-color:#3a6abf}.btn-filter-reset{margin-left:auto;border:1px solid #2a3448;color:#9aa8c0;padding:6px 14px;border-radius:5px;font-size:12px;cursor:pointer;transition:all .15s;align-self:center}.btn-filter-reset:hover{background:#222d42;color:#c4d0e4;border-color:#3a4a64}#game-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px}.game-card{background:#141820;border:1px solid #1e2636;border-radius:8px;padding:16px;transition:all .15s}.game-card:hover{border-color:#2a3448;background:#161c26}.game-top-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}.game-code{font-family:"SF Mono","Consolas",monospace;font-size:12px;font-weight:700;letter-spacing:1.5px;color:#607090;background:#0e1218;padding:3px 8px;border-radius:4px;border:1px solid #1e2636}.game-map{font-size:16px;font-weight:600;color:#e0eaff;display:flex;align-items:center;gap:8px}.map-scope-tag{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;padding:2px 6px;border-radius:3px}.scope-global{background:#1a3050;color:#6aa0d8}.scope-user{background:#3a2a10;color:#d4a030}.game-meta{display:flex;gap:12px;font-size:12px;color:#607090;margin-bottom:8px}.game-meta .players,.hint-text strong{color:#8ba4c4}.game-meta .players.full{color:#e06c5e}.game-tags{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:10px}.game-tag{font-size:10px;padding:2px 7px;border-radius:3px;background:#1a2030;color:#708090;border:1px solid #1e2636}.game-tag-warn{border-color:#4a3520;color:#c89040}.btn-join{width:100%;background:#1a2030;border:1px solid #2a3448;color:#9aa8c0;padding:8px;border-radius:5px;font-size:13px;cursor:pointer;transition:all .15s}.btn-join:hover{background:#2a5090;border-color:#3a6abf;color:#e0eaff}.btn-join:disabled{opacity:.5;cursor:not-allowed}.empty{padding:40px;text-align:center;color:#506080;font-size:14px;border:1px dashed #1e2636;border-radius:8px;grid-column:1/-1}.room-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.room-code-display{font-size:13px;color:#607090;font-weight:600}.room-code-display span{font-family:"SF Mono","Consolas",monospace;font-size:18px;font-weight:700;letter-spacing:3px;color:#e0eaff;background:#0e1218;padding:6px 14px;border-radius:6px;border:1px solid #2a3448;margin-left:8px}.btn-back{background:#1a2030;border:1px solid #2a3448;color:#9aa8c0;padding:7px 14px;border-radius:5px;font-size:13px;cursor:pointer;transition:all .15s}.btn-back:hover{background:#222d42;color:#c4d0e4;border-color:#3a4a64}.room-layout{display:grid;grid-template-columns:1fr 1fr;gap:20px}.room-settings{background:#141820;border:1px solid #1e2636;border-radius:8px;padding:20px}.room-players h3,.room-settings h3{font-size:14px;font-weight:600;color:#8ba4c4;text-transform:uppercase;letter-spacing:.5px;margin-bottom:14px}.settings-grid{display:flex;flex-direction:column;gap:10px}.setting-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid #1a2030}.setting-row:last-child{border-bottom:none}.setting-label{font-size:12px;text-transform:uppercase;letter-spacing:.5px;color:#506080;font-weight:600}.setting-value{font-size:14px;color:#c4d0e4;font-weight:500}.room-players{background:#141820;border:1px solid #1e2636;border-radius:8px;padding:20px}.room-players h3 span{font-weight:400;color:#506080}#room-player-list{display:flex;flex-direction:column;gap:6px}.player-row{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;background:#0e1218;border:1px solid #1a2030;border-radius:6px}.player-name{font-size:14px;font-weight:500;color:#d0d4dc}.player-badges{display:flex;align-items:center;gap:6px}.banned-header span,.host-badge{font-weight:700;text-transform:uppercase;letter-spacing:.5px}.host-badge{font-size:10px;padding:2px 8px;border-radius:3px;background:#2a4020;color:#80c870;border:1px solid #3a5830}.kick-btn{background:0 0;border:1px solid transparent;color:#604040;font-size:18px;line-height:1;cursor:pointer;padding:2px 6px;border-radius:4px;transition:all .15s}.kick-btn:hover{color:#e06c5e;background:#2a1818;border-color:#4a2535}.player-row.empty-slot{border-style:dashed;border-color:#1a2030;background:0 0}.empty-name{color:#303848;font-style:italic;font-weight:400}.banned-section{margin-top:16px;padding:12px;background:#1a1418;border:1px solid #3a2030;border-radius:6px}.banned-section.hidden{display:none}.banned-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.banned-header span{font-size:11px;color:#c87070}.btn-clear-bans{background:#2a1820;border:1px solid #4a2535;color:#c89090;padding:4px 10px;border-radius:4px;font-size:11px;cursor:pointer;transition:all .15s}.btn-clear-bans:hover{background:#3a2030;color:#e0a0a0}.banned-row{display:flex;align-items:center;justify-content:space-between;padding:6px 10px;margin-bottom:4px;background:#0e0a10;border:1px solid #2a1820;border-radius:4px}.banned-row:last-child{margin-bottom:0}.banned-name{font-size:13px;color:#a08080}.btn-launch,.unban-btn{cursor:pointer;transition:all .15s}.unban-btn{background:0 0;border:1px solid #2a3448;color:#708090;padding:3px 10px;border-radius:3px;font-size:11px}.unban-btn:hover{background:#1a2030;color:#c4d0e4;border-color:#3a4a64}.btn-launch{width:100%;margin-top:14px;background:linear-gradient(135deg,#2a7040,#3a9050);border:1px solid #4aa060;color:#e0ffe8;padding:11px 14px;border-radius:6px;font-size:14px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.btn-launch:hover:not(:disabled){background:linear-gradient(135deg,#358848,#44a860);border-color:#5ac070}.btn-launch:disabled{opacity:.5;cursor:not-allowed;background:#1a2a20;border-color:#2a3a30;color:#506060}.btn-launch.hidden,.launch-countdown.hidden,.modal.hidden{display:none}.launch-countdown{margin-top:14px;padding:20px;background:linear-gradient(135deg,#1a2a30,#2a3a50);border:1px solid #3a5070;border-radius:6px;text-align:center}.countdown-label{font-size:12px;text-transform:uppercase;letter-spacing:1px;color:#8ba4c4;margin-bottom:8px}.countdown-number{font-size:48px;font-weight:700;color:#e0eaff;font-family:"SF Mono","Consolas",monospace;line-height:1;text-shadow:0 0 20px #3a6abf88;animation:countdown-pulse 1s ease-out infinite}.status-bar{padding:6px 16px;background:#0e1218;border-top:1px solid #1e2636;font-size:11px;flex-shrink:0}.status-disconnected{color:#e06c5e}.status-connected::before,.status-connecting::before,.status-disconnected::before{content:"●";margin-right:6px}.status-connected{color:#5bc470}.status-connecting{color:#e8a838}.modal{position:fixed;inset:0;background:rgba(0,0,0,.7);display:flex;align-items:center;justify-content:center;z-index:100}.modal-inner{background:#141820;border:1px solid #2a3448;border-radius:8px;padding:24px;width:400px;max-width:90vw;display:flex;flex-direction:column;gap:12px}.modal-inner.create-modal-wide{width:480px;max-height:85vh;overflow-y:auto}.modal-inner h2{font-size:18px;color:#8ba4c4}.modal-inner p{font-size:13px;color:#607090}.modal-inner label{font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:#607090;font-weight:600;margin-top:4px}.label-hint{font-weight:400;text-transform:none;letter-spacing:0;font-size:10px;color:#506070}.hint-text{font-size:12px;color:#506070;line-height:1.5;padding:8px 10px;background:#0e1218;border-radius:4px;border:1px solid #1a2030}.modal-inner input[type=number],.modal-inner input[type=password],.modal-inner input[type=text],.modal-inner select{background:#0e1218;border:1px solid #2a3448;color:#d0d4dc;padding:9px 12px;border-radius:4px;font-size:14px;outline:0;transition:border-color .15s}.modal-inner input:focus,.modal-inner select:focus{border-color:#3a6abf}.modal-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:8px}.modal-actions button{padding:8px 18px;border-radius:5px;font-size:13px;cursor:pointer;border:1px solid #2a3448;transition:all .15s}#btn-create-cancel,#btn-login-cancel{background:#1a2030;color:#9aa8c0}#btn-create-cancel:hover,#btn-login-cancel:hover{background:#222d42}#btn-create-submit,#btn-login-submit{background:#2a5090;border-color:#3a6abf;color:#e0eaff}#btn-create-submit:hover,#btn-login-submit:hover{background:#3060a8}.btn-secondary{background:#1a2a1a;border-color:#2a5030!important;color:#70c478}.btn-secondary:hover{background:#224228!important}.create-form{display:flex;flex-direction:column;gap:0}.form-row{display:flex;align-items:center;justify-content:space-between;padding:10px 0;border-bottom:1px solid #1a2030;gap:16px}.form-row:last-child{border-bottom:none}.form-row>label{font-size:12px;text-transform:uppercase;letter-spacing:.5px;color:#607090;font-weight:600;white-space:nowrap;flex-shrink:0;margin:0}.form-row>input[type=number],.form-row>select{background:#0e1218;border:1px solid #2a3448;color:#d0d4dc;padding:8px 12px;border-radius:4px;font-size:13px;outline:0;transition:border-color .15s;min-width:200px;text-align:right}.form-row>input:focus,.form-row>select:focus{border-color:#3a6abf}.toast{position:fixed;bottom:40px;left:50%;transform:translateX(-50%) translateY(20px);background:#1a3050;color:#c4d8f0;border:1px solid #2a4a70;padding:10px 20px;border-radius:6px;font-size:13px;opacity:0;transition:all .3s ease;z-index:200;pointer-events:none}.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}.toast-error{background:#3a1a1a;border-color:#5a2a2a;color:#f0a0a0}.hidden{display:none!important}