:root{--primary-color: #2266ff;--secondary-color: #ff6622;--background-color: #000000;--text-color: #ffffff;--panel-background: rgba(20, 20, 30, .8);--control-background: rgba(40, 40, 60, .8)}html,body,#root{margin:0;padding:0;width:100%;height:100%;background-color:#000;overflow:hidden}body{font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;background-color:var(--background-color);color:var(--text-color)}#root{text-align:center}.logo{height:6em;padding:1.5em;will-change:filter;transition:filter .3s}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.react:hover{filter:drop-shadow(0 0 2em #61dafbaa)}@keyframes logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (prefers-reduced-motion: no-preference){a:nth-of-type(2) .logo{animation:logo-spin infinite 20s linear}}.card{padding:2em}.read-the-docs{color:#888}.app{width:100%;height:100%;display:flex;flex-direction:column;position:relative;overflow:hidden;background-color:#000!important}.globe-container{width:100%;height:100%;position:relative;z-index:1;overflow:hidden;background-color:#000!important}.black-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#000;z-index:9999;transition:opacity .8s ease-in-out;pointer-events:none}.globe-container canvas{background-color:#000!important}canvas{display:block!important;background-color:#000!important}.loading-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000;z-index:1000}.controls-container{position:absolute;bottom:20px;left:20px;z-index:10;width:auto;max-width:280px;transform:none}.tour-controls-panel{background-color:#000000bf;border-radius:6px;box-shadow:0 2px 8px #0006;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);transition:all .3s ease;overflow:hidden;font-size:11px}.tour-controls-panel.collapsed{width:40px;height:40px;border-radius:6px;overflow:hidden}.tour-controls-panel.expanded{min-width:220px;max-width:280px;height:auto;max-height:80vh;box-shadow:0 4px 12px #0009;border:none!important;outline:none!important;text-decoration:none!important;position:absolute;bottom:0;left:0;overflow-y:auto}.tour-controls-panel .controls{display:flex;flex-direction:column;gap:10px;padding:12px;min-width:220px;animation:fadeInControls .2s ease-out;border-top:1px solid rgba(255,255,255,.1)}@keyframes fadeInControls{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.tour-controls-panel .current-validator,.tour-controls-panel .validator-info{margin-bottom:10px;max-width:100%;overflow-wrap:break-word}.tour-controls-panel .validator-info h2{font-size:18px;margin:0 0 8px}.tour-controls-panel .validator-info p{margin:4px 0;font-size:12px}.tour-controls-panel .collection-status{margin:4px 0}.tour-controls-panel .collection-progress{font-size:10px;color:#acf;font-weight:500}.tour-controls{max-height:80vh;overflow-y:auto}.tour-header,.tour-header h3{display:none}.city-info{margin-bottom:8px}.city-info h2{margin:0 0 3px;font-size:14px;font-weight:600;color:var(--text-color)}.city-info p{margin:1px 0;font-size:10px;color:#fffc}.controls{display:flex;flex-direction:column;gap:6px}.city-selector{display:flex;gap:3px}.city-selector select{flex:1;background-color:var(--control-background);color:var(--text-color);border:none;border-radius:2px;padding:5px 8px;font-size:10px;outline:none}button{cursor:pointer;padding:5px 10px;font-size:10px;font-weight:600;border:none;border-radius:2px;transition:all .2s ease}.go-to-city-btn{background-color:var(--primary-color);color:#fff}.go-to-city-btn:hover{background-color:#37f}.go-to-city-btn:disabled{background-color:#555;cursor:not-allowed}.tour-buttons{display:flex;justify-content:center;margin-top:4px}.start-tour-btn{background-color:var(--primary-color);color:#fff;width:40%;min-width:60px}.start-tour-btn:hover{background-color:#37f}.stop-tour-btn{background-color:var(--secondary-color);color:#fff;width:40%;min-width:60px}.stop-tour-btn:hover{background-color:#f73}.loading{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:var(--text-color);font-size:20px}.loading,.error-container,.webgl-error{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;flex-direction:column;justify-content:center;align-items:center;background-color:#000c;color:#fff;z-index:10;text-align:center;padding:20px}.loading{font-size:24px}.error-container h2,.webgl-error h2{color:#ff6b6b;margin-bottom:16px}.error-container button{margin-top:16px;padding:8px 16px;background-color:#4a6fa5;color:#fff;border:none;border-radius:4px;cursor:pointer}.error-container button:hover{background-color:#3a5a80}@media (max-width: 768px){.controls-container{width:auto;max-width:80%;left:20px;bottom:20px}.city-selector{flex-direction:row;flex-wrap:wrap}.tour-controls-panel.expanded{min-width:180px;max-width:240px;max-height:70vh}.navigator-toggle-btn{padding:8px}.zoom-controls-container{top:20px;left:20px}}@media (max-width: 480px){.controls-container{width:auto;max-width:85%;left:15px;right:5%;bottom:15px}.city-selector{flex-direction:column}.tour-controls button{padding:8px 12px;font-size:14px}.zoom-controls-container{top:15px;left:15px}}@media only screen and (min-device-width: 768px) and (max-device-width: 1024px){html,body,#root,.app,.globe-container{position:relative;width:100%;height:100%;min-height:100%;overflow:hidden}.controls-container{position:absolute;bottom:60px;left:20px;width:208px;max-width:224px;z-index:100;transform:none!important}canvas{height:100vh!important;width:100vw!important;position:fixed!important;top:0!important;left:0!important}.tour-controls{transform:translateZ(0);-webkit-transform:translateZ(0);backface-visibility:hidden;-webkit-backface-visibility:hidden}}.zoom-controls-container{position:absolute;top:20px;left:20px;z-index:10;margin:0}.zoom-controls-panel{background-color:#0009;border-radius:6px;box-shadow:0 2px 8px #0006;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);transition:all .3s ease;overflow:hidden}.zoom-controls-panel.collapsed{width:40px;height:40px}.zoom-controls-panel.expanded{min-width:220px;height:auto;box-shadow:0 4px 12px #0009;border:none!important;outline:none!important;text-decoration:none!important}.camera-toggle-btn{display:flex;align-items:center;gap:8px;background-color:#0009;color:#fff;border:none!important;padding:10px;width:100%;cursor:pointer;border-radius:6px;transition:all .2s ease;box-shadow:0 2px 8px #0006;outline:none!important;-webkit-tap-highlight-color:transparent;text-decoration:none!important}.camera-toggle-btn *,.camera-toggle-btn *:focus,.camera-toggle-btn svg,.camera-toggle-btn svg *,.camera-toggle-btn:focus,.camera-toggle-btn:active,.camera-toggle-btn:hover{outline:none!important;border:none!important;box-shadow:none!important;text-decoration:none!important}.camera-toggle-btn:hover{background-color:#28283ccc;transform:scale(1.02)}.zoom-controls-panel.collapsed .camera-toggle-btn:hover{background-color:#3c3c50e6;transform:scale(1.05);box-shadow:0 3px 10px #0009}.camera-toggle-btn:active{transform:scale(.98)}.zoom-controls-panel.expanded .camera-toggle-btn{border-radius:6px 6px 0 0;box-shadow:none;border-top:none!important;border-left:none!important;border-right:none!important;border-bottom:1px solid rgba(255,255,255,.1)}.panel-title{font-size:13px;font-weight:500;outline:none!important;border:none!important;-webkit-user-select:none;user-select:none;pointer-events:none}.zoom-controls{display:flex;flex-direction:column;gap:10px;padding:12px;min-width:220px;animation:fadeInControls .2s ease-out}@keyframes fadeInControls{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}.slider-container{display:flex;flex-direction:column;gap:5px}.slider-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:2px}.slider-label{font-size:12px;color:#fff;font-weight:500;opacity:.9}.reset-button{width:24px;height:24px;border-radius:4px;border:none;display:flex;align-items:center;justify-content:center;background-color:#ffffff1a;color:#fff;cursor:pointer;transition:all .2s ease;padding:5px;outline:none}.reset-button:hover{background-color:#fff3;transform:scale(1.05)}.reset-button:active{transform:scale(.95)}.slider-control{display:flex;flex-direction:column;gap:5px}.slider-with-icons{display:flex;align-items:center;gap:8px;background-color:#ffffff0d;padding:6px 8px;border-radius:5px}.slider-input{flex:1;width:100%;height:4px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:#ffffff4d;outline:none;border-radius:2px}.slider-input::-webkit-slider-thumb{-webkit-appearance:none;width:12px;height:12px;border-radius:50%;background:#fff;cursor:pointer;box-shadow:0 0 4px #00000080}.slider-input::-moz-range-thumb{width:12px;height:12px;border-radius:50%;background:#fff;cursor:pointer;border:none;box-shadow:0 0 4px #00000080}.slider-icon{color:#fff;opacity:.7;display:flex;align-items:center;justify-content:center;width:18px}.slider-value{color:#fff;font-size:11px;margin-left:auto;opacity:.8;font-weight:500;text-align:right}.tour-controls-panel .api-status{margin-top:12px;padding:8px;background:#0000004d;border-radius:4px;border:1px solid rgba(255,255,255,.1)}.tour-controls-panel .status-indicator{display:flex;align-items:center;gap:6px;font-size:11px;font-weight:500;margin-bottom:4px}.tour-controls-panel .status-dot{width:8px;height:8px;border-radius:50%;background:#f44;transition:background-color .3s ease}.tour-controls-panel .status-indicator.connected .status-dot{background:#4f4;box-shadow:0 0 6px #44ff4480}.tour-controls-panel .error-message{font-size:10px;color:#f66;margin:2px 0}.tour-controls-panel .last-update{font-size:10px;color:#999;margin:2px 0}.zoom-controls-panel *:before,.zoom-controls-panel *:after{border:none!important;outline:none!important;box-shadow:none!important}body .zoom-controls-panel .camera-toggle-btn,body .zoom-controls-panel.expanded .camera-toggle-btn,body .zoom-controls-panel .camera-toggle-btn:hover,body .zoom-controls-panel .camera-toggle-btn:focus,body .zoom-controls-panel .camera-toggle-btn:active,body .zoom-controls-panel .camera-toggle-btn:focus-visible,body .zoom-controls-panel .camera-toggle-btn:focus-within{border-color:transparent!important;outline-color:transparent!important;box-shadow:none!important}.camera-toggle-btn:focus-visible{outline:0!important}.navigator-toggle-btn{display:flex;align-items:center;justify-content:flex-start;gap:8px;background-color:#14141ecc;color:#fff;border:none!important;padding:10px 12px;width:100%;cursor:pointer;border-radius:6px 6px 0 0;transition:all .2s ease;box-shadow:0 2px 4px #0000004d;outline:none!important;-webkit-tap-highlight-color:transparent;text-decoration:none!important;font-weight:500;font-size:13px;letter-spacing:.5px}.navigator-toggle-btn *,.navigator-toggle-btn *:focus,.navigator-toggle-btn svg,.navigator-toggle-btn svg *,.navigator-toggle-btn:focus,.navigator-toggle-btn:active,.navigator-toggle-btn:hover{outline:none!important;border:none!important;box-shadow:none!important;text-decoration:none!important}.navigator-toggle-btn:hover{background-color:#28283ccc;transform:scale(1.02)}.tour-controls-panel.collapsed .navigator-toggle-btn:hover{background-color:#3c3c50e6;transform:scale(1.05);box-shadow:0 3px 10px #0009}.navigator-toggle-btn:active{transform:scale(.98)}.tour-controls-panel.expanded .navigator-toggle-btn{border-radius:6px 6px 0 0;box-shadow:none;border-top:none!important;border-left:none!important;border-right:none!important;border-bottom:1px solid rgba(255,255,255,.1);background-color:#1e1e28cc;padding:12px}.tour-controls-panel,.tour-controls-panel:focus-within,.tour-controls-panel *,.tour-controls-panel *:focus,.tour-controls-panel *:hover,.tour-controls-panel.expanded,.tour-controls-panel.expanded *,.tour-controls-panel.expanded *:focus,.tour-controls-panel.expanded *:hover{outline:none!important;-webkit-tap-highlight-color:transparent!important}.visualization-controls-simple{position:fixed;bottom:20px;left:20px;z-index:1000}.visualization-control-btn{display:flex;align-items:center;gap:8px;background-color:#000c;border:2px solid rgba(255,255,255,.2);border-radius:25px;padding:12px 18px;color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);box-shadow:0 4px 12px #0000004d}.key-hint{font-size:10px;opacity:.7;margin-left:5px;font-weight:400;background-color:#ffffff1a;padding:2px 6px;border-radius:4px;border:1px solid rgba(255,255,255,.2)}.visualization-control-btn:hover{background-color:#000000e6;border-color:#fff6;transform:translateY(-1px);box-shadow:0 6px 16px #0006}.visualization-control-btn.active{background-color:#dc2626cc;border-color:#dc262699}.visualization-control-btn.active:hover{background-color:#dc2626e6;border-color:#dc2626cc}.visualization-control-btn.inactive{background-color:#22c55ecc;border-color:#22c55e99}.visualization-control-btn.inactive:hover{background-color:#22c55ee6;border-color:#22c55ecc}.btn-label{font-size:14px;font-weight:600}.status-panel{position:fixed;top:20px;right:20px;z-index:1000;background-color:#000000bf;border-radius:8px;box-shadow:0 4px 12px #0006;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);transition:all .3s ease;overflow:hidden;font-size:12px;border:1px solid rgba(255,255,255,.1)}.status-panel.collapsed{width:45px;height:45px;border-radius:50%}.status-panel.expanded{min-width:280px;max-width:350px;height:auto;max-height:70vh;border-radius:8px;overflow-y:auto}.status-toggle-btn{width:100%;height:45px;background:transparent;border:none;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;padding:0 12px;transition:all .2s ease;font-size:12px;font-weight:500}.status-toggle-btn:hover{background-color:#ffffff1a}.status-panel.collapsed .status-toggle-btn{width:45px;height:45px;border-radius:50%;padding:0}.status-panel.collapsed .panel-title{display:none}.status-content{padding:16px;display:flex;flex-direction:column;gap:16px;border-top:1px solid rgba(255,255,255,.1);animation:fadeInStatus .3s ease-out}@keyframes fadeInStatus{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.status-content h3{margin:0 0 8px;font-size:14px;font-weight:600;color:#fff;border-bottom:1px solid rgba(255,255,255,.1);padding-bottom:4px}.status-content h4{margin:0 0 6px;font-size:16px;font-weight:600;color:#fff}.connection-status,.current-validator,.simulation-status,.visualization-status{background-color:#ffffff0d;border-radius:6px;padding:12px}.status-indicator,.sim-status,.viz-status{display:flex;align-items:center;gap:8px;margin-bottom:8px;font-weight:500}.status-dot,.sim-dot,.viz-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.status-indicator.connected .status-dot{background-color:#22c55e;box-shadow:0 0 6px #22c55e99}.status-indicator.disconnected .status-dot{background-color:#ef4444;box-shadow:0 0 6px #ef444499}.sim-status.running .sim-dot,.viz-status.running .viz-dot{background-color:#22c55e;box-shadow:0 0 6px #22c55e99}.sim-status.stopped .sim-dot,.viz-status.stopped .viz-dot{background-color:#94a3b8;box-shadow:0 0 6px #94a3b899}.collection-progress{font-size:11px;color:#93c5fd;font-weight:500;margin-bottom:4px}.error-message{background-color:#ef444433;border:1px solid rgba(239,68,68,.4);border-radius:4px;padding:8px;font-size:11px;color:#fca5a5;margin-top:8px}.last-update{font-size:10px;color:#fff9;margin-top:4px}.validator-info p{margin:4px 0;font-size:12px;color:#fffc}.validator-info p strong{color:#fff;font-weight:600}.sim-info{margin-top:8px}.sim-info p{margin:2px 0;font-size:11px;color:#ffffffb3}.status-container{position:absolute;top:0;right:0;pointer-events:none;z-index:1000}.status-container>*{pointer-events:all}.controls-container{position:absolute;top:0;left:0;pointer-events:none;z-index:1000}.controls-container>*{pointer-events:all}.copyright-notice{position:absolute;bottom:10px;right:10px;font-size:10px;color:#ffffff80;text-align:right;pointer-events:none;z-index:100;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif}.performance-notification{position:fixed;bottom:20px;left:50%;transform:translate(-50%);background-color:#000000bf;color:#fff;padding:8px 16px;border-radius:8px;z-index:1000;text-align:center;animation:fadeInOut 2s ease forwards;border:1px solid rgba(255,255,255,.2);box-shadow:0 4px 8px #0000004d}.notification-content{display:flex;flex-direction:column;align-items:center}.notification-key{font-size:.8em;opacity:.7;margin-top:4px}@keyframes fadeInOut{0%{opacity:0;transform:translate(-50%,20px)}20%{opacity:1;transform:translate(-50%)}80%{opacity:1;transform:translate(-50%)}to{opacity:0;transform:translate(-50%)}}.connection-notification{bottom:auto;top:20px;border-color:#228be666;background-color:#000000d9}:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:dark;color:#ffffffde;background-color:#000;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh;background-color:#000}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#fff;background-color:#000}a:hover{color:#747bff}button{background-color:#333}}.webgl-error{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;background-color:#000c;border-radius:8px;color:#fff;text-align:center;width:80%;max-width:500px;margin:2rem auto}.webgl-error button{margin-top:1rem;padding:.5rem 1rem;background-color:#4a90e2;color:#fff;border:none;border-radius:4px;cursor:pointer}.webgl-error button:hover{background-color:#357abd}.loading{display:flex;align-items:center;justify-content:center;height:100%;font-size:1.5rem;color:#fff}.error-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;color:#fff;text-align:center}.performance-warning{position:absolute;bottom:10px;left:10px;padding:8px;background-color:#000000b3;color:#ff9500;border-radius:4px;font-size:12px;z-index:100}
