:root,[data-theme=dark]{--bg:#13161a;--surface:#1c2128;--raised:#2a313c;--border:#30363d;--border-hi:#444c56;--acc:#c3ff51;--acc-text:#13161a;--acc2:#0ea5e9;--acc3:#d946ef;--text:#f0f6fc;--muted:#8b949e;--dim:#484f58;--row-hover:#1e242b;--sel:#c3ff5126;--ok:#4ade80;--warn:#fbbf24;--danger:#f87171;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-pill:99px;--shadow-sm:0 4px 12px #0003;--shadow-lg:0 12px 32px #0006}[data-theme=light]{--bg:#f4f7f6;--surface:#fff;--raised:#f0f2f5;--border:#e2e8f0;--border-hi:#cbd5e1;--acc:#111827;--acc-text:#fff;--acc2:#0284c7;--acc3:#c026d3;--text:#111827;--muted:#64748b;--dim:#94a3b8;--row-hover:#f8fafc;--sel:#1118270f;--ok:#16a34a;--warn:#d97706;--danger:#dc2626;--shadow-sm:0 4px 12px #00000008;--shadow-lg:0 12px 32px #00000014}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;overflow:hidden}body{background:var(--bg);color:var(--text);flex-direction:column;font-family:Inter,-apple-system,system-ui,sans-serif;font-size:13px;display:flex}.app-shell{flex-direction:column;height:100vh;display:flex;position:relative;overflow:hidden}.app-workspace{flex:1;min-height:0;display:flex;overflow:hidden}.topnav{background:var(--surface);border-bottom:1px solid var(--border);z-index:100;align-items:center;gap:8px;height:56px;min-height:56px;padding:0 24px;display:flex}.logo{flex-shrink:0;align-items:center;gap:10px;margin-right:24px;display:flex}.logo-icon{background:var(--acc);border-radius:var(--radius-md);width:32px;height:32px;color:var(--acc-text);letter-spacing:-1px;justify-content:center;align-items:center;font-size:16px;font-weight:900;display:flex}.logo-text{letter-spacing:-.4px;color:var(--text);font-size:16px;font-weight:800}.logo-text span{color:var(--acc)}.nav-item{border-radius:var(--radius-pill);color:var(--muted);cursor:pointer;white-space:nowrap;border:1px solid #0000;padding:8px 16px;font-size:13.5px;font-weight:600;transition:all .15s}.nav-item:hover{color:var(--text);background:var(--raised)}.nav-item.active{color:var(--acc-text);background:var(--acc);border-color:#0000}.nav-item.locked{opacity:.38;pointer-events:none}.nav-spacer{flex:1}.btn{border-radius:var(--radius-pill);cursor:pointer;border:none;align-items:center;gap:8px;padding:8px 16px;font-size:13px;font-weight:600;transition:all .15s;display:flex}.btn-ghost{color:var(--muted);border:1px solid var(--border);background:0 0}.btn-ghost:hover{background:var(--raised);color:var(--text)}.btn-primary{background:var(--acc);color:var(--acc-text);box-shadow:var(--shadow-sm)}.btn-primary:hover{opacity:.9;transform:translateY(-1px)}.btn-sm{padding:6px 12px;font-size:12px}.avatar{background:var(--raised);border:1px solid var(--border);width:32px;height:32px;color:var(--text);cursor:pointer;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:13px;font-weight:700;display:flex}.phase-badge{color:var(--dim);background:var(--raised);border:1px solid var(--border);border-radius:var(--radius-pill);margin-left:4px;padding:2px 8px;font-size:10px;font-weight:700}.theme-toggle{border:1px solid var(--border);width:32px;height:32px;color:var(--muted);cursor:pointer;background:0 0;border-radius:50%;justify-content:center;align-items:center;margin-right:8px;transition:all .15s;display:flex}.theme-toggle:hover{background:var(--raised);color:var(--text)}.subnav{background:var(--surface);border-bottom:1px solid var(--border);align-items:center;gap:4px;height:44px;min-height:44px;padding:0 20px;display:flex}.sub-item{border-radius:var(--radius-pill);color:var(--muted);cursor:pointer;padding:6px 14px;font-size:13px;font-weight:600;transition:all .12s}.sub-item:hover{color:var(--text);background:var(--raised)}.sub-item.active{color:var(--text);background:var(--sel);box-shadow:var(--shadow-sm);border:1px solid var(--border)}.sub-sep{background:var(--border);width:1px;height:16px;margin:0 8px}.workspace,.app-workspace{background:var(--bg);flex:1;display:flex;overflow:hidden}.main-view{flex-direction:column;flex:1;min-width:0;display:flex;overflow:hidden}.grid-wrap{flex:1;overflow:auto}.sidebar{background:var(--surface);border-right:1px solid var(--border);z-index:10;flex-direction:column;flex-shrink:0;width:260px;min-width:260px;display:flex;overflow:hidden}.sidebar.right{border-right:none;border-left:1px solid var(--border)}.sidebar-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:16px 20px 12px;display:flex}.sidebar-title{color:var(--muted);text-transform:uppercase;letter-spacing:.8px;font-size:12px;font-weight:700}.icon-btn{border-radius:var(--radius-pill);width:28px;height:28px;color:var(--muted);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;font-size:16px;transition:all .12s;display:flex}.icon-btn:hover{background:var(--raised);color:var(--text)}.sidebar-body{flex:1;padding:12px;overflow-y:auto}.sidebar-body::-webkit-scrollbar{width:4px}.sidebar-body::-webkit-scrollbar-thumb{background:var(--dim);border-radius:4px}.sidebar-section{color:var(--dim);text-transform:uppercase;letter-spacing:.8px;padding:12px 10px 6px;font-size:11px;font-weight:700}.tree-item{border-radius:var(--radius-md);cursor:pointer;-webkit-user-select:none;user-select:none;color:var(--text);align-items:center;gap:8px;margin-bottom:2px;padding:8px 10px;font-size:13.5px;font-weight:500;transition:all .15s;display:flex}.tree-item:hover{background:var(--raised)}.tree-item.active{background:var(--acc);color:var(--acc-text);box-shadow:var(--shadow-sm)}.tree-arrow{color:var(--muted);flex-shrink:0;width:14px;font-size:10px;transition:transform .15s}.tree-item.active .tree-arrow{color:var(--acc-text);opacity:.7}.tree-arrow.open{transform:rotate(90deg)}.tree-dot{background:var(--dim);border-radius:50%;flex-shrink:0;width:8px;height:8px}.tree-item.active .tree-dot{background:var(--acc-text);opacity:.5}.tree-icon{text-align:center;flex-shrink:0;width:18px;font-size:14px}.tree-label{white-space:nowrap;text-overflow:ellipsis;flex:1;overflow:hidden}.tree-count{color:var(--muted);background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-pill);flex-shrink:0;padding:2px 8px;font-size:11px;font-weight:600}.tree-item.active .tree-count{color:var(--acc-text);background:#fff3;border-color:#0000}.tree-children{padding-left:24px}.art4u-dot{background:linear-gradient(135deg,var(--acc3),#f43f5e);border-radius:50%;flex-shrink:0;width:10px;height:10px}.attr-item{border-radius:var(--radius-md);cursor:pointer;background:var(--bg);border:1px solid #0000;justify-content:space-between;align-items:center;margin-bottom:2px;padding:8px 12px;transition:background .15s;display:flex}.attr-item:hover{background:var(--surface);border-color:var(--border)}.attr-left{align-items:center;gap:10px;display:flex}.attr-chip{border-radius:var(--radius-pill);background:var(--raised);color:var(--text);border:1px solid var(--border);padding:3px 8px;font-size:10.5px;font-weight:700}.attr-chip.teal{color:var(--acc2);background:#2dd4bf26;border-color:#2dd4bf4d}.attr-chip.pink{color:var(--acc3);background:#f472b626;border-color:#f472b64d}.attr-chip.amber{color:var(--warn);background:#fbbf2426;border-color:#fbbf244d}.attr-name{color:var(--text);font-size:13px;font-weight:600}.attr-unit{color:var(--muted);font-size:11.5px}.center{background:var(--bg);flex-direction:column;flex:1;display:flex;position:relative;overflow:hidden}.toolbar{border-bottom:1px solid var(--border);background:var(--surface);flex-shrink:0;align-items:center;gap:12px;padding:14px 20px;display:flex}.breadcrumb{align-items:center;gap:8px;font-size:13.5px;display:flex}.bc-seg{color:var(--muted);cursor:pointer;font-weight:500}.bc-seg:hover{color:var(--text)}.bc-seg.cur{color:var(--text);font-weight:700}.bc-sep{color:var(--dim);font-size:12px}.toolbar-spacer{flex:1}.view-switcher{background:var(--raised);border:1px solid var(--border);border-radius:var(--radius-md);gap:2px;padding:2px;display:flex;position:relative}.view-btn{border-radius:var(--radius-sm);color:var(--muted);cursor:pointer;padding:6px 12px;font-size:12.5px;font-weight:600;transition:all .15s}.view-btn:hover{color:var(--text)}.view-btn.active{background:var(--surface);color:var(--text);box-shadow:var(--shadow-sm);border:1px solid var(--border)}.view-btn.locked{opacity:.38;pointer-events:none}.search-wrap{align-items:center;display:flex;position:relative}.search-icon{color:var(--muted);pointer-events:none;font-size:14px;position:absolute;left:12px}.search-input{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-pill);width:240px;height:36px;color:var(--text);outline:none;padding:0 14px 0 34px;font-size:13px;transition:border-color .15s}.search-input:focus{border-color:var(--acc);box-shadow:0 0 0 2px var(--sel)}.filter-bar{border-bottom:1px solid var(--border);background:var(--surface);flex-shrink:0;align-items:center;gap:8px;padding:10px 20px;display:flex}.fchip{border-radius:var(--radius-pill);cursor:pointer;border:1px solid var(--border);color:var(--muted);background:var(--bg);white-space:nowrap;padding:6px 16px;font-size:12.5px;font-weight:600;transition:all .15s}.fchip:hover{color:var(--text);border-color:var(--border-hi)}.fchip.active{color:var(--text);background:var(--sel);border-color:var(--acc2);box-shadow:var(--shadow-sm)}.fchip.art4u{border-color:#d946ef4d}.fchip.art4u.active{color:var(--acc3);background:#d946ef1f;border-color:#d946ef80}.filter-spacer{flex:1}.filter-count{color:var(--muted);font-size:12px;font-weight:500}.import-banner{background:var(--raised);border-bottom:1px solid var(--border);flex-shrink:0;align-items:center;gap:12px;height:48px;padding:0 20px;font-size:13px;display:none}.import-banner.show{display:flex}.ib-spacer{flex:1}.ib-action{color:var(--acc2);cursor:pointer;border-radius:var(--radius-pill);border:1px solid var(--border);background:var(--surface);box-shadow:var(--shadow-sm);padding:5px 12px;font-size:12px;font-weight:700}.ib-action:hover{background:var(--raised)}.row-actions{background:var(--surface);border:1px solid var(--border-hi);border-radius:var(--radius-pill);box-shadow:var(--shadow-lg);z-index:30;align-items:center;gap:4px;padding:6px 8px;display:none;position:absolute;top:68px;left:50%;transform:translate(-50%)}.row-actions.show{display:flex}.ra-count{color:var(--acc);border-right:1px solid var(--border);padding:5px 12px;font-size:12.5px;font-weight:700}.ra-btn{border-radius:var(--radius-pill);cursor:pointer;color:var(--muted);background:0 0;border:none;align-items:center;gap:6px;padding:6px 14px;font-size:13px;font-weight:600;transition:all .15s;display:flex}.ra-btn:hover{background:var(--raised);color:var(--text)}.ra-btn.danger:hover{color:var(--danger);background:#f871711a}.ra-sep{background:var(--border);width:1px;height:24px}.grid-wrap{flex:1;padding:12px 20px;overflow:auto}.grid-wrap::-webkit-scrollbar{width:8px;height:8px}.grid-wrap::-webkit-scrollbar-track{background:var(--bg)}.grid-wrap::-webkit-scrollbar-thumb{background:var(--border-hi);border-radius:var(--radius-pill)}table.dg{border-collapse:separate;border-spacing:0;table-layout:fixed;background:var(--surface);border-radius:var(--radius-lg);border:1px solid var(--border);width:100%;box-shadow:var(--shadow-sm)}table.dg thead{z-index:10;position:sticky;top:0}.th-wrap{background:var(--raised);border-bottom:1px solid var(--border);border-right:1px solid var(--border);min-width:100px;padding:0}table.dg thead tr th:first-child{border-top-left-radius:var(--radius-lg)}table.dg thead tr th:last-child{border-top-right-radius:var(--radius-lg);border-right:none}.th-wrap.th-xs{width:48px;min-width:48px}.th-wrap.th-sm{width:60px;min-width:60px}.th-inner{padding:10px 14px 8px}.th-human{color:var(--text);cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:6px;padding-bottom:2px;font-size:12.5px;font-weight:700;display:flex}.si{color:var(--muted);opacity:.4;font-size:11px;transition:opacity .15s}.si.on{opacity:1;color:var(--acc2)}.th-erp{color:var(--muted);text-align:left;padding-bottom:2px;font-family:Menlo,Courier New,monospace;font-size:10.5px;font-weight:500}.th-wrap{position:relative}.col-resize-handle{cursor:col-resize;z-index:5;background:0 0;width:6px;height:100%;transition:background .15s;position:absolute;top:0;right:0}.col-resize-handle:hover,.col-resize-handle.active{background:var(--acc2)}.th-wrap.col-drag-over{box-shadow:inset 2px 0 0 var(--acc);background:#c3ff510f}.th-wrap.col-dragging{opacity:.5}table.dg tbody tr{transition:background 80ms}table.dg tbody tr:hover td{background:var(--row-hover)}table.dg tbody tr.sel td{background:var(--sel)}table.dg tbody tr.sel td:first-child{border-left:2px solid var(--acc)}table.dg tbody tr.prow td{background:var(--raised);border-bottom:1px solid var(--border-hi)}table.dg tbody tr.prow:hover td{background:var(--border)}table.dg tbody tr.prow.art4u-row td{background:#d946ef0f}table.dg tbody tr.prow.art4u-row:hover td{background:#d946ef1a;border-bottom:1px solid #d946ef33}table.dg td{border-bottom:1px solid var(--border);border-right:1px solid var(--border);vertical-align:middle;height:40px;color:var(--text);text-overflow:ellipsis;white-space:nowrap;cursor:default;padding:0 12px;font-size:13px;overflow:hidden}table.dg td.td-check{text-align:center;width:48px}table.dg td.td-num{color:var(--muted);text-align:right;font-variant-numeric:tabular-nums;width:60px;font-size:11.5px}input[type=checkbox]{accent-color:var(--acc);cursor:pointer;width:16px;height:16px}.expand-btn{color:var(--muted);cursor:pointer;border-radius:var(--radius-sm);background:0 0;border:none;padding:4px 6px;font-size:12px;transition:transform .15s,color .15s,background .15s}.expand-btn:hover{color:var(--text);background:var(--surface)}.expand-btn.open{color:var(--text);transform:rotate(90deg)}.variant-indent{padding-left:36px!important}.pill{border-radius:var(--radius-pill);align-items:center;gap:6px;padding:4px 10px;font-size:11.5px;font-weight:700;display:inline-flex}.pill-dot{border-radius:50%;width:6px;height:6px}.p-ok{color:var(--ok);background:#4ade8026;border:1px solid #4ade804d}.p-ok .pill-dot{background:var(--ok)}.p-warn{color:var(--warn);background:#fbbf2426;border:1px solid #fbbf244d}.p-warn .pill-dot{background:var(--warn)}.p-draft{color:var(--muted);background:#94a3b826;border:1px solid #94a3b84d}.p-draft .pill-dot{background:var(--muted)}.tag{border-radius:var(--radius-sm);align-items:center;margin-right:4px;padding:3px 8px;font-size:11.5px;font-weight:700;display:inline-flex}.t-blue{color:var(--acc2);background:#0ea5e926;border:1px solid #0ea5e94d}.t-green{color:var(--ok);background:#4ade8026;border:1px solid #4ade804d}.t-purple{color:var(--acc3);background:#c026d326;border:1px solid #c026d34d}.t-teal{color:#14b8a6;background:#2dd4bf26;border:1px solid #2dd4bf4d}.t-amber{color:var(--warn);background:#fbbf2426;border:1px solid #fbbf244d}.t-pink{color:var(--acc3);background:#d946ef26;border:1px solid #d946ef4d}.t-sq{color:#14b8a6;background:#2dd4bf1a;border:1px solid #2dd4bf33;font-family:monospace}.t-finish{color:var(--warn);background:#fbbf241a;border:1px solid #fbbf2433}table.dg tbody tr.finish-row td{background:#fbbf240a}table.dg tbody tr.finish-row:hover td{background:#fbbf2414}.delta-badge{color:var(--muted);border-radius:var(--radius-sm);background:var(--bg);border:1px solid var(--border);align-items:center;gap:6px;padding:3px 8px;font-size:11px;display:inline-flex}.delta-badge.has-delta{color:var(--warn);background:#fbbf2414;border-color:#fbbf244d}.finish-axis-row{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-md);align-items:center;gap:10px;margin-bottom:8px;padding:10px 14px;display:flex}.finish-val-list{flex-direction:column;gap:6px;margin-top:6px;padding-left:14px;display:flex}.finish-val-item{border-radius:var(--radius-sm);background:#fbbf240f;border:1px solid #fbbf2426;align-items:center;gap:10px;padding:8px 12px;display:flex}.finish-val-name{flex:1;font-size:13px;font-weight:600}.finish-delta-tag{color:var(--warn);border-radius:var(--radius-sm);white-space:nowrap;background:#fbbf2426;border:1px solid #fbbf244d;padding:2px 8px;font-size:11px}.add-val-btn{color:var(--text);cursor:pointer;border:1px dashed var(--border-hi);border-radius:var(--radius-sm);background:var(--bg);padding:4px 10px;font-size:12px;font-weight:600}.add-val-btn:hover{background:var(--surface);border-color:var(--acc)}.rent-toggle{cursor:pointer;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-md);align-items:center;gap:12px;margin-bottom:14px;padding:12px 16px;transition:border-color .15s;display:flex}.rent-toggle:hover{border-color:var(--border-hi)}.rent-toggle.on{background:#2dd4bf14;border-color:#2dd4bf66}.rent-badge{border-radius:var(--radius-pill);color:#14b8a6;background:#2dd4bf26;border:1px solid #2dd4bf4d;align-items:center;gap:6px;padding:3px 8px;font-size:10.5px;font-weight:700;display:inline-flex}.rent-fields{gap:14px;margin-bottom:16px;display:none}.rent-fields.show{display:flex}.art4u-section{margin-bottom:16px;display:none}.art4u-section.show{display:block}.art4u-cat-banner{color:var(--acc3);text-transform:uppercase;letter-spacing:.8px;align-items:center;gap:8px;padding:4px 0 10px;font-size:11.5px;font-weight:800;display:flex}.var-name-hint{color:var(--dim);margin-top:-8px;margin-bottom:10px;font-size:11px;font-style:italic}.cat-group-header td{color:var(--text);letter-spacing:.6px;text-transform:uppercase;font-size:11.5px;font-weight:800;background:var(--raised)!important;border-bottom:1px solid var(--border-hi)!important}.swatch{align-items:center;gap:8px;font-size:13px;display:inline-flex}.swatch-dot{border-radius:4px;flex-shrink:0;width:12px;height:12px;box-shadow:inset 0 0 0 1px #0000001a}.vendor-chip{border-radius:var(--radius-pill);background:var(--surface);color:var(--text);border:1px solid var(--border);box-shadow:var(--shadow-sm);align-items:center;gap:6px;margin-right:4px;padding:3px 8px;font-size:11.5px;font-weight:600;display:inline-flex}.vendor-dot{background:var(--acc2);border-radius:50%;width:6px;height:6px}.type-badge{border-radius:var(--radius-sm);letter-spacing:.4px;align-items:center;gap:6px;padding:3px 10px;font-size:11px;font-weight:700;display:inline-flex}.tb-sqm{color:#14b8a6;background:#2dd4bf26;border:1px solid #2dd4bf4d}.tb-fixed{color:var(--acc3);background:#c026d326;border:1px solid #c026d34d}.tb-art4u{color:var(--acc3);background:linear-gradient(90deg,#d946ef26,#c026d326);border:1px solid #d946ef66}.bom-link{color:var(--text);cursor:pointer;border-radius:var(--radius-md);border:1px solid var(--border);background:var(--surface);white-space:nowrap;box-shadow:var(--shadow-sm);align-items:center;gap:6px;padding:3px 10px;font-size:12.5px;font-weight:600;transition:all .15s;display:inline-flex}.bom-link:hover{background:var(--raised);border-color:var(--border-hi)}.cost-cell{color:var(--acc2);font-weight:700}.price-cell{color:var(--ok);font-weight:700}.range-muted{color:var(--muted);font-size:11px}.area-muted{color:var(--dim);font-size:11px}.bom-pop{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);width:380px;box-shadow:var(--shadow-lg);z-index:200;display:none;position:fixed;overflow:hidden}.bom-pop.show{animation:.15s popIn;display:block}@keyframes popIn{0%{opacity:0;transform:scale(.97)translateY(4px)}to{opacity:1;transform:scale(1)translateY(0)}}.bom-pop-head{border-bottom:1px solid var(--border);background:var(--raised);justify-content:space-between;align-items:flex-start;gap:8px;padding:14px 16px;display:flex}.bom-pop-title{color:var(--text);font-size:13.5px;font-weight:700}.bom-pop-sub{color:var(--muted);margin-top:2px;font-size:11.5px}.bom-rate{color:var(--acc2);white-space:nowrap;background:var(--bg);border-radius:var(--radius-pill);border:1px solid var(--border);padding:3px 8px;font-size:11.5px;font-weight:600}.bom-table{border-collapse:collapse;width:100%}.bom-table th{color:var(--muted);text-transform:uppercase;letter-spacing:.5px;text-align:left;border-bottom:1px solid var(--border);background:var(--raised);padding:8px 14px;font-size:10.5px;font-weight:700}.bom-table td{border-bottom:1px solid var(--border);vertical-align:middle;color:var(--text);padding:10px 14px;font-size:12.5px}.bom-table tr:last-child td{border-bottom:none}.bom-table tr:hover td{background:var(--row-hover)}.bom-type{border-radius:var(--radius-md);padding:3px 8px;font-size:10.5px;font-weight:700}.bom-mat{color:var(--acc2);background:#2dd4bf26;border:1px solid #2dd4bf4d}.bom-op{color:var(--acc3);background:#d946ef1f;border:1px solid #d946ef4d}.bom-footer{border-top:1px solid var(--border);background:var(--raised);justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.bom-total{color:var(--text);font-size:14px;font-weight:800}.bom-total span{color:var(--acc2)}.bom-edit-btn{color:var(--acc-text);background:var(--acc);cursor:pointer;border-radius:var(--radius-pill);box-shadow:var(--shadow-sm);border:none;padding:5px 12px;font-size:12px;font-weight:700;transition:opacity .15s}.bom-edit-btn:hover{opacity:.9}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:300;background:#0009;justify-content:center;align-items:center;display:none;position:fixed;inset:0}.modal-overlay.show{animation:.15s fadeIn;display:flex}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--surface);border:1px solid var(--border);width:680px;max-height:88vh;box-shadow:var(--shadow-lg);border-radius:24px;flex-direction:column;display:flex;overflow:hidden}.modal-header{border-bottom:1px solid var(--border);background:var(--raised);flex-shrink:0;align-items:center;gap:12px;padding:20px 24px;display:flex}.modal-icon{background:var(--acc);border-radius:var(--radius-md);width:36px;height:36px;color:var(--acc-text);flex-shrink:0;justify-content:center;align-items:center;font-size:18px;display:flex}.modal-title{color:var(--text);font-size:16px;font-weight:800}.modal-sub{color:var(--muted);margin-top:2px;font-size:12.5px}.modal-body{flex:1;padding:24px 28px;overflow-y:auto}.modal-body::-webkit-scrollbar{width:6px}.modal-body::-webkit-scrollbar-thumb{background:var(--border-hi);border-radius:var(--radius-pill)}.modal-footer{border-top:1px solid var(--border);background:var(--raised);flex-shrink:0;justify-content:flex-end;gap:10px;padding:16px 24px;display:flex}.field-row{gap:16px;margin-bottom:18px;display:flex}.field{flex-direction:column;flex:1;gap:6px;display:flex}.field label{color:var(--dim);text-transform:uppercase;letter-spacing:.6px;font-size:11.5px;font-weight:700}.field input,.field select{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text);outline:none;padding:10px 14px;font-size:13.5px;transition:border-color .15s,box-shadow .15s}.field input:focus,.field select:focus{border-color:var(--acc);box-shadow:0 0 0 2px var(--sel)}.field select option{background:var(--surface);color:var(--text)}.sec-label{color:var(--text);text-transform:uppercase;letter-spacing:.8px;justify-content:space-between;align-items:center;margin-bottom:12px;font-size:12px;font-weight:800;display:flex}.bom-row{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-md);align-items:center;gap:10px;margin-bottom:8px;padding:10px 14px;display:flex}.bom-row-type{border-radius:var(--radius-sm);flex-shrink:0;padding:3px 8px;font-size:10.5px;font-weight:700}.bom-row-del{color:var(--dim);cursor:pointer;flex-shrink:0;font-size:14px;transition:color .12s}.bom-row-del:hover{color:var(--danger)}.bom-row-drag{color:var(--dim);cursor:grab;flex-shrink:0;font-size:16px}.bom-row-cost{color:var(--acc2);text-align:right;flex-shrink:0;min-width:56px;font-size:13px;font-weight:700}.cost-summary{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-md);margin-top:12px;padding:16px 20px}.cost-line{color:var(--muted);justify-content:space-between;margin-bottom:8px;font-size:13px;display:flex}.cost-line.total{color:var(--text);border-top:1px solid var(--border);margin-top:6px;margin-bottom:0;padding-top:10px;font-size:15px;font-weight:800}.cost-line.total span{color:var(--acc2)}.add-step-btn{border-radius:var(--radius-md);border:1px dashed var(--border-hi);width:100%;color:var(--muted);cursor:pointer;background:0 0;justify-content:center;align-items:center;gap:8px;margin-top:8px;padding:10px;font-size:13px;font-weight:600;transition:all .15s;display:flex}.add-step-btn:hover{border-color:var(--acc);color:var(--text);background:var(--surface)}.type-toggle{gap:8px;margin-bottom:20px;display:flex}.tt-btn{border-radius:var(--radius-md);border:1px solid var(--border);background:var(--surface);color:var(--muted);cursor:pointer;text-align:center;flex:1;padding:10px;font-size:13px;font-weight:700;transition:all .15s}.tt-btn:hover{border-color:var(--border-hi);color:var(--text);background:var(--raised)}.tt-btn.active{border-color:var(--acc2);background:var(--sel);color:var(--text);box-shadow:var(--shadow-sm)}.tt-btn.art4u-btn.active{color:var(--acc3);background:#d946ef14;border-color:#d946ef80}.variant-table{border-collapse:collapse;width:100%;margin-bottom:12px}.variant-table th{color:var(--dim);text-transform:uppercase;letter-spacing:.6px;border-bottom:1px solid var(--border);text-align:left;padding:8px 10px;font-size:10.5px;font-weight:700}.variant-table td{border-bottom:1px solid var(--border);vertical-align:middle;padding:8px 6px}.variant-table tr:last-child td{border-bottom:none}.variant-table input{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);outline:none;width:100%;padding:8px 10px;font-size:13px;transition:border-color .15s}.variant-table input:focus{border-color:var(--acc)}.variant-table .area-badge{color:var(--acc2);white-space:nowrap;font-size:11px;font-weight:700}.variant-table .auto-cost{color:var(--acc2);text-align:right;padding:6px 10px;font-size:12.5px;font-weight:700}.del-var{color:var(--dim);cursor:pointer;background:0 0;border:none;padding:4px 6px;font-size:14px;transition:color .12s}.del-var:hover{color:var(--danger)}.add-var-btn{color:var(--text);cursor:pointer;border:1px dashed var(--border-hi);border-radius:var(--radius-md);background:var(--bg);width:100%;padding:8px 14px;font-size:13px;font-weight:600;transition:all .15s}.add-var-btn:hover{background:var(--surface);border-color:var(--acc)}.fab{background:var(--acc);width:48px;height:48px;color:var(--acc-text);cursor:pointer;box-shadow:var(--shadow-lg);z-index:49;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:24px;transition:transform .15s,box-shadow .15s;display:flex;position:absolute;bottom:20px;right:20px}.fab:hover{transform:scale(1.08)}.fab.open{background:var(--surface);border:1px solid var(--border);box-shadow:none;color:var(--text);right:360px}.ai-panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);width:340px;box-shadow:var(--shadow-lg);z-index:50;display:none;position:absolute;bottom:16px;right:16px;overflow:hidden}.ai-panel.show{flex-direction:column;animation:.2s slideUp;display:flex}@keyframes slideUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.ai-header{border-bottom:1px solid var(--border);background:var(--raised);align-items:center;gap:12px;padding:14px 16px;display:flex}.ai-icon{background:var(--acc);border-radius:var(--radius-sm);width:32px;height:32px;color:var(--acc-text);flex-shrink:0;justify-content:center;align-items:center;font-size:16px;display:flex}.ai-title{color:var(--text);font-size:14px;font-weight:800}.ai-sub{color:var(--muted);font-size:11.5px}.ai-body{flex-direction:column;gap:10px;padding:16px;display:flex}.ai-sug{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-md);cursor:pointer;padding:12px 14px;transition:all .15s}.ai-sug:hover{background:var(--surface);border-color:var(--acc2);box-shadow:var(--shadow-sm)}.ai-input-wrap{border-top:1px solid var(--border);background:var(--bg);align-items:center;gap:10px;padding:14px 16px;display:flex}.ai-input{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-pill);color:var(--text);outline:none;flex:1;padding:8px 14px;font-size:13px}.ai-input:focus{border-color:var(--acc2)}.ai-send{background:var(--acc);color:var(--acc-text);cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;transition:transform .15s;display:flex}.ai-send:hover{transform:scale(1.1)}.ai-sug.done{opacity:.45;pointer-events:none}.ai-sug-title{align-items:center;gap:6px;margin-bottom:3px;font-size:12px;font-weight:600;display:flex}.ai-badge{color:var(--acc2);background:#2dd4bf26;border-radius:6px;padding:2px 6px;font-size:10px;font-weight:600}.ai-sug-body{color:var(--muted);font-size:11.5px;line-height:1.5}.ai-foot{gap:6px;padding:0 14px 12px;display:flex}.ai-btn{cursor:pointer;border:none;border-radius:8px;flex:1;padding:7px;font-size:12px;font-weight:600;transition:all .15s}.ai-accept{color:#c4aaff;background:#7c5cbf38;border:1px solid #7c5cbf66}.ai-accept:hover{background:var(--acc);color:#fff}.ai-dismiss{color:var(--muted);border:1px solid var(--border);background:0 0}.ai-dismiss:hover{background:var(--raised);color:var(--text)}.ctx{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);min-width:180px;box-shadow:var(--shadow-lg);z-index:999;padding:6px;display:none;position:fixed}.ctx.show{display:block}.ctx-item{border-radius:var(--radius-sm);cursor:pointer;color:var(--text);align-items:center;gap:10px;padding:8px 12px;font-size:13px;font-weight:500;transition:background .15s;display:flex}.ctx-item:hover{background:var(--raised)}.ctx-item.muted{color:var(--muted);pointer-events:none;font-size:11.5px}.ctx-item.danger{color:var(--danger)}.ctx-item.danger:hover{background:#f871711a}.ctx-sep{background:var(--border);height:1px;margin:6px 0}.drag-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border:2px dashed var(--acc);z-index:1000;color:var(--acc);background:#0009;flex-direction:column;justify-content:center;align-items:center;gap:12px;font-size:24px;font-weight:800;display:none;position:fixed;inset:0}.drag-overlay.show{display:flex}.drag-sub{color:var(--text);font-size:14px;font-weight:600}.statusbar{background:var(--surface);border-top:1px solid var(--border);flex-shrink:0;align-items:center;gap:16px;height:30px;padding:0 20px;display:flex}.st-seg{color:var(--muted);align-items:center;gap:8px;font-size:12px;font-weight:600;display:flex}.st-dot{border-radius:50%;width:8px;height:8px}.st-green{background:var(--ok)}.st-sep{background:var(--border);width:1px;height:16px}.st-spacer{flex:1}.lib-shell{background:var(--bg);flex:1;display:flex;overflow:hidden}.lib-nav{background:var(--surface);border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;gap:2px;width:220px;min-width:220px;padding:20px 12px;display:flex}.lib-nav-title{color:var(--muted);text-transform:uppercase;letter-spacing:.8px;padding:4px 10px 12px;font-size:11px;font-weight:700}.lib-nav-item{border-radius:var(--radius-md);color:var(--muted);cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:10px;width:100%;padding:9px 12px;font-size:13.5px;font-weight:500;transition:all .12s;display:flex}.lib-nav-item:hover{background:var(--raised);color:var(--text)}.lib-nav-item.active{background:var(--acc);color:var(--acc-text);font-weight:700}.lib-nav-item.active .lib-nav-icon{filter:none}.lib-nav-icon{text-align:center;flex-shrink:0;width:20px;font-size:15px}.lib-nav-label{flex:1}.lib-content{flex-direction:column;flex:1;padding:32px 36px;display:flex;overflow-y:auto}.lib-content::-webkit-scrollbar{width:6px}.lib-content::-webkit-scrollbar-thumb{background:var(--border-hi);border-radius:4px}.lib-panel{flex-direction:column;flex:1;max-width:1100px;display:flex}.lib-panel-head{justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:24px;display:flex}.lib-panel-title{color:var(--text);letter-spacing:-.4px;margin-bottom:4px;font-size:22px;font-weight:800}.lib-panel-sub{color:var(--muted);max-width:540px;font-size:13px;line-height:1.5}.lib-table{border-collapse:separate;border-spacing:0;background:var(--surface);border-radius:var(--radius-lg);border:1px solid var(--border);width:100%;box-shadow:var(--shadow-sm)}.lib-table thead tr th{background:var(--raised);color:var(--muted);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border);border-right:1px solid var(--border);text-align:left;padding:10px 14px;font-size:11.5px;font-weight:700}.lib-table thead tr th:first-child{border-top-left-radius:var(--radius-lg)}.lib-table thead tr th:last-child{border-top-right-radius:var(--radius-lg);border-right:none}.lib-table tbody tr td{border-right:1px solid var(--border);border-bottom:1px solid var(--border);vertical-align:middle;height:44px;color:var(--text);padding:0 14px;font-size:13px}.lib-table tbody tr td:last-child{border-right:none}.lib-table tbody tr:last-child td{border-bottom:none}.lib-table tbody tr:last-child td:first-child{border-bottom-left-radius:var(--radius-lg)}.lib-table tbody tr:last-child td:last-child{border-bottom-right-radius:var(--radius-lg)}.lib-row{cursor:default;transition:background 80ms}.lib-row:hover td{background:var(--row-hover)}.lib-row-expanded td{background:var(--sel)}.lib-row-edit td,.lib-row-new td{background:#c3ff510d}.lib-row-detail td{background:var(--bg);padding:0}.lib-td-primary{color:var(--text);font-weight:600}.lib-td-num{color:var(--muted);text-align:right;font-family:Menlo,Courier New,monospace}.lib-cell-input{background:var(--raised);border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text);outline:none;padding:6px 10px;font-size:13px;transition:border-color .15s}.lib-cell-input:focus{border-color:var(--acc);box-shadow:0 0 0 2px var(--sel)}select.lib-cell-input{cursor:pointer}.lib-row-actions{opacity:0;align-items:center;gap:4px;transition:opacity .15s;display:flex}.lib-row:hover .lib-row-actions{opacity:1}.lib-btn-icon{border-radius:var(--radius-sm);cursor:pointer;background:var(--raised);width:28px;height:28px;color:var(--muted);border:none;justify-content:center;align-items:center;font-size:13px;transition:all .12s;display:flex}.lib-btn-icon:hover{background:var(--border);color:var(--text)}.lib-btn-icon.danger:hover{color:var(--danger);background:#f8717126}.lib-btn-save{border-radius:var(--radius-sm);cursor:pointer;background:var(--acc);color:var(--acc-text);border:none;padding:5px 12px;font-size:12px;font-weight:700;transition:opacity .15s}.lib-btn-save:hover{opacity:.85}.lib-btn-cancel{border-radius:var(--radius-sm);border:1px solid var(--border);cursor:pointer;color:var(--muted);background:0 0;padding:5px 10px;font-size:12px;transition:all .12s}.lib-btn-cancel:hover{background:var(--raised);color:var(--text)}.lib-expand-arrow{color:var(--muted);cursor:pointer;margin-right:8px;font-size:9px;transition:transform .15s;display:inline-block}.lib-badge{border-radius:var(--radius-pill);border:1px solid #0000;align-items:center;gap:4px;padding:3px 10px;font-size:11.5px;font-weight:600;display:inline-flex}.lib-badge.locked{color:var(--acc3);background:#d946ef1f;border-color:#d946ef33}.lib-badge.free{color:var(--muted);border-color:var(--border);background:#8b949e1a}.lib-unit-chip{border-radius:var(--radius-pill);background:var(--raised);border:1px solid var(--border);color:var(--muted);padding:2px 8px;font-family:Menlo,Courier New,monospace;font-size:11.5px;font-weight:600;display:inline-block}.lib-values-wrap{flex-wrap:wrap;align-items:center;gap:5px;display:flex}.lib-value-chip{border-radius:var(--radius-pill);background:var(--raised);border:1px solid var(--border);color:var(--text);align-items:center;gap:4px;padding:3px 6px 3px 10px;font-size:12px;display:inline-flex}.lib-value-chip-del{color:var(--muted);cursor:pointer;background:0 0;border:none;padding:0 2px;font-size:13px;line-height:1;transition:color .1s}.lib-value-chip-del:hover{color:var(--danger)}.lib-values-editor{border-top:1px solid var(--border);padding:16px 20px}.lib-add-value-row{align-items:center;gap:8px;margin-top:12px;display:flex}.lib-lock-toggle{cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:6px;font-size:16px;display:flex}.lib-lock-toggle input{display:none}.lib-stub{background:var(--surface);border-radius:var(--radius-lg);border:1px dashed var(--border);text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;min-height:280px;padding:40px;display:flex}.lib-stub-icon{opacity:.5;margin-bottom:12px;font-size:40px}.lib-stub-title{color:var(--text);margin-bottom:6px;font-size:16px;font-weight:700}.lib-stub-desc{color:var(--muted);max-width:380px;font-size:13px;line-height:1.6}.lib-vendor-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);cursor:pointer;flex-direction:column;gap:4px;padding:14px 16px;transition:all .15s;display:flex}.lib-vendor-card:hover{border-color:var(--border-hi);background:var(--raised)}.lib-vendor-name{color:var(--text);font-size:13.5px;font-weight:700}.lib-vendor-meta{color:var(--acc2);font-size:11.5px;font-weight:600}.lib-vendor-email{color:var(--muted);font-size:11px}.lib-drop-zone{background:var(--surface);border:2px dashed var(--border);border-radius:var(--radius-lg);text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:8px;padding:48px 32px;transition:border-color .15s;display:flex}.lib-drop-zone:hover{border-color:var(--border-hi)}.lib-drop-icon{color:var(--muted);margin-bottom:4px;font-size:32px}.lib-drop-title{color:var(--text);font-size:15px;font-weight:700}.lib-drop-sub{color:var(--muted);max-width:340px;font-size:12.5px;line-height:1.5}.lib-format-chips{flex-wrap:wrap;justify-content:center;gap:6px;margin-top:8px;display:flex}.lib-format-chip{border-radius:var(--radius-pill);background:var(--raised);border:1px solid var(--border);color:var(--muted);padding:3px 10px;font-family:Menlo,Courier New,monospace;font-size:11px;font-weight:600}.lib-snapshot-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);align-items:center;gap:12px;padding:14px 18px;transition:all .15s;display:flex}.lib-snapshot-card:hover{border-color:var(--border-hi)}.lib-snapshot-card.current{background:#c3ff510a;border-color:#c3ff514d}.lib-confirm-overlay{z-index:500;background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.lib-confirm-box{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);min-width:320px;box-shadow:var(--shadow-lg);padding:24px;font-size:14px}.type-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);cursor:pointer;text-align:left;flex:1;align-items:center;gap:12px;padding:14px;transition:all .15s;display:flex}.type-card:hover{border-color:var(--border-hi);background:var(--raised)}.type-card.active{background:#0ea5e914;border-color:#0ea5e966;box-shadow:0 0 15px #0ea5e91a}.tc-icon{font-size:20px}.tc-title{color:var(--text);margin-bottom:2px;font-size:14px;font-weight:700}.tc-sub{color:var(--muted);font-size:11.5px}.sub-type-card{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-md);cursor:pointer;text-align:center;flex:1;padding:10px 14px;transition:all .15s}.sub-type-card:hover{border-color:var(--border-hi)}.sub-type-card.active{background:#c3ff510d;border-color:#c3ff5166}.rent-toggle-bar{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);cursor:pointer;align-items:center;gap:12px;margin-bottom:16px;padding:14px 16px;display:flex}.rent-toggle-bar.active{background:#2dd4bf14;border-color:#2dd4bf66}.rent-toggle-bar input[type=checkbox]{pointer-events:none}.mock-section{border-top:1px solid var(--border);margin-top:8px;margin-bottom:16px;padding-top:16px}.sec-title{color:var(--text);letter-spacing:.8px;text-transform:uppercase;margin-bottom:12px;font-size:11px;font-weight:800}.bom-list{flex-direction:column;gap:8px;margin-bottom:8px;display:flex}.bom-row{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);align-items:center;gap:8px;padding:6px 10px;display:flex}.drag-handle{color:var(--border-hi);cursor:grab;padding:0 4px;font-size:14px}.bom-tag{border-radius:var(--radius-sm);text-transform:uppercase;padding:2px 6px;font-size:10px;font-weight:800}.bom-tag.mat{color:var(--acc2);background:#0ea5e926;border:1px solid #0ea5e94d}.bom-tag.op{color:var(--acc3);background:#d946ef26;border:1px solid #d946ef4d}.bom-input{color:var(--text);background:0 0;border:1px solid #0000;border-radius:4px;padding:4px;font-family:inherit;font-size:13px}.bom-input:focus,.bom-input:hover{border-color:var(--border);background:var(--surface);outline:none}.bom-footer{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);flex-direction:column;gap:6px;margin-top:12px;padding:12px;font-size:12px;display:flex}.bom-f-row{color:var(--muted);justify-content:space-between;display:flex}.bom-f-row.total{color:var(--text);border-top:1px solid var(--border-hi);margin-top:4px;padding-top:10px;font-size:14px;font-weight:700}.fin-axis-box{border:1px solid var(--border-hi);border-radius:var(--radius-md);background:var(--bg);margin-bottom:12px;overflow:hidden}.fin-axis-header{background:var(--surface);border-bottom:1px solid var(--border);align-items:center;padding:8px 12px;display:flex}.fin-val-list{flex-direction:column;gap:4px;padding:4px;display:flex}.fin-val-row{border-radius:var(--radius-sm);background:#fbbf240a;border:1px solid #0000;align-items:center;padding:4px 8px;display:flex}.fin-val-row:hover{background:#fbbf2414;border-color:#fbbf2433}.fin-mini-btn{border:1px solid var(--border-hi);color:var(--muted);cursor:pointer;background:0 0;border-radius:4px;margin-left:6px;padding:2px 6px;font-size:10px;transition:all .1s}.fin-mini-btn:hover{color:var(--text);border-color:var(--muted);background:var(--surface)}.fin-add-val{color:var(--text);cursor:pointer;opacity:.7;padding:8px 12px;font-size:12px;font-weight:600}.fin-add-val:hover{opacity:1;background:var(--surface)}.mat-view-bar{align-items:center;gap:12px;margin-bottom:20px;display:flex}.mat-view-switcher{background:var(--raised);border:1px solid var(--border);border-radius:var(--radius-md);gap:2px;padding:2px;display:flex;overflow:hidden}.mat-view-btn{border-radius:var(--radius-sm);color:var(--muted);cursor:pointer;background:0 0;border:none;padding:6px 14px;font-size:12.5px;font-weight:600;transition:all .15s}.mat-view-btn:hover{color:var(--text)}.mat-view-btn.active{background:var(--surface);color:var(--text);box-shadow:var(--shadow-sm);border:1px solid var(--border)}.mat-search{flex:1}.mat-search input{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-pill);width:100%;max-width:280px;height:34px;color:var(--text);outline:none;padding:0 14px 0 34px;font-size:13px;transition:border-color .15s}.mat-search input:focus{border-color:var(--acc);box-shadow:0 0 0 2px var(--sel)}.mat-card-grid{grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:16px;display:grid}.mat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);cursor:pointer;padding:0;transition:all .15s;overflow:hidden}.mat-card:hover{border-color:var(--border-hi);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.mat-card-head{border-bottom:1px solid var(--border);justify-content:space-between;align-items:flex-start;gap:8px;padding:16px 18px 12px;display:flex}.mat-card-name{color:var(--text);margin-bottom:2px;font-size:14px;font-weight:700}.mat-card-sku{color:var(--acc2);font-family:Menlo,Courier New,monospace;font-size:11px;font-weight:600}.mat-card-mfr{color:var(--muted);margin-top:2px;font-size:11.5px}.mat-card-status{border-radius:var(--radius-pill);flex-shrink:0;align-items:center;gap:4px;padding:3px 8px;font-size:10.5px;font-weight:700;display:inline-flex}.mat-card-status.active{color:var(--ok);background:#4ade8026;border:1px solid #4ade804d}.mat-card-status.draft{color:var(--muted);background:#94a3b826;border:1px solid #94a3b84d}.mat-card-status.archived{color:var(--warn);background:#fbbf2426;border:1px solid #fbbf244d}.mat-card-body{grid-template-columns:1fr 1fr;gap:10px 20px;padding:14px 18px;display:grid}.mat-card-field{flex-direction:column;gap:2px;display:flex}.mat-card-label{color:var(--dim);text-transform:uppercase;letter-spacing:.5px;font-size:10px;font-weight:700}.mat-card-val{color:var(--text);font-size:13px;font-weight:500}.mat-card-val.price{color:var(--acc2);font-weight:700}.mat-card-val.dim{color:var(--muted);font-family:Menlo,Courier New,monospace;font-size:12px}.mat-card-tags{border-top:1px solid var(--border);flex-wrap:wrap;gap:6px;padding:10px 18px 14px;display:flex}.mat-card-tag{border-radius:var(--radius-pill);background:var(--raised);border:1px solid var(--border);color:var(--muted);padding:3px 8px;font-size:10.5px;font-weight:600}.mat-card-tag.finish{color:var(--warn);background:#fbbf241a;border-color:#fbbf2433}.mat-card-tag.fire{color:var(--danger);background:#f871711a;border-color:#f8717133}.mat-card-actions{flex-shrink:0;gap:4px;display:flex}.mat-card-vendors{border-top:1px solid var(--border);background:#0ea5e908;padding:10px 18px 14px}.mat-card-vendors-title{color:var(--dim);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;font-size:10.5px;font-weight:700}.mat-card-vendor-row{border-radius:var(--radius-sm);align-items:center;gap:8px;padding:5px 8px;font-size:12px;transition:background .1s;display:flex}.mat-card-vendor-row:hover{background:var(--raised)}.mat-card-vendor-row.primary{background:#c3ff510f;border:1px solid #c3ff5126}.mat-card-vendor-name{color:var(--text);flex:1;align-items:center;gap:4px;font-weight:600;display:flex}.mat-card-primary-badge{color:var(--acc);font-size:11px}.mat-card-vendor-sku{color:var(--muted);flex-shrink:0;font-family:Menlo,Courier New,monospace;font-size:10.5px}.mat-card-vendor-price{color:var(--acc2);white-space:nowrap;flex-shrink:0;font-weight:700}.col-ctx-menu{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);min-width:200px;box-shadow:var(--shadow-lg);z-index:999;padding:6px;position:fixed}.col-ctx-title{color:var(--dim);text-transform:uppercase;letter-spacing:.6px;padding:6px 12px;font-size:10.5px;font-weight:700}.col-ctx-item{border-radius:var(--radius-sm);cursor:pointer;color:var(--text);-webkit-user-select:none;user-select:none;align-items:center;gap:10px;padding:7px 12px;font-size:13px;font-weight:500;transition:background .12s;display:flex}.col-ctx-item:hover{background:var(--raised)}.col-ctx-item input[type=checkbox]{width:14px;height:14px;accent-color:var(--acc)}.col-ctx-sep{background:var(--border);height:1px;margin:6px 0}.lib-loading{text-align:center;color:var(--muted);padding:40px;font-size:13px}
