:root{--bg: #0f1419;--panel: #171e26;--panel-2: #1d2630;--border: #2a3744;--text: #e6edf3;--muted: #8b9bab;--accent: #4da3ff;--green: #3fb950;--red: #f85149;--amber: #d29922;font-family:Segoe UI,system-ui,-apple-system,sans-serif}*{box-sizing:border-box}body{margin:0;background:var(--bg);color:var(--text)}.app{max-width:1200px;margin:0 auto;padding:0 20px 60px}header.topbar{display:flex;align-items:baseline;gap:16px;padding:18px 0 10px;border-bottom:1px solid var(--border);margin-bottom:18px}.topbar h1{font-size:20px;margin:0}.topbar h1 span{color:var(--accent)}.topbar .tag{font-size:11px;color:var(--amber);border:1px solid var(--amber);border-radius:10px;padding:2px 8px}nav.tabs{display:flex;gap:6px;margin-left:auto}nav.tabs button{background:transparent;color:var(--muted);border:1px solid transparent;border-radius:8px;padding:7px 14px;font-size:14px;cursor:pointer}nav.tabs button:hover{color:var(--text)}nav.tabs button.active{background:var(--panel-2);color:var(--text);border-color:var(--border)}.cards{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:20px}.card{background:var(--panel);border:1px solid var(--border);border-radius:10px;padding:14px 16px}.card .num{font-size:26px;font-weight:600}.card .label{color:var(--muted);font-size:12px;margin-top:2px}.panel{background:var(--panel);border:1px solid var(--border);border-radius:10px;padding:16px;margin-bottom:16px}.panel h2{margin:0 0 10px;font-size:16px}.panel p.hint{color:var(--muted);font-size:13px;margin:4px 0 12px}input[type=text],input[type=number],select{background:var(--panel-2);border:1px solid var(--border);color:var(--text);border-radius:8px;padding:8px 12px;font-size:14px}input[type=text]{width:320px}button.primary{background:var(--accent);color:#fff;font-weight:600;border:none;border-radius:8px;padding:8px 16px;font-size:14px;cursor:pointer}button.primary:disabled{opacity:.5;cursor:default}button.ghost{background:transparent;color:var(--muted);border:1px solid var(--border);border-radius:8px;padding:6px 12px;cursor:pointer}table{width:100%;border-collapse:collapse;font-size:13px}th{text-align:left;color:var(--muted);font-weight:500;border-bottom:1px solid var(--border);padding:6px 8px}td{padding:6px 8px;border-bottom:1px solid #20262e}td.num,th.num{text-align:right;font-variant-numeric:tabular-nums}.badge{display:inline-block;font-size:11px;border-radius:9px;padding:1px 8px}.badge.make{background:#16321d;color:var(--green);border:1px solid #1e4527}.badge.buy{background:#1c2a3a;color:#4da3ff;border:1px solid #28405c}.badge.short{background:#3a1518;color:var(--red);border:1px solid #582026}.badge.ok{background:#16321d;color:var(--green);border:1px solid #1e4527}.split{display:grid;grid-template-columns:360px 1fr;gap:16px;align-items:start}.bom-list{max-height:640px;overflow-y:auto}.bom-list .row{padding:8px 10px;border-radius:8px;cursor:pointer;display:flex;justify-content:space-between;gap:8px;font-size:13px}.bom-list .row:hover{background:var(--panel-2)}.bom-list .row.selected{background:var(--panel-2);outline:1px solid var(--accent)}.bom-list .row .meta{color:var(--muted);white-space:nowrap}.tree{font-size:13px}.tree .node{padding:3px 0}.tree .node-row{display:flex;align-items:center;gap:8px;padding:3px 6px;border-radius:6px}.tree .node-row:hover{background:var(--panel-2)}.tree .toggle{width:18px;height:18px;line-height:16px;text-align:center;background:var(--panel-2);border:1px solid var(--border);border-radius:4px;color:#4da3ff;cursor:pointer;font-size:11px;flex:none}.tree .toggle.leaf{visibility:hidden}.tree .sku{color:var(--accent);font-weight:600;white-space:nowrap}.tree .name{color:var(--ink);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tree .qty{color:var(--muted);white-space:nowrap;margin-left:auto;font-variant-numeric:tabular-nums}.tree .children{margin-left:22px;border-left:1px dashed var(--border);padding-left:10px}.pager{display:flex;gap:8px;align-items:center;margin-top:10px;color:var(--muted);font-size:13px}.login-wrap{min-height:90vh;display:flex;align-items:center;justify-content:center}.login-card{width:340px;display:flex;flex-direction:column;gap:12px}.login-card h1{margin:0;font-size:26px;text-align:center}.login-card input{width:100%}.userchip{background:var(--panel-2);color:var(--muted);border:1px solid var(--border);border-radius:8px;padding:7px 12px;font-size:13px;cursor:pointer;margin-left:10px}.userchip:hover{color:var(--red);border-color:var(--red)}.error{color:#d23f3f;font-size:13px}.loading{color:var(--muted);font-size:13px;padding:12px 0}.formrow{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-bottom:12px}:root{--bg: #eef1f5;--panel: #ffffff;--ink: #1f2733;--muted: #586273;--line: #e3e8ef;--accent: #1772c4;--accent-soft: #e7f3fd;--ok: #1f9d57;--ok-soft: #e4f7ec;--ok-ink: #157a42;--warn: #d98a00;--warn-soft: #fdf1dc;--warn-ink: #8a5800;--bad: #d23f3f;--bad-soft: #fde8e8;--bad-ink: #b32d2d;--neutral-soft: #eef1f5;--neutral-ink: #5b6675;--topbar-bg: #11161d;--sidebar-bg: #1a212b;--sidebar-ink: #c2cad6;--sidebar-grp: #939cab;--sidebar-hover: #222b37;--radius: 10px;--radius-sm: 8px;--shadow: 0 1px 2px rgba(16, 24, 40, .06), 0 1px 3px rgba(16, 24, 40, .1);--sp-1: 6px;--sp-2: 10px;--sp-3: 14px;--sp-4: 18px;font-family:Inter,Segoe UI,system-ui,-apple-system,sans-serif}body{color:var(--ink)}.ui-shell{height:100vh;overflow:hidden;display:flex;flex-direction:column}.ui-shell__body{flex:1;display:flex;min-height:0;overflow:hidden}.ui-topbar{position:sticky;top:0;z-index:40;background:var(--topbar-bg);color:#fff;display:flex;align-items:center;gap:14px;padding:0 18px;height:52px}.ui-topbar__logo{font-size:17px;font-weight:700}.ui-topbar__logo span{color:#7aa7ff}.ui-topbar__sub{color:#9aa6b6;font-size:12px}.ui-topbar__user{margin-left:auto;background:#1c2530;color:#c7d0db;border:1px solid #2b3644;border-radius:var(--radius-sm);padding:7px 12px;font-size:13px;cursor:pointer}.ui-topbar__user:hover{color:#fff;border-color:#3a4757}.ui-sidebar{width:248px;flex:0 0 248px;background:var(--sidebar-bg);color:var(--sidebar-ink);padding:12px 0;overflow-y:auto}.ui-sidebar__group{margin-bottom:6px}.ui-sidebar__grp-label{padding:14px 18px 6px;font-size:11px;letter-spacing:.8px;text-transform:uppercase;color:var(--sidebar-grp)}button.ui-sidebar__grp-label{display:flex;align-items:center;justify-content:space-between;width:100%;background:none;border:0;text-align:left;font-family:inherit;cursor:pointer}button.ui-sidebar__grp-label:hover{color:var(--sidebar-ink)}.ui-sidebar__chevron{font-size:10px;opacity:.8}.ui-sidebar__link{display:flex;align-items:center;gap:10px;padding:9px 18px;color:var(--sidebar-ink);text-decoration:none;font-size:14px;border-left:3px solid transparent;cursor:pointer}.ui-sidebar__ic{width:18px;text-align:center;opacity:.85}.ui-sidebar__link:hover{background:var(--sidebar-hover);color:#fff}.ui-sidebar__link.is-active{background:var(--sidebar-hover);color:#fff;border-left-color:var(--accent);font-weight:600}.ui-sidebar__link.is-soon{color:#969fad;cursor:default}.ui-sidebar__link.is-soon:hover{background:transparent;color:#969fad}.ui-sidebar__soon{margin-left:auto;font-size:10px;color:#969fad;border:1px solid #2b3644;border-radius:10px;padding:1px 7px}.ui-content{flex:1;min-width:0;padding:20px 24px 60px;overflow-y:auto}.ui-card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);margin-bottom:18px}.ui-card__head{display:flex;align-items:center;gap:12px;padding:14px 16px;border-bottom:1px solid var(--line)}.ui-card__title{margin:0;font-size:15px}.ui-card__actions{margin-left:auto;display:flex;gap:8px}.ui-card__body{padding:16px}.ui-btn{border:1px solid var(--line);background:#fff;color:var(--ink);padding:8px 14px;border-radius:var(--radius-sm);font-size:14px;cursor:pointer}.ui-btn:disabled{opacity:.5;cursor:default}.ui-btn--primary{background:var(--accent);border-color:var(--accent);color:#fff;font-weight:600}.ui-btn--ghost{background:transparent;color:var(--muted)}.ui-btn--ghost:hover{color:var(--ink)}.ui-btn--danger{background:var(--bad);border-color:var(--bad);color:#fff;font-weight:600}.ui-badge{display:inline-block;font-size:11px;font-weight:600;border-radius:20px;padding:2px 9px}.ui-badge--ok{background:var(--ok-soft);color:var(--ok-ink)}.ui-badge--warn{background:var(--warn-soft);color:var(--warn-ink)}.ui-badge--crit{background:var(--bad-soft);color:var(--bad-ink)}.ui-badge--neutral{background:var(--neutral-soft);color:var(--neutral-ink)}.ui-table{width:100%;border-collapse:collapse;font-size:13px}.ui-table thead th{text-align:left;background:#f7f9fc;color:var(--muted);font-weight:600;padding:10px 14px;border-bottom:1px solid var(--line)}.ui-table td{padding:9px 14px;border-bottom:1px solid var(--line)}.ui-table tbody tr:hover{background:#fbfcfe}.ui-table__num{text-align:right;font-variant-numeric:tabular-nums}.ui-table__row--clickable{cursor:pointer}.ui-table__empty{text-align:center;color:var(--muted);padding:24px}.ui-tabs{display:flex;gap:4px;border-bottom:1px solid var(--line);margin-bottom:16px}.ui-tabs__tab{background:transparent;border:none;border-bottom:2px solid transparent;color:var(--muted);padding:9px 14px;font-size:14px;cursor:pointer}.ui-tabs__tab:hover{color:var(--ink)}.ui-tabs__tab.is-active{color:var(--accent);border-bottom-color:var(--accent);font-weight:600}.ui-field{display:flex;flex-direction:column;gap:4px;margin-bottom:12px}.ui-field__label{font-size:12px;color:var(--muted)}.ui-field__input{border:1px solid var(--line);border-radius:var(--radius-sm);padding:8px 11px;background:#fff;color:var(--ink);font-size:14px}.ui-field__error{font-size:12px;color:var(--bad)}.ui-select{position:relative;width:100%}.ui-select__control,.ui-select__input{width:100%;box-sizing:border-box;border:1px solid var(--line);border-radius:var(--radius-sm);padding:8px 11px;background:#fff;color:var(--ink);font-size:14px;text-align:left}.ui-select__control{display:flex;align-items:center;gap:8px;cursor:pointer}.ui-select__control:disabled{opacity:.55;cursor:default}.ui-select__input:focus,.ui-select__control:focus{outline:2px solid var(--accent);outline-offset:1px;border-color:var(--accent)}.ui-select__value{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ui-select__placeholder{flex:1;color:var(--muted)}.ui-select__clear{color:var(--muted);font-size:16px;line-height:1;padding:0 2px;cursor:pointer}.ui-select__clear:hover{color:var(--bad)}.ui-select__caret{color:var(--muted);font-size:11px}.ui-select__menu{position:absolute;z-index:70;top:calc(100% + 4px);left:0;right:0;margin:0;padding:4px;list-style:none;background:var(--panel);border:1px solid var(--line);border-radius:var(--radius-sm);box-shadow:var(--shadow);max-height:260px;overflow-y:auto}.ui-select__option{display:flex;flex-direction:column;gap:1px;padding:7px 10px;border-radius:var(--radius-sm);cursor:pointer}.ui-select__option.is-active{background:var(--accent-soft)}.ui-select__opt-sku{font-size:13px;font-weight:600;color:var(--ink)}.ui-select__opt-name{font-size:12px;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ui-select__msg{padding:9px 10px;color:var(--muted);font-size:13px}.ui-drawer__overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#10182859;z-index:60;display:flex;justify-content:flex-end}.ui-drawer{width:420px;max-width:90vw;background:var(--panel);height:100%;box-shadow:-4px 0 24px #1018282e;display:flex;flex-direction:column}.ui-drawer__head{display:flex;align-items:center;gap:12px;padding:14px 16px;border-bottom:1px solid var(--line)}.ui-drawer__title{margin:0;font-size:15px}.ui-drawer__close{margin-left:auto;background:transparent;border:none;color:var(--muted);font-size:16px;cursor:pointer}.ui-drawer__body{padding:16px;overflow-y:auto}.kv-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:2px 32px}.kv{display:flex;justify-content:space-between;gap:16px;padding:9px 0;border-bottom:1px solid var(--line)}.kv__k{color:var(--muted);font-size:13px}.kv__v{text-align:right}.ui-card .hint{color:var(--muted);font-size:13px;margin:4px 0 12px}.ui-muted{color:var(--muted);font-size:13px}.split-2{display:grid;grid-template-columns:1fr 1fr;gap:var(--gap, 16px)}@media(max-width:900px){.split-2{grid-template-columns:1fr}}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:var(--sp-4)}.kpi-tile{display:flex;flex-direction:column;gap:var(--sp-2);align-items:flex-start;padding:var(--sp-4);background:var(--panel);border:1px solid var(--line);border-radius:var(--radius)}.kpi-tile__label{color:var(--muted);font-size:13px}.kpi-tile__value{font-size:32px;font-weight:700;color:var(--ink)}.ui-btn:focus-visible,.ui-tabs__tab:focus-visible,.ui-field__input:focus-visible,.ui-sidebar__link:focus-visible,.ui-topbar__user:focus-visible,.ui-drawer__close:focus-visible,.ui-select__clear:focus-visible,.ui-table__row--clickable:focus-visible,a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible,[tabindex]:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:var(--radius-sm)}.ui-sidebar__link:focus-visible{outline-offset:-2px}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
