/* 织布 ERP Redesign — app shell + page layout */

/* ---------- shell ---------- */
.app{display:flex;height:100vh;overflow:hidden;background:var(--bg-app)}
.content{flex:1;display:flex;flex-direction:column;min-width:0;overflow:hidden}
.main{flex:1;overflow:auto;scrollbar-gutter:stable;padding:22px 26px 60px}

/* ---------- sidebar ---------- */
.sb{width:228px;flex-shrink:0;display:flex;flex-direction:column;background:var(--surface);border-right:1px solid var(--line)}
.sb-brand{display:flex;align-items:center;gap:10px;padding:16px 16px 14px}
.sb-mark{width:32px;height:32px;border-radius:9px;background:var(--ink-1);color:#fff;display:grid;place-items:center;font-size:16px;font-weight:700;flex-shrink:0;font-family:var(--font-sans)}
.sb-mark span{transform:translateY(-.5px)}
.sb-brandtext{display:flex;flex-direction:column;min-width:0}
.sb-brandtext b{font-size:14px;font-weight:700;letter-spacing:-.01em;color:var(--ink-1)}
.sb-brandtext span{font-size:11px;color:var(--ink-3);margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sb-nav{flex:1;overflow-y:auto;padding:6px 10px 10px}
.sb-group{margin-top:12px}
.sb-glabel{font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-4);padding:6px 10px 5px}
.sb-link{display:flex;align-items:center;gap:10px;width:100%;height:34px;padding:0 10px;border:0;background:none;border-radius:var(--r-sm);color:var(--ink-2);font-family:inherit;font-size:13px;font-weight:500;cursor:pointer;text-align:left;transition:background .12s,color .12s;position:relative}
.sb-link:hover{background:var(--surface-3);color:var(--ink-1)}
.sb-link.active{background:var(--accent-soft);color:var(--accent-ink);font-weight:600}
.sb-link.active .sb-ic{color:var(--accent)}
.sb-ic{color:var(--ink-3);display:grid;place-items:center;flex-shrink:0;transition:color .12s}
.sb-link:hover .sb-ic{color:var(--ink-2)}
.sb-soon{margin-left:auto;color:var(--ink-4);font-size:18px;line-height:0}
.sb-foot{border-top:1px solid var(--line);padding:10px}
.sb-user{display:flex;align-items:center;gap:10px;padding:6px;border-radius:var(--r-sm)}
.sb-ava,.tb-ava{width:30px;height:30px;border-radius:50%;background:var(--accent-soft);color:var(--accent-ink);display:grid;place-items:center;font-size:13px;font-weight:600;flex-shrink:0}
.sb-utext{display:flex;flex-direction:column;line-height:1.3}
.sb-utext b{font-size:12.5px;font-weight:600}
.sb-utext span{font-size:11px;color:var(--ink-3)}

/* ---------- topbar ---------- */
.tb{height:56px;flex-shrink:0;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:0 26px;background:var(--surface);border-bottom:1px solid var(--line)}
.tb-left{min-width:0;display:flex;align-items:center;gap:12px}
.tb-right{display:flex;align-items:center;gap:10px}
.tb-icon{position:relative;width:34px;height:34px;border:1px solid var(--line);background:var(--surface);border-radius:var(--r-sm);color:var(--ink-2);cursor:pointer;display:grid;place-items:center}
.tb-icon:hover{background:var(--surface-3);color:var(--ink-1)}
.tb-icon .dot{position:absolute;top:7px;right:8px;width:6px;height:6px;border-radius:50%;background:var(--danger);border:1.5px solid var(--surface)}
.tb-ava{cursor:pointer}

/* ---------- generic page ---------- */
.page{max-width:1480px}
.page-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:18px;flex-wrap:wrap}
.page-head .ph-title{font-size:var(--fs-h1);font-weight:600;letter-spacing:-.01em}
.page-head .ph-sub{font-size:var(--fs-sm);color:var(--ink-3);margin-top:3px;white-space:nowrap}
.page-head > div:first-child{min-width:0}
.page-head .ph-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.section-h{display:flex;align-items:center;justify-content:space-between;gap:12px;margin:24px 0 12px}
.section-h .sh-title{font-size:var(--fs-h2);font-weight:600;white-space:nowrap}

