@import "https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@400;600&family=Noto+Sans+SC:wght@400;500;700&display=swap";body{margin:0}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{color:#e2e8f0;background:#0a0e14;width:100%;height:100%;font-family:Noto Sans SC,system-ui,sans-serif;overflow:hidden}.app{flex-direction:column;height:100vh;display:flex}.main-layout{flex:1;min-height:0;display:flex}.scene-container{flex:1;min-width:0;position:relative}.babylon-canvas{touch-action:none;outline:none;width:100%;height:100%;display:block}.scene-overlay{pointer-events:none;gap:12px;display:flex;position:absolute;bottom:16px;left:16px}.overlay-badge{color:#7dd3fc;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0f172ad9;border:1px solid #38bdf84d;border-radius:8px;padding:8px 14px;font-size:12px}.overlay-stats{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0f172ad9;border:1px solid #94a3b833;border-radius:8px;gap:10px;padding:8px 14px;font-family:JetBrains Mono,monospace;font-size:12px;display:flex}.overlay-stats span{color:#94a3b8}.scene-toolbar{background:linear-gradient(#111827 0%,#0f172a 100%);border-bottom:1px solid #38bdf826;flex-shrink:0;align-items:center;gap:20px;padding:10px 20px;display:flex}.toolbar-brand{align-items:center;gap:10px;min-width:160px;display:flex}.brand-icon{font-size:28px}.toolbar-brand strong{color:#f1f5f9;font-size:15px;display:block}.toolbar-brand small{color:#64748b;font-size:11px}.mode-tabs{flex-wrap:wrap;flex:1;gap:6px;display:flex}.mode-tab{color:#94a3b8;cursor:pointer;background:#1e293bcc;border:1px solid #47556980;border-radius:6px;padding:8px 16px;font-family:inherit;font-size:13px;transition:all .2s}.mode-tab:hover{color:#e2e8f0;background:#334155e6}.mode-tab.active{color:#fff;background:linear-gradient(135deg,#0ea5e9 0%,#0284c7 100%);border-color:#38bdf8;font-weight:500}.roam-toggle{color:#94a3b8;cursor:pointer;white-space:nowrap;align-items:center;gap:8px;font-size:13px;display:flex}.roam-toggle input{accent-color:#0ea5e9}.toolbar-hint{color:#475569;white-space:nowrap;font-size:11px}.control-panel{background:linear-gradient(#0f172a 0%,#0a0f1a 100%);border-left:1px solid #38bdf81f;flex-shrink:0;width:340px;overflow-y:auto}.panel-header{border-bottom:1px solid #4755694d;padding:18px 20px 14px}.panel-header h2{color:#f1f5f9;margin-bottom:4px;font-size:16px;font-weight:600}.update-time{color:#64748b;font-family:JetBrains Mono,monospace;font-size:11px}.panel-section{border-bottom:1px solid #47556933;padding:14px 20px}.panel-section h3{color:#64748b;text-transform:uppercase;letter-spacing:.05em;margin-bottom:10px;font-size:12px;font-weight:500}.sensor-grid{flex-direction:column;gap:8px;display:flex}.sensor-card{background:#1e293b99;border:1px solid #47556966;border-radius:8px;padding:10px 12px;transition:border-color .3s}.sensor-card.status-warning{background:#fbbf240d;border-color:#fbbf2480}.sensor-card.status-critical{background:#ef444414;border-color:#ef444499;animation:1.5s infinite pulse}@keyframes pulse{0%,to{opacity:1}50%{opacity:.85}}.sensor-top{align-items:center;gap:6px;margin-bottom:4px;display:flex}.sensor-icon{font-size:14px}.sensor-name{color:#cbd5e1;flex:1;font-size:12px}.sensor-badge{border-radius:4px;padding:2px 6px;font-size:10px;font-weight:500}.sensor-badge.normal{color:#4ade80;background:#22c55e26}.sensor-badge.warning{color:#fbbf24;background:#fbbf2426}.sensor-badge.critical{color:#f87171;background:#ef444433}.sensor-value{color:#f1f5f9;font-family:JetBrains Mono,monospace;font-size:22px;font-weight:700}.sensor-value small{color:#64748b;margin-left:4px;font-size:12px;font-weight:400}.level-bar{background:#47556980;border-radius:2px;height:4px;margin-top:8px;overflow:hidden}.level-fill{background:linear-gradient(90deg,#0ea5e9,#38bdf8);border-radius:2px;height:100%;transition:width .5s}.device-list{list-style:none}.device-list li{border-bottom:1px solid #47556926;align-items:center;gap:8px;padding:8px 0;font-size:12px;display:flex}.device-dot{background:#22c55e;border-radius:50%;width:8px;height:8px;box-shadow:0 0 6px #22c55e99}.device-list li.stopped .device-dot{box-shadow:none;background:#64748b}.device-name{color:#cbd5e1;flex:1}.device-status{color:#4ade80;font-size:11px}.device-list li.stopped .device-status{color:#64748b}.device-speed{color:#64748b;font-family:JetBrains Mono,monospace;font-size:11px}.terrain-info p{color:#94a3b8;margin-bottom:4px;font-size:12px}.terrain-info .ok{color:#4ade80}.terrain-info .warn{color:#fbbf24}.terrain-info .error{color:#f87171}.terrain-info .tile-count{font-family:JetBrains Mono,monospace;font-size:11px}@media (width<=900px){.main-layout{flex-direction:column}.control-panel{border-top:1px solid #38bdf81f;border-left:none;width:100%;max-height:40vh}.toolbar-hint{display:none}}
