.lobby-room{background:#000000b3;padding:30px;border-radius:16px;box-shadow:0 15px 40px #00000080;min-width:1100px;max-width:1800px;margin:0 auto;border:1px solid rgba(255,255,255,.1)}.lobby-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;padding-bottom:20px;border-bottom:1px solid rgba(255,255,255,.1)}.lobby-header h2{color:#e5e7eb;font-size:2rem;margin:0}.leave-button{padding:10px 20px;background:#ef444433;color:#ef4444;border:1px solid #ef4444;border-radius:6px;cursor:pointer;font-weight:600;transition:all .3s}.leave-button:hover:not(:disabled){background:#ef44444d;transform:translateY(-1px)}.leave-button:disabled{opacity:.5;cursor:not-allowed}.lobby-content{display:grid;grid-template-columns:4fr 1fr;gap:30px;margin-bottom:30px}.players-panel{background:#ffffff0d;border-radius:12px;padding:20px;border:1px solid rgba(255,255,255,.1)}.players-panel h3{color:#e5e7eb;margin:0 0 20px;font-size:1.2rem}.players-list{display:flex;flex-direction:column;gap:2px}.players-header{display:grid;grid-template-columns:2fr 80px 120px 80px 60px;gap:10px;padding:10px 15px;background:#ffffff1a;border-radius:6px 6px 0 0;font-weight:600;font-size:14px;color:#9ca3af;text-transform:uppercase}.player-row{display:grid;grid-template-columns:2fr 80px 120px 80px 60px;gap:10px;padding:12px 15px;background:#0000004d;border:1px solid rgba(255,255,255,.05);transition:all .2s}.player-row:hover{background:#0006;border-color:#ffffff1a}.player-row.empty-slot{background:#ffffff05;border-style:dashed;opacity:.7}.col-player{display:flex;align-items:center;color:#e5e7eb}.col-team,.col-playstyle,.col-ready,.col-actions{display:flex;align-items:center;justify-content:center}.player-name{font-weight:500}.player-name.bot{color:#60a5fa}.slot-type-selector{width:100%;padding:6px 10px;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:4px;color:#e5e7eb;cursor:pointer;transition:all .2s}.slot-type-selector:hover{background:#ffffff26;border-color:#ffffff4d}.slot-type-selector:focus{outline:none;border-color:#60a5fa}.team-button{padding:6px 12px;border:none;border-radius:4px;cursor:pointer;font-weight:600;font-size:13px;transition:all .2s;min-width:60px}.team-button.team-a{background:#4a9eff33;color:#60a5fa;border:1px solid #60a5fa}.team-button.team-a:hover:not(:disabled){background:#4a9eff4d}.team-button.team-b{background:#a855f733;color:#a855f7;border:1px solid #a855f7}.team-button.team-b:hover:not(:disabled){background:#a855f74d}.team-button:disabled{opacity:.5;cursor:not-allowed}.team-label{padding:6px 12px;border-radius:4px;font-weight:600;font-size:13px;min-width:60px;text-align:center}.team-label.team-a{background:#4a9eff1a;color:#60a5fa}.team-label.team-b{background:#a855f71a;color:#a855f7}.team-label:not(.team-a):not(.team-b){background:#ffffff0d;color:#9ca3af}.playstyle-select{width:100%;padding:6px 10px;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:4px;color:#e5e7eb;cursor:pointer;transition:all .2s}.playstyle-select:hover{background:#ffffff26;border-color:#ffffff4d}.playstyle-select:focus{outline:none;border-color:#60a5fa}.playstyle-select:disabled{opacity:.5;cursor:not-allowed}.playstyle-label{color:#9ca3af;font-size:13px}.ready-indicator{font-size:18px;font-weight:700}.ready-indicator.ready{color:#10b981}.ready-indicator.not-ready{color:#6b7280}.remove-button{width:30px;height:30px;padding:0;background:#ef444433;color:#ef4444;border:1px solid #ef4444;border-radius:4px;cursor:pointer;font-size:20px;line-height:1;transition:all .2s}.remove-button:hover:not(:disabled){background:#ef44444d}.remove-button:disabled{opacity:.5;cursor:not-allowed}.empty-slot-text{color:#6b7280;font-style:italic}.game-settings{background:#ffffff0d;border-radius:12px;padding:20px;border:1px solid rgba(255,255,255,.1)}.game-settings h3{color:#e5e7eb;margin:0 0 15px;font-size:1.2rem}.game-settings p{color:#9ca3af;margin:8px 0}.lobby-footer{text-align:center}.join-section{margin-bottom:20px}.join-section p{color:#e5e7eb;margin-bottom:15px;font-size:16px}.team-buttons{display:flex;gap:20px;justify-content:center}.join-team-btn{padding:12px 30px;border:none;border-radius:6px;cursor:pointer;font-weight:700;font-size:16px;transition:all .3s}.join-team-btn.team-a{background:linear-gradient(135deg,#4a9eff,#2563eb);color:#fff}.join-team-btn.team-a:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 5px 15px #4a9eff66}.join-team-btn.team-b{background:linear-gradient(135deg,#a855f7,#7c3aed);color:#fff}.join-team-btn.team-b:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 5px 15px #a855f766}.join-team-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.ready-button{padding:15px 50px;border:none;border-radius:8px;cursor:pointer;font-weight:700;font-size:18px;transition:all .3s;margin-bottom:20px}.ready-button.not-ready{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.ready-button.ready{background:linear-gradient(135deg,#6b7280,#4b5563);color:#fff}.ready-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 5px 15px #10b98166}.ready-button:disabled{opacity:.5;cursor:not-allowed;transform:none}.host-controls{margin-top:20px}.start-button{padding:18px 60px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:700;font-size:20px;transition:all .3s}.start-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 7px 20px #667eea80}.start-button:disabled{background:linear-gradient(135deg,#9ca3af,#6b7280);cursor:not-allowed;transform:none}.start-hint{color:#ef4444;margin-top:10px;font-size:14px}.waiting-hint{color:#9ca3af;font-style:italic;font-size:16px;margin-top:10px}@media (max-height: 500px){.lobby-room{min-width:unset;max-width:100%;width:100%;padding:8px;margin:0;max-height:100vh;overflow-y:auto}.lobby-room .lobby-header{display:none}.lobby-content{grid-template-columns:3fr 1fr;gap:10px;margin-bottom:8px}.players-panel{padding:8px}.players-panel h3{font-size:.9rem;margin-bottom:8px}.players-header{grid-template-columns:2fr 65px 100px 60px 45px;gap:4px;padding:4px 6px;font-size:10px}.player-row{grid-template-columns:2fr 65px 100px 60px 45px;gap:4px;padding:6px}.col-player{font-size:12px}.player-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.team-button,.team-label{min-width:48px;padding:4px 6px;font-size:9px}.playstyle-select,.slot-type-selector{font-size:10px;padding:2px 4px}.playstyle-label{font-size:9px}.ready-indicator{font-size:12px}.remove-button{width:22px;height:22px;font-size:14px}.game-settings{padding:8px}.game-settings h3{font-size:.85rem;margin-bottom:6px}.game-settings p{font-size:11px;margin:4px 0}.waiting-hint{text-align:center;margin-bottom:8px}.lobby-footer{padding:6px 0;margin-top:8px;display:grid;grid-template-columns:1fr 1fr;grid-template-rows:auto auto;gap:10px;align-items:start}.ready-button{width:100%;padding:8px 20px;font-size:14px;margin-bottom:0;height:40px;display:flex;align-items:center;justify-content:center;grid-row:1;grid-column:1}.host-controls{margin-top:0;width:100%;display:contents}.start-button{width:100%;padding:8px 25px;font-size:14px;height:40px;display:flex;align-items:center;justify-content:center;grid-row:1;grid-column:2;margin-top:0!important}.start-hint{grid-row:2;grid-column:1 / -1}.start-hint,.waiting-hint{font-size:10px;margin-top:4px}}.main-menu{display:flex;flex-direction:column;gap:30px;align-items:center;padding:60px;background:#000000b3;border-radius:16px;box-shadow:0 15px 40px #00000080;border:1px solid rgba(255,255,255,.1);min-width:800px;max-width:1400px;margin:0 auto}.main-menu h1{color:#fff;font-size:3rem;margin-bottom:2rem;text-shadow:2px 2px 4px rgba(0,0,0,.3);background:linear-gradient(90deg,#60a5fa,#a78bfa);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.btn-create,.btn-join,.btn-matchmaking,.btn-how-to-play,.btn-encyclopedia{width:300px;height:80px;font-size:28px;font-weight:700;border:none;border-radius:12px;cursor:pointer;transition:all .3s;text-transform:uppercase;letter-spacing:1px}.btn-create{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 5px 15px #667eea66}.btn-create:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 7px 20px #667eea80}.btn-join{background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff;box-shadow:0 5px 15px #f093fb66}.btn-join:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 7px 20px #f093fb80}.btn-matchmaking{background:linear-gradient(135deg,#4facfe,#00f2fe);color:#fff;box-shadow:0 5px 15px #4facfe66}.btn-matchmaking:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 7px 20px #4facfe80}.btn-how-to-play{background:linear-gradient(135deg,#10b981,#059669);color:#fff;box-shadow:0 5px 15px #10b98166}.btn-how-to-play:hover{transform:translateY(-2px);box-shadow:0 7px 20px #10b98180}.btn-encyclopedia{background:linear-gradient(135deg,#8b5cf6,#6366f1);color:#fff;box-shadow:0 5px 15px #8b5cf666}.btn-encyclopedia:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 7px 20px #8b5cf680}.btn-create:disabled,.btn-join:disabled,.btn-matchmaking:disabled,.btn-encyclopedia:disabled{opacity:.5;cursor:not-allowed;transform:none}.back-button{background:#ffffff1a;color:#9ca3af;border:1px solid rgba(255,255,255,.2);padding:10px 20px;border-radius:6px;cursor:pointer;margin-bottom:20px;font-size:16px;transition:all .2s}.no-games{text-align:center;color:#9ca3af;padding:40px;font-size:18px}.games-container{display:flex;flex-direction:column;gap:15px;width:100%}.game-item{border:2px solid rgba(255,255,255,.1);border-radius:10px;padding:20px;background:#ffffff0d;transition:all .3s;display:flex;justify-content:space-between;align-items:center}.game-item:hover{border-color:#60a5fa;box-shadow:0 4px 12px #60a5fa33;background:#ffffff14}.game-info{display:flex;flex-direction:column;gap:5px}.game-info h3{color:#e5e7eb;margin:0}.player-count{color:#9ca3af;font-size:14px}.team-counts{display:flex;gap:10px;font-size:14px;color:#9ca3af}.game-age{font-size:12px;color:#6b7280;font-style:italic}.view-game-btn{padding:10px 24px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:6px;cursor:pointer;font-weight:700;transition:all .3s}.view-game-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #667eea66}.view-game-btn:disabled{opacity:.5;cursor:not-allowed}.error-message{background:#ef44441a;color:#ef4444;padding:12px 20px;border-radius:6px;border:1px solid rgba(239,68,68,.3);margin-bottom:20px;text-align:center}@media (max-height: 500px){.main-menu{min-width:unset;max-width:100%;width:100%;padding:80px 15px 15px;margin:0;gap:15px}.main-menu h1{font-size:1.75rem;margin-bottom:.75rem}.btn-create,.btn-join,.btn-matchmaking,.btn-how-to-play,.btn-encyclopedia{width:100%;max-width:300px;height:50px;font-size:18px}}.matchmaking-container{max-width:1200px;margin:0 auto;padding:2rem;color:#fff}.matchmaking-container h1{text-align:center;font-size:2.5rem;margin-bottom:1rem;text-shadow:2px 2px 4px rgba(0,0,0,.5)}.matchmaking-description{text-align:center;font-size:1.2rem;margin-bottom:2rem;color:#ccc}.game-modes{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-bottom:2rem}.game-mode-button{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:12px;padding:2rem;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 6px #0000001a}.game-mode-button:hover{transform:translateY(-4px);box-shadow:0 8px 12px #0003}.game-mode-button:disabled{opacity:.5;cursor:not-allowed}.mode-title{font-size:2rem;font-weight:700;margin-bottom:.5rem;color:#fff}.mode-description{font-size:1rem;color:#ffffffe6}.ready-check-banner{background:linear-gradient(135deg,#f093fb,#f5576c);border-radius:12px;padding:2rem;margin-bottom:2rem;text-align:center;animation:pulse 2s infinite}@keyframes pulse{0%{transform:scale(1)}50%{transform:scale(1.02)}to{transform:scale(1)}}.ready-check-banner h2{font-size:2rem;margin-bottom:1rem}.ready-timer{font-size:1.5rem;font-weight:700;margin-bottom:1rem;color:#fff}.ready-button{background:#4caf50;color:#fff;border:none;border-radius:8px;padding:1rem 2rem;font-size:1.2rem;font-weight:700;cursor:pointer;transition:background .3s;box-shadow:0 4px 6px #0003}.ready-button:hover{background:#45a049}.ready-status{font-size:1.2rem;color:#4caf50;font-weight:700}.queue-status{text-align:center;margin-bottom:2rem;padding:1.5rem;background:#ffffff1a;border-radius:8px}.queue-status p{font-size:1.3rem;margin-bottom:.5rem}.queue-progress{font-size:1.5rem;font-weight:700;color:#4caf50}.player-slots{margin-bottom:2rem}.teams-container{display:grid;grid-template-columns:1fr 1fr;gap:2rem}.team{background:#ffffff0d;border-radius:12px;padding:1.5rem}.team h3{text-align:center;margin-bottom:1rem;font-size:1.5rem;color:#fff}.player-slot{background:#ffffff1a;border-radius:8px;padding:1rem;margin-bottom:.5rem;display:flex;justify-content:space-between;align-items:center;transition:background .3s}.player-slot.filled{background:#4caf5033;border:1px solid rgba(76,175,80,.5)}.player-slot.empty{background:#ffffff0d;border:1px dashed rgba(255,255,255,.2)}.player-name{font-weight:700;color:#fff}.empty-slot{color:#ffffff80;font-style:italic}.ready-indicator{font-size:1.2rem;font-weight:700}.ready-indicator.ready{color:#4caf50}.ready-indicator.waiting{color:#ffffff80}.leave-queue-button{display:block;margin:0 auto;background:#f44336;color:#fff;border:none;border-radius:8px;padding:.75rem 1.5rem;font-size:1rem;cursor:pointer;transition:background .3s}.leave-queue-button:hover{background:#d32f2f}.starting-message{text-align:center;font-size:1.5rem;font-weight:700;color:#4caf50;animation:fadeInOut 1.5s infinite}@keyframes fadeInOut{0%,to{opacity:.5}50%{opacity:1}}.back-button{display:block;margin:2rem auto 0;background:#ffffff1a;color:#fff;border:1px solid rgba(255,255,255,.3);border-radius:8px;padding:.75rem 1.5rem;font-size:1rem;cursor:pointer;transition:all .3s}.back-button:hover{background:#fff3;transform:translateY(-2px)}.error-message{background:#f4433633;border:1px solid #f44336;border-radius:8px;padding:1rem;margin-bottom:1rem;text-align:center;color:#ff6b6b}.game-hud{position:fixed;inset:0;pointer-events:none;z-index:100;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}.game-hud>*{pointer-events:auto}.hud-top-bar{position:absolute;top:0;left:0;right:0;display:flex;justify-content:space-between;align-items:stretch;background:linear-gradient(to bottom,#000000f2,#000000d9);border-bottom:2px solid #333;padding:0;min-height:120px;height:auto}.team-panel-top{flex:2;padding:10px 20px;color:#fff;display:flex;flex-direction:column;gap:8px}.team-panel-top.team-a{background:linear-gradient(135deg,rgba(74,158,255,.2),transparent);border-right:1px solid rgba(74,158,255,.3)}.team-panel-top.team-b{background:linear-gradient(-135deg,rgba(168,85,247,.2),transparent);border-left:1px solid rgba(168,85,247,.3)}.team-panel-top.player-team{box-shadow:inset 0 0 20px #ffffff1a}.team-panel-top h3{margin:0;font-size:18px;text-align:center;font-weight:700;text-shadow:2px 2px 4px rgba(0,0,0,.8)}.team-panel-top.team-a h3{color:#4a9eff}.team-panel-top.team-b h3{color:#a855f7}.team-income{text-align:center;color:#4ade80;font-size:12px;font-weight:600;margin:-4px 0 4px;text-shadow:1px 1px 2px rgba(0,0,0,.8)}.team-resources{display:flex;flex-direction:column;gap:6px;flex:1}.team-resources.players-2{display:grid;grid-template-columns:1fr 1fr;gap:8px}.team-resources.players-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:6px}.team-resources.players-4{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:auto auto;gap:8px}.team-resources.players-1{display:flex;flex-direction:column;gap:6px}.player-resources{position:relative;padding:4px 8px;background:#ffffff0d;border-radius:4px;border:1px solid rgba(255,255,255,.1);display:flex;flex-direction:column;gap:4px;min-width:0}.player-resources.current-player{background:#4ade8040;border-color:#4ade80bf;box-shadow:0 0 12px #4ade8080}.player-disconnected-overlay{position:absolute;inset:0;background:#808080b3;border-radius:4px;display:flex;align-items:center;justify-content:center;z-index:10}.disconnect-icon{font-size:48px;color:#ff6b6b;text-shadow:0 0 10px rgba(255,107,107,.8),2px 2px 4px rgba(0,0,0,.8);animation:pulse-disconnect 2s ease-in-out infinite}@keyframes pulse-disconnect{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.1)}}@keyframes pulse-green{0%,to{box-shadow:0 0 12px #4ade8080;border-color:#4ade80bf}50%{box-shadow:0 0 20px #4ade80b3;border-color:#4ade80e6}}.player-header{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:6px}.player-addr{font-size:11px;color:#bbb;font-family:monospace;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.player-level{color:#60a5fa;font-size:11px;font-weight:700;text-align:center}.player-stats{display:flex;gap:6px;align-items:center;justify-content:flex-end;font-size:11px}.player-stats .gold{color:#fc0;font-weight:700}.resource-row{display:flex;gap:8px;align-items:center;font-size:13px}.player-units{display:flex;flex-wrap:nowrap;gap:3px;min-height:24px;max-height:24px;overflow-x:hidden;overflow-y:hidden;cursor:pointer;position:relative;width:100%}.player-units:hover{overflow-x:auto}.player-units::-webkit-scrollbar{height:2px}.player-units::-webkit-scrollbar-track{background:#ffffff0d}.player-units::-webkit-scrollbar-thumb{background:#fff3;border-radius:1px}.player-units .unit-icon{width:24px;height:24px;background-size:20px 20px;background-position:center;background-repeat:no-repeat;border:1px solid;image-rendering:-moz-crisp-edges;image-rendering:-webkit-crisp-edges;image-rendering:crisp-edges;flex-shrink:0;box-sizing:border-box;cursor:pointer;will-change:auto;transform:translateZ(0);backface-visibility:hidden}.player-units .unit-icon.tower-icon{border-radius:2px}.player-units .unit-icon.minion-icon{border-radius:50%}.team-resources.players-2 .player-stats,.team-resources.players-3 .player-stats,.team-resources.players-4 .player-stats{gap:4px;font-size:10px}.team-resources.players-3 .player-resources{padding:3px 6px}.team-resources.players-3 .player-addr{font-size:11px}.team-resources.players-3 .player-stats{gap:4px;font-size:11px}.team-resources.players-3 .player-units .unit-icon{width:20px;height:20px}.resource-row .gold{color:#fc0;font-weight:700}.resource-row .level{color:#60a5fa;font-size:11px}.game-info-center{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:10px 20px;background:none}.wave-info{text-align:center;color:#fff}.wave-number{font-size:24px;font-weight:700;text-shadow:2px 2px 4px rgba(0,0,0,.8)}.next-wave{font-size:14px;color:#ccc;margin-top:4px}.view-indicator{background:#ffffff1a;padding:6px 12px;border-radius:20px;border:1px solid rgba(255,255,255,.2)}.view-indicator.clickable{cursor:pointer;transition:all .2s ease}.view-indicator.clickable:hover{background:#ffffff26;border-color:#ffffff4d;transform:scale(1.05)}.view-indicator.clickable:active{transform:scale(.98)}.view-indicator span{font-size:14px;font-weight:700;text-shadow:1px 1px 2px rgba(0,0,0,.8);pointer-events:none}.view-indicator .view-a{color:#4a9eff}.view-indicator .view-b{color:#a855f7}.level-up-dropdown{position:absolute;top:-100px;left:50%;transform:translate(-50%);transition:top .4s cubic-bezier(.68,-.55,.265,1.55),opacity .3s ease;z-index:200;opacity:0;pointer-events:none}.level-up-dropdown.show{top:120px;opacity:1;pointer-events:auto}.level-up-dropdown.hide{top:-100px;opacity:0;pointer-events:none}.level-up-button-large{background:linear-gradient(135deg,#10b981e6,#059669e6);backdrop-filter:blur(10px);color:#10f981;border:1px solid rgba(16,185,129,.5);padding:10px 24px;font-size:14px;font-weight:700;border-radius:8px;cursor:pointer;transition:all .3s ease;box-shadow:inset 0 1px #ffffff1a,0 4px 12px #10b98133,0 0 20px #10b9811a;display:flex;align-items:center;gap:12px;text-transform:uppercase;letter-spacing:1px;animation:glow 2s ease-in-out infinite}.level-up-button-large:hover:not(:disabled){background:linear-gradient(135deg,#10b981,#059669);border-color:#10b981cc;box-shadow:inset 0 1px #fff3,0 4px 20px #10b98166,0 0 30px #10b98133;transform:translateY(-2px);color:#3bff9f}.level-up-button-large:active:not(:disabled){transform:translateY(0)}.level-up-button-large:disabled{background:linear-gradient(135deg,#374151e6,#1f2937e6);border-color:#37415180;color:#6b7280;cursor:not-allowed;opacity:.7;animation:none;box-shadow:none}.level-up-text{font-size:14px;font-weight:700;text-shadow:0 0 10px rgba(16,185,129,.5)}.level-up-cost{font-size:12px;opacity:.9;color:#a7f3d0}@keyframes glow{0%,to{box-shadow:inset 0 1px #ffffff1a,0 4px 12px #10b98133,0 0 20px #10b9811a}50%{box-shadow:inset 0 1px #ffffff1a,0 4px 16px #10b9814d,0 0 30px #10b98133}}.hud-bottom{position:absolute;bottom:20px;left:50%;transform:translate(-50%);background:#000000d9;padding:10px 20px;border-radius:10px;color:#fff;border:1px solid #333}.action-bar{display:flex;gap:15px;align-items:center}.action-item{display:flex;align-items:center;gap:8px;padding:5px 10px;background:#ffffff1a;border-radius:5px}.action-item .action-type{color:#4a9eff;font-weight:700;font-size:14px}.action-item .action-id{color:#ccc;font-size:12px}.processing-indicator{display:flex;align-items:center;gap:8px}.processing-spinner{width:16px;height:16px;border:2px solid rgba(74,158,255,.3);border-top-color:#4a9eff;border-radius:50%;animation:spin 1s linear infinite}.castle-status{margin-bottom:10px}.castle-label{font-size:12px;color:#ccc;margin-bottom:3px}.health-bar{height:20px;background:#ffffff1a;border-radius:10px;overflow:hidden;position:relative}.health-fill{height:100%;transition:width .3s ease}.health-fill.team-a{background:linear-gradient(90deg,#4a9eff,#2563eb)}.health-fill.team-b{background:linear-gradient(90deg,#a855f7,#7c3aed)}.health-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:12px;font-weight:700;color:#fff;text-shadow:1px 1px 2px rgba(0,0,0,.8)}.castle-status.destroyed{opacity:.5}.castle-status.destroyed .health-fill{background:#dc2626}.game-over-overlay{position:fixed;inset:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:10000;animation:fadeIn .5s ease-in}.game-over-content{text-align:center;padding:40px;background:linear-gradient(135deg,#1a1a2e,#0f0f23);border-radius:20px;border:3px solid #4a9eff;box-shadow:0 0 50px #4a9eff80}.game-over-content h1{font-size:48px;margin:0 0 20px;color:#fff;text-shadow:2px 2px 4px rgba(0,0,0,.8)}.game-over-content p{font-size:24px;color:#ccc;margin:0}.return-home-button{margin-top:30px;padding:16px 40px;font-size:18px;font-weight:600;color:#fff;background:linear-gradient(135deg,#4a90e2,#357abd);border:2px solid rgba(255,255,255,.2);border-radius:8px;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #4a90e24d;text-transform:uppercase;letter-spacing:1px}.return-home-button:hover{background:linear-gradient(135deg,#5aa0f2,#4680cd);box-shadow:0 6px 20px #4a90e280;transform:translateY(-2px);border-color:#ffffff4d}.return-home-button:active{transform:translateY(0);box-shadow:0 2px 10px #4a90e266}@media (max-width: 1200px){.team-panel-top{max-width:350px}.resource-row{font-size:12px}}@media (max-width: 900px){.hud-top-bar{flex-direction:column;min-height:auto}.team-panel-top{max-width:none}.game-info-center{order:-1;padding:10px;width:100%;flex-direction:row;justify-content:space-around}}@media (max-width: 768px){.hud-top-bar{min-height:80px;padding:0}.team-panel-top{padding:6px 12px;gap:4px}.team-panel-top h3{font-size:14px}.team-income{font-size:10px;margin:-2px 0 2px}.team-resources,.team-resources.players-2,.team-resources.players-3,.team-resources.players-4{gap:4px}.player-resources{padding:3px 6px;gap:3px}.player-addr,.player-level{font-size:9px}.player-stats{gap:4px;font-size:9px}.resource-row{font-size:11px;gap:6px}.player-units{min-height:20px;max-height:20px;gap:2px}.player-units .unit-icon{width:20px;height:20px;background-size:16px 16px}.team-resources.players-3 .player-resources{padding:2px 4px}.team-resources.players-3 .player-addr,.team-resources.players-3 .player-stats{font-size:9px}.team-resources.players-3 .player-units .unit-icon{width:18px;height:18px}.disconnect-icon{font-size:32px}.game-info-center{gap:6px;padding:6px 12px}.wave-number{font-size:18px}.next-wave{font-size:12px}.view-indicator{padding:4px 10px}.view-indicator span{font-size:12px}.level-up-dropdown.show{top:80px}.level-up-button-large{padding:8px 16px;font-size:12px;gap:8px}.level-up-text{font-size:12px}.level-up-cost{font-size:10px}}@media (max-height: 500px){.hud-top-bar{display:flex!important;flex-direction:row!important;min-height:60px;padding:0;justify-content:flex-end!important;background:transparent!important;border-bottom:none!important}.team-panel-top,.view-indicator{display:none!important}.game-info-center{order:0!important;flex:0 0 auto!important;flex-direction:column!important;width:auto!important;padding:8px 12px!important;background:#000000e6!important;border-radius:8px;margin:4px 4px 0 0}.team-panel-top h3{font-size:12px}.team-income{font-size:9px;margin:-2px 0 2px}.team-resources,.team-resources.players-2,.team-resources.players-3,.team-resources.players-4{gap:3px}.player-resources{padding:2px 4px;gap:2px}.player-addr,.player-level{font-size:8px}.player-stats{gap:3px;font-size:8px}.resource-row{font-size:10px;gap:4px}.player-units{min-height:16px;max-height:16px;gap:2px}.player-units .unit-icon{width:16px;height:16px;background-size:14px 14px;border-width:1px}.team-resources.players-3 .player-resources{padding:2px 3px}.team-resources.players-3 .player-addr,.team-resources.players-3 .player-stats{font-size:8px}.team-resources.players-3 .player-units .unit-icon{width:14px;height:14px}.disconnect-icon{font-size:24px}.game-info-center{gap:4px;padding:4px 8px}.wave-number{font-size:16px}.next-wave{font-size:10px}.view-indicator{padding:3px 8px}.view-indicator span{font-size:11px}.level-up-dropdown.show{top:60px}.level-up-button-large{padding:6px 12px;font-size:11px;gap:6px}.level-up-text{font-size:11px}.level-up-cost{font-size:9px}}.bottom-bar{position:fixed;bottom:0;left:0;right:0;background:linear-gradient(to top,#000000f2,#000000d9);border-top:2px solid #333;z-index:100;pointer-events:auto}.mobile-deselect-btn{display:none;position:absolute;bottom:12px;left:12px;width:50px;height:50px;background:#ef4444e6;color:#fff;border:2px solid #ef4444;border-radius:8px;font-size:24px;font-weight:700;cursor:pointer;transition:all .2s;z-index:101;padding:0;line-height:1}.mobile-deselect-btn:hover{background:#ef4444;transform:scale(1.05)}.mobile-deselect-btn:active{transform:scale(.95)}.mobile-switch-view-btn{display:none;position:absolute;bottom:12px;right:12px;width:50px;height:50px;background:#ffffff1a;border:2px solid rgba(255,255,255,.2);border-radius:8px;font-size:24px;font-weight:700;cursor:pointer;transition:all .2s;z-index:101;padding:0;line-height:1}.mobile-switch-view-btn.view-a{color:#4a9eff;border-color:#4a9eff;background:#4a9eff26}.mobile-switch-view-btn.view-b{color:#a855f7;border-color:#a855f7;background:#a855f726}.mobile-switch-view-btn:hover{background:#fff3;transform:scale(1.05)}.mobile-switch-view-btn:active{transform:scale(.95)}.bottom-bar.spectator-mode{background:linear-gradient(to top,#282828f2,#1e1e1ed9);border-top-color:#555}.spectator-message{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:20px;width:100%}.spectator-label{font-size:20px;font-weight:700;color:#fff;text-shadow:2px 2px 4px rgba(0,0,0,.8);letter-spacing:2px}.spectator-hint{font-size:14px;color:#aaa;font-style:italic}.bottom-bar-content{display:flex;justify-content:center;align-items:stretch;padding:10px 20px;gap:20px;min-height:80px}.minion-section,.tower-section{flex:0 0 auto;display:flex}.minion-section{justify-content:flex-end;flex:1;max-width:500px}.tower-section{justify-content:flex-start;flex:1;max-width:500px}.unit-group{background:linear-gradient(135deg,rgba(74,158,255,.1),transparent);border-radius:8px;padding:8px 12px;display:flex;flex-direction:column;gap:8px}.tower-section .unit-group{background:linear-gradient(-135deg,rgba(168,85,247,.1),transparent)}.section-title{font-size:12px;font-weight:700;color:#888;letter-spacing:1px;text-shadow:1px 1px 2px rgba(0,0,0,.8)}.section-title.team-a{color:#4a9eff}.section-title.team-b{color:#a855f7}.unit-icons{display:flex;gap:8px;align-items:center;flex-wrap:nowrap;overflow-x:auto;padding:4px 0}.unit-icons::-webkit-scrollbar{height:4px}.unit-icons::-webkit-scrollbar-track{background:#ffffff0d;border-radius:2px}.unit-icons::-webkit-scrollbar-thumb{background:#fff3;border-radius:2px}.unit-icon{position:relative;width:48px;height:48px;padding:0;background:#0009;border:2px solid rgba(255,255,255,.2);border-radius:6px;cursor:pointer;transition:all .2s ease;flex-shrink:0;display:flex;align-items:center;justify-content:center}.unit-icons .unit-icon:hover{background:#ffffff1a;border-color:#fff6;transform:translateY(-2px);box-shadow:0 4px 8px #0006}.unit-icons .unit-icon.selected{background:#ffd70033;border-color:gold;box-shadow:0 0 12px #ffd70066}.unit-icons .unit-icon.disabled{opacity:.4;cursor:pointer}.unit-icons .unit-icon img{image-rendering:pixelated;image-rendering:-moz-crisp-edges;image-rendering:crisp-edges;width:32px;height:32px}.unit-cost{position:absolute;bottom:-2px;right:-2px;background:#000000e6;color:gold;font-size:10px;font-weight:700;padding:2px 4px;border-radius:4px;border:1px solid rgba(255,215,0,.5);min-width:18px;text-align:center}.no-units{color:#666;font-style:italic;font-size:12px;padding:10px}.center-section{flex:0 0 300px;width:300px;display:flex;flex-direction:column;gap:12px;align-items:center;justify-content:center;padding:8px 20px}.gold-display{font-size:28px;font-weight:700;color:gold;text-shadow:0 0 10px rgba(255,215,0,.5),2px 2px 4px rgba(0,0,0,.8);letter-spacing:1px}.level-up-button-bottom{background:#4ade8040;color:#4ade80;border:2px solid rgba(74,222,128,.75);padding:8px 20px;font-size:14px;font-weight:400;border-radius:6px;cursor:pointer;transition:all .2s ease;text-transform:uppercase;letter-spacing:.5px;box-shadow:0 0 12px #4ade8080}.level-up-button-bottom:not(:disabled){animation:pulse-level-up 2s ease-in-out infinite}.level-up-button-bottom:hover:not(:disabled){background:#4ade8059;border-color:#4ade80e6;transform:translateY(-1px);box-shadow:0 0 20px #4ade80b3}.level-up-button-bottom:disabled{background:linear-gradient(135deg,#4b5563e6,#374151e6);border-color:#4b556399;color:#9ca3af;cursor:not-allowed;opacity:.6}@keyframes pulse-level-up{0%,to{box-shadow:0 0 12px #4ade8080;border-color:#4ade80bf}50%{box-shadow:0 0 20px #4ade80b3;border-color:#4ade80e6}}.action-queue-section{display:none}.action-queue-section .section-title{color:gold;text-align:center}.action-queue-display{position:relative;flex:1;display:flex;align-items:center;justify-content:center}.queue-empty{color:#666;font-size:11px;font-style:italic}.queue-items{display:flex;gap:6px;align-items:center}.queue-item{width:28px;height:28px;background:#0009;border:1px solid rgba(255,255,255,.2);border-radius:4px;display:flex;align-items:center;justify-content:center;position:relative;font-size:12px;transition:all .2s ease}.queue-item.processing{border-color:gold;background:#ffd7001a;animation:pulse 1s infinite}.queue-item.complete{border-color:#4ade80;background:#4ade801a;color:#4ade80}.queue-item.failed{border-color:#ef4444;background:#ef44441a;color:#ef4444}.queue-number{font-size:10px;color:#888;position:absolute;top:-6px;left:50%;transform:translate(-50%);background:#000c;padding:0 3px;border-radius:2px}.queue-status{font-size:14px}.queue-status.hidden{display:none}.queue-icon{width:20px;height:20px;image-rendering:pixelated;image-rendering:-moz-crisp-edges;image-rendering:crisp-edges}.queue-more{color:#666;font-size:11px;padding:0 4px}.processing-indicator{position:absolute;bottom:2px;left:50%;transform:translate(-50%);width:60%;height:2px;background:linear-gradient(90deg,transparent,#ffd700,transparent);animation:slide 1.5s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}@keyframes slide{0%{transform:translate(-100%)}to{transform:translate(100%)}}@media (max-width: 1200px){.bottom-bar-content{padding:8px 12px}.unit-icon{width:40px;height:40px}.unit-icon img{width:28px;height:28px}}@media (max-width: 768px){.bottom-bar-content{padding:6px 10px;gap:12px;min-height:60px}.spectator-message{padding:12px}.spectator-label{font-size:16px}.spectator-hint{font-size:12px}.minion-section,.tower-section{max-width:400px}.unit-group{padding:6px 8px;gap:6px}.section-title{font-size:10px}.unit-icons{gap:6px;padding:3px 0}.unit-icon{width:36px;height:36px;border-width:1.5px}.unit-icon img{width:24px;height:24px}.unit-cost{font-size:9px;padding:1px 3px;bottom:-1px;right:-1px;min-width:16px}.center-section{flex:0 0 200px;width:200px;gap:8px;padding:6px 12px}.gold-display{font-size:22px}.level-up-button-bottom{padding:6px 16px;font-size:12px}.no-units{font-size:10px;padding:6px}}@media (max-width: 480px){.bottom-bar-content{padding:4px 8px;gap:8px;min-height:50px}.unit-icon{width:32px;height:32px}.unit-icon img{width:20px;height:20px}.unit-cost{font-size:8px;padding:1px 2px;min-width:14px}.center-section{flex:0 0 150px;width:150px;gap:6px;padding:4px 8px}.gold-display{font-size:18px}.level-up-button-bottom{padding:5px 12px;font-size:11px}}@media (max-height: 500px){.bottom-bar{background:transparent!important;border-top:none!important}.mobile-deselect-btn{display:block;width:40px;height:40px;font-size:24px;bottom:auto;top:0;left:22px}.mobile-switch-view-btn{display:block;width:40px;height:40px;font-size:24px;bottom:auto;top:0;right:22px}.bottom-bar-content{padding:2px 6px;gap:8px;min-height:40px}.spectator-message{padding:8px}.spectator-label{font-size:12px}.spectator-hint{font-size:10px}.minion-section,.tower-section{max-width:350px}.unit-group{padding:0;gap:0;background:none}.section-title{display:none}.unit-icons{gap:4px;padding:0}.unit-icon{width:40px!important;height:40px!important;border-width:1.5px;border-radius:4px}.unit-icon img{width:32px!important;height:32px!important}.unit-cost{font-size:8px;padding:1px 2px;bottom:-1px;right:-1px;min-width:14px}.center-section{flex:0 0 120px;width:120px;gap:2px;padding:2px 4px}.gold-display{font-size:16px}.level-up-button-bottom{padding:3px 8px;font-size:9px;background:#1a4d2cb3!important;border-color:#4ade80e6!important}.no-units{font-size:9px;padding:4px}}.info-panel{position:fixed;bottom:120px;right:20px;width:320px;background:linear-gradient(to bottom,#000000f2,#000000e6);border:2px solid #333;border-radius:8px;color:#fff;z-index:99;box-shadow:0 4px 12px #00000080;animation:slideIn .2s ease-out}@keyframes slideIn{0%{transform:translate(20px);opacity:0}to{transform:translate(0);opacity:1}}.info-content{padding:12px}.info-header{display:flex;gap:12px;margin-bottom:12px;padding-bottom:10px;border-bottom:1px solid rgba(255,255,255,.2)}.info-icon{width:48px;height:48px;image-rendering:pixelated;image-rendering:-moz-crisp-edges;image-rendering:crisp-edges;border:2px solid rgba(255,255,255,.2);border-radius:4px;background:#00000080;padding:4px}.info-title{flex:1}.info-title h3{margin:0 0 4px;font-size:18px;font-weight:700;text-shadow:2px 2px 4px rgba(0,0,0,.8)}.info-title h3.team-a{color:#4a9eff}.info-title h3.team-b{color:#a855f7}.info-type{margin:0;font-size:12px;color:#888;text-transform:uppercase;letter-spacing:1px}.info-stats{display:flex;flex-direction:column;gap:6px}.stat-row{display:flex;justify-content:space-between;align-items:center;padding:4px 8px;font-size:13px}.stat-label{color:#aaa;font-weight:500}.stat-value{color:#fff;font-weight:700;text-align:right;white-space:nowrap;min-width:120px}.stat-value.ready{color:#4ade80;text-shadow:0 0 4px rgba(74,222,128,.5)}.stat-value.cooldown{color:#fbbf24;font-size:11px}.stat-divider{height:1px;background:#ffffff1a;margin:8px 0}.info-description{margin:8px 0 0;padding:8px;background:#ffffff08;border-radius:4px;font-size:11px;line-height:1.4;color:#bbb;font-style:italic;border-left:2px solid rgba(255,255,255,.2)}.health-bar-container{margin-top:8px;padding:4px 8px;background:#0000004d;border-radius:4px}.health-bar-label{font-size:11px;color:#888;margin-bottom:4px}.health-bar{height:8px;background:#f003;border-radius:4px;overflow:hidden;border:1px solid rgba(255,255,255,.1)}.health-bar-fill{height:100%;background:linear-gradient(90deg,#dc2626,#ef4444);transition:width .3s ease;box-shadow:0 0 4px #ef444480}.health-text{text-align:center;font-size:10px;color:#ccc;margin-top:2px}.upgrade-button{width:100%;padding:10px;margin-top:8px;background:linear-gradient(135deg,#28a745,#20c997);border:2px solid #20c997;border-radius:4px;color:#fff;font-weight:700;font-size:14px;cursor:pointer;transition:all .2s ease;display:flex;flex-direction:column;align-items:center;gap:4px}.upgrade-button:hover:not(.disabled){background:linear-gradient(135deg,#34ce57,#2dd4aa);border-color:#2dd4aa;transform:translateY(-1px);box-shadow:0 4px 8px #20c9974d}.upgrade-button:active:not(.disabled){transform:translateY(0)}.upgrade-button.disabled{background:linear-gradient(135deg,#6c757d,#5a6268);border-color:#5a6268;cursor:not-allowed;opacity:.7}.upgrade-text{font-size:14px;text-transform:uppercase;letter-spacing:.5px}.upgrade-cost{font-size:12px;color:gold;font-weight:400}.sell-button{width:100%;padding:10px;margin-top:8px;background:linear-gradient(135deg,#dc3545,#c82333);border:2px solid #bd2130;border-radius:4px;color:#fff;font-weight:700;font-size:14px;cursor:pointer;transition:all .2s ease;display:flex;flex-direction:column;align-items:center;gap:4px}.sell-button:hover{background:linear-gradient(135deg,#e74c3c,#d32535);border-color:#d32535;transform:translateY(-1px);box-shadow:0 4px 8px #dc35454d}.sell-button:active{transform:translateY(0)}.sell-text{font-size:14px;text-transform:uppercase;letter-spacing:.5px}.sell-value{font-size:12px;color:gold;font-weight:700}@media (max-width: 1400px){.info-panel{width:280px}.info-icon{width:40px;height:40px}.info-title h3{font-size:16px}.stat-row{font-size:12px}}@media (max-height: 500px){.info-panel{inset:auto 4px 48px auto;width:240px;max-width:240px;height:auto;max-height:calc((100vh - 108px) / .7);overflow-y:auto;zoom:.7;z-index:102}.info-content{padding:4px 0}.info-header{gap:4px;margin-bottom:4px;padding-bottom:4px}.info-icon{width:24px;height:24px;padding:2px}.info-title h3{font-size:12px;margin:0 0 2px}.info-type{font-size:9px}.info-stats{gap:1px}.info-panel .stat-row{padding:2px 3px!important;font-size:10px!important}.info-panel .stat-label{font-size:9px!important}.info-panel .stat-value{font-size:10px!important;min-width:60px!important}.stat-divider{margin:3px 0}.info-description{margin:3px 0 0;padding:3px;font-size:8px;line-height:1.2}.health-bar-container{margin-top:3px;padding:2px 3px}.health-bar-label{font-size:8px;margin-bottom:2px}.health-bar{height:5px}.health-text{font-size:7px;margin-top:1px}.upgrade-button{padding:4px;margin-top:3px;gap:1px}.upgrade-text{font-size:10px}.upgrade-cost{font-size:9px}.sell-button{padding:4px;margin-top:3px;gap:1px}.sell-text{font-size:10px}.sell-value{font-size:9px}}.level-up-modal-overlay{position:fixed;inset:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .3s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.level-up-modal{background:linear-gradient(135deg,#1e1e2e,#2d2d44);border:2px solid #4a9eff;border-radius:12px;padding:24px;width:95%;max-width:1600px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #00000080,0 0 40px #4a9eff4d;animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(50px);opacity:0}to{transform:translateY(0);opacity:1}}.level-up-header{text-align:center;margin-bottom:24px;border-bottom:1px solid rgba(74,158,255,.3);padding-bottom:16px}.level-up-header h2{color:#4a9eff;font-size:28px;margin:0 0 8px;text-shadow:0 0 20px rgba(74,158,255,.5)}.team-indicator{color:#888;font-size:14px;text-transform:uppercase;letter-spacing:2px}.level-up-content{display:flex;gap:24px}.selection-area{flex:1;display:flex;flex-direction:column;gap:24px}.unit-selection-section{background:#0000004d;border-radius:8px;padding:16px}.unit-selection-section h3{color:#fff;font-size:18px;margin:0 0 16px}.unit-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:12px}.unit-card{background:#ffffff0d;border:2px solid rgba(255,255,255,.1);border-radius:8px;padding:8px;cursor:pointer;transition:all .2s ease;text-align:center;display:flex;flex-direction:column;align-items:center;gap:4px;position:relative}.minion-card{border-radius:50%;padding:12px;aspect-ratio:1 / 1;justify-content:center}.stage-indicator{position:absolute;top:4px;right:4px;padding:2px 6px;border-radius:4px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;z-index:1}.stage-early .stage-indicator{background:#4caf50cc;color:#fff}.stage-mid .stage-indicator{background:#ff9800cc;color:#fff}.stage-late .stage-indicator{background:#f44336cc;color:#fff}.unit-card:hover{background:#ffffff1a;border-color:#ffffff4d;transform:translateY(-2px)}.unit-card.selected{background:#4a9eff80;border-color:#4a9eff;box-shadow:0 0 20px #4a9eff99}.unit-card.disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.unit-card.darkened{opacity:.25;filter:grayscale(.9) brightness(.6);background:#0006!important}.unit-card.darkened:hover{opacity:.4;filter:grayscale(.7) brightness(.7)}.tower-card.selected{background:#4a9eff80;border-color:#4a9eff;box-shadow:0 0 25px #4a9effb3}.minion-card.selected{background:#a855f780;border-color:#a855f7;box-shadow:0 0 25px #a855f7b3}.unit-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center}.unit-icon img{width:100%;height:100%;object-fit:contain;image-rendering:pixelated}.minion-card .unit-icon{width:60%;height:60%;max-width:64px;max-height:64px}.minion-card .unit-name{position:relative;font-size:10px;margin-top:4px}.unit-name{color:#fff;font-weight:700;font-size:12px;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;width:100%}.detail-card{width:320px;background:#00000080;border:2px solid rgba(74,158,255,.3);border-radius:12px;padding:20px;display:flex;flex-direction:column;gap:16px}.detail-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;height:100%;min-height:300px;color:#888}.detail-placeholder h3{color:#4a9eff;font-size:18px;margin:0 0 12px}.detail-placeholder p{margin:0;font-size:14px;line-height:1.5}@keyframes slideIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.detail-header{display:flex;align-items:center;gap:16px;padding-bottom:12px;border-bottom:1px solid rgba(74,158,255,.2);margin:0}.detail-icon{width:64px;height:64px;object-fit:contain;image-rendering:pixelated;margin:0}.detail-header h3{color:#4a9eff;font-size:20px;margin:0;flex:1;line-height:1}.detail-description{color:#ccc;font-size:14px;line-height:1.5;padding:12px;background:#0000004d;border-radius:6px}.detail-card .detail-stats{display:flex;flex-direction:column;gap:8px;padding:10px;margin:0}.stat-row{display:flex;justify-content:space-between;padding:8px 12px;background:#ffffff05;border-radius:4px;font-size:14px}.stat-label{color:#888;font-weight:500}.stat-value{color:#fff;font-weight:700}.level-up-footer{display:flex;justify-content:space-between;align-items:center;margin-top:24px;padding-top:16px;border-top:1px solid rgba(74,158,255,.3)}.selection-status{display:flex;gap:24px;color:#aaa;font-size:14px}.selection-status span{padding:4px 12px;background:#0000004d;border-radius:4px}.confirm-button{padding:12px 32px;background:linear-gradient(135deg,#4a9eff,#3d7dd4);color:#fff;border:none;border-radius:6px;font-size:16px;font-weight:700;cursor:pointer;transition:all .2s ease;text-transform:uppercase;letter-spacing:1px}.confirm-button:hover:not(:disabled){background:linear-gradient(135deg,#5aa5ff,#4a8ae0);transform:translateY(-2px);box-shadow:0 10px 20px #4a9eff4d}.confirm-button:disabled{background:#444;color:#888;cursor:not-allowed;opacity:.5}.level-up-modal::-webkit-scrollbar{width:8px}.level-up-modal::-webkit-scrollbar-track{background:#0000004d;border-radius:4px}.level-up-modal::-webkit-scrollbar-thumb{background:#4a9eff80;border-radius:4px}.level-up-modal::-webkit-scrollbar-thumb:hover{background:#4a9effb3}.color-filter-section{display:flex;align-items:center;gap:16px;padding:16px;background:#0000004d;border-radius:8px;margin-bottom:20px}.filter-label{font-size:16px;font-weight:600;color:#fff}.color-filter-buttons{display:flex;gap:8px}.color-filter-btn{width:40px;height:40px;border:2px solid;border-radius:8px;cursor:pointer;font-weight:700;font-size:18px;display:flex;align-items:center;justify-content:center;transition:all .2s;position:relative}.color-filter-btn.none{background:linear-gradient(135deg,#4a4a4a,#2a2a2a);border-color:#666;color:#fff;font-size:12px;padding:0 8px;width:auto;min-width:50px}.color-filter-btn:hover{transform:scale(1.1);box-shadow:0 4px 12px #0000004d}.color-filter-btn.active{transform:scale(1.15);box-shadow:0 0 20px #4a9eff99;border-width:3px}.color-filter-btn.active:after{content:"✓";position:absolute;top:-8px;right:-8px;background:#4a9eff;color:#fff;width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px}.countdown-timer-container{position:relative;width:100%;height:40px;background:#00000080;border:2px solid rgba(74,158,255,.3);border-radius:8px;margin-bottom:20px;overflow:hidden}.countdown-timer-bar{position:absolute;top:0;left:0;height:100%;background:linear-gradient(90deg,#f44336cc,#ff9800cc,#ffc107cc 60%,#4caf50cc);box-shadow:0 0 20px #4a9eff4d}.countdown-timer-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#fff;font-size:18px;font-weight:700;text-shadow:2px 2px 4px rgba(0,0,0,.8);z-index:1;letter-spacing:1px}.bonus-choice-section{margin:24px 0;padding:20px;background:#0000004d;border-radius:8px;border:1px solid rgba(74,158,255,.3)}.bonus-choice-section h3{text-align:center;margin-bottom:16px;color:#4a9eff;font-size:1.2em}.bonus-choice-buttons{display:flex;gap:16px;justify-content:center}.bonus-choice-btn{flex:1;max-width:200px;padding:20px;background:linear-gradient(135deg,#2a2a3e,#1e1e2e);border:2px solid #4a4a6e;border-radius:8px;cursor:pointer;transition:all .3s ease;display:flex;flex-direction:column;align-items:center;gap:8px}.bonus-choice-btn:hover:not(:disabled){border-color:#4a9eff;transform:translateY(-2px);box-shadow:0 4px 12px #4a9eff4d}.bonus-choice-btn.selected{border-color:#4a9eff;background:linear-gradient(135deg,#3a3a5e,#2e2e4e);box-shadow:0 0 20px #4a9eff66}.bonus-choice-btn:disabled{opacity:.5;cursor:not-allowed}.bonus-title{font-size:1.1em;font-weight:700;color:#fff}.bonus-value{font-size:1.5em;font-weight:700;color:#4a9eff}.bonus-description{font-size:.9em;color:#aaa}@media (max-width: 768px){.level-up-modal{padding:12px;width:95%;max-width:100%;max-height:90vh;border-radius:8px;overflow-y:visible}.level-up-header h2{font-size:20px}.team-indicator{font-size:12px}.level-up-content{flex-direction:column;gap:16px}.color-filter-section{padding:12px;gap:12px}.filter-label{font-size:14px}.color-filter-btn{width:32px;height:32px;font-size:14px}.color-filter-btn.none{font-size:10px;min-width:40px}.selection-area{max-height:45vh;overflow-y:auto}.unit-selection-section{padding:12px}.unit-selection-section h3{font-size:16px;margin-bottom:12px}.unit-grid{grid-template-columns:repeat(auto-fill,minmax(70px,1fr));gap:8px}.unit-card{padding:6px}.stage-indicator{font-size:8px;padding:2px 4px}.unit-icon{width:36px;height:36px}.minion-card .unit-icon{width:50%;height:50%;max-width:48px;max-height:48px}.unit-name{font-size:10px}.minion-card .unit-name{font-size:8px}.detail-card{width:100%;padding:12px}.detail-header{gap:12px}.detail-icon{width:48px;height:48px}.detail-header h3{font-size:16px}.detail-description{font-size:12px;padding:8px}.detail-stats{padding:8px;gap:6px}.stat-row{padding:6px 8px;font-size:12px}.bonus-choice-section{padding:12px;margin:16px 0}.bonus-choice-section h3{font-size:16px;margin-bottom:12px}.bonus-choice-buttons{flex-direction:column;gap:10px}.bonus-choice-btn{max-width:100%;padding:14px}.bonus-title{font-size:1em}.bonus-value{font-size:1.3em}.bonus-description{font-size:.85em}.level-up-footer{flex-direction:column;gap:12px;margin-top:16px;padding-top:12px}.selection-status{width:100%;justify-content:center;flex-wrap:wrap;gap:8px;font-size:12px}.confirm-button{width:100%;padding:10px 24px;font-size:14px}.countdown-timer-container{height:32px}.countdown-timer-text{font-size:14px}}@media (max-height: 500px){.level-up-modal{padding:8px;max-height:95vh;overflow-y:visible;zoom:.7;display:flex;flex-direction:column}.level-up-header{display:none!important}.countdown-timer-container{height:24px;margin-bottom:8px}.countdown-timer-text{font-size:12px}.level-up-content{gap:12px;flex:1;min-height:0}.selection-area{max-height:none;flex:1;overflow-y:auto;min-height:0}.color-filter-section{display:none!important}.filter-label{font-size:12px}.color-filter-btn{width:28px;height:28px;font-size:12px}.unit-selection-section{padding:8px}.unit-selection-section h3{display:none}.unit-grid{grid-template-columns:repeat(auto-fill,minmax(60px,1fr));gap:6px}.unit-card{padding:4px}.unit-icon{width:32px;height:32px}.unit-name{font-size:9px}.stage-indicator{font-size:7px;padding:1px 3px}.detail-card{padding:4px!important;gap:4px!important}.detail-header{gap:4px!important;padding:0 0 2px!important;margin:0!important;border-bottom:none!important}.detail-icon{width:20px!important;height:20px!important;margin:0!important}.detail-header h3{font-size:13px!important;margin:0!important;line-height:1!important}.detail-description{font-size:11px!important;padding:2px!important;margin:0!important}.level-up-modal .detail-card .detail-stats{padding:0!important;gap:1px!important;margin:0!important;display:grid!important;grid-template-columns:1fr 1fr!important}.level-up-modal .detail-card .stat-row{padding:1px 2px!important;font-size:11px!important;flex-direction:column!important;align-items:flex-start!important;gap:0!important}.level-up-modal .detail-card .stat-label{font-size:9px!important}.level-up-modal .detail-card .stat-value{font-size:11px!important}.bonus-choice-section{padding:8px;margin:12px 0}.bonus-choice-section h3{font-size:14px;margin-bottom:8px}.bonus-choice-btn{padding:10px}.bonus-title{font-size:.9em}.bonus-value{font-size:1.2em}.bonus-description{font-size:.8em}.level-up-footer{margin-top:8px;padding-top:8px;flex-shrink:0}.selection-status{font-size:11px;gap:12px}.confirm-button{padding:8px 20px;font-size:13px}}@keyframes slideDown{0%{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes slideUp{0%{transform:translateY(0);opacity:1}to{transform:translateY(-100%);opacity:0}}.error-notification{position:fixed;top:20px;left:20px;z-index:10000;animation:slideDown .3s ease-out forwards}.error-notification.leaving{animation:slideUp .3s ease-in forwards}.error-notification-content{background:linear-gradient(135deg,#f44,#c00);color:#fff;padding:8px 12px;border-radius:6px;box-shadow:0 2px 8px #00000040,0 1px 2px #00000026;display:flex;align-items:center;gap:8px;font-size:12px;font-weight:500;max-width:280px;backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2)}.error-icon{font-size:14px;flex-shrink:0}.error-message{line-height:1.4;word-wrap:break-word}.game-view{position:relative;width:100%;height:100vh;overflow:hidden;background:#000}.game-canvas{width:100%;height:100%}.loading-overlay{position:absolute;inset:0;background:#000000e6;display:flex;align-items:center;justify-content:center;z-index:2000}.loading-content{text-align:center;color:#fff}.spinner{width:50px;height:50px;border:3px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 20px}.loading-content p{font-size:18px;color:#ccc}.error-overlay{position:absolute;inset:0;background:#000000e6;display:flex;align-items:center;justify-content:center;z-index:2000}.error-content{background:#ff00001a;border:2px solid #cc0000;border-radius:10px;padding:30px;max-width:500px;text-align:center;color:#fff}.error-content h2{color:#f66;margin:0 0 15px}.error-content p{color:#ccc;margin:0}.game-container{position:relative;width:100vw!important;height:100vh!important;max-width:none!important;padding:0!important;margin:0!important;overflow:hidden;background:#000;border:none!important;border-radius:0!important}.game-loading-overlay{position:absolute;inset:0;background:#000000e6;display:flex;align-items:center;justify-content:center;z-index:2000}.game-loading-overlay .loading-content h2{font-size:32px;margin-bottom:30px;color:#fff}.game-loading-overlay .loading-content p{font-size:18px;color:#aaa;margin-top:20px}.loading-spinner-container{display:flex;justify-content:center;margin:20px 0}.loading-spinner{width:50px;height:50px;border:4px solid rgba(255,255,255,.2);border-top-color:#4ade80;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.game-ended{width:100%;height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#000;color:#fff}.game-ended h1{font-size:48px;margin:0 0 20px}.game-ended h2{font-size:36px;margin:0 0 15px;color:#4ade80}.game-ended p{font-size:24px;color:#ccc}.replay-controls{position:fixed;bottom:20px;left:50%;transform:translate(-50%);background:#000000e6;border:2px solid #333;border-radius:8px;padding:15px 20px;display:flex;align-items:center;gap:20px;z-index:1000;min-width:600px}.replay-label{color:#ff6b6b;font-weight:700;font-size:14px;text-transform:uppercase;letter-spacing:1px}.replay-timeline-container{display:flex;align-items:center;gap:15px;flex:1}.replay-play-button{background:#4ade80;border:none;color:#000;width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:16px;transition:all .2s}.replay-play-button:hover{background:#5ee88a;transform:scale(1.1)}.replay-timeline{flex:1;height:6px;background:#333;border-radius:3px;outline:none;-webkit-appearance:none;appearance:none}.replay-timeline::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:16px;height:16px;background:#4ade80;border-radius:50%;cursor:pointer;transition:transform .2s}.replay-timeline::-webkit-slider-thumb:hover{transform:scale(1.2)}.replay-timeline::-moz-range-thumb{width:16px;height:16px;background:#4ade80;border-radius:50%;cursor:pointer;border:none;transition:transform .2s}.replay-timeline::-moz-range-thumb:hover{transform:scale(1.2)}.replay-time{color:#888;font-size:12px;min-width:80px;text-align:right}.replay-speed-controls{display:flex;gap:8px}.speed-button{background:#222;border:1px solid #444;color:#888;padding:6px 12px;border-radius:4px;cursor:pointer;font-size:12px;transition:all .2s}.speed-button:hover{background:#333;color:#aaa}.speed-button.active{background:#4ade80;border-color:#4ade80;color:#000;font-weight:700}.game-loading-overlay .error-title{color:#ef4444;font-size:36px;margin-bottom:20px}.game-loading-overlay .error-icon{font-size:64px;margin:20px 0}.game-loading-overlay .error-message{font-size:18px;color:#fca5a5;margin:20px 0;max-width:500px;line-height:1.5}.game-loading-overlay .retry-button{margin-top:30px;padding:12px 24px;font-size:16px;font-weight:600;background:#4ade80;color:#000;border:none;border-radius:8px;cursor:pointer;transition:all .2s}.game-loading-overlay .retry-button:hover{background:#22c55e;transform:scale(1.05)}.game-loading-overlay .retry-button:active{transform:scale(.98)}.connection-indicator{display:flex;align-items:center;gap:8px;padding:8px 16px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:20px;font-size:14px;transition:all .3s ease}.connection-text{font-weight:500}.play-now-button{padding:8px 20px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:20px;font-weight:600;font-size:14px;cursor:pointer;transition:all .3s ease}.play-now-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.encyclopedia{min-height:100vh;background:#0a0e1a;background-image:radial-gradient(ellipse at top,rgba(102,126,234,.1) 0%,transparent 50%),radial-gradient(ellipse at bottom,rgba(118,75,162,.1) 0%,transparent 50%);padding:20px;color:#e0e0e0}.encyclopedia-top-bar{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding:0 20px}.encyclopedia-back-button{padding:10px 20px;background:#ffffff1a;color:#fff;border:1px solid rgba(255,255,255,.2);border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:8px}.encyclopedia-back-button:hover{background:#ffffff26;transform:translate(-2px);box-shadow:0 4px 12px #0000004d}.server-connection-status{display:flex;align-items:center;gap:16px}.connection-indicator{display:flex;align-items:center;gap:8px;padding:8px 16px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:20px;font-size:14px;font-weight:600}.connection-dot{width:8px;height:8px;border-radius:50%;animation:pulse 2s infinite}.connection-indicator.connected .connection-dot{background:#10b981;box-shadow:0 0 8px #10b98199}.connection-indicator.disconnected .connection-dot{background:#ef4444;box-shadow:0 0 8px #ef444499}.connection-indicator.checking .connection-dot{background:#f59e0b;box-shadow:0 0 8px #f59e0b99;animation:pulse 1s infinite}.connection-text{color:#e0e0e0}.connection-indicator.connected .connection-text{color:#10b981}.connection-indicator.disconnected .connection-text{color:#ef4444}.connection-indicator.checking .connection-text{color:#f59e0b}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.play-now-button{padding:10px 24px;background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:700;cursor:pointer;transition:all .2s;text-transform:uppercase;letter-spacing:1px}.play-now-button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #10b98166}.encyclopedia-header{text-align:center;margin-bottom:30px}.encyclopedia-header h1{color:#fff;font-size:36px;margin-bottom:20px;text-shadow:0 0 20px rgba(102,126,234,.5);font-weight:700;letter-spacing:2px}.tab-container{display:inline-flex;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:4px;gap:4px;backdrop-filter:blur(10px)}.tab{padding:12px 32px;background:transparent;border:none;color:#fff9;font-size:16px;font-weight:600;cursor:pointer;border-radius:6px;transition:all .2s;text-transform:uppercase;letter-spacing:1px}.tab:hover{background:#ffffff1a;color:#fff}.tab.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 0 20px #667eea66}.encyclopedia-main{display:flex;gap:20px;max-width:1600px;margin:0 auto}.encyclopedia-sidebar{display:flex;flex-direction:column;gap:20px;flex:1;max-width:800px}.color-filter{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);backdrop-filter:blur(10px);border-radius:12px;padding:20px}.color-filter h3{margin:0 0 15px;font-size:14px;color:#fff9;text-transform:uppercase;letter-spacing:1px;font-weight:600}.filter-btn{padding:10px 16px;margin-right:10px;margin-bottom:10px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:6px;color:#ffffffb3;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;display:inline-block}.filter-btn:hover{background:#ffffff1a;border-color:#fff3;color:#fff}.filter-btn.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-color:transparent;box-shadow:0 0 20px #667eea4d}.items-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:12px;background:#ffffff08;border:1px solid rgba(255,255,255,.1);backdrop-filter:blur(10px);border-radius:12px;padding:20px;max-height:calc(100vh - 300px);overflow-y:auto}.items-grid::-webkit-scrollbar{width:8px}.items-grid::-webkit-scrollbar-track{background:#ffffff0d;border-radius:4px}.items-grid::-webkit-scrollbar-thumb{background:#fff3;border-radius:4px}.items-grid::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.item-card{background:#ffffff0d;border:2px solid var(--item-border-color, rgba(255, 255, 255, .1));border-radius:8px;padding:12px;cursor:pointer;transition:all .2s;text-align:center;position:relative}.item-card:hover{transform:translateY(-2px);background:#ffffff14;box-shadow:0 8px 20px #0000004d;border-color:var(--item-border-color, rgba(255, 255, 255, .3))}.item-card.selected{background:#667eea33;border-color:#667eea;box-shadow:0 0 20px #667eea66}.item-image{width:64px;height:64px;object-fit:contain;margin:0 auto 8px;image-rendering:pixelated;filter:drop-shadow(0 2px 4px rgba(0,0,0,.5))}.item-card h4{margin:0;font-size:12px;color:#ffffffe6;font-weight:500}.detail-panel-empty{flex:1;display:flex;align-items:center;justify-content:center;background:#ffffff08;border:1px solid rgba(255,255,255,.1);backdrop-filter:blur(10px);border-radius:12px;min-height:400px;color:#fff6;font-size:18px}.detail-panel{flex:1;background:#ffffff08;border:1px solid rgba(255,255,255,.1);backdrop-filter:blur(10px);border-radius:12px;overflow-y:auto;max-height:calc(100vh - 200px);animation:fadeIn .3s ease-out}@keyframes fadeIn{0%{opacity:0;transform:scale(.98)}to{opacity:1;transform:scale(1)}}.detail-panel::-webkit-scrollbar{width:8px}.detail-panel::-webkit-scrollbar-track{background:#ffffff0d;border-radius:4px}.detail-panel::-webkit-scrollbar-thumb{background:#fff3;border-radius:4px}.detail-header{padding:40px 30px;background:linear-gradient(135deg,#667eea26,#764ba226);border-bottom:1px solid rgba(255,255,255,.1);position:relative}.detail-header:before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at center,rgba(102,126,234,.1) 0%,transparent 70%);pointer-events:none}.detail-image{width:120px;height:120px;object-fit:contain;margin:0 auto 20px;display:block;image-rendering:pixelated;filter:drop-shadow(0 4px 8px rgba(0,0,0,.5))}.detail-title h2{margin:0 0 10px;font-size:28px;text-align:center;color:#fff;text-shadow:0 0 10px rgba(102,126,234,.5)}.detail-description{margin:0 0 15px;text-align:center;color:#ffffffb3;line-height:1.5;font-size:14px}.detail-colors{display:flex;justify-content:center;gap:10px;flex-wrap:wrap}.color-badge{padding:8px 16px;border-radius:20px;font-size:11px;font-weight:700;color:#000000e6;border:2px solid;text-transform:uppercase;letter-spacing:1.5px;backdrop-filter:brightness(1.2);box-shadow:0 2px 8px #0000004d}.detail-stats{padding:30px}.detail-stats h3{margin:0 0 20px;font-size:18px;color:#ffffffe6;border-bottom:1px solid rgba(255,255,255,.1);padding-bottom:10px;text-transform:uppercase;letter-spacing:1px;font-weight:600}.stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:30px}.stat-item{display:flex;flex-direction:row;align-items:baseline;gap:8px;padding:8px 12px;background:#ffffff05;border:1px solid rgba(255,255,255,.05);border-radius:6px}.stat-item.full-width{grid-column:1 / -1}.stat-label{font-size:12px;color:#fff9;font-weight:600;text-transform:uppercase;letter-spacing:.5px;min-width:90px}.stat-value{font-size:16px;color:#fff;font-weight:600;flex:1;text-align:right}.levels-container{display:flex;flex-direction:column;gap:20px}.level-section{background:#ffffff08;border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:20px}.level-section h4{margin:0 0 15px;font-size:16px;color:#667eea;font-weight:600;text-transform:uppercase;letter-spacing:1px}.level-stats{display:grid;grid-template-columns:1fr 1fr;gap:12px}.level-stats .stat-item{background:#ffffff03;border-color:#ffffff08}@media (max-width: 1200px){.encyclopedia-main{flex-direction:column}.encyclopedia-sidebar{max-width:100%}.items-grid{max-height:400px}.detail-panel{max-height:600px}}@media (max-width: 768px){.items-grid{grid-template-columns:repeat(auto-fill,minmax(80px,1fr))}.item-image{width:48px;height:48px}.stats-grid,.level-stats{grid-template-columns:1fr}}.app{min-height:100vh;background:linear-gradient(135deg,#1e3c72,#2a5298);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:20px}.game-loading-overlay{position:fixed;inset:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:9999}.game-loading-overlay .loading-content{text-align:center;color:#fff}.game-loading-overlay h2{font-size:32px;margin-bottom:10px}.game-loading-overlay p{font-size:16px;opacity:.8}.title{font-size:48px;font-weight:700;color:#fff;margin-bottom:40px;text-shadow:2px 2px 4px rgba(0,0,0,.3)}.wallet-connect{background:#fff;padding:40px;border-radius:12px;box-shadow:0 10px 30px #0003;text-align:center}.wallet-connect h2{margin-bottom:20px;color:#333}.connect-button{background:#4a9eff;color:#fff;border:none;padding:15px 30px;font-size:18px;border-radius:8px;cursor:pointer;transition:background .3s}.connect-button:hover:not(:disabled){background:#2563eb}.connect-button:disabled{background:#ccc;cursor:not-allowed}.wallet-info{background:#fff;padding:20px;border-radius:12px;box-shadow:0 5px 15px #0000001a;position:fixed;top:20px;right:20px}.address{font-family:monospace;color:#666;margin-bottom:10px}.disconnect-button{background:#ef4444;color:#fff;border:none;padding:8px 16px;border-radius:4px;cursor:pointer;transition:background .3s}.disconnect-button:hover{background:#dc2626}.upgrade-button{background:#4a9eff;color:#fff;border:none;padding:8px 16px;border-radius:4px;cursor:pointer;transition:background .3s}.upgrade-button:hover{background:#2563eb}.switch-network-button{background:#ff9800;color:#fff;border:none;padding:8px 16px;border-radius:4px;cursor:pointer;transition:background .3s;margin-right:10px}.switch-network-button:hover{background:#f57c00}.initializing{text-align:center;padding:40px}.initializing h2{color:#60a5fa;margin:0 0 10px;font-size:28px}.initializing p{color:#9ca3af;margin:0;font-size:16px}.games-list{background:#000000b3;padding:30px;border-radius:16px;box-shadow:0 15px 40px #00000080;min-width:600px;max-width:800px;border:1px solid rgba(255,255,255,.1)}.games-list h2{color:#e5e7eb;margin-bottom:20px}.app-header{position:absolute;top:0;left:0;right:0;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;padding:20px 40px;background:#ffffff1a;backdrop-filter:blur(10px)}.server-status-center{display:flex;justify-content:center;align-items:center}.app-header .title{margin:0;font-size:32px;transition:transform .2s,text-shadow .2s}.app-header .title:hover{transform:scale(1.05);text-shadow:2px 2px 8px rgba(0,0,0,.5)}.user-info{display:flex;align-items:center;justify-content:flex-end;gap:20px;color:#fff;font-size:16px}.logout-button{padding:8px 16px;background:#e53e3e;color:#fff;border:none;border-radius:4px;cursor:pointer;font-weight:600;transition:background .3s}.logout-button:hover{background:#c53030}@media (max-height: 500px){body:has(.lobby-room) .app-header{display:none}}.connecting-message,.loading-message{color:#fff;font-size:1.5rem;text-align:center;padding:2rem;background:#ffffff1a;border-radius:12px;animation:pulse 1.5s infinite}.server-error-banner{position:fixed;top:0;left:0;right:0;background:#ef4444f2;color:#fff;padding:12px 20px;display:flex;align-items:center;justify-content:center;gap:12px;font-size:16px;z-index:1000;box-shadow:0 2px 10px #0000004d;animation:slideDown .3s ease-out}.server-error-banner .error-icon{font-size:20px}.server-error-banner .error-message{display:flex;align-items:center;gap:8px}.server-error-banner .status-link{color:#fff;font-weight:600;text-decoration:underline;margin-left:4px;transition:opacity .2s}.server-error-banner .status-link:hover{opacity:.8}.connecting-banner{position:fixed;top:0;left:0;right:0;background:#3b82f6f2;color:#fff;padding:8px 20px;display:flex;align-items:center;justify-content:center;font-size:14px;z-index:1000;animation:slideDown .3s ease-out}@keyframes slideDown{0%{transform:translateY(-100%)}to{transform:translateY(0)}}*{margin:0;padding:0;box-sizing:border-box}.app{width:100%;height:100vh;display:flex;flex-direction:column;background:linear-gradient(135deg,#0a0a0a,#1a1a2e);color:#fff}.app-header{padding:20px;text-align:center;border-bottom:1px solid rgba(255,255,255,.1)}.app-header h1{font-size:2.5rem;margin-bottom:8px;background:linear-gradient(90deg,#60a5fa,#a78bfa);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.app-header p{color:#9ca3af;font-size:1.1rem}.connect-button{margin-top:20px;padding:12px 24px;font-size:1rem;background:linear-gradient(90deg,#60a5fa,#a78bfa);color:#fff;border:none;border-radius:8px;cursor:pointer;transition:transform .2s,box-shadow .2s}.connect-button:hover{transform:translateY(-2px);box-shadow:0 8px 16px #60a5fa4d}.connected-status{margin-top:20px;color:#10b981}.app-main{flex:1;display:flex;justify-content:center;align-items:center;padding:20px}.wallet-connect,.wallet-connected{display:flex;align-items:center;gap:12px}.wallet-connected .address{color:#10b981;font-family:monospace;font-size:.9rem}.disconnect-button{padding:8px 16px;background:#ef444433;color:#ef4444;border:1px solid #ef4444;border-radius:6px;cursor:pointer;transition:all .2s}.disconnect-button:hover{background:#ef44444d}.upgrade-button{padding:8px 16px;background:#4a9eff33;color:#4a9eff;border:1px solid #4a9eff;border-radius:6px;cursor:pointer;transition:all .2s}.upgrade-button:hover{background:#4a9eff4d}.create-lobby,.join-lobby{padding:20px;background:#ffffff05;border-radius:8px;border:1px solid rgba(255,255,255,.05)}.divider{display:flex;align-items:center;color:#4b5563;font-weight:700}.match-input{width:100%;padding:10px;margin:10px 0;background:#00000080;border:1px solid rgba(255,255,255,.2);border-radius:6px;color:#fff;font-family:monospace}.team-select{display:flex;gap:20px;margin:15px 0}.team-select label{display:flex;align-items:center;gap:8px;cursor:pointer}.create-button,.join-button,.start-button{width:100%;padding:12px;margin-top:15px;background:linear-gradient(90deg,#60a5fa,#a78bfa);color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:1rem;transition:all .2s}.create-button:hover,.join-button:hover,.start-button:hover{transform:translateY(-2px);box-shadow:0 8px 16px #60a5fa4d}.create-button:disabled,.join-button:disabled,.start-button:disabled{opacity:.5;cursor:not-allowed;transform:none}.teams{display:grid;grid-template-columns:1fr 1fr;gap:30px;margin:30px 0}.team{padding:20px;background:#ffffff05;border-radius:8px;border:1px solid rgba(255,255,255,.1)}.team-a{border-color:#60a5fa}.team-b{border-color:#f87171}.team h3{margin-bottom:15px;color:#e5e7eb}.player-list{display:flex;flex-direction:column;gap:8px}.player{padding:8px 12px;background:#ffffff0d;border-radius:4px;font-family:monospace;font-size:.9rem}.no-players{color:#6b7280;font-style:italic}.match-info{margin:20px 0;padding:15px;background:#00000080;border-radius:8px;border:1px solid rgba(255,255,255,.1)}.match-info code{color:#60a5fa;font-family:monospace;font-size:.85rem}.connect-prompt{text-align:center;color:#9ca3af}.connect-prompt h2{color:#e5e7eb;margin-bottom:15px}.back-button{margin-top:20px;padding:10px 20px;background:#ffffff1a;color:#9ca3af;border:1px solid rgba(255,255,255,.2);border-radius:6px;cursor:pointer;transition:all .2s}.back-button:hover{background:#ffffff26;color:#e5e7eb}