/* ---------- dashboard ---------- */
.dash-grid{display:grid;grid-template-columns:2fr 1fr;gap:18px;align-items:start}
.dash-col{display:flex;flex-direction:column;gap:18px}
.flow-rail{display:flex;align-items:stretch;gap:0;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-sm)}
.flow-step{flex:1;padding:14px 16px;border-right:1px solid var(--line);position:relative;cursor:pointer;transition:background .12s}
.flow-step:last-child{border-right:0}
.flow-step:hover{background:var(--surface-3)}
.flow-step .fs-top{display:flex;align-items:center;gap:8px;color:var(--ink-3);font-size:11px;font-weight:600;letter-spacing:.04em}
.flow-step .fs-n{font-size:26px;font-weight:600;font-variant-numeric:tabular-nums;letter-spacing:-.01em;margin-top:8px;color:var(--ink-1)}
.flow-step .fs-n small{font-size:12px;font-weight:500;color:var(--ink-3);margin-left:3px}
.flow-step .fs-sub{font-size:11px;color:var(--ink-3);margin-top:3px}
.flow-step.alert .fs-n{color:var(--warn-ink)}
.task-row{display:flex;align-items:center;gap:12px;padding:11px 0;border-bottom:1px solid var(--line)}
.task-row:last-child{border-bottom:0}
.task-ic{width:34px;height:34px;border-radius:var(--r-sm);display:grid;place-items:center;flex-shrink:0}
.task-main{flex:1;min-width:0}
.task-main b{font-size:13px;font-weight:600;display:block}
.task-main span{font-size:12px;color:var(--ink-3)}
.mini-bar-row{display:flex;align-items:center;gap:12px;padding:9px 0;border-bottom:1px solid var(--line);font-size:12px}
.mini-bar-row:last-child{border-bottom:0}
.mini-bar-row .mb-name{width:96px;flex-shrink:0;font-weight:500;display:flex;align-items:center;gap:7px}
.mini-bar-row .mb-track{flex:1;height:8px;border-radius:99px;background:var(--bg-sunken);overflow:hidden}
.mini-bar-row .mb-track i{display:block;height:100%;border-radius:99px}
.mini-bar-row .mb-val{width:90px;text-align:right;font-variant-numeric:tabular-nums;color:var(--ink-2)}

/* ---------- inventory ---------- */
.inv-toolbar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:14px}
.inv-card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(258px,1fr));gap:14px}
.inv-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);overflow:hidden;cursor:pointer;transition:border-color .14s,box-shadow .14s,transform .14s}
.inv-card:hover{border-color:var(--line-strong);box-shadow:var(--shadow-md);transform:translateY(-1px)}
.inv-card-top{padding:14px 15px 12px;display:flex;align-items:flex-start;justify-content:space-between;gap:10px;border-bottom:1px solid var(--line)}
.inv-card-name{font-size:14px;font-weight:600;letter-spacing:-.005em}
.inv-card-code{font-family:var(--font-mono);font-size:11px;color:var(--ink-3);margin-top:3px}
.inv-card-meters{padding:12px 15px;display:flex;align-items:baseline;justify-content:space-between}
.inv-card-meters .m-big{font-size:23px;font-weight:600;font-variant-numeric:tabular-nums;letter-spacing:-.01em}
.inv-card-meters .m-big small{font-size:12px;font-weight:500;color:var(--ink-3);margin-left:3px}
.inv-card-swatches{display:flex;gap:0;padding:0 15px 14px;align-items:center}
.inv-card-swatches .sw-dot{width:18px;height:18px;border-radius:5px;border:1.5px solid var(--surface);box-shadow:0 0 0 1px rgba(16,19,26,.1);margin-right:-5px}
.inv-card-swatches .sw-more{margin-left:11px;font-size:11px;color:var(--ink-3);white-space:nowrap}
.inv-card-foot{display:flex;align-items:center;gap:10px;padding:10px 15px;background:var(--surface-2);border-top:1px solid var(--line);font-size:11.5px;color:var(--ink-3)}
.inv-card-foot .sep{width:1px;height:11px;background:var(--line-2)}

/* grouped accordion */
.inv-acc{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-sm)}
.inv-acc-row{border-bottom:1px solid var(--line)}
.inv-acc-row:last-child{border-bottom:0}
.inv-acc-head{display:flex;align-items:center;gap:14px;padding:12px 16px;cursor:pointer;transition:background .12s}
.inv-acc-head:hover{background:var(--surface-3)}
.inv-acc-head .caret{color:var(--ink-3);transition:transform .16s;flex-shrink:0}
.inv-acc-row.open .caret{transform:rotate(90deg)}
.inv-acc-name{font-size:13.5px;font-weight:600;min-width:170px}
.inv-acc-metrics{display:flex;gap:22px;margin-left:auto;font-size:12px;color:var(--ink-2);flex-shrink:0;align-items:center}
.inv-acc-metrics > span{white-space:nowrap}
.inv-acc-metrics b{font-variant-numeric:tabular-nums;color:var(--ink-1)}
.inv-acc-body{display:none;padding:4px 16px 14px 42px;background:var(--surface-2)}
.inv-acc-row.open .inv-acc-body{display:block}
.color-line{display:flex;align-items:center;gap:12px;padding:9px 0;border-bottom:1px solid var(--line)}
.color-line:last-child{border-bottom:0}
.color-line .cl-name{display:flex;align-items:center;gap:8px;font-weight:500;width:120px}
.color-line .cl-metrics{display:flex;gap:20px;margin-left:auto;color:var(--ink-2);font-size:12px}

