.login{align-items:center;background:#242424;display:flex;height:100%;justify-content:center;width:100%}.login-container{background:#fefefe;border:1px solid #ebecec;border-radius:0;box-shadow:0 2px 8px #00000026;max-width:500px;padding:0;width:90%}.login-header{background:#242424;border-bottom:4px solid #fdc700;padding:30px 40px;text-align:center}.login-header .logo{height:auto;margin-bottom:15px;max-width:180px}.login-header .subtitle{color:#fdc700;font-size:12px;font-weight:600;letter-spacing:2px;text-transform:uppercase}.login-form-container{padding:40px}.mode-switcher{border-bottom:2px solid #ebecec;display:flex;gap:10px;margin-bottom:30px}.mode-button{background:#0000;border:none;border-bottom:3px solid #0000;color:#666;cursor:pointer;flex:1 1;font-size:14px;font-weight:700;letter-spacing:1px;margin-bottom:-2px;padding:15px 20px;transition:all .2s}.mode-button:hover{color:#242424}.mode-button.active{border-bottom-color:#fdc700;color:#242424}.login-form{display:flex;flex-direction:column;gap:20px}.error-message{background:#f443361a;border:1px solid #f44336;border-radius:0;color:#d32f2f;font-size:14px;font-weight:500;padding:12px 16px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{color:#242424;font-size:12px;font-weight:700;letter-spacing:1px;text-transform:uppercase}.form-input{background:#fff;border:1px solid #ebecec;border-radius:0;font-size:16px;font-weight:400;outline:none;padding:14px 16px;transition:all .2s}.form-input:focus{background:#fefefe;border-color:#fdc700;box-shadow:none}.form-input::placeholder{color:#999}.submit-button{background:#fdc700;border:none;border-radius:0;color:#242424;cursor:pointer;font-size:14px;font-weight:700;letter-spacing:1.5px;margin-top:10px;padding:16px 32px;text-transform:uppercase;transition:all .15s}.submit-button:hover:not(:disabled){background:#e5b600;box-shadow:0 2px 4px #00000026}.submit-button:active:not(:disabled){background:#cc9f00}.submit-button:disabled{cursor:not-allowed;opacity:.6}.login-info{border-top:1px solid #ebecec;margin-top:20px;padding-top:20px;text-align:center}.login-info p{color:#666;font-size:13px;margin:0}.lobby{align-items:center;background:#242424;display:flex;flex:1 1;justify-content:center;position:relative;width:100%}.lobby:before{background-image:radial-gradient(circle at 20% 50%,#fdc70008 0,#0000 50%),radial-gradient(circle at 80% 50%,#fdc70008 0,#0000 50%);bottom:0;content:"";left:0;pointer-events:none;position:absolute;right:0;top:0}.lobby-container{background:#fefefe;border-radius:8px;box-shadow:0 8px 32px #0006;max-height:92vh;max-width:1000px;overflow-y:auto;padding:40px;position:relative;width:92%}.lobby-header{border-bottom:3px solid #fdc700;margin-bottom:30px;padding-bottom:20px;text-align:center}.lobby-header .logo{display:block;height:auto;margin-bottom:16px;margin-left:auto;margin-right:auto;max-width:200px}.subtitle{color:#666;font-size:16px;font-weight:700;letter-spacing:2px;text-transform:uppercase}.lobby-info{display:flex;flex-direction:column;gap:24px}.waiting-message{background:#242424;border:2px solid #fdc700;border-radius:8px;box-shadow:0 4px 16px #0003;color:#fdc700;padding:24px;text-align:center}.waiting-message h2{color:#fff;font-size:24px;font-weight:700;margin-bottom:12px}.players-count{color:#fdc700;font-size:36px;font-weight:900;margin:12px 0}.needed-count{color:#ebecec;font-size:16px;margin-bottom:16px;opacity:.9}.add-bot-button{background:#fdc700;border:none;border-radius:6px;box-shadow:0 4px 12px #fdc70066;color:#242424;cursor:pointer;font-size:16px;font-weight:700;letter-spacing:1px;padding:12px 24px;text-transform:uppercase;transition:all .2s ease}.add-bot-button:hover{box-shadow:0 6px 16px #fdc70080;transform:translateY(-2px)}.add-bot-button:active{transform:translateY(0)}.start-game-button{animation:pulse 2s infinite;background:linear-gradient(135deg,#fdc700,#fdb700);border:none;border-radius:8px;box-shadow:0 8px 24px #fdc70099;color:#242424;cursor:pointer;font-size:20px;font-weight:900;letter-spacing:2px;margin-top:16px;padding:16px 40px;text-transform:uppercase;transition:all .3s ease}.start-game-button:hover{box-shadow:0 12px 32px #fdc700cc;transform:translateY(-3px) scale(1.05)}.start-game-button:active{transform:translateY(0) scale(1)}@keyframes pulse{0%,to{box-shadow:0 8px 24px #fdc70099}50%{box-shadow:0 8px 32px #fdc700e6}}.team-switcher{background:#f9f9f9;border:1px solid #ebecec;border-radius:8px;margin:20px 0;padding:20px}.team-switcher h3{color:#242424;font-size:14px;font-weight:700;letter-spacing:1px;margin-bottom:14px;text-transform:uppercase}.team-buttons{gap:16px}.team-button,.team-buttons{display:flex;justify-content:center}.team-button{align-items:center;background:#fff;border:3px solid;border-radius:6px;box-shadow:0 2px 8px #0000001a;cursor:pointer;flex:1 1;flex-direction:row;font-size:16px;font-weight:700;gap:10px;padding:14px 20px;transition:all .25s ease}.team-button.red{border-color:#e31e24;color:#e31e24}.team-button.green{border-color:#367c2b;color:#367c2b}.team-button.red:hover:not(.selected){background:#fff5f5;box-shadow:0 4px 12px #e31e2433;transform:translateY(-2px)}.team-button.green:hover:not(.selected){background:#f0fdf4;box-shadow:0 4px 12px #367c2b33;transform:translateY(-2px)}.team-button.red.selected{background:#e31e24;border-color:#e31e24;box-shadow:0 6px 16px #e31e2466;color:#fff}.team-button.green.selected{background:#367c2b;border-color:#367c2b;box-shadow:0 6px 16px #367c2b66;color:#fff}.team-button.small{font-size:15px;padding:12px 16px}.team-button .team-logo{height:24px;object-fit:contain;width:auto}.team-button.small .team-logo{height:22px}.team-button.selected .team-logo{filter:brightness(0) invert(1)}.role-selector{background:#f9f9f9;border:1px solid #ebecec;border-radius:8px;margin:20px 0;padding:20px}.role-selector h3{color:#242424;font-size:14px;font-weight:700;letter-spacing:1px;margin-bottom:14px;text-transform:uppercase}.role-buttons{display:flex;gap:12px;justify-content:center}.role-button{align-items:center;background:#fff;border:3px solid #ebecec;border-radius:6px;box-shadow:0 2px 8px #0000001a;color:#242424;cursor:pointer;display:flex;flex:1 1;flex-direction:column;gap:8px;padding:18px 12px;transition:all .25s ease}.role-button:hover:not(.disabled){background:#fffdf5;border-color:#fdc700;box-shadow:0 6px 16px #fdc7004d;transform:translateY(-3px)}.role-button.selected{background:#fdc700;border-color:#fdc700;box-shadow:0 6px 20px #fdc70080;color:#242424}.role-button.disabled{background:#f5f5f5;border-color:#ddd;cursor:not-allowed;opacity:.4}.role-vehicle-icon{filter:contrast(1.2) saturate(.8);height:auto;margin-bottom:6px;transition:all .3s ease;width:80px}.role-button.selected .role-vehicle-icon{filter:contrast(1.3) saturate(1) drop-shadow(0 2px 8px rgba(36,36,36,.3))}.role-button.disabled .role-vehicle-icon{filter:grayscale(1);opacity:.3}.role-button:hover:not(.disabled) .role-vehicle-icon{transform:scale(1.1)}.role-name{font-size:15px;font-weight:700}.role-desc{font-size:12px;line-height:1.4;opacity:.8;text-align:center}.role-taken{font-size:10px;letter-spacing:.5px;margin-top:6px;text-transform:uppercase}.role-error,.role-taken{color:#e31e24;font-weight:700}.role-error{background:#fff5f5;border:2px solid #fecaca;border-radius:6px;font-size:14px;margin-bottom:12px;padding:12px;text-align:center}.players-list h3{color:#242424;font-size:16px;font-weight:700;letter-spacing:1px;margin-bottom:18px;text-transform:uppercase}.teams-container{display:flex;gap:20px}.team-column{flex:1 1}.team-header{align-items:center;border-radius:6px;box-shadow:0 4px 12px #00000026;display:flex;font-size:14px;font-weight:900;gap:10px;justify-content:center;letter-spacing:1.5px;margin-bottom:12px;padding:14px;text-align:center;text-transform:uppercase}.team-header-logo{height:40px;max-width:80px;object-fit:contain;width:auto}.team-header.red{background:#e31e24;border:none;color:#fff}.team-header.green{background:#367c2b;border:none;color:#fff}.team-players{gap:10px}.player-card,.team-players{display:flex;flex-direction:column}.player-card{align-items:center;background:#fff;border:2px solid #ebecec;border-radius:6px;box-shadow:0 2px 8px #00000014;height:130px;justify-content:center;padding:14px;text-align:center;transition:all .2s ease}.player-card.team-red{background:#fff5f5;border-color:#fca5a5}.player-card.team-red .player-name,.player-card.team-red .player-role{color:#000!important}.player-card.team-green{background:#f0fdf4;border-color:#86efac}.player-card.team-green .player-name,.player-card.team-green .player-role{color:#000!important}.player-card.empty{background:#f9f9f9;border-color:#ccc;border-style:dashed;opacity:.5}.player-card.empty.clickable{cursor:pointer;transition:all .3s ease}.player-card.empty.clickable:hover{background:#fffdf5;border-color:#fdc700;border-style:solid;box-shadow:0 4px 12px #fdc7004d;opacity:.8;transform:translateY(-2px)}.player-card.empty.clickable .player-avatar{font-size:36px}.player-card.empty.clickable .player-name{color:#666;font-size:12px}.player-card.bot-player{border-width:3px;box-shadow:0 0 0 3px #fdc70033}.bot-badge{background:#242424;border-radius:4px;color:#fdc700;font-size:10px;font-weight:700;letter-spacing:.5px;margin-left:6px;padding:3px 8px;text-transform:uppercase}.player-avatar{font-size:32px;margin-bottom:8px}.player-name{color:#000;font-weight:800;margin-bottom:6px}.player-role{color:#1a1a1a;font-size:14px;font-weight:700;margin-bottom:4px}.game-rules{background:#f9f9f9;border:1px solid #ebecec;border-left:4px solid #fdc700;border-radius:6px;padding:20px}.game-rules h3{color:#242424;font-size:16px;font-weight:900;letter-spacing:1.5px;margin-bottom:16px;text-transform:uppercase}.game-rules ul{list-style:none;padding:0}.game-rules li{border-bottom:1px solid #ebecec;color:#555;font-size:14px;line-height:1.6;padding:10px 0 10px 28px;position:relative}.game-rules li:before{color:#fdc700;content:"▸";font-size:16px;font-weight:700;left:8px;position:absolute}.game-rules li:last-child{border-bottom:none}.game-rules strong{color:#242424;font-weight:700}.leaderboard{background:#f9f9f9;border:1px solid #ebecec;border-radius:4px;margin-left:auto;margin-right:auto;margin-top:20px;max-width:500px;padding:20px}.leaderboard-title{border-bottom:3px solid #fdc700;color:#242424;font-size:20px;font-weight:700;letter-spacing:1px;margin-bottom:15px;padding-bottom:10px;text-align:center;text-transform:uppercase}.leaderboard-empty{color:#ffffff80;font-style:italic;padding:20px;text-align:center}.leaderboard-list{display:flex;flex-direction:column;gap:8px}.leaderboard-entry{align-items:center;background:#fff;border:1px solid #ebecec;border-radius:4px;display:flex;gap:12px;padding:12px 15px;transition:all .2s ease}.leaderboard-entry:hover{border-color:#fdc700;transform:scale(1.02)}.leaderboard-entry.rank-1{background:#fdc700;border-color:#fdc700}.leaderboard-entry.rank-2{background:#ebecec;border-color:silver}.leaderboard-entry.rank-3{background:#cd7f32;border-color:#b8733b;color:#fff}.rank{color:#242424;font-size:24px;font-weight:700;min-width:45px;text-align:center}.leaderboard-entry.rank-3 .rank{color:#fff}.player-info{display:flex;flex:1 1;flex-direction:column;gap:4px}.player-name{color:#fff;font-size:16px;font-weight:700}.player-stats{display:flex;font-size:12px;gap:10px}.stat{background:#0000004d;border-radius:4px;color:#fff9;padding:2px 8px}.points{font-size:18px;font-weight:700;min-width:70px;text-align:right}.leaderboard-entry.rank-1 .points,.leaderboard-entry.rank-2 .points,.points{color:#242424}.leaderboard-entry.rank-3 .points{color:#fff}.game-container{background:#242424;display:flex;flex-direction:column;height:100vh;position:relative;width:100vw}.game-hud{background:linear-gradient(180deg,#242424f2,#0000);left:0;padding:20px;position:absolute;right:0;top:0;z-index:10}.team-scores{display:flex;gap:20px;justify-content:space-between;margin:0 auto;max-width:800px}.score{border:2px solid;border-radius:4px;color:#fff;flex:1 1;padding:15px 20px}.score.red-team{background:#ff6b6bf2;border-color:#ee5a6f}.score.green-team{background:#10b981f2;border-color:#059669}.team-label{font-size:14px;font-weight:700;margin-bottom:5px;opacity:.9}.score-value{font-size:24px;margin-bottom:10px}.progress-bar{background:#0000004d;border-radius:4px;height:8px;overflow:hidden;width:100%}.progress-fill{height:100%;transition:width .3s ease}.progress-fill.green,.progress-fill.red{background:#fff}.game-timer{background:#fdc700;border:2px solid #242424;border-radius:4px;margin-left:auto;margin-right:auto;margin-top:15px;max-width:200px;padding:10px 20px;text-align:center}.timer-label{font-size:12px;letter-spacing:1px;margin-bottom:5px;text-transform:uppercase}.timer-label,.timer-value{color:#242424;font-weight:700}.timer-value{font-family:Courier New,monospace;font-size:32px}.timer-value.timer-warning{animation:pulse-timer 1s infinite;color:#ff6b6b}@keyframes pulse-timer{0%,to{opacity:1;transform:scale(1)}50%{opacity:.9;transform:scale(1.05)}}.controls-hint{color:#fff;font-size:14px;margin-top:15px;opacity:.8;text-align:center}.game-canvas{background:#8fbc8f;cursor:crosshair;display:block;image-rendering:pixelated;image-rendering:-moz-crisp-edges;image-rendering:crisp-edges;margin:0 auto;max-height:100vh;max-width:100%;transform:scale(1.5);transform-origin:center center}.loading{align-items:center;color:#fff;display:flex;font-size:24px;height:100vh;justify-content:center;width:100vw}.minimap-container{border-radius:10px;bottom:20px;box-shadow:0 4px 12px #00000080;overflow:hidden;position:fixed;right:20px;transition:transform .2s ease;z-index:100}.minimap-container:hover{transform:scale(1.1)}.minimap-canvas{border-radius:10px;display:block}.match-history-overlay{align-items:center;background:#242424e6;display:flex;height:100%;justify-content:center;left:0;position:fixed;top:0;width:100%;z-index:1000}.match-history-container{background:#fefefe;border:1px solid #ebecec;border-radius:0;box-shadow:0 4px 20px #0000004d;display:flex;flex-direction:column;max-height:80vh;max-width:700px;width:90%}.match-history-header{align-items:center;background:#242424;border-bottom:4px solid #fdc700;display:flex;justify-content:space-between;padding:20px 30px}.match-history-header h2{color:#fdc700;font-size:20px;font-weight:700;letter-spacing:1.5px;margin:0;text-transform:uppercase}.close-button{align-items:center;background:#0000;border:none;color:#fdc700;cursor:pointer;display:flex;font-size:28px;height:32px;justify-content:center;padding:0;transition:all .2s;width:32px}.close-button:hover{color:#e5b600;transform:scale(1.1)}.match-history-content{flex:1 1;overflow-y:auto;padding:20px}.empty-message,.loading-message{color:#666;padding:60px 20px;text-align:center}.empty-message p{font-size:16px;margin:0}.matches-list{display:flex;flex-direction:column;gap:15px}.match-card{background:#fff;border:2px solid #ebecec;border-radius:0;padding:0;transition:all .2s}.match-card:hover{box-shadow:0 2px 8px #0000001a}.match-card.won{border-left:4px solid #4caf50}.match-card.lost{border-left:4px solid #f44336}.match-header{align-items:center;background:#fefefe;border-bottom:1px solid #ebecec;display:flex;justify-content:space-between;padding:15px 20px}.match-result{border-radius:0;font-size:14px;font-weight:700;letter-spacing:1.5px;padding:6px 12px}.match-result.win{background:#4caf5026;color:#4caf50}.match-result.lose{background:#f4433626;color:#f44336}.match-date{color:#666;font-size:13px;font-weight:500}.match-details{display:flex;flex-direction:column;gap:10px;padding:15px 20px}.detail-row{align-items:center;border-bottom:1px solid #f5f5f5;display:flex;justify-content:space-between;padding:8px 0}.detail-row:last-child{border-bottom:none}.detail-label{color:#666;font-size:13px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.detail-value{color:#242424;font-size:14px;font-weight:700}.detail-value.team-red{color:#ff6b6b}.detail-value.team-green{color:#10b981}.detail-value.points{color:#fdc700;font-size:16px}.match-history-content::-webkit-scrollbar{width:8px}.match-history-content::-webkit-scrollbar-track{background:#fefefe}.match-history-content::-webkit-scrollbar-thumb{background:#ebecec;border-radius:0}.match-history-content::-webkit-scrollbar-thumb:hover{background:#d0d0d0}.App{background:#242424;display:flex;flex-direction:column;height:100vh;position:relative;width:100vw}.app-header{align-items:center;background:#242424f2;border:1px solid #fdc700;box-shadow:0 2px 8px #0000004d;display:flex;gap:20px;left:50%;padding:12px 24px;position:absolute;top:20px;transform:translateX(-50%);z-index:100}.user-info{color:#fefefe;font-size:14px;font-weight:400;letter-spacing:.5px}.user-info strong{color:#fdc700;font-weight:700}.header-buttons{display:flex;gap:10px}.header-button{background:#fdc700;border:none;border-radius:0;color:#242424;cursor:pointer;font-size:12px;font-weight:700;letter-spacing:1px;padding:8px 16px;text-transform:uppercase;transition:all .15s}.header-button:hover{background:#e5b600}.header-button:active{background:#cc9f00}.header-button.logout{background:#0000;border:1px solid #fdc700;color:#fdc700}.header-button.logout:hover{background:#fdc7001a}.game-end{align-items:center;background:#242424;display:flex;height:100%;justify-content:center;width:100%}.game-end-container{background:#fefefe;border-radius:4px;box-shadow:0 4px 20px #00000080;max-width:600px;padding:40px;text-align:center;width:90%}.game-end-logo{height:auto;margin-bottom:30px;max-width:200px}.game-end-title{border-bottom:3px solid #fdc700;color:#242424;font-size:36px;font-weight:700;margin-bottom:30px;padding-bottom:20px}.winner-announcement{border:2px solid;border-radius:4px;margin-bottom:30px;padding:20px}.winner-announcement h2{font-size:28px;font-weight:700;margin:0}.winner-announcement.red{background:#ff6b6b;border-color:#ee5a6f;color:#fff}.winner-announcement.green{background:#10b981;border-color:#059669;color:#fff}.winner-announcement.draw{background:#ebecec;border-color:#242424;color:#242424}.final-scores{display:flex;gap:20px;margin-bottom:30px}.final-score{border:2px solid;border-radius:4px;flex:1 1;padding:20px}.final-score.red{background:#ff6b6b1a;border-color:#ff6b6b}.final-score.green{background:#10b9811a;border-color:#10b981}.team-name{font-size:14px;letter-spacing:1px;margin-bottom:10px;text-transform:uppercase}.score-value,.team-name{color:#242424;font-weight:700}.score-value{font-size:32px}.return-lobby-button{background:#fdc700;border:none;border-radius:4px;color:#242424;cursor:pointer;font-size:18px;font-weight:700;letter-spacing:1px;padding:15px 40px;text-transform:uppercase;transition:all .2s}.return-lobby-button:hover{box-shadow:0 4px 15px #fdc70066;transform:scale(1.05)}
/*# sourceMappingURL=main.426c2969.css.map*/