body{margin:0;padding:0;background:#000;display:flex;justify-content:center;align-items:center;height:100vh;font-family:Courier New,Courier,monospace;color:#0f0}#menu{text-align:center;max-width:600px;position:relative}#qrCode{position:fixed;bottom:20px;right:20px;text-align:center;opacity:.85}#qrCode canvas{display:block;margin:0 auto}#qrCode .qr-label{font-size:11px;color:#0f0;margin-top:4px}#menu h1{font-size:48px;margin-bottom:40px}#menu h2{font-size:24px;margin:20px 0}.menu-buttons{display:flex;flex-direction:column;gap:20px}.menu-btn{background:#000;color:#0f0;border:2px solid #0f0;padding:15px 30px;font-size:18px;font-family:monospace;cursor:pointer;transition:all .2s}.menu-btn:hover{background:#0f0;color:#000}#replayListContent{max-height:60vh;overflow-y:auto}.game-item,.replay-item{background:#00ff001a;border:1px solid #0f0;padding:10px;margin:10px 0;cursor:pointer;transition:all .2s;width:100%;text-align:left;font-family:monospace;font-size:14px;color:#0f0}.game-item:hover,.replay-item:hover{background:#0f03}.game-item:focus,.replay-item:focus{outline:2px solid #0f0;outline-offset:2px}.difficulty-buttons{display:flex;flex-direction:column;gap:15px;margin:20px 0}#difficultySelect.hidden{display:none!important}.difficulty-btn{background:#00ff001a;border:2px solid #0f0;padding:20px;cursor:pointer;transition:all .2s;font-family:monospace;color:#0f0;text-align:left}.difficulty-btn:hover{background:#0f03;transform:translate(5px)}.difficulty-btn:focus{outline:2px solid #0f0;outline-offset:2px}.help-content{max-height:500px;overflow-y:auto;text-align:left;padding:20px;background:#0000004d;border:1px solid #0f0;margin:20px 0}.help-section{margin-bottom:30px}.help-section h3{color:#0f0;font-size:20px;margin-bottom:10px;border-bottom:1px solid #0f0;padding-bottom:5px}.help-section p{margin:8px 0;line-height:1.6;color:#0f0}.help-section strong{color:#0ff}#helpScreen h2{color:#0f0;margin-bottom:10px;outline:2px solid #0f0;outline-offset:2px}.difficulty-name{font-size:24px;font-weight:700;margin-bottom:5px}.difficulty-desc{font-size:14px;color:#aaa}#lobby{text-align:center;max-width:600px}#lobby h1{font-size:48px;margin-bottom:40px}.lobby-buttons{display:flex;flex-direction:column;gap:20px;margin-bottom:40px}.room-list{margin:30px 0}.room-list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px}.room-list h3{font-size:20px;margin:0;color:#0f0}.refresh-btn{background:#00ff001a;border:1px solid #0f0;color:#0f0;padding:5px 10px;font-size:12px;font-family:monospace;cursor:pointer;transition:all .2s}.refresh-btn:hover{background:#0f03}#roomListContent{min-height:100px;background:#00ff000d;border:1px solid #0f0;padding:15px;margin-bottom:20px}.room-item{background:#00ff001a;border:1px solid #0f0;padding:15px;margin:10px 0;cursor:pointer;transition:all .2s;font-family:monospace;color:#0f0;text-align:left}.room-item:hover{background:#0f03;transform:translate(5px)}.room-name{font-size:16px;font-weight:700;margin-bottom:5px}.room-info{font-size:12px;color:#aaa}.no-rooms{color:#aaa;font-style:italic;text-align:center;padding:20px}#app{position:fixed;top:0;left:0;width:100vw;height:100vh;display:flex;justify-content:center;align-items:center;background:#000}#gameCanvas{border:2px solid #333;display:block;margin:0 auto}#modeIndicator{position:absolute;top:10px;right:10px;background:#000c;padding:10px 20px;border:2px solid #0f0;font-size:16px;color:#0f0;z-index:50}#controlSwap{position:fixed;top:60px;right:10px;display:none;padding:8px 12px;background:#00ff004d;border:2px solid #0f0;color:#0f0;border-radius:5px;font-size:14px;font-weight:700;z-index:1000;cursor:pointer}#mobileMenuControls{position:fixed;top:100px;right:10px;display:none;flex-direction:row;gap:10px;z-index:1000}.mobile-menu-btn{width:50px;height:50px;font-size:24px;background:#0f03;border:2px solid #0f0;color:#0f0;border-radius:8px;cursor:pointer;user-select:none;-webkit-user-select:none;touch-action:manipulation;display:flex;align-items:center;justify-content:center}.mobile-menu-btn:active{background:#0f06}.mobile-btn{width:80px;height:80px;font-size:40px;background:#0f03;border:2px solid #0f0;color:#0f0;border-radius:10px;cursor:pointer;user-select:none;-webkit-user-select:none;touch-action:manipulation;display:flex;align-items:center;justify-content:center}.mobile-btn:active{background:#0f06}.mobile-btn.thrust-btn{width:80px;height:80px;font-size:40px}#status{position:fixed!important;top:50%!important;left:50%!important;transform:translate(-50%,-50%)!important;background:#000000e6!important;padding:20px 40px!important;border:2px solid #0f0!important;font-size:18px!important;text-align:center!important;min-width:400px!important;max-width:90%!important;z-index:2000!important;display:none}#status.visible{display:block!important}#status.hidden{display:none!important}@media (max-width: 768px){#status{min-width:300px!important;font-size:16px!important;padding:15px 20px!important}#qrCode{display:none}}#pauseOverlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#000c;display:flex;align-items:center;justify-content:center;z-index:2000}.pause-content{text-align:center;color:#0f0;font-family:monospace}.pause-content h1{font-size:72px;margin:0 0 20px;text-shadow:0 0 20px #0f0}.pause-content p{font-size:24px;margin:0}.hidden{display:none!important}.visible{display:block!important}#mobileControls{position:fixed;bottom:30px;left:0;right:0;width:100%;display:none;flex-direction:row;justify-content:space-between;align-items:flex-end;padding:0 20px;z-index:100;pointer-events:none;box-sizing:border-box}.mobile-control-group{display:flex;gap:15px;pointer-events:auto;flex-shrink:0}#mobileControls.visible{display:flex!important;flex-direction:row!important;justify-content:space-between!important}#controlSwap.visible{display:block!important}#mobileMenuControls.visible{display:flex!important}@media (max-width: 768px){canvas{max-height:100vh;width:auto}#mobileControls{bottom:10px;padding:0 10px}.mobile-btn{width:70px;height:70px;font-size:32px}.mobile-btn.thrust-btn{width:90px;height:90px;font-size:42px}}@media (max-width: 768px) and (orientation: portrait){canvas{max-width:100%;height:auto}}.modal{position:fixed;top:0;left:0;width:100%;height:100%;background:#000c;display:flex;align-items:center;justify-content:center;z-index:3000}.modal-content{background:#000;border:2px solid #0f0;padding:30px;max-width:400px;width:90%;font-family:monospace;color:#0f0}.modal-content h2{margin:0 0 20px;font-size:24px;text-align:center}.modal-field{margin-bottom:20px}.modal-field label{display:block;margin-bottom:5px;font-size:14px}.modal-field input{width:100%;padding:10px;background:#000;border:1px solid #0f0;color:#0f0;font-family:monospace;font-size:16px;box-sizing:border-box}.modal-field input:focus{outline:none;border-color:#0ff;box-shadow:0 0 5px #00ffff4d}.modal-buttons{display:flex;gap:10px;justify-content:center;margin-top:25px}.modal-btn{padding:10px 20px;background:#000;border:2px solid #0f0;color:#0f0;font-family:monospace;font-size:16px;cursor:pointer;transition:all .2s}.modal-btn:hover{background:#0f0;color:#000}.modal-btn.primary{background:#00ff001a}#waitingLobby{position:fixed;top:0;left:0;width:100%;height:100%;background:#000;color:#0f0;display:flex;align-items:center;justify-content:center;font-family:Courier New,Courier,monospace;z-index:1000}.waiting-content{text-align:center;max-width:600px;padding:40px;border:2px solid #0f0;background:#00ff000d}.waiting-content h1{font-size:36px;margin-bottom:30px;color:#0f0}#roomInfo{margin-bottom:30px;font-size:18px}#roomName{color:#0ff;font-weight:700}#playerListSection{margin-bottom:30px}#playerListSection h3{font-size:20px;margin-bottom:15px;color:#0f0}#playerNames{display:flex;flex-direction:column;gap:8px;margin-bottom:20px}.player-item{padding:8px 15px;background:#00ff001a;border:1px solid #0f0;border-radius:3px;font-size:16px}.player-item.creator{border-color:#ff0;color:#ff0}.player-item.creator:after{content:" (Creator)";font-size:12px}#gameControls{margin-bottom:30px}#waitingMessage{font-size:16px;color:#aaa;font-style:italic}.menu-btn.primary{background:#0f0;color:#000;border-color:#0f0}.menu-btn.primary:hover{background:#0a0;border-color:#0a0}.menu-btn.danger{background:#000;color:red;border-color:red}.menu-btn.danger:hover{background:red;color:#000}#app.presentation-mode{position:fixed;top:0;left:0;width:100vw;height:100vh;z-index:999;background:#000}#app.presentation-mode #gameCanvas{width:100%;height:100%;object-fit:contain}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;transition-duration:.01ms!important}}#artemis-ticker{position:fixed;bottom:60px;left:0;width:100%;background:#0b3d91e6;color:#fff;font-family:Courier New,monospace;font-size:14px;padding:8px 0;overflow:hidden;z-index:500;display:none}#artemis-ticker span{display:inline-block;white-space:nowrap;animation:ticker-scroll 20s linear infinite;padding-left:100%}@keyframes ticker-scroll{0%{transform:translate(0)}to{transform:translate(-100%)}}.diff-filter{background:transparent;color:#0f0;border:1px solid #0f0;padding:4px 12px;margin:0 3px;cursor:pointer;font-family:Courier New,monospace}.diff-filter.active{background:#0f0;color:#000}.outcome-filter{background:transparent;color:#0f0;border:1px solid #0f0;padding:4px 12px;margin:0 3px;cursor:pointer;font-family:Courier New,monospace}.outcome-filter.active{background:#0f0;color:#000}#devTools{position:fixed;bottom:10px;right:10px;width:280px;max-height:350px;background:#000000f2;border:2px solid #0f0;border-radius:5px;color:#0f0;font-family:monospace;font-size:11px;padding:10px;overflow-y:auto;z-index:10000;transition:transform .3s ease;box-shadow:0 0 20px #00ff004d}#devTools::-webkit-scrollbar{width:8px}#devTools::-webkit-scrollbar-track{background:#00000080}#devTools::-webkit-scrollbar-thumb{background:#0f0;border-radius:4px}#devTools.hidden{transform:translate(calc(100% + 20px))}#devTools h3{margin:0 0 10px;color:#0ff;font-size:14px}#devTools .dev-section{margin-bottom:10px;padding-bottom:10px;border-bottom:1px solid #0f0}#devTools .dev-section:last-child{border-bottom:none}#devTools .dev-label{color:#888;display:inline-block;width:100px}#devTools .dev-value,#devTools .dev-status-ok{color:#0f0}#devTools .dev-status-error{color:red}#devTools .dev-status-warn{color:#ff0}#perfMonitor{position:fixed;top:10px;left:10px;background:#000c;border:1px solid #0f0;padding:10px;font-family:Courier New,Courier,monospace;font-size:12px;color:#0f0;z-index:9999;min-width:120px}.perf-row{display:flex;justify-content:space-between;margin:2px 0;gap:10px}.perf-good{color:#0f0}.perf-ok{color:#ff0}.perf-warn{color:red}.commentary-bar{position:fixed;bottom:20px;left:50%;transform:translate(-50%);background:#000000d9;border:1px solid rgba(255,200,0,.4);border-radius:8px;padding:10px 24px;color:#fff;font-family:Courier New,monospace;font-size:16px;z-index:1000;max-width:80%;text-align:center;opacity:0;transition:opacity .4s ease;pointer-events:none}.commentary-bar.visible{opacity:1}.commentary-bar .commentary-role{color:gold;font-weight:700;margin-right:8px;text-transform:uppercase}.commentary-bar .commentary-text{color:#fff}