/* ---------- product detail ---------- */
.pd-hero{display:grid;grid-template-columns:120px 1fr;gap:18px;align-items:center}
.pd-thumb{width:120px;height:120px;border-radius:var(--r-lg);border:1px solid var(--line);display:grid;place-items:center;overflow:hidden;position:relative}
.pd-meta{display:flex;flex-direction:column;gap:6px}
.pd-spec{display:flex;gap:22px;flex-wrap:wrap;margin-top:6px}
.pd-spec .s{font-size:12px;color:var(--ink-3)}
.pd-spec .s b{display:block;font-size:14px;color:var(--ink-1);font-weight:600;margin-top:2px;font-variant-numeric:tabular-nums}
.color-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px}
.color-tile{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);overflow:hidden;cursor:pointer;transition:border-color .14s,box-shadow .14s}
.color-tile:hover,.color-tile.sel{border-color:var(--accent);box-shadow:var(--ring)}
.color-tile .swatch-lg{height:64px}
.color-tile .ct-body{padding:9px 11px}
.color-tile .ct-name{font-size:13px;font-weight:600;display:flex;align-items:center;justify-content:space-between}
.color-tile .ct-sub{font-size:11px;color:var(--ink-3);margin-top:3px;display:flex;gap:10px;font-variant-numeric:tabular-nums}

/* ---------- purchase ---------- */
.prog-cell{display:flex;align-items:center;gap:8px;min-width:120px}
.prog-cell .pc-track{flex:1;height:6px;border-radius:99px;background:var(--bg-sunken);overflow:hidden}
.prog-cell .pc-track i{display:block;height:100%;border-radius:99px;background:var(--accent)}
.prog-cell .pc-num{font-size:11px;color:var(--ink-3);font-variant-numeric:tabular-nums;white-space:nowrap}

/* roll mini list in inspection */
.roll-list{border:1px solid var(--line);border-radius:var(--r-md);overflow:hidden}
.roll-item{display:grid;grid-template-columns:28px 1fr 90px 70px 28px;gap:10px;align-items:center;padding:8px 12px;border-bottom:1px solid var(--line);font-size:12px}
.roll-item:last-child{border-bottom:0}
.roll-item .ri-no{width:24px;height:24px;border-radius:6px;background:var(--surface-3);color:var(--ink-2);display:grid;place-items:center;font-size:11px;font-weight:600;font-variant-numeric:tabular-nums}
.roll-item input{height:28px}

/* variant note */
.variant-note{display:inline-flex;align-items:center;gap:7px;font-size:11px;color:var(--ink-3);background:var(--surface-2);border:1px dashed var(--line-2);border-radius:var(--r-pill);padding:4px 11px}
.variant-note b{color:var(--accent-ink);font-weight:600}

/* ---------- product dictionary detail ---------- */
.proc-row{display:flex;align-items:center;gap:13px;padding:11px 0;border-bottom:1px solid var(--line)}
.proc-row:last-child{border-bottom:0}
.proc-n{width:24px;height:24px;border-radius:7px;background:var(--accent-soft);color:var(--accent-ink);display:grid;place-items:center;font-size:12px;font-weight:600;font-variant-numeric:tabular-nums;flex-shrink:0}
.proc-main{min-width:0;flex:1}
.proc-main b{font-size:13px;font-weight:600;display:block}
.proc-main span{font-size:12px;color:var(--ink-3)}
.proc-tags{display:flex;gap:5px;flex-shrink:0;flex-wrap:wrap;justify-content:flex-end;max-width:46%}
.spec-grid{display:grid;grid-template-columns:auto 1fr;gap:0 18px}
.spec-grid .sg-k{font-size:12px;color:var(--ink-3);padding:7px 0;border-bottom:1px solid var(--line);white-space:nowrap}
.spec-grid .sg-v{font-size:12.5px;color:var(--ink-1);padding:7px 0;border-bottom:1px solid var(--line);text-align:right;font-variant-numeric:tabular-nums}
.spec-grid .sg-k:last-of-type,.spec-grid .sg-v:last-of-type{border-bottom:0}

