:root{--bg:#05070d;--panel-bg:#0d121ec7;--panel-border:#7da0dc29;--text:#dbe4f5;--text-dim:#7d8aa5;--accent:#4da6ff;--accent-glow:#7df9ff;--warn:#ffb347;--radius:12px;--safe-top:env(safe-area-inset-top,0px);--safe-bottom:env(safe-area-inset-bottom,0px)}*{box-sizing:border-box}html,body,#root{background:var(--bg);height:100%;color:var(--text);-webkit-font-smoothing:antialiased;margin:0;font-family:Inter,Hiragino Sans,Noto Sans JP,system-ui,sans-serif;font-size:14px;overflow:hidden}.app{position:fixed;inset:0}.hud{pointer-events:none;z-index:10;position:absolute;inset:0}.hud>*{pointer-events:auto}.hud-top{top:calc(8px + var(--safe-top));pointer-events:none;justify-content:space-between;align-items:flex-start;gap:12px;display:flex;position:absolute;left:12px;right:12px}.hud-top>*{pointer-events:auto}.brand h1{letter-spacing:.22em;text-transform:uppercase;background:linear-gradient(90deg, var(--accent-glow), var(--accent));color:#0000;text-shadow:0 0 24px #4da6ff59;-webkit-background-clip:text;background-clip:text;margin:0;font-size:20px;font-weight:700}.data-age{color:var(--text-dim);font-size:11px}.data-age.stale{color:var(--warn)}.panel{background:var(--panel-bg);border:1px solid var(--panel-border);border-radius:var(--radius);-webkit-backdrop-filter:blur(14px);box-shadow:0 8px 32px #00000073}.side-panel{top:calc(64px + var(--safe-top));scrollbar-width:thin;flex-direction:column;gap:10px;width:300px;max-height:calc(100% - 140px);display:flex;position:absolute;right:12px;overflow-y:auto}.time-controls{flex-direction:column;align-items:flex-end;gap:6px;padding:8px 12px;display:flex}.sim-clock{font-variant-numeric:tabular-nums;color:var(--accent-glow);letter-spacing:.06em;font-size:13px}.time-buttons{gap:4px;display:flex}.btn{border:1px solid var(--panel-border);color:var(--text);cursor:pointer;background:#4da6ff14;border-radius:8px;padding:5px 10px;font-size:12px;transition:background .15s,border-color .15s}.btn:hover{border-color:var(--accent);background:#4da6ff33}.btn-active{border-color:var(--accent);color:#fff;background:#4da6ff52}.btn-close{margin-left:auto;padding:2px 8px;font-size:14px;line-height:1}.search-box{position:relative}.search-input{background:var(--panel-bg);border:1px solid var(--panel-border);border-radius:var(--radius);width:100%;color:var(--text);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);outline:none;padding:10px 12px;font-size:14px}.search-input:focus{border-color:var(--accent)}.search-results{background:var(--panel-bg);border:1px solid var(--panel-border);border-radius:var(--radius);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);max-height:240px;margin:6px 0 0;padding:4px;list-style:none;overflow-y:auto}.search-result{text-align:left;width:100%;color:var(--text);cursor:pointer;background:0 0;border:none;border-radius:6px;padding:7px 10px;font-size:13px;display:block}.search-result:hover{background:#4da6ff2e}.info-panel{padding:12px 14px}.info-header{align-items:center;gap:8px;display:flex}.info-header h2{overflow-wrap:anywhere;margin:0;font-size:15px;font-weight:600}.info-grid{grid-template-columns:auto 1fr;gap:5px 14px;margin:10px 0 0;display:grid}.info-grid dt{color:var(--text-dim);font-size:12px}.info-grid dd{font-variant-numeric:tabular-nums;text-align:right;margin:0;font-size:12px}.filter-legend{background:var(--panel-bg);border:1px solid var(--panel-border);border-radius:var(--radius);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);padding:12px 14px}.legend-header{color:var(--text-dim);justify-content:space-between;margin-bottom:8px;font-size:12px;display:flex}.visible-count{color:var(--accent-glow);font-variant-numeric:tabular-nums}.filter-legend ul{flex-direction:column;gap:2px;margin:0;padding:0;list-style:none;display:flex}.legend-item{cursor:pointer;align-items:center;gap:8px;padding:4px 2px;font-size:13px;display:flex}.legend-item input{accent-color:var(--accent)}.cat-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px;box-shadow:0 0 6px}.legend-label{flex:1}.legend-count{color:var(--text-dim);font-variant-numeric:tabular-nums;font-size:11px}.overhead-control{bottom:calc(20px + var(--safe-bottom));flex-direction:column;align-items:center;gap:8px;display:flex;position:absolute;left:50%;transform:translate(-50%)}.btn-overhead{border:1px solid var(--accent);white-space:nowrap;background:#4da6ff29;border-radius:999px;padding:11px 22px;font-size:14px;box-shadow:0 0 24px #4da6ff40}.overhead-badge{background:var(--panel-bg);border:1px solid var(--panel-border);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border-radius:999px;padding:5px 14px;font-size:12px}.overhead-badge strong{color:var(--accent-glow)}.toast{bottom:calc(84px + var(--safe-bottom));color:#ffd7d7;border-radius:var(--radius);background:#281010eb;border:1px solid #ff787866;max-width:min(90vw,420px);padding:10px 18px;font-size:13px;position:absolute;left:50%;transform:translate(-50%)}.loading-overlay{background:#05070d99;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.loading-card{text-align:center;flex-direction:column;align-items:center;gap:12px;padding:28px 36px;display:flex}.loading-card progress{width:200px;accent-color:var(--accent)}.loading-spinner{border:3px solid var(--panel-border);border-top-color:var(--accent-glow);border-radius:50%;width:36px;height:36px;animation:.9s linear infinite spin}.error-detail{color:var(--text-dim);overflow-wrap:anywhere;max-width:320px;font-size:12px}@keyframes spin{to{transform:rotate(360deg)}}.bottom-sheet{z-index:20;transform:translateY(calc(100% - 40px - var(--safe-bottom)));background:var(--panel-bg);border-top:1px solid var(--panel-border);-webkit-backdrop-filter:blur(18px);border-radius:16px 16px 0 0;flex-direction:column;max-height:70vh;transition:transform .28s cubic-bezier(.3,.9,.3,1);display:flex;position:absolute;bottom:0;left:0;right:0}.bottom-sheet.open{transform:translateY(0)}.sheet-handle{cursor:pointer;background:0 0;border:none;flex-shrink:0;padding:12px 0}.handle-bar{background:var(--text-dim);border-radius:2px;width:44px;height:4px;margin:0 auto;display:block}.sheet-content{padding:0 14px calc(14px + var(--safe-bottom));flex-direction:column;gap:10px;display:flex;overflow-y:auto}@media (width<=768px){.hud-top{flex-direction:column;align-items:stretch}.time-controls{flex-direction:row;justify-content:space-between;align-items:center;padding:6px 10px}.brand h1{font-size:16px}.overhead-control{bottom:calc(56px + var(--safe-bottom))}}
