*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#0a0a0a;color:#e0e0e0;min-height:100vh}#app{max-width:1400px;margin:0 auto;padding:12px 16px}header{padding:8px 0 12px;border-bottom:1px solid #222;margin-bottom:12px}header h1{font-size:18px;font-weight:600;color:#fff}header .subtitle{font-weight:400;color:#666;font-size:13px}.header-row{display:flex;align-items:center;justify-content:space-between}.btn-config{font-size:12px;padding:4px 12px;background:#1a1a1a;border:1px solid #333;border-radius:4px;color:#888;cursor:pointer;transition:color .15s,border-color .15s}.btn-config:hover,.btn-config.active{color:#4a9eff;border-color:#4a9eff}.config-panel{margin-top:12px;background:#111;border:1px solid #222;border-radius:6px;padding:12px}.config-grid{display:grid;grid-template-columns:auto 1fr;gap:6px 12px;align-items:center}.config-grid label{font-size:12px;color:#888;white-space:nowrap}.config-grid select,.config-grid input[type=number]{padding:4px 8px;background:#1a1a1a;border:1px solid #333;border-radius:4px;color:#e0e0e0;font-size:12px;font-family:SF Mono,Fira Code,monospace}.config-grid select:focus,.config-grid input[type=number]:focus{outline:none;border-color:#4a9eff}#tabs{display:flex;gap:2px;border-bottom:1px solid #222;margin-bottom:12px;overflow-x:auto}.tab-btn{padding:6px 14px;background:none;border:none;border-bottom:2px solid transparent;color:#888;cursor:pointer;font-size:13px;white-space:nowrap;transition:color .15s,border-color .15s}.tab-btn:hover{color:#ccc}.tab-btn.active{color:#fff;border-bottom-color:#4a9eff}#content{min-height:500px}.toolbar{display:flex;align-items:center;gap:12px;flex-wrap:wrap;padding:8px 12px;background:#111;border:1px solid #222;border-radius:6px;margin-bottom:10px}.toolbar select{padding:4px 8px;background:#1a1a1a;border:1px solid #333;border-radius:4px;color:#e0e0e0;font-size:12px}.toolbar select:focus{outline:none;border-color:#4a9eff}.toolbar label{font-size:12px;color:#888}.toolbar .checkbox-row{display:flex;align-items:center;gap:4px;margin:0}.toolbar .checkbox-row input[type=checkbox]{accent-color:#4a9eff}.toolbar .checkbox-row label{font-size:12px;color:#ccc}.toolbar .sep{width:1px;height:20px;background:#333;flex-shrink:0}.toolbar .status-text{font-size:11px;color:#555;margin-left:auto}.workspace{display:flex;gap:10px;min-height:480px}.panel-canvas{flex:0 0 auto;width:520px;min-width:0}.panel-info{flex:1;min-width:240px;display:flex;flex-direction:column;gap:8px;overflow-y:auto;max-height:calc(100vh - 160px)}.canvas-container{position:relative;background:#111;border:1px solid #222;border-radius:6px;overflow:hidden}.canvas-container canvas{display:block;width:100%;aspect-ratio:1;cursor:crosshair}.controls{background:#111;border:1px solid #222;border-radius:6px;padding:12px}.controls h3{font-size:13px;font-weight:600;color:#aaa;text-transform:uppercase;letter-spacing:.5px;margin-bottom:10px}.controls label{display:block;font-size:13px;color:#ccc;margin-bottom:6px}.controls select,.controls input[type=text]{width:100%;padding:6px 10px;background:#1a1a1a;border:1px solid #333;border-radius:4px;color:#e0e0e0;font-size:13px;margin-bottom:10px}.controls select:focus,.controls input[type=text]:focus{outline:none;border-color:#4a9eff}.btn{display:inline-flex;align-items:center;gap:6px;padding:5px 12px;background:#1a1a1a;border:1px solid #333;border-radius:4px;color:#e0e0e0;font-size:12px;cursor:pointer;transition:background .15s}.btn:hover{background:#252525}.btn-primary{background:#1a3a5c;border-color:#4a9eff;color:#4a9eff}.btn-primary:hover{background:#1d4570}.btn-danger{border-color:#ff4a4a;color:#ff4a4a}.btn-danger:hover{background:#2a1010}.btn-group{display:flex;gap:4px;flex-wrap:wrap}.info-panel{background:#111;border:1px solid #222;border-radius:6px;padding:10px}.info-panel h3{font-size:11px;font-weight:600;color:#666;text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.info-row{display:flex;justify-content:space-between;font-size:12px;padding:3px 0;border-bottom:1px solid #1a1a1a}.info-row:last-child{border-bottom:none}.info-label{color:#888}.info-value{color:#e0e0e0;font-family:SF Mono,Fira Code,monospace;font-size:11px}.info-value.ok{color:#4aff7a}.info-value.error{color:#ff4a4a}.info-value.warn{color:#ffa94a}.status-bar{font-size:11px;color:#555;padding:4px 0;text-align:center}.checkbox-row{display:flex;align-items:center;gap:8px;margin-bottom:8px}.checkbox-row input[type=checkbox]{accent-color:#4a9eff}.log{max-height:200px;overflow-y:auto;font-family:SF Mono,Fira Code,monospace;font-size:12px;line-height:1.5;color:#aaa;background:#0d0d0d;border-radius:4px;padding:8px}.log .entry{padding:2px 0}.help-text{font-size:11px;color:#555;line-height:1.4}.trace-details{background:#111;border:1px solid #222;border-radius:6px;padding:0}.trace-details summary{padding:8px 10px;font-size:11px;font-weight:600;color:#888;cursor:pointer;user-select:none;text-transform:uppercase;letter-spacing:.5px}.trace-details summary:hover{color:#ccc}.trace-details[open] summary{border-bottom:1px solid #1a1a1a}.trace-list{padding:4px 10px;max-height:180px;overflow-y:auto}.trace-entry{display:flex;align-items:baseline;gap:6px;font-size:11px;padding:2px 0;border-bottom:1px solid #1a1a1a;flex-wrap:wrap}.trace-entry:last-child{border-bottom:none}.trace-index{color:#555;font-family:SF Mono,Fira Code,monospace;min-width:18px}.trace-strategy{color:#e0e0e0;font-family:SF Mono,Fira Code,monospace;font-size:11px}.trace-rotation{color:#666;font-family:SF Mono,Fira Code,monospace;font-size:10px}.trace-entry .info-value{margin-left:auto;font-size:11px}.topo-error-detail{font-size:11px;color:#ff4a4a;background:#1a0808;border:1px solid #331010;border-radius:4px;padding:6px 8px;margin:4px 0 2px;line-height:1.4;font-family:SF Mono,Fira Code,monospace}.debug-details{background:#111;border:1px solid #222;border-radius:6px;padding:0}.debug-details summary{padding:8px 10px;font-size:11px;font-weight:600;color:#888;cursor:pointer;user-select:none;text-transform:uppercase;letter-spacing:.5px}.debug-details summary:hover{color:#ccc}.debug-details[open] summary{border-bottom:1px solid #1a1a1a}.debug-content{padding:6px 10px;max-height:500px;overflow-y:auto}.debug-section{margin-bottom:8px;padding-bottom:6px;border-bottom:1px solid #1a1a1a}.debug-section:last-child{border-bottom:none;margin-bottom:0}.debug-section-title{font-size:10px;font-weight:600;color:#666;text-transform:uppercase;letter-spacing:.5px;margin-bottom:3px}.debug-row{display:flex;justify-content:space-between;font-size:11px;padding:1px 0}.debug-label{color:#666;font-size:10px}.debug-value{color:#ccc;font-family:SF Mono,Fira Code,monospace;font-size:10px}.debug-value.debug-ok{color:#51cf66}.debug-value.debug-warn{color:#ffa94a}.debug-copy-row{margin:2px 0}.debug-code{display:block;background:#0d0d0d;border:1px solid #1a1a1a;border-radius:3px;padding:3px 5px;font-family:SF Mono,Fira Code,monospace;font-size:10px;color:#aaa;word-break:break-all;white-space:pre-wrap;max-height:100px;overflow-y:auto;cursor:pointer;transition:outline .15s}.debug-code:hover{border-color:#333}.debug-muted{color:#555;font-size:11px}.debug-part{margin:4px 0;padding:4px;background:#0d0d0d;border-radius:4px;border:1px solid #1a1a1a}@media(max-width:900px){.workspace{flex-direction:column}.panel-info{width:100%;max-height:none}}
