:root{--bg: #070910;--bg-2: #0d111b;--panel: #121826;--panel-2: #18202f;--border: #232c3e;--text: #e7ecf3;--text-dim: #93a0b4;--accent: #5b8cff;--accent-2: #23d18b;color-scheme:dark}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);font-size:14px;overflow:hidden}.app{display:flex;flex-direction:column;height:100vh}.topbar{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:10px 18px;background:linear-gradient(180deg,var(--bg-2),var(--bg));border-bottom:1px solid var(--border);flex:0 0 auto}.brand{display:flex;align-items:center;gap:12px}.brand .logo{font-size:26px}.brand h1{margin:0;font-size:17px;letter-spacing:.3px}.brand p{margin:2px 0 0;font-size:12px;color:var(--text-dim)}.transport{display:flex;align-items:center;gap:10px}.engine-switch,.seg-group{display:inline-flex;border:1px solid var(--border);border-radius:8px;overflow:hidden}.seg{background:var(--panel);color:var(--text-dim);border:none;padding:8px 12px;cursor:pointer;font-size:13px}.seg+.seg{border-left:1px solid var(--border)}.seg.active{background:var(--accent);color:#fff}.seg:hover:not(.active){background:var(--panel-2)}.btn{background:var(--panel);color:var(--text);border:1px solid var(--border);border-radius:8px;padding:8px 14px;cursor:pointer;font-size:13px}.btn:hover{background:var(--panel-2)}.btn.primary{background:var(--accent);border-color:var(--accent);color:#fff}.btn.primary:hover{filter:brightness(1.08)}.layout{display:grid;grid-template-columns:92px 1fr 320px;flex:1 1 auto;min-height:0}.toolbar{background:var(--bg-2);border-right:1px solid var(--border);padding:12px 8px;display:flex;flex-direction:column;gap:6px;overflow-y:auto}.tool{display:flex;flex-direction:column;align-items:center;gap:3px;background:var(--panel);border:1px solid var(--border);border-radius:8px;padding:8px 4px;color:var(--text-dim);cursor:pointer}.tool:hover{background:var(--panel-2);color:var(--text)}.tool.active{border-color:var(--accent);color:#fff;background:#5b8cff29}.tool-icon{font-size:18px}.tool-label{font-size:10.5px}.tool-sep{height:1px;background:var(--border);margin:6px 2px}.tool-mat-label{font-size:10.5px;color:var(--text-dim);text-align:center}.stage{position:relative;display:flex;flex-direction:column;background:radial-gradient(1200px 600px at 50% -10%,#111a2e,transparent),var(--bg);min-width:0;min-height:0}.tabs{display:flex;align-items:center;gap:8px;padding:8px 12px;border-bottom:1px solid var(--border);background:var(--bg-2);flex:0 0 auto}.tab{background:var(--panel);color:var(--text-dim);border:1px solid var(--border);border-radius:7px;padding:6px 12px;cursor:pointer;font-size:13px}.tab.active{background:var(--accent);color:#fff;border-color:var(--accent)}.tab:hover:not(.active){background:var(--panel-2)}.tab-hint{font-size:11.5px;color:var(--text-dim);margin-left:4px}.views{position:relative;flex:1 1 auto;min-height:0}.view-pane{position:absolute;inset:0}.room-canvas,.scene3d{width:100%;height:100%;display:block;touch-action:none}.scene3d canvas{display:block}.badge{font-size:10px;background:var(--accent);color:#fff;padding:1px 6px;border-radius:6px;vertical-align:middle;margin-left:4px}.grid2{display:grid;grid-template-columns:1fr 1fr;gap:8px}.grid3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px}.grid2 .field,.grid3 .field{margin-bottom:10px}.plane-row{margin-bottom:12px}.plane-row:last-of-type{margin-bottom:8px}.x{background:transparent;border:none;color:var(--text-dim);cursor:pointer;font-size:12px;margin-left:8px}.x:hover{color:#ff6b6b}.item-head>span,.readout>span:last-child{display:inline-flex;align-items:center}.legend{position:absolute;left:16px;bottom:16px;background:#0a0d14d1;border:1px solid var(--border);border-radius:10px;padding:10px 12px;width:230px;backdrop-filter:blur(4px)}.legend-title{font-size:11.5px;color:var(--text-dim);margin-bottom:6px}.legend-bar{height:12px;border-radius:4px;border:1px solid rgba(255,255,255,.12)}.legend-scale{display:flex;justify-content:space-between;font-size:11px;color:var(--text-dim);margin-top:4px}.panel{background:var(--bg-2);border-left:1px solid var(--border);overflow-y:auto;padding:12px;display:flex;flex-direction:column;gap:12px}.card{background:var(--panel);border:1px solid var(--border);border-radius:10px;padding:12px}.card h2{margin:0 0 10px;font-size:12px;text-transform:uppercase;letter-spacing:.8px;color:var(--text-dim)}.field{display:flex;flex-direction:column;gap:4px;margin-bottom:10px}.field>span{font-size:12px;color:var(--text-dim)}.field:last-child{margin-bottom:0}input[type=number],.select{background:var(--bg);border:1px solid var(--border);border-radius:7px;color:var(--text);padding:7px 9px;font-size:13px;width:100%}input[type=range]{width:100%;accent-color:var(--accent)}.select{cursor:pointer}.checkline{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text);cursor:pointer}.checkline.small{font-size:11.5px;color:var(--text-dim)}.checkline input{accent-color:var(--accent)}.seg-group .seg{flex:1;padding:7px 8px}.item{border:1px solid var(--border);border-radius:8px;padding:10px;margin-bottom:10px;background:var(--panel-2)}.item:last-child{margin-bottom:0}.item-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.readout{display:flex;justify-content:space-between;align-items:center;padding:7px 10px;background:var(--panel-2);border:1px solid var(--border);border-radius:8px;margin-bottom:6px}.readout:last-child{margin-bottom:0}.readout strong{color:var(--accent-2);font-variant-numeric:tabular-nums}.hint{font-size:12px;color:var(--text-dim);line-height:1.5;margin:0 0 8px}.hint:last-child{margin-bottom:0}@media (max-width: 900px){.layout{grid-template-columns:72px 1fr}.panel{display:none}}
