.app-root{display:flex;flex-direction:column;width:100%;height:100%;background:#0f1117}.app-workspace{display:flex;flex:1;min-height:0;overflow:hidden}.app-pane{flex:1;min-width:0;overflow:hidden;position:relative}.app-pane-left{border-right:1px solid #1e2535}.app-pane-divider{width:1px;background:#1e2535;flex-shrink:0;cursor:col-resize}.prop-panel{position:absolute;top:36px;right:10px;width:200px;background:#11141cf0;border:1px solid #2a3040;border-radius:6px;padding:8px 10px 10px;z-index:20;font-size:12px;color:#cbd5e1;box-shadow:0 6px 24px #0006}.prop-header{display:flex;justify-content:space-between;align-items:center;font-weight:600;color:#e2e8f0;margin-bottom:8px}.prop-close{background:none;border:none;color:#64748b;font-size:16px;cursor:pointer;line-height:1}.prop-close:hover{color:#e2e8f0}.prop-row{display:flex;align-items:center;justify-content:space-between;margin:4px 0}.prop-label{color:#94a3b8}.prop-input{width:90px;background:#0f1117;border:1px solid #2a3040;border-radius:4px;color:#e2e8f0;padding:3px 6px;font-size:12px}.prop-input:focus{outline:none;border-color:#3b82f6}.prop-static{color:#e2e8f0}.prop-delete{margin-top:8px;width:100%;background:#ef44441f;border:1px solid rgba(239,68,68,.4);color:#f87171;border-radius:4px;padding:5px;font-size:12px;cursor:pointer}.prop-delete:hover{background:#ef444433}.pm-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#05070c99;display:flex;align-items:center;justify-content:center;z-index:100}.pm-modal{width:380px;max-height:70vh;overflow:auto;background:#11141c;border:1px solid #2a3040;border-radius:8px;padding:14px 16px;color:#cbd5e1;box-shadow:0 12px 40px #00000080}.pm-head{display:flex;justify-content:space-between;align-items:center;font-weight:600;color:#e2e8f0;font-size:14px;margin-bottom:10px}.pm-close{background:none;border:none;color:#64748b;font-size:18px;cursor:pointer}.pm-close:hover{color:#e2e8f0}.pm-error{background:#ef44441a;border:1px solid rgba(239,68,68,.35);color:#f87171;border-radius:4px;padding:6px 8px;font-size:12px;margin-bottom:8px}.pm-empty{color:#64748b;font-size:13px;padding:12px 0}.pm-list{list-style:none;margin:0;padding:0}.pm-item{display:flex;align-items:center;border:1px solid #1e2535;border-radius:6px;margin-bottom:6px;overflow:hidden}.pm-item.active{border-color:#3b82f6}.pm-open{flex:1;display:flex;flex-direction:column;align-items:flex-start;gap:2px;background:none;border:none;color:#e2e8f0;padding:8px 10px;cursor:pointer;text-align:left}.pm-open:hover{background:#161b27}.pm-name{font-size:13px}.pm-meta{font-size:11px;color:#64748b}.pm-del{background:none;border:none;color:#64748b;font-size:16px;cursor:pointer;padding:0 12px;align-self:stretch}.pm-del:hover{color:#f87171}.ai-popover{position:absolute;top:44px;right:220px;width:220px;background:#11141c;border:1px solid #2a3040;border-radius:8px;padding:8px;z-index:60;display:flex;flex-direction:column;gap:6px;box-shadow:0 10px 30px #00000073}.ai-action{background:#161b27;border:1px solid #2a3040;color:#e2e8f0;border-radius:5px;padding:8px 10px;font-size:12px;cursor:pointer;text-align:left}.ai-action:hover:not(:disabled){background:#1d2433;border-color:#3b82f6}.ai-action:disabled{opacity:.6;cursor:default}.ai-error{background:#ef44441a;border:1px solid rgba(239,68,68,.35);color:#f87171;border-radius:4px;padding:6px 8px;font-size:11px}.toolbar{display:flex;align-items:center;gap:4px;padding:0 12px;height:44px;background:#141824;border-bottom:1px solid #1e2535;flex-shrink:0;overflow-x:auto;overflow-y:hidden}.toolbar-brand{font-size:15px;font-weight:700;color:#3b82f6;letter-spacing:-.02em;white-space:nowrap;margin-right:4px}.toolbar-divider{width:1px;height:24px;background:#1e2535;margin:0 6px;flex-shrink:0}.toolbar-group{display:flex;align-items:center;gap:4px}.toolbar-btn{display:flex;align-items:center;gap:5px;padding:4px 8px;height:28px;background:transparent;border:1px solid transparent;border-radius:4px;color:#94a3b8;font-size:11.5px;cursor:pointer;white-space:nowrap;transition:color .15s,background .15s,border-color .15s;font-family:inherit;flex-shrink:0}.toolbar-btn:hover{background:#1e2535;color:#e2e8f0;border-color:#2a3040}.toolbar-btn.active{background:#1a3057;color:#60a5fa;border-color:#2563eb}.toolbar-btn-primary{background:#1d4ed8;color:#e2e8f0;border-color:#2563eb}.toolbar-btn-primary:hover{background:#2563eb;color:#fff;border-color:#3b82f6}.toolbar-label{display:flex;align-items:center;gap:4px;font-size:11px;color:#64748b;white-space:nowrap;cursor:default}.toolbar-input{width:52px;height:22px;padding:0 4px;background:#0f1117;border:1px solid #2a3040;border-radius:3px;color:#e2e8f0;font-size:11px;font-family:monospace;text-align:right}.toolbar-input:focus{outline:none;border-color:#3b82f6}.toolbar-unit{font-size:10px;color:#475569}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{width:100%;height:100%;overflow:hidden}body{font-family:Inter,system-ui,-apple-system,sans-serif;background:#0f1117;color:#e2e8f0;-webkit-font-smoothing:antialiased}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:#141824}::-webkit-scrollbar-thumb{background:#2a3040;border-radius:3px}input[type=number]::-webkit-inner-spin-button,input[type=number]::-webkit-outer-spin-button{opacity:.5}
