.cart-badge{position:absolute;top:0;right:0;background:#e53935;color:#fff;border-radius:50%;min-width:16px;height:16px;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;padding:0 3px;line-height:1;pointer-events:none}.shop-overlay{position:fixed;inset:0;background:#0009;z-index:2000;display:flex;align-items:stretch;justify-content:center}.shop-panel{background:#1e1e30;display:flex;flex-direction:column;width:100%;max-width:1100px;margin:20px;border-radius:8px;box-shadow:0 8px 40px #0009;overflow:hidden}.shop-header{display:flex;align-items:center;gap:12px;padding:12px 16px;background:#252538;border-bottom:1px solid rgba(255,255,255,.1);flex-shrink:0}.shop-header h2{margin:0;font-size:16px;font-weight:600;color:#fff;flex-shrink:0}.shop-search{flex:1;height:30px;background:#ffffff14;border:1px solid rgba(255,255,255,.15);border-radius:4px;color:#fff;font-size:13px;padding:0 10px;font-family:inherit}.shop-search::placeholder{color:#ffffff59}.shop-search:focus{outline:none;border-color:var(--accent-light);background:#ffffff1f}.shop-close-btn{background:none;border:none;color:#fff9;cursor:pointer;font-size:20px;padding:2px 6px;border-radius:4px;line-height:1;flex-shrink:0}.shop-close-btn:hover{color:#fff;background:#ffffff1a}.shop-body{display:flex;flex:1;min-height:0;overflow:hidden}.shop-sidebar{width:180px;flex-shrink:0;background:#252538;border-right:1px solid rgba(255,255,255,.08);overflow-y:auto;padding:8px 0}.shop-category-btn{display:block;width:100%;text-align:left;padding:8px 14px;background:none;border:none;color:#ffffffb3;font-size:12px;cursor:pointer;font-family:inherit;transition:background .1s,color .1s}.shop-category-btn:hover{background:#ffffff12;color:#fff}.shop-category-btn.active{background:#1976d24d;color:#fff;font-weight:600}.shop-category-count{float:right;opacity:.5;font-size:11px}.shop-grid-wrap{flex:1;overflow-y:auto;padding:16px}.shop-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px}.shop-article-card{background:#252538;border:1px solid rgba(255,255,255,.08);border-radius:6px;overflow:hidden;display:flex;flex-direction:column;transition:border-color .15s,box-shadow .15s}.shop-article-card:hover{border-color:#1976d280;box-shadow:0 2px 12px #0000004d}.shop-article-image{width:100%;aspect-ratio:1;object-fit:contain;background:#ffffff0a}.shop-article-image-placeholder{width:100%;aspect-ratio:1;background:#ffffff0a;display:flex;align-items:center;justify-content:center;color:#ffffff26;font-size:28px}.shop-article-info{padding:8px 10px;flex:1;display:flex;flex-direction:column;gap:3px}.shop-article-name{font-size:12px;color:#fff;font-weight:500;line-height:1.3}.shop-article-artnr{font-size:10px;color:#fff6;font-family:var(--font-mono)}.shop-article-footer{display:flex;align-items:center;justify-content:space-between;padding:6px 10px;border-top:1px solid rgba(255,255,255,.06)}.shop-article-price{font-size:13px;font-weight:600;color:#fff}.shop-add-btn{background:var(--accent-light);border:none;border-radius:50%;width:24px;height:24px;color:#fff;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:1;transition:background .1s}.shop-add-btn:hover{background:var(--accent-hover)}.shop-loading,.shop-empty{text-align:center;padding:60px 20px;color:#fff6;font-size:14px}.cart-overlay{position:fixed;inset:0;background:#00000080;z-index:2100;display:flex;justify-content:flex-end}.cart-panel{background:#1e1e30;width:400px;max-width:100vw;height:100%;display:flex;flex-direction:column;box-shadow:-4px 0 24px #00000080;animation:cart-slide-in .2s ease}@keyframes cart-slide-in{0%{transform:translate(100%)}to{transform:translate(0)}}.cart-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;background:#252538;border-bottom:1px solid rgba(255,255,255,.1);flex-shrink:0}.cart-header h2{margin:0;font-size:15px;font-weight:600;color:#fff}.cart-close-btn{background:none;border:none;color:#fff9;cursor:pointer;font-size:20px;padding:2px 6px;border-radius:4px;line-height:1}.cart-close-btn:hover{color:#fff;background:#ffffff1a}.cart-items{flex:1;overflow-y:auto;padding:12px;display:flex;flex-direction:column;gap:10px}.cart-empty{text-align:center;padding:60px 20px;color:#ffffff59;font-size:14px}.cart-plate-card{background:#252538;border:1px solid rgba(255,255,255,.08);border-radius:6px;padding:10px;display:flex;gap:10px}.cart-plate-preview{width:56px;height:40px;flex-shrink:0;border-radius:3px;border:1px solid rgba(255,255,255,.12);background:#444}.cart-plate-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.cart-plate-name{font-size:12px;font-weight:600;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cart-plate-dims{font-size:11px;color:#ffffff8c}.cart-plate-material{font-size:11px;color:#ffffff73}.cart-plate-entities{font-size:10px;color:#ffffff59;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cart-article-row{background:#252538;border:1px solid rgba(255,255,255,.08);border-radius:6px;padding:10px;display:flex;align-items:center;gap:10px}.cart-article-info{flex:1;min-width:0}.cart-article-name{font-size:12px;font-weight:500;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cart-article-artnr{font-size:10px;color:#ffffff59;font-family:var(--font-mono)}.cart-item-controls{display:flex;align-items:center;gap:8px;flex-shrink:0}.cart-qty-input{width:48px;height:26px;background:#ffffff14;border:1px solid rgba(255,255,255,.15);border-radius:3px;color:#fff;text-align:center;font-size:12px;padding:0 4px;font-family:inherit}.cart-qty-input:focus{outline:none;border-color:var(--accent-light)}.cart-item-price{font-size:12px;font-weight:600;color:#fff;min-width:52px;text-align:right}.cart-remove-btn{background:none;border:none;color:#ffffff4d;cursor:pointer;font-size:16px;padding:2px 4px;border-radius:3px;line-height:1;transition:color .1s,background .1s}.cart-remove-btn:hover{color:#ef5350;background:#ef53501f}.cart-footer{flex-shrink:0;padding:14px 16px;background:#252538;border-top:1px solid rgba(255,255,255,.1);display:flex;flex-direction:column;gap:8px}.cart-total-row{display:flex;justify-content:space-between;align-items:baseline}.cart-total-label{font-size:13px;color:#ffffffb3}.cart-total-value{font-size:18px;font-weight:700;color:#fff}.cart-vat-hint{font-size:11px;color:#ffffff59;text-align:right}.cart-checkout-btn{width:100%;padding:10px;background:var(--accent-light);color:#fff;border:none;border-radius:5px;font-size:14px;font-weight:600;cursor:pointer;font-family:inherit;transition:background .15s}.cart-checkout-btn:hover{background:var(--accent-hover)}.cart-checkout-btn:disabled{opacity:.5;cursor:not-allowed}:root{--toolbar-h: 44px;--statusbar-h: 26px;--sidebar-w: 140px;--props-w: 240px;--tabbar-h: 28px;--accent: #1565C0;--accent-light: #1976D2;--accent-hover: #1E88E5;--danger: #c62828;--bg-toolbar: #2d2d44;--bg-sidebar: #252538;--bg-props: #f5f5f5;--bg-canvas: #e0e0e0;--bg-modal: rgba(0,0,0,.5);--border: #ddd;--text: #333;--text-light: #fff;--text-muted: #888;--font-mono: "SF Mono", "Fira Code", monospace;--font-ui: system-ui, -apple-system, sans-serif;--radius: 4px;--transition: .15s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#app,#root{width:100%;height:100vh;margin:0;padding:0;overflow:hidden;font-family:var(--font-ui);font-size:13px;color:var(--text);background:var(--bg-canvas)}.app{display:flex;flex-direction:column;width:100%;height:100vh}.toolbar{height:var(--toolbar-h);background:var(--bg-toolbar);color:var(--text-light);display:flex;align-items:center;padding:0 8px;gap:4px;flex-shrink:0;overflow-x:auto;overflow-y:hidden;scrollbar-width:none}.toolbar::-webkit-scrollbar{display:none}.toolbar-tools{flex:1;flex-wrap:wrap;gap:2px}.toolbar-right{margin-left:auto}.toolbar-brand{font-weight:700;font-size:14px;letter-spacing:-.5px;white-space:nowrap;padding-right:8px;border-right:1px solid rgba(255,255,255,.2);margin-right:4px}.toolbar-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:1px solid transparent;border-radius:var(--radius);background:transparent;color:var(--text-light);font-size:16px;cursor:pointer;transition:background var(--transition),border-color var(--transition)}.toolbar-btn:hover:not(:disabled){background:#ffffff1a}.toolbar-btn.active{background:var(--accent);border-color:var(--accent-light)}.toolbar-btn:disabled{opacity:.3;cursor:default}.toolbar-btn-text{width:auto;padding:0 8px;font-size:12px;white-space:nowrap}.toolbar-select{height:26px;padding:0 4px;font-size:11px;background:transparent;color:var(--text-light);border:1px solid rgba(255,255,255,.2);border-radius:var(--radius);cursor:pointer}.toolbar-select:hover{background:#ffffff1a}.toolbar-btn-sm{width:26px;height:26px;padding:0}.toolbar-btn-accent{width:auto;padding:0 12px;background:var(--accent);font-size:12px;font-weight:600;white-space:nowrap}.toolbar-btn-accent:hover{background:var(--accent-light)}.toolbar-price{display:inline-flex;align-items:center;padding:0 10px;height:26px;color:var(--text-light);font-size:13px;font-weight:600;font-variant-numeric:tabular-nums;white-space:nowrap;cursor:pointer;border-radius:3px}.toolbar-price:hover{background:#ffffff14}.toolbar-price-empty{color:#ffffff59;cursor:default}.toolbar-price-empty:hover{background:none}.toolbar-label{display:flex;align-items:center;gap:4px;color:#ffffffa6;font-size:12px;cursor:pointer;white-space:nowrap}.toolbar-label input[type=checkbox]{accent-color:var(--accent)}.toolbar-select{background:#ffffff1a;color:var(--text-light);border:1px solid rgba(255,255,255,.15);border-radius:var(--radius);padding:4px 8px;font-size:12px;cursor:pointer}.toolbar-select option{background:var(--bg-toolbar);color:var(--text-light)}.main-layout{flex:1;display:flex;overflow:hidden}.sidebar{width:var(--sidebar-w);background:var(--bg-sidebar);display:flex;flex-direction:column;align-items:stretch;padding:6px;gap:2px;overflow:hidden;flex-shrink:0;position:relative;z-index:250}.canvas-container{flex:1;position:relative;background:var(--bg-canvas);overflow:hidden;display:grid;grid-template-columns:1fr 12px;grid-template-rows:1fr 12px}.canvas-area{grid-column:1;grid-row:1;position:relative;min-width:0;min-height:0;overflow:hidden}.canvas-container canvas{display:block;width:100%;height:100%;cursor:crosshair;cursor:default}.scrollbar-track{background:#1e1e1e;position:relative;user-select:none}.scrollbar-track-x{grid-column:1;grid-row:2}.scrollbar-track-y{grid-column:2;grid-row:1}.scrollbar-thumb{position:absolute;background:#4a4a4a;border-radius:4px}.scrollbar-thumb-x{top:2px;bottom:2px}.scrollbar-thumb-y{left:2px;right:2px}.scrollbar-thumb:hover{background:#5a5a5a}.scrollbar-thumb.dragging{background:#6a6a6a}.scrollbar-corner{grid-column:2;grid-row:2;background:#1e1e1e}.properties-panel{width:var(--props-w);background:var(--bg-props);display:flex;flex-direction:column;overflow:hidden;flex-shrink:0;border-left:1px solid var(--border)}.statusbar{background:#1a1a2e;color:#aaa;font-size:11px;flex-shrink:0;border-top:1px solid #333}.statusbar-main{height:var(--statusbar-h);display:flex;align-items:center;padding:0 10px;gap:4px}.statusbar-warnings{background:#3d2a00;border-bottom:1px solid #665200;padding:4px 10px;display:flex;flex-direction:column;gap:2px}.statusbar-warning{color:#ffb74d;font-size:11px;line-height:1.4}.toolbar-group{display:flex;align-items:center;gap:3px;flex-shrink:0}.toolbar-sep{width:1px;height:24px;background:#ffffff26;margin:0 4px;flex-shrink:0}.toolbar-sep-sm{width:6px;flex-shrink:0}.toolbar-label{color:#ffffffa6;font-size:11px;white-space:nowrap}.toolbar-input{width:65px;height:26px;background:#ffffff1a;border:1px solid rgba(255,255,255,.15);border-radius:3px;color:var(--text-light);text-align:center;font-size:12px;padding:0 4px}.toolbar-input:focus{outline:none;border-color:var(--accent-light);background:#ffffff26}.toolbar-spacer{flex:1}.btn{display:inline-flex;align-items:center;gap:4px;padding:4px 8px;border:none;border-radius:var(--radius);cursor:pointer;font-size:12px;font-family:inherit;transition:background var(--transition),opacity var(--transition);white-space:nowrap}.btn:disabled{opacity:.4;cursor:not-allowed}.btn:active:not(:disabled){transform:scale(.97)}.btn-primary{background:var(--accent);color:var(--text-light)}.btn-primary:hover:not(:disabled){background:var(--accent-light)}.btn-secondary{background:#ccc;color:var(--text)}.btn-secondary:hover:not(:disabled){background:#bbb}.btn-danger{background:var(--danger);color:var(--text-light)}.btn-danger:hover:not(:disabled){background:#b71c1c}.btn-icon{background:#ffffff14;color:#ffffffd9;padding:4px 7px;border-radius:3px;font-size:11px}.btn-icon:hover:not(:disabled){background:#ffffff29;color:var(--text-light)}.btn-icon svg{flex-shrink:0}.btn-toggle.active{background:var(--accent);color:var(--text-light)}.btn-align{padding:3px 6px;font-size:13px}.btn-material{background:silver;color:#000;border-radius:var(--radius);padding:4px 12px;font-size:12px;min-width:160px;text-align:left}.btn-material:hover{filter:brightness(1.08)}.btn-sm{padding:3px 8px;font-size:11px}.btn-close{background:none;color:#666;border:none;cursor:pointer;font-size:16px;padding:2px 6px}.btn-close:hover{color:#000}.toolbar-dropdown{position:fixed;background:#2a2a44;border:1px solid #555;border-radius:6px;box-shadow:0 4px 16px #0006;min-width:180px;z-index:1000;padding:4px 0}.toolbar-dropdown-item{display:flex;align-items:center;justify-content:space-between;width:100%;padding:6px 12px;background:none;border:none;color:#e0e0e0;font-size:13px;cursor:pointer;font-family:inherit;text-align:left}.toolbar-dropdown-item:hover{background:#00bcd426}.toolbar-dropdown-count{color:#888;font-size:11px;margin-left:12px}.toolbar-dropdown-sep{height:1px;background:#444;margin:4px 8px}.toolbar-dropdown-backdrop{position:fixed;inset:0;z-index:999}.toolbar-dropdown-hint{color:#888;font-size:11px;margin-left:24px;white-space:nowrap}.toolbar-dropdown-section{padding:6px 12px 2px;color:#888;font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase}.toolbar-btn-caret{opacity:.6;font-size:10px;margin-left:2px}.sidebar-section{padding:8px 6px;border-bottom:1px solid rgba(255,255,255,.1)}.sidebar-section h3{font-size:10px;text-transform:uppercase;letter-spacing:.5px;color:#ffffff73;margin-bottom:6px}.sidebar-section label{display:flex;flex-direction:column;gap:2px;font-size:11px;color:#ffffffb3;margin-bottom:6px}.sidebar-section input[type=number]{width:100%;padding:3px 6px;border:1px solid rgba(255,255,255,.2);border-radius:var(--radius);background:#ffffff14;color:var(--text-light);font-size:12px;font-family:var(--font-mono)}.sidebar-section input[type=number]:focus{outline:none;border-color:var(--accent)}.sidebar .checkbox-label{flex-direction:row!important;align-items:center;gap:6px!important}.sidebar .checkbox-label input[type=checkbox]{accent-color:var(--accent)}.sidebar .material-preview{width:100%;height:32px;border-radius:var(--radius);display:flex;align-items:center;justify-content:center;margin-bottom:4px;border:1px solid rgba(255,255,255,.2)}.sidebar .material-name{font-size:11px;font-weight:600;text-shadow:0 1px 2px rgba(0,0,0,.5)}.sidebar .text-muted{font-size:11px;color:var(--text-muted)}.sidebar-grid{display:grid;grid-template-columns:auto 1fr;gap:4px 8px;align-items:center;margin-bottom:4px}.sidebar-grid label{font-size:10px;color:#ffffffb3;margin-bottom:0;flex-direction:row;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-input-wrap{display:flex;align-items:center;gap:4px}.sidebar-input-wrap input[type=number]{flex:1;min-width:0;width:50px}.sidebar-unit{font-size:10px;color:#fff6;min-width:20px}.plate-info .prop-row{display:flex;align-items:center;justify-content:space-between;gap:6px;margin-bottom:3px;min-height:22px}.plate-info .prop-value{font-size:11px;color:var(--text);font-family:var(--font-mono);text-align:right}.tool-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2px;padding:2px;overflow:hidden;flex-shrink:0;scrollbar-width:thin;scrollbar-color:#555 transparent}.tool-grid-btn{display:flex;align-items:center;justify-content:center;width:100%;min-width:28px;min-height:28px;aspect-ratio:1;padding:4px;background:transparent;border:1px solid transparent;border-radius:var(--radius);cursor:grab;color:#ffffffa6;transition:background .12s,color .12s}.tool-grid-btn:active{cursor:grabbing}.tool-grid-btn svg{pointer-events:none;display:block}.tool-grid-btn:hover{background:#ffffff1a;color:var(--text-light)}.tool-grid-btn.active{background:var(--accent);color:var(--text-light);border-color:var(--accent-light)}.tg-icon{font-size:17px;line-height:1}.tool-grid-wide{grid-column:1 / -1;aspect-ratio:auto;padding:4px 0;font-size:11px}.tool-grid-wide .tg-icon{font-size:14px}.tool-grid-section{grid-column:1 / -1;font-size:8px;text-transform:uppercase;letter-spacing:.8px;color:#ffffff4d;padding:4px 2px 1px;margin-top:2px}.tool-action-row{display:flex;gap:4px}.tool-action-btn{flex:1;padding:5px 4px;background:#1a3a5c;border:1px solid rgba(255,255,255,.1);border-radius:var(--radius);color:#ffffffb3;font-size:10px;cursor:pointer;text-align:center;transition:background .12s}.tool-action-btn:hover{background:#1f4a70;color:var(--text-light)}.tool-separator{height:1px;background:#ffffff1a;margin:4px 0}.zoom-group{display:flex;gap:2px;flex-wrap:wrap;justify-content:center}.entity-list{flex:1;overflow-y:auto;font-size:10px}.entity-list-empty{color:#ffffff4d;text-align:center;padding:8px 4px}.entity-item{display:flex;align-items:center;gap:4px;padding:4px 6px;border-radius:3px;cursor:pointer;color:#ffffffa6;transition:background .1s}.entity-item:hover{background:#ffffff14}.entity-item.selected{background:#1565c066;color:var(--text-light)}.entity-type-icon{font-size:12px}.entity-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.properties-empty{padding:16px 12px;text-align:center;color:var(--text-muted);font-size:12px}.property-grid{display:grid;grid-template-columns:auto 1fr;gap:4px 8px;align-items:center;margin-bottom:8px;padding-bottom:8px;border-bottom:1px solid var(--border)}.property-grid label{font-size:11px;color:var(--text-muted);white-space:nowrap}.property-grid input[type=number]{width:100%;padding:2px 4px;border:1px solid var(--border);border-radius:var(--radius);font-size:12px;font-family:var(--font-mono)}.property-grid input[type=number]:focus{outline:none;border-color:var(--accent)}.prop-readonly{font-size:12px;color:var(--text-muted);padding:2px 4px}.property-row{display:flex;align-items:center;gap:8px;margin-bottom:4px}.property-row label{font-size:11px;color:var(--text-muted);min-width:60px;white-space:nowrap}.property-row input[type=number],.property-row input[type=text]{flex:1;padding:2px 4px;border:1px solid var(--border);border-radius:var(--radius);font-size:12px;font-family:var(--font-mono)}.property-row input:focus{outline:none;border-color:var(--accent)}.property-row select{flex:1;padding:2px 4px;border:1px solid var(--border);border-radius:var(--radius);font-size:12px}.property-row .unit{font-size:10px;color:var(--text-muted);min-width:20px}.properties-header{background:#3a3a4a;color:var(--text-light);padding:8px 12px;font-weight:600;font-size:12px;border-bottom:1px solid #555;flex-shrink:0}.properties-content{flex:1;overflow-y:auto;padding:0}.prop-empty{padding:16px 12px;color:var(--text-muted);font-size:12px;line-height:1.6}.prop-header{background:#e8e8e8;padding:8px 12px;font-weight:600;font-size:12px;border-bottom:1px solid #ddd;position:sticky;top:0;z-index:1}.prop-section{padding:8px 0}.prop-group{padding:4px 12px 8px}.prop-group-title{font-size:10px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:5px}.prop-row{display:flex;align-items:center;gap:6px;margin-bottom:5px;min-height:24px}.prop-label{font-size:11px;color:#555;width:90px;flex-shrink:0}.prop-hint{display:block;font-size:9px;color:#666;font-weight:400}.prop-input{flex:1;height:24px;border:1px solid #ccc;border-radius:3px;padding:0 6px;font-size:11px;font-family:inherit;background:#fff}.prop-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px #1565c026}input[type=checkbox].prop-input{width:auto;height:auto;flex:none}select.prop-input{height:26px;padding:0 4px}.prop-material-swatch{padding:6px 10px;border-radius:var(--radius);font-size:11px;font-weight:600;color:#000;text-shadow:0 1px 2px rgba(255,255,255,.5);border:1px solid rgba(0,0,0,.15)}.prop-unit{font-size:10px;color:var(--text-muted);min-width:20px;flex-shrink:0}.prop-note{font-size:10px;color:var(--text-muted);padding:2px 0 0;font-style:italic}.prop-footer{padding:8px 12px;border-top:1px solid var(--border)}.price-panel{border-top:1px solid var(--border);background:#f9f9f9;flex-shrink:0}.price-header{padding:6px 12px;font-size:11px;font-weight:600;color:#555;background:#eee;border-bottom:1px solid var(--border)}.price-display{padding:8px 12px;font-size:18px;font-weight:700;color:#1a5c1a}.price-unit{font-size:14px;color:#555;display:block}.price-discount{background:#ffd54f;color:var(--text);font-size:11px;padding:1px 5px;border-radius:3px;margin-left:4px}.price-total{font-size:18px;font-weight:700;color:#1a5c1a;display:block}.price-breakdown{padding:4px 12px 8px;font-size:10px;color:#666;max-height:130px;overflow-y:auto}.breakdown-row{display:flex;justify-content:space-between;padding:1px 0;border-bottom:1px solid #eee}.breakdown-total{display:flex;justify-content:space-between;padding:3px 0 0;font-weight:600;color:var(--text)}.statusbar-group{display:flex;align-items:center;gap:8px}.statusbar-right{margin-left:auto}.statusbar-item{white-space:nowrap}.statusbar-selection{color:var(--accent-light);font-weight:600}.status-item{font-family:var(--font-mono);white-space:nowrap}.status-sep{color:#555}.status-spacer{flex:1}.status-hint{color:#666;font-family:inherit;font-size:10px}.no-tabs-bg{flex:1;background:#252535}.tabbar{display:flex;align-items:center;height:var(--tabbar-h);background:#252535;flex-shrink:0;user-select:none;padding:0 4px;gap:4px}.tabbar-tabs{display:flex;flex:1 1 0;min-width:0;overflow-x:auto;overflow-y:hidden;gap:4px;align-items:center;height:100%;scroll-behavior:smooth}.tabbar-tabs::-webkit-scrollbar{height:3px}.tabbar-tabs::-webkit-scrollbar-thumb{background:#fff3;border-radius:2px}.tabbar-scroll{display:flex;align-items:center;justify-content:center;width:20px;height:24px;flex-shrink:0;border:none;border-radius:3px;background:transparent;color:#fff6;font-size:14px;cursor:pointer}.tabbar-scroll:hover{color:#ffffffd9;background:#ffffff1a}.tabbar-tab{display:flex;align-items:center;gap:6px;padding:4px 10px;font-size:12px;color:#ffffff8c;border:1px solid rgba(255,255,255,.12);border-radius:4px;background:#ffffff0a;cursor:pointer;white-space:nowrap;transition:background var(--transition),color var(--transition),border-color var(--transition)}.tabbar-tab:hover{background:#ffffff14;color:#ffffffd9;border-color:#fff3}.tabbar-tab.active{background:#ffffff1a;color:#fffffff2;border-color:#ffffff40}.tabbar-tab-name{pointer-events:none}.tabbar-tab-close{display:flex;align-items:center;justify-content:center;width:14px;height:14px;border:none;border-radius:3px;background:transparent;color:inherit;font-size:12px;line-height:1;cursor:pointer;opacity:.45;padding:0;margin-left:-2px}.tabbar-tab-close:hover{opacity:1;background:#ffffff26}.tabbar-add{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border:1px dashed rgba(255,255,255,.15);border-radius:4px;background:transparent;color:#fff6;font-size:14px;cursor:pointer;transition:color var(--transition),border-color var(--transition)}.tabbar-add:hover{color:#ffffffd9;border-color:#ffffff4d}.tabbar-add-empty{width:auto;padding:0 10px;font-size:12px;color:#ffffffb3;border-color:#ffffff59}.tab-bar{display:flex;align-items:center;background:#2a2a2a;border-bottom:1px solid #444;padding:0 4px;height:var(--tabbar-h);overflow-x:auto;gap:2px;flex-shrink:0}.tab-bar::-webkit-scrollbar{height:3px}.tab-bar::-webkit-scrollbar-thumb{background:#555;border-radius:2px}.tab{display:flex;align-items:center;gap:6px;padding:4px 12px;background:#333;border:1px solid #444;border-bottom:none;border-radius:6px 6px 0 0;color:#aaa;font-size:12px;cursor:pointer;white-space:nowrap;user-select:none;max-width:180px}.tab:hover{background:#3a3a3a;color:#ddd}.tab.active{background:#1e1e1e;color:var(--text-light);border-color:#555}.tab-name{overflow:hidden;text-overflow:ellipsis}.tab-name[contenteditable]{outline:none;background:#444;padding:0 4px;border-radius:2px}.tab-close{font-size:14px;color:#666;cursor:pointer;line-height:1;padding:0 2px;border-radius:3px}.tab-close:hover{color:#ff6b6b;background:#ff6b6b26}.tab-add{display:flex;align-items:center;justify-content:center;width:24px;height:24px;background:transparent;border:1px dashed #555;border-radius:6px 6px 0 0;color:#777;font-size:16px;cursor:pointer}.tab-add:hover{background:#333;color:var(--text-light);border-color:#777}.modal-backdrop,.modal-overlay{position:fixed;inset:0;background:var(--bg-modal);display:flex;align-items:center;justify-content:center;z-index:1000}.modal-dialog{background:#fff;border-radius:8px;box-shadow:0 8px 32px #0000004d;min-width:320px;max-width:90vw;max-height:90vh;display:flex;flex-direction:column;overflow:hidden}.modal-header{padding:14px 16px;font-weight:600;font-size:14px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}.modal-body{padding:16px;overflow-y:auto;flex:1}.modal-footer{padding:12px 16px;display:flex;gap:8px;justify-content:flex-end;border-top:1px solid var(--border);flex-shrink:0;background:#f9f9f9}.modal-close{background:none;border:none;font-size:18px;line-height:1;padding:0;width:24px;height:24px;cursor:pointer;color:#666;border-radius:var(--radius);display:flex;align-items:center;justify-content:center}.modal-close:hover{background:#f0f0f0;color:var(--text)}.material-picker-dialog{width:700px;max-width:95vw;height:520px;max-height:90vh}.material-picker-body{display:flex;gap:0;flex:1;min-height:0;overflow:hidden}.material-groups{width:280px;overflow-y:auto;padding:8px;border-right:1px solid var(--border);flex-shrink:0;min-height:0;scrollbar-gutter:stable}.material-groups,.mat-preview-pane,.mat-ral-grid{scrollbar-width:thin;scrollbar-color:#b0b0b0 transparent}.material-groups::-webkit-scrollbar,.mat-preview-pane::-webkit-scrollbar,.mat-ral-grid::-webkit-scrollbar{width:8px}.material-groups::-webkit-scrollbar-thumb,.mat-preview-pane::-webkit-scrollbar-thumb,.mat-ral-grid::-webkit-scrollbar-thumb{background:#b0b0b0;border-radius:4px}.material-groups::-webkit-scrollbar-thumb:hover,.mat-preview-pane::-webkit-scrollbar-thumb:hover,.mat-ral-grid::-webkit-scrollbar-thumb:hover{background:#888}.material-groups::-webkit-scrollbar-track,.mat-preview-pane::-webkit-scrollbar-track,.mat-ral-grid::-webkit-scrollbar-track{background:#f0f0f0;border-radius:4px}.mat-group{margin-bottom:12px}.mat-group-title{font-size:10px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;padding:4px 4px 6px;border-bottom:1px solid #eee;margin-bottom:4px}.mat-item{display:flex;align-items:center;gap:8px;width:100%;padding:5px 6px;background:transparent;border:1px solid transparent;border-radius:var(--radius);cursor:pointer;font-size:12px;text-align:left;transition:background .1s}.mat-item:hover{background:#f0f4ff;border-color:#c5d5f5}.mat-item.selected{background:#e3eeff;border-color:var(--accent)}.mat-swatch-small{width:20px;height:20px;border-radius:3px;border:1px solid rgba(0,0,0,.15);flex-shrink:0}.mat-preview-pane{flex:1;padding:16px;display:flex;flex-direction:column;gap:12px;overflow-y:auto}.mat-preview-swatch{width:100%;height:100px;border-radius:8px;border:2px solid rgba(0,0,0,.15);box-shadow:inset 0 2px 6px #0000001a,0 2px 8px #00000026}.mat-preview-info{font-size:13px;line-height:1.6}.mat-preview-info strong{font-size:14px}.mat-swatch-rainbow{background:linear-gradient(135deg,red,#ff0,#0f0,#0ff,#00f,#f0f,red)!important}.mat-item-ral{font-weight:600}.mat-ral-surcharge{color:#e65100;font-weight:600;font-size:13px;margin-top:2px}.mat-ral-search{margin-top:4px}.mat-ral-search input{width:100%;padding:6px 8px;border:1px solid #ccc;border-radius:4px;font-size:12px;box-sizing:border-box}.mat-ral-search input:focus{border-color:var(--accent);outline:none}.mat-ral-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(60px,1fr));gap:3px;overflow-y:auto;flex:1;min-height:0;margin-top:6px}.mat-ral-color{height:32px;border:2px solid transparent;border-radius:3px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:border-color .1s}.mat-ral-color:hover{border-color:#0006}.mat-ral-color.selected{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent)}.mat-ral-label{font-size:9px;font-weight:700;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.7);pointer-events:none}.thickness-picker{margin-top:8px}.thickness-picker label{font-size:11px;color:#666;display:block;margin-bottom:4px}.thickness-btns{display:flex;flex-wrap:wrap;gap:4px}.thickness-btn{padding:4px 8px;border:1px solid #ccc;border-radius:3px;background:#fff;cursor:pointer;font-size:11px;transition:background .1s}.thickness-btn:hover{background:#e8f0fe;border-color:var(--accent)}.thickness-btn.selected{background:var(--accent);color:var(--text-light);border-color:var(--accent)}.text-edit-dialog{display:flex;flex-direction:column;gap:12px}.text-edit-label{font-size:12px;color:var(--text-muted)}.text-edit-textarea{width:100%;min-height:100px;padding:8px;border:1px solid #ccc;border-radius:4px;font-family:inherit;font-size:13px;resize:vertical;box-sizing:border-box}.text-edit-textarea:focus{border-color:var(--accent);outline:none}.text-edit-buttons{display:flex;gap:8px;justify-content:flex-end}.btn-primary{padding:6px 16px;background:var(--accent);color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:13px}.btn-primary:hover{opacity:.9}.btn-secondary{padding:6px 16px;background:#f0f0f0;color:var(--text);border:1px solid #ccc;border-radius:4px;cursor:pointer;font-size:13px}.btn-secondary:hover{background:#e4e4e4}.toast{position:fixed;bottom:40px;left:50%;transform:translate(-50%) translateY(20px);background:#323232;color:var(--text-light);padding:10px 20px;border-radius:6px;font-size:13px;box-shadow:0 4px 16px #0000004d;z-index:2000;opacity:0;transition:opacity .2s,transform .2s;pointer-events:none;white-space:nowrap}.toast.show,.toast.visible{opacity:1;transform:translate(-50%) translateY(0)}.toast-success{background:#2e7d32}.toast-error{background:#c62828}.toast-warning{background:#f57f17;color:var(--text-light)}.toast-info{background:#1565c0}.drop-overlay{position:absolute;inset:0;background:#1565c026;border:3px dashed var(--accent);display:flex;align-items:center;justify-content:center;z-index:100;pointer-events:none}.drop-message{display:flex;flex-direction:column;align-items:center;gap:12px;color:var(--accent);font-size:16px;font-weight:600;text-shadow:0 2px 8px rgba(255,255,255,.8)}.price-modal-content{display:flex;flex-direction:column;gap:20px}.price-modal-summary{text-align:center;padding:16px;background:#f8fafc;border-radius:8px;border:1px solid #e2e8f0}.price-modal-plate{color:#64748b;font-size:13px;display:flex;flex-direction:column;gap:2px;margin-bottom:12px}.price-modal-total-value{font-size:32px;font-weight:700;color:#1e293b}.price-modal-unit{display:block;font-size:13px;color:#64748b;margin-top:2px}.price-modal-discount{color:#16a34a;font-size:13px;font-weight:500;margin-top:6px}.price-modal-unit-line{color:#475569;font-size:14px;margin-top:4px}.price-modal-breakdown-header{font-weight:600;font-size:13px;color:#475569;text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px}.price-modal-table{width:100%;border-collapse:collapse;font-size:13px}.price-modal-table td{padding:6px 0;border-bottom:1px solid #f1f5f9}.price-modal-table .breakdown-label{color:#475569}.price-modal-table .breakdown-cost{text-align:right;font-variant-numeric:tabular-nums;color:#1e293b}.price-modal-table tfoot td{border-top:2px solid #cbd5e1;border-bottom:none;font-weight:600;padding-top:8px;color:#1e293b}.price-modal-table tfoot td:last-child{text-align:right}.price-modal-quantity{display:flex;align-items:center;gap:10px;padding-top:8px;border-top:1px solid #e2e8f0}.price-modal-quantity label{font-size:13px;color:#475569}.price-modal-quantity input{width:80px;padding:4px 8px;border:1px solid #cbd5e1;border-radius:4px;font-size:13px;text-align:center}.dxf-contour-dialog{display:flex;flex-direction:column;gap:12px}.dxf-contour-file{display:flex;align-items:center;gap:8px}.dxf-contour-filename{font-size:13px;color:var(--text);font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dxf-contour-row{display:flex;align-items:center;gap:8px}.dxf-contour-row .prop-label{min-width:110px}.dxf-contour-hint{font-size:11px;color:var(--text-muted);line-height:1.4}.dxf-contour-error{padding:8px 10px;background:#fef2f2;border:1px solid #fecaca;border-radius:4px;color:#dc2626;font-size:12px}.print-import-dialog{display:flex;flex-direction:column;gap:12px}.print-import-preview{display:flex;justify-content:center;align-items:center;background:var(--bg-muted, #f1f5f9);padding:12px;border-radius:4px}.print-import-paths{width:100%;border-collapse:collapse;font-size:13px}.print-import-paths th,.print-import-paths td{border-bottom:1px solid var(--border, #e2e8f0);padding:6px 8px;text-align:left;vertical-align:middle}.print-import-paths th{font-weight:600;color:var(--text-muted, #64748b)}.print-import-plate-tag{display:inline-block;padding:2px 8px;background:var(--bg-muted, #e2e8f0);border-radius:3px;font-size:12px;color:var(--text-muted, #475569)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#0003;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#00000059}.sidebar::-webkit-scrollbar{width:6px}.sidebar::-webkit-scrollbar-track{background:#ffffff0d}.sidebar::-webkit-scrollbar-thumb{background:#ffffff4d;border-radius:3px}.sidebar::-webkit-scrollbar-thumb:hover{background:#ffffff80}.sidebar{scrollbar-color:rgba(255,255,255,.3) rgba(255,255,255,.05)}.material-picker{position:relative}.material-picker .material-preview{width:100%;height:32px;border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;border:1px solid rgba(255,255,255,.2);transition:border-color .15s}.material-picker .material-preview:hover{border-color:var(--accent)}.material-preview-label{font-size:12px;font-weight:600;text-shadow:0 1px 2px rgba(0,0,0,.5)}.material-type{font-size:11px;color:#ffffff80;margin-top:2px}.material-dropdown{position:absolute;left:0;top:100%;width:220px;max-height:400px;overflow-y:auto;background:#2a2a3e;border:1px solid rgba(255,255,255,.15);border-radius:6px;padding:8px;z-index:1000;box-shadow:0 8px 24px #0006}.material-group h5{font-size:10px;text-transform:uppercase;letter-spacing:.5px;color:#ffffff80;margin:8px 0 4px;padding-bottom:2px;border-bottom:1px solid rgba(255,255,255,.1)}.material-group:first-child h5{margin-top:0}.material-items{display:flex;flex-direction:column;gap:2px}.material-item{display:flex;align-items:center;gap:8px;padding:4px 6px;border:none;background:transparent;color:#fff;font-size:12px;border-radius:3px;cursor:pointer;text-align:left}.material-item:hover{background:#ffffff1a}.material-item.active{background:var(--accent)}.material-swatch{width:16px;height:16px;border-radius:3px;border:1px solid rgba(255,255,255,.2);flex-shrink:0}.material-picker .material-name{flex:1}.sidebar-select-section{padding:6px}.sidebar-select-btn{display:flex;align-items:center;gap:6px;width:100%;padding:6px 8px;background:#ffffff14;border:1px solid rgba(255,255,255,.2);border-radius:var(--radius);color:#ffffffa6;font-size:12px;font-weight:600;cursor:pointer;transition:background var(--transition),color var(--transition),border-color var(--transition)}.sidebar-select-btn:hover{background:#ffffff26;color:var(--text-light);border-color:#ffffff4d}.sidebar-select-btn.active{background:var(--accent);color:var(--text-light);border:1px solid var(--accent);box-shadow:0 0 0 2px #1565c04d}.sidebar-entity-list{flex:1;overflow-y:auto;border-top:1px solid rgba(255,255,255,.1);margin-top:8px;display:flex;flex-direction:column;min-height:0}.sidebar-entity-list-header{text-align:center;padding:4px 6px;flex-shrink:0}.sidebar-entity-list-items{flex:1;overflow-y:auto}.sidebar-no-elements{font-size:11px;color:#ffffff4d}.sidebar-element-count{font-size:11px;color:#fff9}.entity-list-item{display:flex;align-items:center;gap:6px;padding:2px 8px;font-size:11px;color:#ffffffb3;cursor:pointer;border-radius:2px}.entity-list-item:hover{background:#ffffff14}.entity-list-item.selected{background:var(--accent);color:#fff}.entity-icon{font-size:10px;width:14px;text-align:center;flex-shrink:0}.entity-label{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-tools-section{padding-bottom:4px}.sidebar-tools-section .tool-grid{margin-bottom:2px}.preview3d-container{width:100%;height:100%;position:relative}.preview3d-container canvas{width:100%;height:100%;display:block}.preview3d-views{position:absolute;top:8px;left:8px;display:flex;gap:4px;z-index:10}.preview3d-view-btn{width:28px;height:28px;border:1px solid rgba(255,255,255,.25);border-radius:4px;background:#1e293bcc;color:#e2e8f0;font-size:11px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(4px)}.preview3d-view-btn:hover{background:#3b82f6b3;border-color:#3b82f6cc}.preview3d-loading{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;background:#0f172ad9;color:#e2e8f0;font-size:13px;z-index:10}.preview3d-spinner{width:28px;height:28px;border:3px solid rgba(255,255,255,.15);border-top-color:#3b82f6;border-radius:50%;animation:spin3d .7s linear infinite}@keyframes spin3d{to{transform:rotate(360deg)}}.preview3d-back-hint{position:absolute;bottom:12px;left:50%;transform:translate(-50%);width:calc(100% - 24px);padding:8px 14px;background:#1e283ce6;color:#cbd5e1;font-size:11px;line-height:1.4;border-radius:8px;border:1px solid rgba(100,120,160,.3);text-align:center;z-index:10;pointer-events:none}.bevel-preview{margin:8px 12px;padding:0;background:var(--bg-props)}.bevel-preview-title{font-size:11px;color:#555;padding:4px 8px 0}.bevel-preview svg{display:block;width:100%;height:auto}.bevel-errors{padding:4px 8px 6px;border-top:1px solid #ecc}.bevel-error{font-size:10px;color:#c62828;line-height:1.4;padding:1px 0}.bevel-error:before{content:"⚠️"}.btn-ungroup{display:block;width:100%;padding:6px;margin-top:12px;background:#8b0000;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:12px;font-weight:600}.btn-ungroup:hover{background:#a10000}.btn-delete{display:block;width:100%;padding:6px;margin-top:12px;background:var(--danger);color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:12px;font-weight:600}.btn-delete:hover{opacity:.9}.btn-action{display:block;width:100%;padding:6px;margin-top:8px;background:var(--accent, #1565c0);color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:12px}.btn-action:hover:not(:disabled){opacity:.9}.btn-action:disabled{opacity:.5;cursor:default}.btn-action.active{background:#e8a33d;color:#1a1a1a;animation:btn-action-pulse 1s ease-in-out infinite}@keyframes btn-action-pulse{0%,to{background:#e8a33d}50%{background:#f5c16e}}.import-banner{display:flex;align-items:flex-start;gap:12px;padding:10px 14px;background:#ffc1071f;border-bottom:1px solid rgba(255,193,7,.45);color:#3a2c00;font-size:13px;line-height:1.4}.import-banner-text{flex:1}.import-banner-close{flex:0 0 auto;width:24px;height:24px;border:none;background:transparent;color:inherit;font-size:18px;line-height:1;cursor:pointer;border-radius:3px}.import-banner-close:hover{background:#00000014}@media(max-width:900px){:root{--sidebar-w: 44px;--props-w: 200px}.tool-label{display:none}}.admin-materials,.admin-main,.admin-sidebar,.admin-pricing-container{scrollbar-width:thin;scrollbar-color:#888 #1e1e30}.admin-materials::-webkit-scrollbar,.admin-main::-webkit-scrollbar,.admin-sidebar::-webkit-scrollbar,.admin-pricing-container::-webkit-scrollbar{width:8px}.admin-materials::-webkit-scrollbar-track,.admin-main::-webkit-scrollbar-track,.admin-sidebar::-webkit-scrollbar-track,.admin-pricing-container::-webkit-scrollbar-track{background:#1e1e30}.admin-materials::-webkit-scrollbar-thumb,.admin-main::-webkit-scrollbar-thumb,.admin-sidebar::-webkit-scrollbar-thumb,.admin-pricing-container::-webkit-scrollbar-thumb{background:#888;border-radius:4px}.admin-materials::-webkit-scrollbar-thumb:hover,.admin-main::-webkit-scrollbar-thumb:hover,.admin-sidebar::-webkit-scrollbar-thumb:hover,.admin-pricing-container::-webkit-scrollbar-thumb:hover{background:#aaa}.ctx-item{padding:6px 12px;cursor:pointer;white-space:nowrap;display:flex;align-items:center;gap:8px}.admin-layout{min-height:100vh;background:#1a1a2e;color:#e0e0e0;font-family:var(--font-ui)}.admin-header{background:#252538;padding:12px 24px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid #333}.admin-header h1{font-size:20px;color:#00bcd4;font-weight:600}.admin-nav{display:flex;gap:8px}.admin-nav button,.admin-nav a{padding:8px 16px;background:#333;color:#e0e0e0;border:1px solid #555;border-radius:4px;cursor:pointer;text-decoration:none;font-size:13px;font-family:inherit;line-height:1.2}.admin-nav button:hover,.admin-nav a:hover{background:#444}.admin-nav button.active{background:var(--accent);border-color:var(--accent);color:#fff}.admin-back{display:inline-flex;align-items:center}.admin-materials{display:flex;height:calc(100vh - 60px)}.admin-sidebar{width:300px;min-width:300px;background:#20203a;border-right:1px solid #333;padding:16px;overflow-y:auto}.admin-sidebar h2{color:#00bcd4;font-size:16px;margin-bottom:12px}.admin-main{flex:1;padding:24px;overflow-y:auto}.admin-group-item{padding:8px 12px;margin-bottom:4px;border-radius:4px;cursor:pointer;display:flex;align-items:center;gap:8px;border:1px solid transparent;transition:background .15s}.admin-group-item:hover{background:#ffffff0d}.admin-group-item.active{background:#00bcd426;border-color:#00bcd4}.admin-swatch{display:inline-block;width:18px;height:18px;border-radius:3px;border:1px solid #555;vertical-align:middle;margin-right:6px;flex-shrink:0}.admin-table{width:100%;border-collapse:collapse;font-size:13px}.admin-table th{text-align:left;padding:6px;background:#2a2a44;color:#00bcd4;border-bottom:2px solid #444;font-weight:600;white-space:nowrap}.admin-table td{padding:4px 6px;border-bottom:1px solid #333}.admin-table tr:hover{background:#ffffff08}.admin-input{background:#1a1a2e;color:#e0e0e0;border:1px solid #555;padding:6px 10px;border-radius:4px;font-size:13px;font-family:inherit}.admin-input:focus{border-color:#00bcd4;outline:none}.admin-btn-save{background:#00bcd4;color:#fff;border:none;padding:10px 24px;border-radius:4px;font-size:14px;cursor:pointer;font-weight:600;font-family:inherit}.admin-btn-save:hover{background:#00acc1}.admin-btn-save:disabled{opacity:.5;cursor:default}.admin-btn-add{background:transparent;color:#00bcd4;border:1px solid #00BCD4;padding:6px 12px;border-radius:4px;cursor:pointer;font-size:12px;font-family:inherit}.admin-btn-add:hover{background:#00bcd41a}.admin-btn-toggle{background:none;border:none;cursor:pointer;font-size:14px;padding:2px 4px;border-radius:3px;opacity:.9;transition:opacity .15s}.admin-btn-toggle:hover{opacity:1;background:#ffffff1a}.admin-btn-toggle.inactive{opacity:.4}.admin-group-item.inactive{opacity:.45}.admin-group-item.inactive>span:nth-child(2){text-decoration:line-through}.admin-group-item.inactive .admin-swatch{filter:grayscale(80%)}.admin-row-inactive{opacity:.4}.admin-btn-remove{background:transparent;color:#f44;border:1px solid #f44;width:24px;height:24px;border-radius:3px;cursor:pointer;font-size:13px;line-height:1;display:inline-flex;align-items:center;justify-content:center}.admin-btn-remove:hover{background:#ff444426}.admin-pricing-container{padding:24px;width:100%;overflow-y:auto;height:calc(100vh - 60px)}.admin-pricing-section{background:#252538;border-radius:8px;padding:20px;margin-bottom:20px}.admin-pricing-section h2{color:#00bcd4;font-size:16px;margin-bottom:4px}.admin-pricing-section h3{color:#00bcd4}.admin-pricing-section p{color:#888;font-size:12px;margin-bottom:12px}.admin-ref-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:4px}.admin-ref-item{display:flex;justify-content:space-between;align-items:center;padding:4px 8px;border-radius:3px;background:#ffffff05}.admin-ref-item:hover{background:#ffffff0d}.admin-ref-label{color:#aaa;font-size:12px}.admin-ref-value{color:#e0e0e0;font-family:monospace;font-size:13px;font-weight:600}.admin-tpl-main{flex:1;display:flex;flex-direction:column;overflow:hidden;position:relative}.admin-tpl-header-row{display:flex;align-items:center;justify-content:space-between;padding:16px 24px 8px;flex-shrink:0}.admin-tpl-section-title{color:#00bcd4;font-size:16px;font-weight:600}.admin-tpl-empty{color:#666;text-align:center;margin-top:60px;font-size:14px}.admin-tpl-grid-wrap{flex:1;overflow-y:auto;padding:0 24px 24px}.admin-tpl-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px}.admin-tpl-card{background:#252538;border-radius:10px;border:1px solid #333;overflow:hidden;transition:border-color .15s}.admin-tpl-card:hover{border-color:#555}.admin-tpl-card[draggable=true]{cursor:grab}.admin-tpl-card[draggable=true]:active{cursor:grabbing}.admin-tpl-card-canvas{width:100%;aspect-ratio:16 / 9;display:block;background:#1a1a2e}.admin-tpl-card-body{padding:12px 14px}.admin-tpl-card-name{font-size:14px;font-weight:600;color:#e0e0e0;margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.admin-tpl-card-meta{display:flex;gap:12px;font-size:12px;color:#888;margin-bottom:10px}.admin-tpl-card-actions{display:flex;gap:6px;align-items:center}.admin-tpl-btn-delete{padding:4px 10px;background:#c62828;border:none;border-radius:4px;color:#fff;font-size:11px;cursor:pointer;font-family:inherit}.admin-tpl-btn-delete:hover{background:#e53935}.admin-tpl-create-form{display:flex;gap:16px;align-items:stretch;padding:12px 24px;flex-shrink:0;background:#252538;border-bottom:1px solid #333}.admin-tpl-create-fields{display:flex;flex-direction:column;gap:6px;flex:1}.admin-tpl-create-cat{font-size:11px;color:#888;white-space:nowrap}.admin-tpl-fpd-drop{width:160px;flex-shrink:0;border:2px dashed #444;border-radius:8px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;cursor:pointer;transition:border-color .15s,background .15s}.admin-tpl-fpd-drop:hover{border-color:#00bcd4;background:#00bcd40d}.admin-tpl-fpd-drop.active{border-color:#00bcd4;background:#00bcd426}.admin-tpl-fpd-drop-icon{font-size:18px;font-weight:700;color:#00bcd4;background:#00bcd41f;padding:4px 10px;border-radius:4px}.admin-tpl-fpd-drop-text{font-size:10px;color:#888;text-align:center;line-height:1.4}.admin-tpl-sidebar-header{display:flex;align-items:center;justify-content:space-between;padding-bottom:8px;border-bottom:1px solid #333;margin-bottom:4px}.admin-tpl-tree-item{display:flex;align-items:center;gap:4px;padding:6px 8px;cursor:pointer;color:#ccc;font-size:13px;transition:background .1s;border-right:2px solid transparent}.admin-tpl-tree-item:hover{background:#ffffff0a}.admin-tpl-tree-item.drop-target,.admin-tpl-cat-item.drop-target,.admin-tpl-sidebar-header.drop-target{background:#00bcd440!important;outline:2px dashed #00BCD4;outline-offset:-2px}.admin-tpl-tree-item.active{background:#00bcd41f;color:#00bcd4;border-right-color:#00bcd4}.admin-tpl-tree-arrow{color:#888;font-size:8px;width:14px;display:inline-block;text-align:center;transition:transform .15s}.admin-tpl-tree-arrow.expanded{transform:rotate(90deg)}.admin-tpl-tree-name{flex:1}.admin-tpl-tree-addfolder{background:none;border:1px solid #555;color:#888;width:18px;height:18px;border-radius:3px;cursor:pointer;font-size:13px;line-height:1;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .15s}.admin-tpl-tree-item:hover .admin-tpl-tree-addfolder,.admin-tpl-sidebar-header .admin-tpl-tree-addfolder{opacity:1}.admin-tpl-tree-addfolder:hover{background:#00bcd433;color:#00bcd4;border-color:#00bcd4}.admin-tpl-tree-delfolder{background:none;border:1px solid transparent;color:#666;width:18px;height:18px;border-radius:3px;cursor:pointer;font-size:14px;line-height:1;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .15s}.admin-tpl-tree-item:hover .admin-tpl-tree-delfolder{opacity:1}.admin-tpl-tree-delfolder:hover{color:#f44;border-color:#f44;background:#ff44441a}.admin-tpl-rename-input{flex:1;padding:1px 4px!important;font-size:13px!important;min-width:60px}.admin-tpl-tree-item.drag-over-above{border-top:2px solid #00BCD4!important}.admin-tpl-tree-item[draggable=true]{cursor:grab}.admin-tpl-new-folder{display:flex;gap:4px;padding:4px 8px;align-items:center}.admin-tpl-tree-btn-ok{background:#00838f;border:none;color:#fff;width:22px;height:22px;border-radius:3px;cursor:pointer;font-size:13px;display:flex;align-items:center;justify-content:center}.admin-tpl-tree-btn-ok:hover{background:#00acc1}.admin-tpl-tree-btn-cancel{background:#4a1a1a;border:none;color:#ef9a9a;width:22px;height:22px;border-radius:3px;cursor:pointer;font-size:15px;display:flex;align-items:center;justify-content:center}.admin-tpl-tree-btn-cancel:hover{background:#c62828;color:#fff}.admin-tpl-dragover{outline:2px dashed #00BCD4;outline-offset:-4px}.admin-tpl-drop-overlay{position:absolute;inset:0;background:#00bcd414;display:flex;align-items:center;justify-content:center;z-index:10;pointer-events:none}.admin-tpl-drop-text{color:#00bcd4;font-size:18px;font-weight:600;text-align:center}.admin-tpl-importing{padding:8px 24px;color:#00bcd4;font-size:13px;animation:pulse 1.5s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.admin-templates-layout{display:flex;height:calc(100vh - 60px)}.admin-tpl-sidebar{width:220px;flex-shrink:0;background:#1a1a2e;border-right:1px solid #333;padding:16px 0;overflow-y:auto}.admin-tpl-sidebar-title{color:#00bcd4;font-size:13px;font-weight:600;padding:0 16px 12px;border-bottom:1px solid #333;margin-bottom:4px}.admin-tpl-cat-item{display:flex;justify-content:space-between;align-items:center;padding:8px 16px;cursor:pointer;color:#ccc;font-size:13px;transition:background .1s}.admin-tpl-cat-item:hover{background:#ffffff0a}.admin-tpl-cat-item.active{background:#00bcd41f;color:#00bcd4;border-right:2px solid #00BCD4}.admin-tpl-cat-count{font-size:11px;color:#888;background:#ffffff0f;padding:1px 6px;border-radius:8px;min-width:20px;text-align:center}.admin-tpl-form{max-width:500px}.admin-tpl-form-field{margin-bottom:10px}.admin-tpl-form-field label{display:block;color:#aaa;font-size:12px;margin-bottom:4px}.admin-input{width:100%;background:#1a1a2e;border:1px solid #444;color:#e0e0e0;padding:6px 10px;border-radius:4px;font-size:13px;font-family:inherit;box-sizing:border-box}.admin-input:focus{outline:none;border-color:#00bcd4}textarea.admin-input{resize:vertical}.admin-cat-dropdown{position:absolute;top:100%;left:0;right:0;background:#252538;border:1px solid #444;border-radius:4px;max-height:160px;overflow-y:auto;z-index:10;box-shadow:0 4px 12px #0006}.admin-cat-dropdown-item{padding:6px 10px;cursor:pointer;color:#ccc;font-size:13px}.admin-cat-dropdown-item:hover{background:#00bcd41f;color:#00bcd4}.tpl-overlay{position:fixed;inset:0;background:#0009;z-index:9999;display:flex;align-items:center;justify-content:center}.tpl-dialog-dark{background:#1e1e2e;border-radius:12px;width:calc(100vw - 80px);height:calc(100vh - 80px);max-width:1200px;max-height:800px;display:flex;flex-direction:column;box-shadow:0 8px 32px #0009}.tpl-header{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;border-bottom:1px solid #333;flex-shrink:0}.tpl-header-title{font-size:16px;font-weight:600;color:#cdd6f4}.tpl-header-actions{display:flex;gap:10px;align-items:center}.tpl-checkbox-label{display:flex;align-items:center;gap:5px;font-size:12px;color:#aaa;cursor:pointer;white-space:nowrap}.tpl-checkbox-label input{margin:0;cursor:pointer}.tpl-btn-primary{padding:6px 16px;border:1px solid #1565C0;border-radius:6px;background:#1565c0;color:#fff;font-size:13px;font-weight:600;cursor:pointer;font-family:inherit}.tpl-btn-primary:hover:not(:disabled){opacity:.85}.tpl-btn-primary:disabled{opacity:.4;cursor:default}.tpl-btn-secondary{padding:6px 16px;border:1px solid #555;border-radius:6px;background:#2a2a3e;color:#ccc;font-size:13px;cursor:pointer;font-family:inherit}.tpl-btn-secondary:hover{background:#3a3a50}.tpl-btn-del{background:none;border:none;color:#666;font-size:16px;cursor:pointer;margin-left:auto;padding:0 4px}.tpl-btn-del:hover{color:#f44}.tpl-body{display:flex;flex:1;min-height:0}.tpl-list{flex:0 0 380px;overflow-y:auto;border-right:1px solid #333;padding:8px}.tpl-list-empty{color:#555;text-align:center;padding:40px 0;font-size:13px}.tpl-cat-section{margin-bottom:2px}.tpl-cat-header{padding:8px 10px;background:#2a2a3e;border-radius:6px;cursor:pointer;color:#cdd6f4;font-weight:600;font-size:13px;display:flex;align-items:center;gap:6px;user-select:none}.tpl-cat-header:hover{background:#333350}.tpl-cat-arrow{color:#888;font-size:12px;transition:transform .2s;display:inline-block}.tpl-cat-arrow.expanded{transform:rotate(90deg)}.tpl-cat-name{flex:1}.tpl-cat-count{color:#555;font-weight:400;font-size:10px}.tpl-cat-items{padding:2px 0 2px 4px}.tpl-item{padding:6px 10px;margin:1px 0;border-radius:4px;cursor:pointer;color:#bac2de;font-size:12px;border:1px solid transparent;transition:background .1s}.tpl-item:hover{background:#2a2a3e}.tpl-item.selected{background:#2a3a5e;border-color:#5af}.tpl-item-name{font-weight:500;color:#cdd6f4;font-size:12px}.tpl-item-desc{color:#666;font-size:10px;margin-top:1px}.tpl-preview{flex:1;display:flex;flex-direction:column;padding:16px;min-width:0}.tpl-preview-empty{flex:1;display:flex;align-items:center;justify-content:center;color:#555;font-size:14px}.tpl-preview-info{display:flex;gap:16px;flex-wrap:wrap;margin-bottom:8px;color:#888;font-size:12px;align-items:center}.tpl-preview-dims{font-weight:600;color:#cdd6f4}.tpl-preview-desc-text{color:#aaa;font-size:11px;font-style:italic}.tpl-preview-canvas{flex:1;width:100%;border-radius:6px;background:#2a2a3e;display:block}.tpl-dialog-small{background:#1e1e2e;border:1px solid #555;border-radius:10px;padding:20px;width:420px;max-width:90vw;box-shadow:0 12px 40px #00000080}.tpl-dialog-title{font-size:15px;font-weight:600;color:#cdd6f4;margin-bottom:16px}.tpl-save-form{display:flex;flex-direction:column;gap:12px}.tpl-save-field{display:flex;flex-direction:column;gap:4px}.tpl-save-field label{font-size:11px;color:#888;font-weight:500}.tpl-save-field input,.tpl-save-field textarea{padding:7px 10px;background:#252538;border:1px solid #555;border-radius:4px;color:#e0e0e0;font-size:13px;font-family:inherit;box-sizing:border-box;width:100%;outline:none}.tpl-save-field input:focus,.tpl-save-field textarea:focus{border-color:#5af}.tpl-save-field textarea{resize:vertical;min-height:48px}.tpl-save-info{font-size:11px;color:#888;padding:6px 8px;background:#252538;border-radius:4px}.tpl-save-buttons{display:flex;gap:8px;justify-content:flex-end;padding-top:4px}.sidebar-lib-btn{width:100%;padding:6px 8px;background:var(--bg-surface, #252538);border:1px solid #444;border-radius:4px;color:#ccc;font-size:12px;cursor:pointer;text-align:left;transition:background .15s}.sidebar-lib-btn:hover{background:#333}.sidebar-lib-btn.active{background:#00838f;color:#fff;border-color:#00bcd4}.clib-panel{position:absolute;left:var(--sidebar-w);top:0;bottom:0;width:240px;background:#1e1e32;z-index:300;display:flex;flex-direction:column;border-right:1px solid #444;box-shadow:4px 0 16px #0000004d}.clib-header{display:flex;align-items:center;justify-content:space-between;padding:8px 10px;border-bottom:1px solid #444;flex-shrink:0}.clib-header h3{color:#00bcd4;font-size:13px;margin:0;font-weight:600}.clib-count{color:#888;font-weight:400;margin-left:4px}.clib-close{background:none;border:none;color:#888;font-size:18px;cursor:pointer;padding:0 4px}.clib-close:hover{color:#fff}.clib-actions{display:flex;gap:6px;padding:8px;flex-shrink:0}.clib-btn-save{flex:1;padding:6px 10px;background:#00838f;border:none;border-radius:4px;color:#fff;font-size:11px;cursor:pointer;transition:background .15s}.clib-btn-save:hover:not(:disabled){background:#00acc1}.clib-btn-save:disabled{opacity:.4;cursor:default}.clib-btn-folder{width:32px;height:32px;background:#2a2a40;border:1px solid #555;border-radius:4px;color:#aaa;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center}.clib-btn-folder:hover{background:#00838f;color:#fff;border-color:#00bcd4}.clib-new-folder{display:flex;gap:4px;padding:0 8px 8px}.clib-new-folder input{flex:1;padding:4px 8px;background:#252538;border:1px solid #555;border-radius:3px;color:#e0e0e0;font-size:12px;outline:none}.clib-new-folder input:focus{border-color:#00bcd4}.clib-new-folder button{padding:4px 10px;background:#00838f;border:none;border-radius:3px;color:#fff;font-size:12px;cursor:pointer}.clib-search{padding:0 8px 8px;flex-shrink:0}.clib-search input{width:100%;padding:5px 8px;box-sizing:border-box;background:#252538;border:1px solid #444;border-radius:4px;color:#e0e0e0;font-size:12px;outline:none}.clib-search input:focus{border-color:#00bcd4}.clib-search input::placeholder{color:#666}.clib-tree{flex:1;overflow-y:auto;min-height:0;border-bottom:1px solid #444;scrollbar-width:thin;scrollbar-color:#555 #1e1e30}.clib-tree::-webkit-scrollbar{width:8px}.clib-tree::-webkit-scrollbar-track{background:#1e1e30}.clib-tree::-webkit-scrollbar-thumb{background:#555;border-radius:4px}.clib-tree::-webkit-scrollbar-thumb:hover{background:#777}.clib-folder{border-bottom:1px solid #2a2a3e}.clib-folder-header{display:flex;align-items:center;gap:6px;padding:6px 8px;cursor:pointer;user-select:none;transition:background .1s}.clib-folder-header:hover{background:#ffffff0d}.clib-folder-header.expanded{background:#00bcd414}.clib-folder-arrow{color:#888;font-size:9px;width:10px}.clib-folder-name{flex:1;color:#ccc;font-size:11px;font-weight:600;letter-spacing:.5px}.clib-folder-count{color:#888;font-size:10px;min-width:16px;text-align:right}.clib-folder-del{background:none;border:none;color:#666;font-size:14px;cursor:pointer;padding:0 2px;line-height:1}.clib-folder-del:hover{color:#f44}.clib-folder-items{padding:2px 0 4px}.clib-empty-folder{color:#555;font-size:11px;padding:4px 24px}.clib-item{display:flex;align-items:center;gap:8px;padding:4px 8px 4px 20px;cursor:pointer;border:1px solid transparent;border-radius:3px;margin:1px 4px;transition:background .1s,border-color .1s}.clib-item:hover{background:#ffffff0d;border-color:#444}.clib-item.selected{background:#00bcd426;border-color:#00838f}.clib-item-thumb{width:36px;height:36px;border-radius:3px;object-fit:contain;flex-shrink:0;background:#1a1a2e;border:1px solid #333}.clib-item-thumb-empty{display:flex;align-items:center;justify-content:center}.clib-item-info{flex:1;min-width:0}.clib-item-name{color:#e0e0e0;font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:flex;align-items:center;gap:4px}.clib-item-meta{color:#888;font-size:10px}.clib-badge{font-size:8px;padding:1px 3px;border-radius:2px;font-weight:700;flex-shrink:0}.clib-badge-system{background:#37474f;color:#90a4ae}.clib-badge-public{background:#1b5e20;color:#81c784}.clib-item-actions{flex-shrink:0}.clib-btn-place{width:22px;height:22px;border:1px solid #555;border-radius:3px;background:#2a2a40;color:#aaa;font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center}.clib-btn-place:hover{background:#00838f;color:#fff;border-color:#00bcd4}.clib-empty{color:#888;text-align:center;margin-top:30px;font-size:12px}.clib-preview{flex-shrink:0;padding:8px;border-top:1px solid #444;max-height:35%;overflow-y:auto;scrollbar-width:thin;scrollbar-color:#555 #1e1e30}.clib-preview-label{font-size:10px;color:#888;letter-spacing:1px;font-weight:600;margin-bottom:6px}.clib-preview-empty{color:#555;font-size:11px;text-align:center;padding:20px 0}.clib-preview-img{width:100%;max-height:120px;object-fit:contain;background:transparent;border:none;border-radius:4px;display:block}.clib-preview-placeholder{display:flex;align-items:center;justify-content:center;min-height:120px}.clib-preview-info{margin-top:6px}.clib-preview-name{color:#e0e0e0;font-size:13px;font-weight:600}.clib-preview-meta{color:#888;font-size:11px;margin-top:2px}.clib-preview-desc{color:#aaa;font-size:11px;margin-top:4px}.clib-preview-notes{margin-top:8px;padding:6px 8px;background:#252538;border-radius:3px;border:1px solid #333}.clib-preview-notes-label{font-size:9px;color:#888;text-transform:uppercase;letter-spacing:.5px;margin-bottom:2px}.clib-preview-notes-text{color:#ccc;font-size:11px;line-height:1.4}.clib-preview-shop{display:inline-block;margin-top:6px;padding:3px 8px;background:#1b5e20;color:#81c784;border-radius:3px;font-size:11px;text-decoration:none;transition:background .15s}.clib-preview-shop:hover{background:#2e7d32}.clib-preview-owner{color:#666;font-size:10px;margin-top:4px}.clib-preview-actions{display:flex;gap:4px;margin-top:8px;flex-wrap:wrap}.clib-btn-place-lg{flex:1;padding:6px 10px;background:#00838f;border:none;border-radius:4px;color:#fff;font-size:11px;cursor:pointer}.clib-btn-place-lg:hover{background:#00acc1}.clib-btn-edit{padding:6px 10px;background:#37474f;border:none;border-radius:4px;color:#ccc;font-size:11px;cursor:pointer}.clib-btn-edit:hover{background:#455a64}.clib-btn-del{padding:6px 10px;background:#4a1a1a;border:none;border-radius:4px;color:#ef9a9a;font-size:11px;cursor:pointer}.clib-btn-del:hover{background:#c62828;color:#fff}.clib-dialog-overlay{position:fixed;inset:0;background:#0009;z-index:500;display:flex;align-items:center;justify-content:center}.clib-dialog{background:#1e1e32;border:1px solid #555;border-radius:8px;padding:20px;width:340px;max-width:90vw;box-shadow:0 12px 40px #00000080}.clib-dialog h4{margin:0 0 14px;color:#00bcd4;font-size:14px}.clib-dialog label{display:block;margin-bottom:10px;color:#aaa;font-size:11px}.clib-dialog input[type=text],.clib-dialog input[type=url],.clib-dialog select,.clib-dialog textarea{display:block;width:100%;margin-top:4px;padding:6px 8px;background:#252538;border:1px solid #555;border-radius:4px;color:#e0e0e0;font-size:12px;outline:none;box-sizing:border-box;font-family:inherit}.clib-dialog input:focus,.clib-dialog select:focus,.clib-dialog textarea:focus{border-color:#00bcd4}.clib-dialog select{cursor:pointer}.clib-dialog-checkbox{display:flex!important;align-items:center;gap:8px;flex-direction:row}.clib-dialog-checkbox input[type=checkbox]{width:auto;margin:0}.clib-dialog-buttons{display:flex;justify-content:flex-end;gap:8px;margin-top:16px}.clib-dialog-buttons button{padding:6px 14px;border:1px solid #555;border-radius:4px;background:#2a2a40;color:#ccc;font-size:12px;cursor:pointer}.clib-dialog-buttons button:hover{background:#3a3a50}.clib-btn-primary{background:#00838f!important;border-color:#00bcd4!important;color:#fff!important}.clib-btn-primary:hover:not(:disabled){background:#00acc1!important}.clib-btn-primary:disabled{opacity:.4;cursor:default}.clib-dialog-folder-row{display:flex;gap:4px;margin-top:4px}.clib-dialog-folder-row select,.clib-dialog-folder-row input{flex:1}.clib-btn-new-folder{width:32px;flex-shrink:0;background:#00838f;border:1px solid #00BCD4;border-radius:4px;color:#fff;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center}.clib-btn-new-folder:hover{background:#00acc1}.clib-btn-new-folder.cancel{background:#4a1a1a;border-color:#c62828;color:#ef9a9a}.clib-btn-new-folder.cancel:hover{background:#c62828;color:#fff}.drop-overlay{position:fixed;left:0;right:0;bottom:0;top:var(--toolbar-h);z-index:50;background:#1e3c788c;display:flex;align-items:center;justify-content:center;pointer-events:none}.drop-overlay-content{text-align:center;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.4)}.drop-overlay-icon{font-size:64px;line-height:1;margin-bottom:12px;opacity:.9}.drop-overlay-text{font-size:22px;font-weight:600;margin-bottom:6px}.drop-overlay-hint{font-size:14px;opacity:.85}.import-progress-overlay{position:fixed;inset:0;z-index:10000;background:#00000073;backdrop-filter:blur(2px);display:flex;align-items:center;justify-content:center;pointer-events:none;animation:import-overlay-fadein .16s ease-out}.import-progress-card{background:#fff;color:#1a1a1a;padding:28px 40px 24px;border-radius:10px;box-shadow:0 12px 48px #00000059;display:flex;flex-direction:column;align-items:center;min-width:280px;max-width:420px}.import-progress-logo-wrap{position:relative;width:88px;height:88px;display:flex;align-items:center;justify-content:center}.import-progress-logo{width:48px;height:48px;image-rendering:-webkit-optimize-contrast;image-rendering:crisp-edges;user-select:none;-webkit-user-drag:none}.import-progress-spinner{position:absolute;inset:0;border:4px solid rgba(21,101,192,.15);border-top-color:var(--accent, #1565c0);border-radius:50%;animation:import-progress-rotate .9s linear infinite}.import-progress-label{margin-top:18px;font-size:15px;font-weight:600;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:340px}.import-progress-sub{margin-top:4px;font-size:12px;color:#666}@keyframes import-progress-rotate{to{transform:rotate(360deg)}}@keyframes import-overlay-fadein{0%{opacity:0}to{opacity:1}}.app.is-drop-active [data-drop-target]{border-color:var(--accent, #1565c0)!important;background:#1565c040;color:#fff;animation:drop-target-pulse 1s ease-in-out infinite;position:relative;z-index:60}.app.is-drop-active [data-drop-target]:hover,.app.is-drop-active [data-drop-target].is-drop-hover{background:var(--accent, #1565c0)!important;color:#fff!important;border-color:#fff!important;animation:none}@keyframes drop-target-pulse{0%,to{background:#1565c033}50%{background:#1565c099}}.ai-chat-btn{display:inline-flex;align-items:center;gap:5px;padding:2px 10px;background:var(--accent);color:var(--text-light);border:none;border-radius:var(--radius);font:12px var(--font-ui);cursor:pointer;transition:background var(--transition);white-space:nowrap}.ai-chat-btn:hover{background:var(--accent-hover)}.ai-chat-btn svg{width:14px;height:14px;fill:currentColor}.ai-chat-popup{position:fixed;bottom:calc(var(--statusbar-h) + 8px);right:16px;width:400px;height:520px;max-height:70vh;display:flex;flex-direction:column;background:#1e1e2e;border:1px solid #3a3a5c;border-radius:12px;box-shadow:0 8px 32px #0006;z-index:1000;font-family:var(--font-ui);overflow:hidden}.ai-chat-header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;background:var(--bg-toolbar);border-bottom:1px solid #3a3a5c;flex-shrink:0;cursor:grab;user-select:none}.ai-chat-header:active{cursor:grabbing}.ai-chat-header-title{font-size:13px;font-weight:600;color:var(--text-light);pointer-events:none}.ai-chat-minimize{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:16px;line-height:1;padding:2px 6px;border-radius:var(--radius);transition:color var(--transition),background var(--transition)}.ai-chat-minimize:hover{color:var(--text-light);background:#ffffff1a}.ai-chat-messages{flex:1;overflow-y:auto;padding:12px;display:flex;flex-direction:column;gap:8px}.ai-chat-messages::-webkit-scrollbar{width:6px}.ai-chat-messages::-webkit-scrollbar-thumb{background:#4a4a6a;border-radius:3px}.ai-chat-msg{max-width:85%;padding:8px 12px;border-radius:10px;font-size:13px;line-height:1.4;word-wrap:break-word;white-space:pre-wrap}.ai-chat-msg-user{align-self:flex-end;background:var(--accent);color:var(--text-light);border-bottom-right-radius:4px}.ai-chat-msg-assistant{align-self:flex-start;background:#2a2a40;color:#e0e0e0;border-bottom-left-radius:4px}.ai-chat-msg-error{align-self:flex-start;background:#3a1520;color:#f87171;border:1px solid #5a2030;border-bottom-left-radius:4px}.ai-chat-tools{align-self:flex-start;display:flex;flex-wrap:wrap;gap:4px;max-width:85%}.ai-chat-tool-chip{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;background:#1a3a2a;color:#4ade80;border-radius:6px;font-size:11px;font-family:var(--font-mono)}.ai-chat-tool-chip.failed{background:#3a1a1a;color:#f87171}.ai-chat-loading{align-self:flex-start;padding:8px 12px;background:#2a2a40;border-radius:10px 10px 10px 4px}.ai-chat-loading-dots{display:flex;gap:4px}.ai-chat-loading-dots span{width:6px;height:6px;background:#888;border-radius:50%;animation:ai-chat-bounce 1.2s infinite}.ai-chat-loading-dots span:nth-child(2){animation-delay:.2s}.ai-chat-loading-dots span:nth-child(3){animation-delay:.4s}@keyframes ai-chat-bounce{0%,60%,to{transform:translateY(0);opacity:.4}30%{transform:translateY(-4px);opacity:1}}.ai-chat-input-area{display:flex;gap:6px;padding:10px 12px;border-top:1px solid #3a3a5c;background:#252538;flex-shrink:0}.ai-chat-input{flex:1;padding:8px 10px;background:#1e1e2e;color:#e0e0e0;border:1px solid #3a3a5c;border-radius:8px;font:13px var(--font-ui);resize:none;outline:none;min-height:36px;max-height:80px}.ai-chat-input:focus{border-color:var(--accent)}.ai-chat-input::placeholder{color:#666}.ai-chat-send{padding:8px 14px;background:var(--accent);color:var(--text-light);border:none;border-radius:8px;font:13px var(--font-ui);cursor:pointer;transition:background var(--transition);align-self:flex-end}.ai-chat-send:hover:not(:disabled){background:var(--accent-hover)}.ai-chat-send:disabled{opacity:.5;cursor:not-allowed}
