*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{width:100%;height:100%;overflow:hidden;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#0d1117}#map{position:absolute;inset:0}#controls{position:absolute;top:12px;right:12px;z-index:10;background:#0d1117e0;border:1px solid rgba(255,255,255,.12);border-radius:10px;padding:14px 16px;width:240px;backdrop-filter:blur(8px);color:#e6edf3;box-shadow:0 4px 24px #00000080}#controls h2{font-size:13px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:#58a6ff;margin-bottom:12px}.control-row{margin-bottom:12px}.control-row:last-child{margin-bottom:0}.control-label{display:flex;justify-content:space-between;align-items:center;font-size:12px;color:#8b949e;margin-bottom:5px}.control-label span:last-child{color:#e6edf3;font-weight:500}input[type=range]{-webkit-appearance:none;appearance:none;width:100%;height:4px;background:#ffffff26;border-radius:2px;outline:none}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;border-radius:50%;background:#58a6ff;cursor:pointer;border:2px solid #0d1117;box-shadow:0 0 4px #58a6ff80}input[type=range]::-moz-range-thumb{width:14px;height:14px;border-radius:50%;background:#58a6ff;cursor:pointer;border:2px solid #0d1117;box-shadow:0 0 4px #58a6ff80}input[type=range]::-moz-range-track{height:4px;background:#ffffff26;border-radius:2px;border:none}.dual-range{position:relative;height:24px}.dual-range:after{content:"";position:absolute;left:0;right:0;top:50%;height:4px;transform:translateY(-50%);background:#ffffff26;border-radius:2px;pointer-events:none}.dual-range input[type=range]{position:absolute;left:0;top:0;width:100%;height:100%;margin:0;pointer-events:none;background:transparent}.dual-range input[type=range]::-webkit-slider-thumb{pointer-events:auto}.dual-range input[type=range]::-moz-range-thumb{pointer-events:auto}.dual-range input[type=range]::-moz-range-track{background:transparent;border:none}.status-row{display:flex;align-items:center;gap:6px;font-size:11px;color:#8b949e;margin-top:4px}#status-dot{width:8px;height:8px;border-radius:50%;background:#3fb950;flex-shrink:0}#status-dot.loading{background:#d29922;animation:pulse 1s ease-in-out infinite}#status-dot.error{background:#f85149}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}#timestamp{font-size:11px;color:#8b949e;word-break:break-all}.btn-row{display:flex;gap:6px;margin-top:4px}#controls button,#animation-bar button,#legend-toggle button{flex:1;padding:5px 8px;font-size:11px;font-weight:500;border:1px solid rgba(255,255,255,.15);border-radius:6px;background:#ffffff0f;color:#e6edf3;cursor:pointer;transition:background .15s,border-color .15s}#controls button:hover,#animation-bar button:hover,#legend-toggle button:hover{background:#58a6ff26;border-color:#58a6ff}#controls button:active,#animation-bar button:active,#legend-toggle button:active{background:#58a6ff40}#legend-toggle{position:absolute;bottom:28px;right:12px;z-index:10}#legend{position:absolute;bottom:60px;right:12px;z-index:10;background:#0d1117e0;border:1px solid rgba(255,255,255,.12);border-radius:10px;padding:10px 12px;backdrop-filter:blur(8px);display:none}#legend.visible{display:block}.legend-item{display:flex;align-items:center;gap:8px;padding:2px 0}.legend-swatch{width:18px;height:10px;border-radius:2px;flex-shrink:0}.legend-item span{font-size:11px;color:#e6edf3;white-space:nowrap}.seg-control{display:flex;gap:0;border-radius:6px;overflow:hidden;border:1px solid rgba(255,255,255,.15)}#controls .seg-btn{flex:1;padding:5px 10px;font-size:11px;font-weight:500;border:none;background:#ffffff0a;color:#8b949e;cursor:pointer;transition:background .15s,color .15s;border-radius:0}#controls .seg-btn:not(:last-child){border-right:1px solid rgba(255,255,255,.1)}#controls .seg-btn:hover:not(.active){background:#ffffff14;color:#c9d1d9}#controls .seg-btn.active{background:#58a6ff33;color:#58a6ff}.seg-control-4 .seg-btn{padding:5px 2px;font-size:10.5px;overflow:visible}.volume-status-label{font-size:11px;color:#8b949e;font-weight:500}#animation-bar{position:absolute;bottom:28px;left:50%;transform:translate(-50%);z-index:10;display:flex;align-items:center;gap:10px;background:#0d1117e0;border:1px solid rgba(255,255,255,.12);border-radius:10px;padding:8px 14px;backdrop-filter:blur(8px);color:#e6edf3;box-shadow:0 4px 24px #00000080;min-width:340px}#btn-play{flex:none;width:32px;height:32px;display:flex;align-items:center;justify-content:center;padding:0;border-radius:50%}#frame-scrubber{flex:1;min-width:80px}#frame-time{font-size:11px;color:#8b949e;white-space:nowrap;min-width:44px;text-align:center}#frame-counter{font-size:11px;color:#58a6ff;font-weight:500;white-space:nowrap;min-width:30px;text-align:center}#speed-select{font-size:11px;font-weight:500;color:#e6edf3;background:#ffffff0f;border:1px solid rgba(255,255,255,.15);border-radius:6px;padding:4px 6px;cursor:pointer;outline:none}#speed-select:hover{border-color:#58a6ff;background:#58a6ff26}#speed-select option{background:#161b22;color:#e6edf3}#controls button:focus-visible,#animation-bar button:focus-visible,#legend-toggle button:focus-visible,input[type=range]:focus-visible,select:focus-visible{outline:2px solid #58a6ff;outline-offset:2px}#embed-bar{position:absolute;bottom:16px;left:50%;transform:translate(-50%);z-index:10;display:flex;align-items:center;gap:10px;background:#0d1117e0;border:1px solid rgba(255,255,255,.12);border-radius:10px;padding:8px 14px;backdrop-filter:blur(8px);color:#e6edf3;box-shadow:0 4px 24px #00000080}#embed-bar .seg-control{display:flex;gap:0;border-radius:6px;overflow:hidden;border:1px solid rgba(255,255,255,.15)}#embed-bar .seg-btn{padding:5px 10px;font-size:11px;font-weight:500;border:none;background:#ffffff0a;color:#8b949e;cursor:pointer;transition:background .15s,color .15s;border-radius:0}#embed-bar .seg-btn:not(:last-child){border-right:1px solid rgba(255,255,255,.1)}#embed-bar .seg-btn:hover:not(.active){background:#ffffff14;color:#c9d1d9}#embed-bar .seg-btn.active{background:#58a6ff33;color:#58a6ff}#embed-bar input[type=range]{width:80px}#embed-expand{flex:none;width:32px;height:32px;display:flex;align-items:center;justify-content:center;padding:0;border:1px solid rgba(255,255,255,.15);border-radius:6px;background:#ffffff0f;color:#e6edf3;cursor:pointer;transition:background .15s,border-color .15s}#embed-expand:hover{background:#58a6ff26;border-color:#58a6ff}.maplibregl-ctrl-attrib{font-size:10px!important}