/* ---------- putaway scan station ---------- */
.scan-slot{display:flex;align-items:center;gap:14px;padding:14px 16px;border:1px solid var(--line-2);border-radius:var(--r-md);background:var(--surface-2);transition:border-color .14s,background .14s;position:relative}
.scan-slot.filled{border-color:var(--accent);background:var(--accent-soft)}
.scan-slot.dim{opacity:.55}
.scan-step{width:24px;height:24px;border-radius:50%;background:var(--surface);border:1px solid var(--line-2);color:var(--ink-3);display:grid;place-items:center;font-size:12px;font-weight:600;flex-shrink:0}
.scan-slot.filled .scan-step{background:var(--accent);border-color:var(--accent);color:#fff}
.scan-ic{width:46px;height:46px;border-radius:var(--r-sm);background:var(--surface);border:1px solid var(--line);display:grid;place-items:center;color:var(--ink-3);flex-shrink:0}
.scan-slot.filled .scan-ic{color:var(--accent-ink);border-color:var(--accent-soft-2)}
.scan-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}
.scan-info b{font-size:13px;font-weight:600}
.scan-info span{font-size:12px;color:var(--ink-3);display:flex;align-items:center;gap:6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.scan-slot .btn{flex-shrink:0}

/* ---------- outsourcing kanban ---------- */
.kanban{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;align-items:start}
.kan-col{background:var(--surface-2);border:1px solid var(--line);border-radius:var(--r-lg);min-height:200px}
.kan-head{display:flex;align-items:center;gap:8px;padding:12px 14px;border-bottom:1px solid var(--line)}
.kan-head b{font-size:13px;font-weight:600;white-space:nowrap}
.kan-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.kan-count{font-size:11px;font-weight:600;color:var(--ink-2);background:var(--surface);border:1px solid var(--line);border-radius:99px;padding:1px 7px;font-variant-numeric:tabular-nums}
.kan-hint{margin-left:auto;font-size:11px;color:var(--ink-4);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}
.kan-body{padding:10px;display:flex;flex-direction:column;gap:10px}
.kan-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);box-shadow:var(--shadow-sm);padding:12px 13px;cursor:pointer;transition:border-color .14s,box-shadow .14s,transform .14s}
.kan-card:hover{border-color:var(--line-strong);box-shadow:var(--shadow-md);transform:translateY(-1px)}
.kan-meta{display:flex;flex-direction:column;gap:4px;font-size:12px;color:var(--ink-2);margin-bottom:10px}
.kan-meta span{display:flex;align-items:center;gap:6px}
.kan-meta svg{color:var(--ink-3)}
.kan-foot{display:flex;align-items:center;justify-content:space-between;gap:8px;padding-top:10px;border-top:1px solid var(--line)}
.kan-foot b{color:var(--ink-1);font-weight:600}
.kan-owner{font-size:11px;color:var(--ink-3);background:var(--surface-3);border-radius:99px;padding:2px 9px;white-space:nowrap}
.kan-empty{text-align:center;color:var(--ink-4);font-size:12px;padding:24px 0}

/* ---------- locations map ---------- */
.heat-key{width:11px;height:11px;border-radius:3px;display:inline-block}
.heat-key.free{background:var(--surface-3);border:1px solid var(--line-2)}
.heat-key.partial{background:var(--accent-soft-2)}
.heat-key.full{background:var(--accent)}
.rack-row{display:flex;align-items:center;gap:16px;padding:11px 0;border-bottom:1px solid var(--line)}
.rack-row:last-child{border-bottom:0}
.rack-label{width:150px;flex-shrink:0;font-size:12px;font-weight:600;color:var(--ink-2)}
.rack-cells{display:flex;gap:8px;flex-wrap:wrap}
.loc-cell{width:96px;border:1px solid var(--line-2);border-radius:var(--r-sm);background:var(--surface);padding:7px 8px;cursor:pointer;text-align:left;font-family:inherit;transition:border-color .12s,box-shadow .12s;display:flex;flex-direction:column;gap:5px}
.loc-cell:hover{border-color:var(--accent)}
.loc-cell.sel{border-color:var(--accent);box-shadow:var(--ring)}
.loc-cell.free{background:var(--surface-2)}
.loc-cell.full{background:var(--accent-soft)}
.lc-code{font-family:var(--font-mono);font-size:11px;font-weight:500;color:var(--ink-1)}
.lc-fill{height:5px;border-radius:99px;background:var(--bg-sunken);overflow:hidden}
.lc-fill i{display:block;height:100%;border-radius:99px;background:var(--accent)}
.loc-cell.full .lc-fill i{background:var(--danger)}
.lc-n{font-size:10px;color:var(--ink-3);font-variant-numeric:tabular-nums}

/* ---------- system prefs ---------- */
.pref-row{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px 20px;border-bottom:1px solid var(--line)}
.pref-row:last-child{border-bottom:0}
.pref-row b{font-size:13px;font-weight:600;display:block}
.pref-row span{font-size:12px;color:var(--ink-3);margin-top:2px;display:block}
.toggle:disabled{opacity:.5;cursor:not-allowed}
