body{margin:0;padding:0;font-family:Courier New,monospace;background-color:#000;overflow:hidden}#root{width:100vw;height:100vh;overflow:hidden}*{margin:0;padding:0;box-sizing:border-box}.app-container{position:relative;width:100vw;height:100vh;background-color:#000;overflow:hidden;transition:background-color .5s ease-in-out}.app-container.inverted{background-color:red}.app-container *{user-select:none;-webkit-user-select:none}.instructions{position:fixed;top:20px;left:50%;transform:translate(-50%);background-color:#000c;color:red;padding:14px 28px;border:1px solid #ff0000;border-radius:4px;font-family:Courier New,monospace;font-size:16px;z-index:1000;pointer-events:none!important;transition:all .5s ease-in-out}.inverted .instructions{background-color:#f00c;color:#000;border-color:#000}.debug-info{position:fixed;top:70px;left:50%;transform:translate(-50%);background-color:#000000e6;color:red;padding:12px 20px;border:1px solid #ff0000;border-radius:4px;font-family:Courier New,monospace;font-size:12px;z-index:1000;pointer-events:none!important;transition:all .5s ease-in-out;display:flex;flex-direction:column;gap:4px;text-align:center}.inverted .debug-info{background-color:#ff0000e6;color:#000;border-color:#000}.debug-info .ready{color:#0f0;font-weight:700;animation:pulse 1s infinite}.inverted .debug-info .ready{color:#0f0}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.gps-status-indicator{display:flex;flex-direction:column;gap:10px;background-color:#00000080;padding:16px 20px;border:2px solid #ff0000;border-radius:8px;margin-top:16px;width:100%;max-width:320px;pointer-events:none;transition:all .5s ease-in-out}.inverted .gps-status-indicator{background-color:#ff000080;border-color:#000}.status-row{display:flex;align-items:center;gap:10px;font-family:Courier New,monospace;font-size:14px;transition:all .3s ease-in-out}.status-icon{font-size:18px;min-width:22px;text-align:center}.status-row.verified .status-icon,.status-row.verified .status-text,.inverted .status-row.verified .status-icon,.inverted .status-row.verified .status-text{color:#0f0}.inverted .status-row.pending-idle .status-icon{animation:blink-red-orange-icon-inverted 2s ease-in-out infinite}.inverted .status-row.pending-idle .status-text{animation:blink-red-orange-text-inverted 2s ease-in-out infinite}@keyframes blink-red-orange-icon-inverted{0%,to{color:#000}50%{color:#f60}}@keyframes blink-red-orange-text-inverted{0%,to{color:#000}50%{color:#f60}}.status-row.pending-idle .status-icon{animation:blink-red-orange-icon 2s ease-in-out infinite}.status-row.pending-idle .status-text{animation:blink-red-orange-text 2s ease-in-out infinite;font-size:15px;font-weight:700}@keyframes blink-red-orange-icon{0%,to{color:red}50%{color:#f90}}@keyframes blink-red-orange-text{0%,to{color:red}50%{color:#f90}}.status-row.pending-active{background-color:#ffa50026;padding:8px 12px;margin:-4px -8px;border-radius:4px;border:2px solid #ff9900;animation:pulse-orange-glow 1s ease-in-out infinite}.inverted .status-row.pending-active{background-color:#ffa50026;border-color:#f60}@keyframes pulse-orange-glow{0%,to{box-shadow:0 0 #ffa50000;background-color:#ffa50026}50%{box-shadow:0 0 20px #ffa50099;background-color:#ffa5004d}}.status-row.pending-active .status-icon{color:#f90;font-size:20px;animation:blink-orange 1s ease-in-out infinite}.inverted .status-row.pending-active .status-icon{color:#f60}@keyframes blink-orange{0%,to{opacity:1;color:#f90}50%{opacity:.4;color:#f60}}.status-row.pending-active .status-text{color:#f90;font-size:15px;font-weight:700;animation:blink-text 1s ease-in-out infinite}.inverted .status-row.pending-active .status-text{color:#f60}@keyframes blink-text{0%,to{opacity:1}50%{opacity:.5}}.status-text{color:red;font-weight:700;letter-spacing:.5px;transition:color .3s ease-in-out}.inverted .status-text{color:#000}.modal-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background-color:#000c;display:flex;justify-content:center;align-items:center;z-index:2000;animation:fadeIn .3s ease-in-out}.inverted .modal-overlay{background-color:#f00c}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background-color:#000;border:2px solid #ff0000;padding:40px;border-radius:8px;max-width:500px;width:90%;text-align:center;animation:slideUp .4s ease-out;transition:all .3s ease-in-out}.inverted .modal-content{background-color:red;border-color:#000}@keyframes slideUp{0%{transform:translateY(50px);opacity:0}to{transform:translateY(0);opacity:1}}.qr-code-container{display:flex;justify-content:center;align-items:center;margin-bottom:24px;padding:20px;background-color:#ff00000d;border-radius:8px;border:1px solid #ff0000;transition:all .3s ease-in-out}.inverted .qr-code-container{background-color:#0000000d;border-color:#000}.qr-code{filter:drop-shadow(0 0 10px currentColor)}.modal-content h2{color:red;font-family:Courier New,monospace;font-size:36px;margin-bottom:12px;font-weight:700;letter-spacing:3px;text-transform:uppercase;transition:color .3s ease-in-out}.inverted .modal-content h2{color:#000}.modal-content p{color:red;font-family:Courier New,monospace;font-size:16px;margin-bottom:24px;opacity:.8;transition:color .3s ease-in-out}.inverted .modal-content p{color:#000}.city-name{font-size:32px!important;font-weight:700!important;opacity:1!important;letter-spacing:2px!important;margin-bottom:28px!important}.modal-content button{background-color:transparent;border:2px solid #ff0000;color:red;padding:14px 36px;font-family:Courier New,monospace;font-size:18px;cursor:pointer;border-radius:4px;transition:all .3s ease-in-out;text-transform:uppercase;letter-spacing:1px}.inverted .modal-content button{border-color:#000;color:#000}.modal-content button:hover{background-color:red;color:#000;transform:scale(1.05)}.inverted .modal-content button:hover{background-color:#000;color:red}canvas{outline:none;-webkit-tap-highlight-color:transparent;touch-action:none;cursor:grab;filter:brightness(1.3) contrast(1.3) saturate(1.5) drop-shadow(0 0 25px rgba(255,0,0,.4));transition:filter .5s ease-in-out}.inverted canvas{filter:brightness(1.3) contrast(1.3) saturate(1.5) drop-shadow(0 0 25px rgba(0,0,0,.4))}canvas:active{cursor:grabbing}.rotation-controls{position:fixed;bottom:20px;left:50%;transform:translate(-50%);display:flex;flex-direction:column;align-items:center;gap:12px;background-color:#000c;padding:16px 24px;border:1px solid #ff0000;border-radius:8px;z-index:1000;pointer-events:auto;transition:all .5s ease-in-out}.inverted .rotation-controls{background-color:#f00c;border-color:#000}.control-label{color:red;font-family:Courier New,monospace;font-size:14px;text-transform:uppercase;letter-spacing:1px;margin-bottom:4px;transition:color .3s ease-in-out}.inverted .control-label{color:#000}.arrow-controls{display:flex;flex-direction:column;align-items:center;gap:4px}.horizontal-arrows{display:flex;gap:40px;align-items:center}.arrow-btn{background-color:transparent;border:2px solid #ff0000;color:red;width:48px;height:48px;font-size:24px;cursor:pointer;border-radius:4px;transition:all .2s ease-in-out;display:flex;align-items:center;justify-content:center;user-select:none;-webkit-user-select:none;touch-action:manipulation}.inverted .arrow-btn{border-color:#000;color:#000}.arrow-btn:hover{background-color:red;color:#000;transform:scale(1.1)}.inverted .arrow-btn:hover{background-color:#000;color:red}.arrow-btn:active{transform:scale(.95)}.drag-pad{width:200px;height:80px;background-color:#0000004d;border:1px dashed #ff0000;border-radius:8px;display:flex;align-items:center;justify-content:center;color:red;font-family:Courier New,monospace;font-size:16px;cursor:move;transition:all .3s ease-in-out;margin-top:8px;user-select:none;-webkit-user-select:none;touch-action:none}.inverted .drag-pad{border-color:#000;color:#000;background-color:#ff00004d}.drag-pad:hover{background-color:#f003;border-style:solid}.inverted .drag-pad:hover{background-color:#0003}.drag-pad:active{background-color:#f006;transform:scale(.98)}.inverted .drag-pad:active{background-color:#0006}@media(max-width:768px){.rotation-controls{bottom:10px;padding:12px 16px}.arrow-btn{width:44px;height:44px;font-size:22px}.drag-pad{width:160px;height:60px;font-size:14px}.horizontal-arrows{gap:30px}.instructions{font-size:14px;padding:12px 20px}.modal-content h2{font-size:28px}.city-name{font-size:24px!important}.gps-status-indicator{margin-top:12px;padding:12px 16px;max-width:100%}.status-row{font-size:12px}.status-icon{font-size:16px}.status-row.pending-idle .status-text{font-size:13px}.rotation-controls{padding:12px 16px}}
