*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg-dark: #0d1117;--bg-panel: #161b22;--bg-toolbar: #1c2128;--bg-hover: #21262d;--bg-active: #1f3a5f;--bg-selected: #2d3748;--border: #30363d;--border-light:#3d444d;--text: #dde2e8;--text-dim: #a0aab4;--text-bright: #e6edf3;--accent: #4fc3f7;--accent2: #58a6ff;--danger: #f85149;--success: #3fb950;--warning: #d29922;--toolbar-h: 46px;--toolbar-h2: 32px;--messagebar-h: 26px;--command-h: 30px;--sidebar-w: 228px;--preview-w: 300px;--statusbar-h: 28px;--handle-color:#ffcc00}html,body{width:100%;height:100%;overflow:hidden;font-family:Segoe UI,system-ui,-apple-system,sans-serif;font-size:13px;background:var(--bg-dark);color:var(--text)}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:var(--bg-dark)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-dim)}#toolbar-wrapper{position:fixed;top:0;left:0;right:0;z-index:200;display:flex;flex-direction:column;background:var(--bg-toolbar);border-bottom:1px solid var(--border)}#toolbar{height:var(--toolbar-h);display:flex;align-items:center;gap:2px;padding:0 6px;-webkit-user-select:none;user-select:none;overflow-x:auto;overflow-y:hidden;flex-shrink:0}.toolbar-brand{display:flex;align-items:center;gap:7px;font-weight:700;font-size:13px;color:var(--accent);padding-right:10px;border-right:1px solid var(--border);margin-right:2px;white-space:nowrap;flex-shrink:0}.toolbar-group{display:flex;align-items:center;gap:1px;padding:0 4px;border-right:1px solid var(--border);flex-shrink:0}.toolbar-actions{display:flex;align-items:center;gap:3px;border-right:none;flex-wrap:nowrap;overflow-x:auto}.tool-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;width:46px;height:40px;background:transparent;border:1px solid transparent;border-radius:6px;color:var(--text-dim);cursor:pointer;transition:background .12s,color .12s,border-color .12s;font-size:9px;font-weight:500;text-transform:uppercase;letter-spacing:.04em;flex-shrink:0}.tool-btn svg{width:15px;height:15px;stroke:currentColor;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}.tool-btn:hover{background:var(--bg-hover);color:var(--text);border-color:var(--border-light)}.tool-btn.active{background:var(--bg-active);color:var(--accent);border-color:var(--accent2)}.action-btn{display:inline-flex;align-items:center;gap:3px;padding:4px 9px;background:transparent;border:1px solid var(--border);border-radius:5px;color:var(--text-dim);cursor:pointer;font-size:11px;white-space:nowrap;transition:all .12s;flex-shrink:0}.action-btn:hover{background:var(--bg-hover);color:var(--text);border-color:var(--accent2)}.action-btn.active{background:var(--bg-active);color:var(--accent);border-color:var(--accent2)}.action-btn.full-width{width:100%;justify-content:center}.action-btn:disabled{opacity:.4;cursor:not-allowed}.separator{width:1px;height:26px;background:var(--border);margin:0 3px;flex-shrink:0}#toolbar-row2{display:flex;align-items:center;gap:8px;height:var(--toolbar-h2);padding:0 10px;border-top:1px solid var(--border);flex-shrink:0;overflow:hidden}.toolbar-project-info{display:flex;align-items:center;gap:8px;flex-shrink:0}.toolbar-project-name{font-size:12px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px}.toolbar-project-actions{display:flex;gap:4px;flex-shrink:0}.toolbar-project-actions .action-btn{padding:3px 8px;font-size:10px}.toolbar-project-actions .action-btn:disabled{opacity:.5}.toolbar-readout{margin-left:8px;padding:2px 10px 2px 8px;font-size:10px;font-family:Consolas,Courier New,monospace;color:var(--text-dim);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-align:right}.toolbar-readout.success{color:var(--success)}.toolbar-readout.error{color:var(--danger)}.toolbar-readout.warning{color:var(--warning)}.toolbar-readout.info{color:var(--accent)}#main-content{position:fixed;top:calc(var(--toolbar-h) + var(--toolbar-h2));bottom:var(--statusbar-h);left:0;right:0;display:flex;overflow:hidden}#sidebar{width:var(--sidebar-w);min-width:var(--sidebar-w);background:var(--bg-panel);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow-y:auto;overflow-x:hidden}.sidebar-section{border-bottom:1px solid var(--border);padding-bottom:6px}.sidebar-title{display:flex;align-items:center;justify-content:space-between;padding:7px 10px 5px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--text-dim)}.sidebar-title button{background:transparent;border:1px solid var(--border);border-radius:4px;color:var(--text-dim);cursor:pointer;width:18px;height:18px;font-size:14px;line-height:1;display:flex;align-items:center;justify-content:center;transition:all .12s}.sidebar-title button:hover{background:var(--bg-hover);color:var(--accent);border-color:var(--accent2)}#layer-list{list-style:none;padding:0 4px}#layer-list li{display:flex;align-items:center;gap:4px;padding:4px 5px;border-radius:5px;cursor:pointer;font-size:11px;color:var(--text-dim);transition:background .1s;position:relative}#layer-list li:hover{background:var(--bg-hover)}#layer-list li.active{background:var(--bg-active);color:var(--accent)}#layer-list li.locked{opacity:.55}.layer-vis{width:13px;height:13px;border-radius:3px;border:1px solid var(--border);cursor:pointer;flex-shrink:0;transition:background .1s}.layer-lock{cursor:pointer;font-size:10px;color:var(--text-dim);flex-shrink:0;opacity:.6;padding:0 1px}.layer-lock:hover,.layer-lock.locked{color:var(--warning);opacity:1}.layer-color{width:10px;height:10px;border-radius:50%;flex-shrink:0;cursor:pointer}.layer-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:11px}.layer-name-input{flex:1;background:var(--bg-dark);border:1px solid var(--accent2);border-radius:3px;color:var(--text);padding:1px 4px;font-size:11px;min-width:0;outline:none}.layer-delete{background:transparent;border:none;cursor:pointer;color:transparent;font-size:11px;padding:0 1px;transition:color .1s;flex-shrink:0}#layer-list li:hover .layer-delete{color:var(--danger)}.prop-row{display:flex;align-items:center;gap:5px;padding:3px 8px;font-size:11px}.prop-row label{width:50px;color:var(--text-dim);flex-shrink:0;font-size:11px}.prop-row input[type=color]{width:30px;height:20px;border:1px solid var(--border);border-radius:3px;background:var(--bg-dark);cursor:pointer;padding:1px;flex-shrink:0}.prop-row input[type=number]{background:var(--bg-dark);border:1px solid var(--border);border-radius:4px;color:var(--text);padding:3px 5px;font-size:11px;min-width:0}.prop-row input[type=number]:focus{outline:none;border-color:var(--accent2)}.prop-row input[type=range]{flex:1;accent-color:var(--accent);height:3px}.prop-row input[type=checkbox]{accent-color:var(--accent);width:13px;height:13px;cursor:pointer}.prop-row span{color:var(--accent);font-size:10px;min-width:20px}.prop-swatch{width:14px;height:14px;border-radius:3px;border:1px solid var(--border);flex-shrink:0;display:inline-block}.prop-label-row{padding:5px 8px 2px;font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--text-dim);opacity:.7}#shape-info-fields{padding:2px 8px 6px}.shape-info-row{display:flex;align-items:center;gap:5px;padding:2px 0;font-size:10px}.shape-info-row label{width:46px;color:var(--text-dim);flex-shrink:0}.shape-info-row input[type=number]{flex:1;background:var(--bg-dark);border:1px solid var(--border);border-radius:3px;color:var(--text);padding:2px 4px;font-size:10px;min-width:0}.shape-info-row input[type=number]:focus{outline:none;border-color:var(--accent2)}#canvas-wrapper{flex:1;display:flex;flex-direction:column;overflow:hidden;position:relative}#canvas-container{flex:1;position:relative;overflow:hidden;background:#0a0f14;cursor:crosshair}#canvas2d{position:absolute;top:0;left:0;display:block}#canvas-overlay{position:absolute;bottom:8px;left:8px;display:flex;gap:10px;pointer-events:none;align-items:center}#canvas-overlay span{background:#0d1117d9;border:1px solid var(--border);border-radius:4px;padding:2px 7px;font-size:10px;font-family:Consolas,Courier New,monospace;color:var(--text-dim)}#zoom-display{cursor:pointer;pointer-events:all}#zoom-display:hover{color:var(--accent);border-color:var(--accent2)}#zoom-controls{position:absolute;bottom:8px;right:8px;display:flex;flex-direction:column;gap:2px}#zoom-controls button{width:26px;height:26px;background:#0d1117d9;border:1px solid var(--border);border-radius:5px;color:var(--text-dim);cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;transition:all .12s}#zoom-controls button:hover{background:var(--bg-hover);color:var(--accent);border-color:var(--accent2)}#command-bar{height:var(--command-h);background:#0e1218;border-top:1px solid var(--border);display:flex;align-items:center;gap:0;padding:0;flex-shrink:0}#command-prompt{padding:0 8px;font-size:10px;font-family:Consolas,monospace;color:var(--accent);white-space:nowrap;flex-shrink:0;border-right:1px solid var(--border)}#command-input{flex:1;background:transparent;border:none;color:var(--text);padding:0 8px;font-size:11px;font-family:Consolas,monospace;outline:none;min-width:0}#command-input::placeholder{color:var(--text-dim);opacity:.5}#command-enter{width:30px;height:var(--command-h);background:transparent;border:none;border-left:1px solid var(--border);color:var(--text-dim);cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;transition:all .12s}#command-enter:hover{background:var(--bg-hover);color:var(--accent)}#statusbar{position:fixed;bottom:0;left:0;right:0;height:var(--statusbar-h);background:var(--bg-toolbar);border-top:1px solid var(--border);display:flex;align-items:center;gap:12px;padding:0 10px;font-size:10px;color:var(--text-dim);z-index:200;-webkit-user-select:none;user-select:none}#statusbar>span{white-space:nowrap}#status-hint{opacity:.7}#status-selection{color:var(--accent)}#osnap-toggles{display:flex;align-items:center;gap:3px;margin-left:auto;flex-shrink:0}.osnap-toggle-label{font-size:9px;color:var(--text-dim);margin-right:2px;text-transform:uppercase;letter-spacing:.06em}.osnap-btn{padding:2px 5px;background:var(--bg-dark);border:1px solid var(--border);border-radius:3px;color:var(--text-dim);cursor:pointer;font-size:9px;font-weight:700;font-family:Consolas,monospace;letter-spacing:.04em;transition:all .1s}.osnap-btn.active{background:#4fc3f71f;color:var(--accent);border-color:#4fc3f766}.osnap-btn:hover{border-color:var(--accent2);color:var(--text)}.context-menu{position:fixed;background:var(--bg-panel);border:1px solid var(--border-light);border-radius:7px;padding:4px 0;z-index:9000;min-width:190px;box-shadow:0 8px 32px #0009;font-size:12px;-webkit-user-select:none;user-select:none}.ctx-item{display:flex;align-items:center;justify-content:space-between;padding:6px 14px;cursor:pointer;color:var(--text-dim);transition:background .1s,color .1s;gap:16px}.ctx-item:hover{background:var(--bg-active);color:var(--text)}.ctx-item.ctx-danger:hover{background:#f8514926;color:var(--danger)}.ctx-item kbd{font-size:9px;color:var(--text-dim);background:var(--bg-dark);border:1px solid var(--border);border-radius:3px;padding:1px 4px;font-family:Consolas,monospace}.ctx-divider{height:1px;background:var(--border);margin:3px 0}#help-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000a6;z-index:9100;display:flex;align-items:center;justify-content:center}#help-box{background:var(--bg-panel);border:1px solid var(--border-light);border-radius:10px;width:min(680px,94vw);max-height:80vh;overflow-y:auto;box-shadow:0 20px 60px #000000b3}#help-header{display:flex;align-items:center;justify-content:space-between;padding:14px 18px 12px;border-bottom:1px solid var(--border);font-weight:700;font-size:14px;color:var(--text)}#help-close{background:transparent;border:1px solid var(--border);border-radius:5px;color:var(--text-dim);cursor:pointer;width:24px;height:24px;display:flex;align-items:center;justify-content:center;font-size:12px;transition:all .12s}#help-close:hover{background:var(--danger);color:#fff;border-color:var(--danger)}#help-body{display:grid;grid-template-columns:repeat(3,1fr);gap:0;padding:6px 0 12px}.help-col{padding:8px 18px;border-right:1px solid var(--border)}.help-col:last-child{border-right:none}.help-section{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--accent);padding:6px 0 4px}.help-row{display:flex;align-items:center;justify-content:space-between;padding:2px 0;gap:8px;font-size:11px;color:var(--text-dim)}.help-row kbd{font-size:9px;background:var(--bg-dark);border:1px solid var(--border);border-radius:3px;padding:2px 5px;font-family:Consolas,monospace;color:var(--text);white-space:nowrap;flex-shrink:0}.help-row span{text-align:right}.room-sub-header{display:flex;align-items:center;gap:6px;padding:5px 10px 4px;background:var(--bg-toolbar);border-top:1px solid var(--border);border-bottom:1px solid var(--border);cursor:pointer;-webkit-user-select:none;user-select:none;font-size:10px;font-weight:600;color:var(--text-dim);letter-spacing:.05em;transition:background .12s}.room-sub-header:hover{background:var(--bg-hover);color:var(--text)}.rs-import-header{border-top:2px solid rgba(79,195,247,.35)}.rs-num-import{background:#4fc3f733;color:var(--accent);font-size:12px}.rs-num{display:inline-flex;align-items:center;justify-content:center;width:15px;height:15px;border-radius:50%;background:var(--bg-active);color:var(--accent);font-size:9px;font-weight:700;flex-shrink:0}.rs-arrow{margin-left:auto;font-size:9px;color:var(--text-dim)}.room-sub-body{overflow:hidden;max-height:2000px;transition:max-height .2s ease}.room-sub-body.rs-collapsed{max-height:0}.rs-label-row{padding:4px 10px 2px;font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-dim);opacity:.7}.rs-empty{padding:5px 10px 7px;font-size:10px;color:var(--text-dim);font-style:italic;line-height:1.4}.rs-indent{padding-left:18px!important}.rs-toggle{position:relative;display:inline-flex;align-items:center;width:30px;height:16px;cursor:pointer;flex-shrink:0}.rs-toggle input[type=checkbox]{opacity:0;width:0;height:0;position:absolute}.rs-toggle-track{display:block;width:30px;height:16px;border-radius:8px;background:var(--border);transition:background .2s}.rs-toggle input:checked~.rs-toggle-track{background:var(--success)}.rs-toggle-knob{position:absolute;left:2px;top:2px;width:12px;height:12px;border-radius:50%;background:#fff;transition:left .2s;pointer-events:none}.rs-toggle input:checked~.rs-toggle-knob{left:16px}.rs-toggle-label{font-size:10px;color:var(--text-dim);min-width:20px}.room-shape-grid{display:grid;grid-template-columns:1fr 1fr;gap:5px;padding:5px 7px 7px}.room-shape-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;padding:7px 4px 5px;background:var(--bg-dark);border:1px solid var(--border);border-radius:6px;color:var(--text-dim);cursor:pointer;font-size:9px;transition:all .12s}.room-shape-btn svg{width:36px;height:22px}.room-shape-btn:hover{background:var(--bg-hover);color:var(--text);border-color:var(--accent2)}.room-shape-btn.active{background:var(--bg-active);color:var(--accent);border-color:var(--accent2)}.room-select{flex:1;background:var(--bg-dark);border:1px solid var(--border);border-radius:4px;color:var(--text);padding:3px 5px;font-size:11px;cursor:pointer;min-width:0}.room-select:focus{outline:none;border-color:var(--accent2)}.room-wall-input-row{display:flex;align-items:center;gap:5px;padding:3px 8px}.room-wall-input-row label{width:50px;font-size:10px;color:var(--text-dim);flex-shrink:0}.room-wall-input-row input[type=number]{flex:1;background:var(--bg-dark);border:1px solid var(--border);border-radius:4px;color:var(--text);padding:3px 5px;font-size:11px;min-width:0}.room-wall-input-row input[type=number]:focus{outline:none;border-color:var(--accent2)}.room-wall-input-row .unit-badge{font-size:9px;color:var(--text-dim);min-width:16px}#btn-apply-room{color:var(--success);border-color:var(--success);font-weight:600}#btn-apply-room:hover{background:#3fb9501a}.wc-card{margin:3px 7px;background:var(--bg-dark);border:1px solid var(--border);border-radius:6px;overflow:hidden}.wc-header{display:flex;align-items:center;justify-content:space-between;padding:4px 7px 3px;background:var(--bg-active);border-bottom:1px solid var(--border)}.wc-label{font-size:10px;font-weight:700;color:var(--accent);text-transform:uppercase;letter-spacing:.06em}.wc-remove{background:transparent;border:none;cursor:pointer;font-size:11px;color:var(--text-dim);padding:0 1px;transition:color .12s}.wc-remove:hover{color:var(--danger)}.wc-field-row{display:flex;align-items:center;gap:5px;padding:3px 7px}.wc-field-row label{width:44px;font-size:10px;color:var(--text-dim);flex-shrink:0}.wc-input{flex:1;background:var(--bg-panel);border:1px solid var(--border);border-radius:4px;color:var(--text);padding:2px 4px;font-size:11px;min-width:0}.wc-input:focus{outline:none;border-color:var(--accent2)}.wc-select{flex:1;background:var(--bg-panel);border:1px solid var(--border);border-radius:4px;color:var(--text);padding:2px 4px;font-size:10px;cursor:pointer}.wc-select:focus{outline:none;border-color:var(--accent2)}.rs-ap-header{display:flex;align-items:center;gap:5px;padding:4px 10px 2px;font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-dim)}.ap-card{margin:2px 7px 3px;background:var(--bg-dark);border:1px solid var(--border);border-radius:5px;overflow:hidden}.ap-card-header{display:flex;align-items:center;justify-content:space-between;padding:3px 7px 2px;background:#ffffff08;border-bottom:1px solid var(--border)}.ap-badge{font-size:8px;font-weight:700;text-transform:uppercase;padding:1px 5px;border-radius:3px;letter-spacing:.06em}.ap-badge-opening{background:#4fc3f726;color:var(--accent)}.ap-badge-utility{background:#f8514926;color:var(--danger)}.ri-source-tabs{display:flex;gap:3px;padding:5px 7px 3px}.ri-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:3px;padding:4px 3px;background:var(--bg-dark);border:1px solid var(--border);border-radius:5px;color:var(--text-dim);font-size:9px;font-weight:700;cursor:pointer;transition:all .12s;white-space:nowrap}.ri-tab:hover{background:var(--bg-hover);color:var(--text);border-color:var(--accent2)}.ri-tab.active{background:var(--bg-active);color:var(--accent);border-color:var(--accent2)}.ri-dropzone{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;margin:3px 7px;padding:11px 7px 9px;background:var(--bg-dark);border:1.5px dashed var(--border);border-radius:7px;cursor:pointer;color:var(--text-dim);transition:all .12s;-webkit-user-select:none;user-select:none;outline:none}.ri-dropzone:hover,.ri-dropzone:focus{border-color:var(--accent2);background:#4fc3f70a;color:var(--text)}.ri-dropzone.ri-dropzone-drag{border-color:var(--accent);background:#4fc3f714;color:var(--accent)}.ri-dropzone.ri-dropzone-ready{border-color:var(--success);border-style:solid;background:#3fb9500f;color:var(--success)}.ri-dropzone svg{opacity:.5}.ri-dropzone-main{font-size:10px;font-weight:600;text-align:center}.ri-dropzone-hint{font-size:9px;color:var(--text-dim);opacity:.7}.ri-paste-label{padding:3px 10px 1px;font-size:9px;color:var(--text-dim);text-align:center;opacity:.6}.ri-textarea{display:block;margin:0 7px 3px;width:calc(100% - 14px);height:58px;resize:vertical;background:var(--bg-dark);border:1px solid var(--border);border-radius:5px;color:var(--text);font-size:10px;font-family:Consolas,monospace;padding:4px 6px}.ri-textarea:focus{outline:none;border-color:var(--accent2)}.ri-import-btn{color:var(--accent);border-color:var(--accent2);font-weight:600}.ri-import-btn:hover{background:#4fc3f71a}.ri-status{margin:0 7px 7px;padding:5px 7px;border-radius:5px;font-size:9px;line-height:1.45;border:1px solid transparent}.ri-status-success{background:#3fb9501a;border-color:#3fb95059;color:var(--success)}.ri-status-error{background:#f851491a;border-color:#f8514959;color:var(--danger)}.ri-status-info{background:#4fc3f714;border-color:#4fc3f74d;color:var(--accent)}#selection-box{position:absolute;border:1px dashed var(--accent);background:#4fc3f70f;pointer-events:none}@media print{#toolbar,#sidebar,#preview3d-container,#statusbar,#command-bar,#context-menu,#help-overlay,#zoom-controls,#canvas-overlay{display:none!important}body{background:#fff}#main-content{position:static;display:block}#canvas-wrapper{width:100%;height:100vh}#canvas-container{width:100%;height:100%}#canvas2d{width:100%!important;height:100%!important}}#auth-gate{position:fixed;top:0;right:0;bottom:0;left:0;z-index:99999;background:#0d1117;display:flex;align-items:center;justify-content:center}#auth-gate-inner{display:flex;flex-direction:column;align-items:center;gap:16px;color:var(--text-dim);font-size:13px;animation:auth-pulse 1.6s ease-in-out infinite}@keyframes auth-pulse{0%,to{opacity:.5}50%{opacity:1}}.user-info{display:flex;align-items:center;gap:7px;margin-left:auto;padding-left:10px;border-left:1px solid var(--border);flex-shrink:0}.user-avatar{width:26px;height:26px;border-radius:50%;border:1px solid var(--border);object-fit:cover;flex-shrink:0}.user-avatar-initials{background:var(--bg-active);color:var(--accent);font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center}.user-name{font-size:11px;color:var(--text-dim);max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.unit-badge{font-size:9px;color:var(--text-dim);min-width:16px;flex-shrink:0}.rs-draw-hint{display:flex;gap:8px;align-items:flex-start;padding:7px 9px 6px;margin:5px 7px 0;background:#4fc3f70f;border:1px solid rgba(79,195,247,.22);border-radius:6px}.rs-draw-hint-icon{font-size:14px;flex-shrink:0;opacity:.6;margin-top:1px}.rs-draw-hint-text{font-size:10px;color:var(--text-dim);line-height:1.5}.rs-draw-hint-text strong{color:var(--accent);font-weight:600}.fw-card{display:flex;flex-direction:column;gap:0;margin:3px 7px;background:var(--bg-dark);border:1px solid var(--border);border-radius:6px;overflow:hidden}.fw-card-header{display:flex;align-items:center;justify-content:space-between;padding:4px 8px 3px;background:var(--bg-active);border-bottom:1px solid var(--border)}.fw-label{font-size:10px;font-weight:700;color:var(--accent);text-transform:uppercase;letter-spacing:.07em}.fw-prop-row{display:flex;align-items:center;gap:5px;padding:3px 8px;border-bottom:1px solid rgba(255,255,255,.04)}.fw-prop-row label{width:58px;font-size:10px;color:var(--text-dim);flex-shrink:0}.fw-prop-row .wc-input{flex:1;min-width:0}.fw-flip-row{padding:4px 8px;border-bottom:none}.fw-flip-btn{flex:1;width:100%;padding:4px 8px;background:var(--bg-panel);border:1px solid var(--border);border-radius:4px;color:var(--text-dim);cursor:pointer;font-size:10px;font-weight:600;text-align:center;letter-spacing:.04em;transition:color .15s,border-color .15s,background .15s}.fw-flip-btn:hover{color:var(--accent);border-color:var(--accent);background:#4fc3f712}.fw-flip-btn.active{color:var(--accent);border-color:var(--accent);background:#4fc3f721}.fw-len-input{flex:1;background:var(--bg-panel);border:1px solid var(--border);border-radius:3px;color:var(--text);padding:2px 4px;font-size:11px;min-width:0}.fw-len-input:focus{outline:none;border-color:var(--accent2)}.fw-thick-input{width:44px;flex:0 0 44px}.fw-field-label{font-size:9px;color:var(--text-dim);padding:0 2px;flex-shrink:0;align-self:center}.wc-flip{background:transparent;border:1px solid var(--border);border-radius:3px;color:var(--text-dim);cursor:pointer;font-size:12px;padding:1px 5px;line-height:1;flex-shrink:0;transition:color .15s,border-color .15s,background .15s}.wc-flip:hover{color:var(--accent);border-color:var(--accent)}.wc-flip.active{color:var(--accent);border-color:var(--accent);background:color-mix(in srgb,var(--accent) 12%,transparent)}.ap-palette{display:flex;flex-wrap:wrap;gap:5px;padding:5px 8px 7px}.ap-chip{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;padding:6px 8px 5px;border-radius:7px;border:1.5px solid var(--border);background:var(--bg-dark);cursor:grab;font-size:18px;-webkit-user-select:none;user-select:none;transition:all .12s;min-width:52px}.ap-chip span{font-size:8px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-dim)}.ap-chip:hover{border-color:var(--accent2);background:var(--bg-hover);transform:translateY(-1px);box-shadow:0 3px 10px #0006}.ap-chip:active,.ap-chip-dragging{cursor:grabbing;opacity:.7;transform:scale(.96)}.ap-chip-opening{border-color:#4fc3f74d}.ap-chip-opening:hover{border-color:var(--accent)}.ap-chip-opening span{color:var(--accent)}.ap-chip-utility{border-color:#f851494d}.ap-chip-utility:hover{border-color:var(--danger)}.ap-chip-utility span{color:var(--danger)}#ui-settings-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;z-index:9200;display:flex;align-items:center;justify-content:center}#ui-settings-box{background:var(--bg-panel);border:1px solid var(--border-light);border-radius:12px;width:min(420px,96vw);box-shadow:0 24px 64px #000000b3;overflow:hidden}.ui-settings-header{display:flex;align-items:center;justify-content:space-between;padding:14px 18px 12px;border-bottom:1px solid var(--border);font-weight:700;font-size:14px;color:var(--text);background:var(--bg-toolbar)}.ui-settings-header button{background:transparent;border:1px solid var(--border);border-radius:5px;color:var(--text-dim);cursor:pointer;width:24px;height:24px;display:flex;align-items:center;justify-content:center;font-size:12px;transition:all .12s}.ui-settings-header button:hover{background:var(--danger);color:#fff;border-color:var(--danger)}.ui-settings-body{padding:16px 18px 20px}.ui-settings-section{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--accent);margin-bottom:8px}.ui-settings-row{display:flex;align-items:center;gap:10px;margin-bottom:6px}.ui-settings-label{font-size:11px;color:var(--text-dim);min-width:38px;flex-shrink:0}.ui-settings-hint{font-size:10px;color:var(--text-dim)}.ui-theme-grid{display:flex;gap:10px}.ui-theme-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px;padding:8px;background:var(--bg-dark);border:2px solid var(--border);border-radius:8px;cursor:pointer;color:var(--text-dim);font-size:11px;font-weight:600;transition:all .15s}.ui-theme-btn:hover{border-color:var(--accent2);color:var(--text)}.ui-theme-btn.active{border-color:var(--accent);color:var(--accent);background:var(--bg-active)}.ui-theme-preview{width:100%;height:36px;border-radius:5px;border:1px solid var(--border)}.dark-preview{background:linear-gradient(135deg,#0d1117 50%,#1c2128)}.light-preview{background:linear-gradient(135deg,#f0f2f5 50%,#e8eaed)}.ui-font-size-btns{display:flex;gap:4px}.ui-fs-btn{padding:3px 9px;background:var(--bg-dark);border:1px solid var(--border);border-radius:4px;color:var(--text-dim);cursor:pointer;font-size:11px;font-family:Consolas,monospace;transition:all .1s}.ui-fs-btn:hover{border-color:var(--accent2);color:var(--text)}.ui-fs-btn.active{background:var(--bg-active);border-color:var(--accent);color:var(--accent)}.ui-accent-swatches{display:flex;gap:5px;flex-wrap:wrap}.ui-swatch{width:22px;height:22px;border-radius:50%;border:2px solid transparent;cursor:pointer;transition:all .1s;flex-shrink:0}.ui-swatch:hover{transform:scale(1.2)}.ui-swatch.active{border-color:#fff;box-shadow:0 0 0 2px var(--accent)}body.theme-light{--bg-dark: #ffffff;--bg-panel: #f0f2f5;--bg-toolbar: #e4e7ec;--bg-hover: #dde1e9;--bg-active: #c8d8f0;--bg-selected: #d0ddf5;--border: #c8cbd4;--border-light:#b0b4bc;--text: #1a1d28;--text-dim: #525870;--text-bright: #000008;--accent: #0060cc;--accent2: #0044aa;--danger: #cc1100;--success: #006600;--warning: #885500;--handle-color:#ff6600}body.theme-light #canvas-container{background:#f8f8f8;cursor:crosshair}body.theme-light #command-bar{background:#f0f2f5;border-top-color:var(--border)}body.theme-light .dark-preview{background:linear-gradient(135deg,#0d1117 50%,#1c2128)}body.theme-light .light-preview{background:linear-gradient(135deg,#f0f2f5 50%,#e8eaed);border-color:#b0b4bc}body.theme-light #auth-gate{background:#f0f2f5}body.theme-light #auth-gate-inner{color:#525870}.project-panel-section{padding:8px 0 6px;border-bottom:1px solid var(--border);flex-shrink:0}.project-panel-header{display:flex;align-items:center;gap:6px;padding:2px 10px 6px}.project-panel-name{flex:1;font-size:12px;font-weight:600;color:var(--text-bright);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;cursor:text;-webkit-user-select:none;user-select:none;border-radius:3px;padding:1px 3px;transition:background .15s}.project-panel-name:hover{background:var(--bg-hover)}.project-panel-actions{display:flex;gap:4px;padding:0 8px}.project-action-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:4px;font-size:10px;padding:4px 6px;border-radius:5px;border:1px solid var(--border);background:var(--bg-panel);color:var(--text-dim);cursor:pointer;transition:background .15s,color .15s,border-color .15s;white-space:nowrap}.project-action-btn:hover{background:var(--bg-hover);color:var(--accent);border-color:var(--accent)}.project-action-btn:active{background:var(--bg-active)}.project-action-btn:disabled{opacity:.5;cursor:not-allowed}.project-save-status{display:flex;align-items:center;padding:6px 10px 2px;min-height:22px}#save-status-text{font-size:10px;font-family:Consolas,monospace;color:var(--text-dim);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}#save-status-text.success{color:var(--success)}#save-status-text.error{color:var(--danger)}#save-status-text.warning{color:var(--warning)}@keyframes fadeInUp{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}body.theme-light .project-panel-section{border-color:#d0d7de}body.theme-light .project-panel-name{color:#1a202c}body.theme-light .project-action-btn{background:#f6f8fa;border-color:#d0d7de;color:#57606a}body.theme-light .project-action-btn:hover{background:#e8eaed;color:var(--accent);border-color:var(--accent)}
