:root{color-scheme:light;font-family:Microsoft YaHei,PingFang SC,Segoe UI,Arial,sans-serif;--blue-900: #12395b;--blue-800: #1d4f7a;--blue-700: #256a9b;--blue-500: #5aa6d9;--blue-100: #e8f5ff;--blue-050: #f5fbff;--cyan-100: #e6fbff;--cyan-700: #177589;--line: #d9e9f5;--text: #173047;--muted: #6c8194;--danger: #b42318;--amber: #946200;--surface: #ffffff;--shadow: 0 16px 45px rgba(28, 78, 116, .11)}*{box-sizing:border-box}body{margin:0;color:var(--text);background:linear-gradient(180deg,#edf8ff,#f8fcff 38%,#fff)}button,input,select{font:inherit}button{cursor:pointer}.app-shell{min-height:100vh;display:grid;grid-template-columns:260px minmax(0,1fr)}.sidebar{padding:22px 16px;background:linear-gradient(180deg,#dff3ff,#f3fbff);border-right:1px solid var(--line);position:sticky;top:0;height:100vh}.brand{display:flex;gap:12px;align-items:center;padding:8px 6px 22px}.brand-logo{width:46px;height:46px;border-radius:12px;object-fit:cover;border:2px solid rgba(255,255,255,.9);box-shadow:0 8px 18px #195b8929}.brand h1{margin:0;font-size:18px;line-height:1.2;color:var(--blue-900)}.brand p{margin:5px 0 0;font-size:12px;color:var(--muted)}.nav-list{display:grid;gap:7px}.nav-button{width:100%;height:42px;border:1px solid transparent;border-radius:8px;display:flex;align-items:center;gap:10px;padding:0 12px;color:var(--blue-800);background:transparent;text-align:left}.nav-button:hover,.nav-button.active{background:#fff;border-color:#c9e5f7;box-shadow:0 8px 20px #195b891a}.main{padding:24px 28px 40px;min-width:0}.topbar{display:flex;justify-content:space-between;gap:20px;align-items:center;margin-bottom:20px}.eyebrow{margin:0 0 4px;color:var(--blue-700);font-size:13px;font-weight:700}.topbar h2{margin:0;font-size:28px;color:var(--blue-900)}.page-stack{display:grid;gap:18px}.page-grid{display:grid;grid-template-columns:minmax(320px,420px) minmax(0,1fr);gap:18px;align-items:start}.split-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}.panel{background:var(--surface);border:1px solid var(--line);border-radius:8px;box-shadow:var(--shadow);padding:18px;min-width:0}.panel.wide{min-width:0}.panel-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.panel-head>div{display:flex;align-items:center;gap:8px;color:var(--blue-800)}.panel h3{margin:0;font-size:17px;color:var(--blue-900)}.metric-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}.metric-grid.three{grid-template-columns:repeat(3,minmax(0,1fr))}.metric{min-height:92px;border:1px solid var(--line);border-radius:8px;background:#fff;box-shadow:var(--shadow);padding:18px;display:flex;gap:12px;align-items:center}.metric-icon{width:42px;height:42px;border-radius:8px;display:grid;place-items:center;background:var(--blue-100);color:var(--blue-700)}.metric span{display:block;color:var(--muted);font-size:13px}.metric strong{display:block;margin-top:4px;font-size:27px;color:var(--blue-900)}.metric.cyan .metric-icon{background:var(--cyan-100);color:var(--cyan-700)}.metric.amber .metric-icon{background:#fff6df;color:var(--amber)}.metric.red .metric-icon{background:#fff0ef;color:var(--danger)}.form-grid{display:grid;gap:12px}.toolbar-form{display:grid;grid-template-columns:minmax(220px,1fr) 180px 180px auto;gap:12px;align-items:end}.field{display:grid;gap:6px}.field span{font-size:13px;font-weight:700;color:#365a76}.field input,.field select{height:38px;width:100%;border:1px solid #c9dfef;border-radius:7px;padding:0 10px;outline:none;background:#fbfdff;color:var(--text)}.field input:focus,.field select:focus{border-color:var(--blue-500);box-shadow:0 0 0 3px #5aa6d92e}.primary-button,.ghost-button{height:38px;border-radius:7px;border:1px solid transparent;padding:0 13px;display:inline-flex;gap:7px;align-items:center;justify-content:center;font-weight:700;white-space:nowrap}.primary-button{background:var(--blue-800);color:#fff}.primary-button:hover{background:var(--blue-900)}.primary-button:disabled,.ghost-button:disabled{opacity:.55;cursor:not-allowed}.ghost-button{color:var(--blue-800);background:#fff;border-color:#c9e2f4}.ghost-button:hover{background:var(--blue-050)}.ghost-button.compact{height:34px;justify-self:start}.table-wrap{overflow-x:auto;border:1px solid var(--line);border-radius:8px}table{width:100%;border-collapse:collapse;min-width:680px}.table-wrap.compact table{min-width:560px}th,td{padding:11px 12px;border-bottom:1px solid #e6f1f8;text-align:left;vertical-align:middle;font-size:14px}.compact th,.compact td{padding:8px 10px;font-size:13px}th{background:#f1f8fd;color:#38627f;font-weight:800}tr:last-child td{border-bottom:0}.empty-cell,.empty-state,.loading{color:var(--muted);text-align:center;padding:28px 12px}.alert{margin-bottom:14px;background:#fff0ef;border:1px solid #ffd0cd;color:var(--danger);padding:12px 14px;border-radius:8px}.badge,.role-badge,.status{display:inline-flex;align-items:center;min-height:24px;padding:3px 9px;border-radius:999px;font-size:12px;font-weight:800;white-space:nowrap}.badge,.role-badge{color:var(--blue-800);background:var(--blue-100)}.role-老板{color:#7a2e0e;background:#fff2e8}.role-财务{color:#146c43;background:#e8f7ef}.role-采购{color:var(--blue-800);background:var(--blue-100)}.role-收发{color:#73510d;background:#fff7d8}.status{color:#17633f;background:#e7f8ef}.status.pending{color:var(--amber);background:#fff6df}.status.short,.status.over{color:var(--danger);background:#fff0ef}.status.stock,.status.minor{color:var(--blue-800);background:var(--blue-100)}.subform{display:grid;gap:10px;padding:12px;background:#f6fbff;border:1px solid var(--line);border-radius:8px}.subform-title{font-weight:800;color:var(--blue-800)}.bom-row,.deduction-row{display:grid;gap:8px}.bom-row{grid-template-columns:minmax(0,1.4fr) minmax(0,1fr) minmax(0,1fr)}.deduction-row{grid-template-columns:minmax(0,1.2fr) minmax(0,.8fr) minmax(0,1.2fr)}.product-list,.order-list{display:grid;gap:14px}.product-row,.order-card{border:1px solid var(--line);border-radius:8px;padding:14px;background:#fbfdff}.product-head,.order-head{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:12px}.product-head strong,.order-head strong{display:block;color:var(--blue-900);font-size:16px}.product-head span,.order-head span{display:block;margin-top:3px;color:#31536c;font-size:14px}.product-head small{display:block;margin-top:3px;color:var(--muted)}.stock-choice{display:grid;grid-template-columns:auto 96px;gap:8px;align-items:center}.stock-choice label{display:inline-flex;align-items:center;gap:5px;white-space:nowrap}.stock-choice input[type=number]{width:96px;height:30px;border:1px solid #c9dfef;border-radius:6px;padding:0 8px}.blue-note{background:#eaf6ff;border:1px solid #cae7fb;color:#285b80;padding:14px 16px;border-radius:8px}.danger-text{color:var(--danger)}.login-page{min-height:100vh;display:grid;place-items:center;padding:24px;background:linear-gradient(180deg,#e4f6ff,#f8fcff)}.login-card{width:min(420px,100%);display:grid;gap:16px;padding:28px;background:#fff;border:1px solid var(--line);border-radius:8px;box-shadow:var(--shadow)}.login-card img{width:74px;height:74px;object-fit:cover;border-radius:18px;box-shadow:0 12px 26px #195b892e}.login-card h1{margin:0;color:var(--blue-900);font-size:26px}.table-action{height:28px;border:1px solid #c9e2f4;border-radius:6px;padding:0 10px;background:#fff;color:var(--blue-800);font-weight:700}.table-action:hover{background:var(--blue-050)}.catalog-field{position:relative}.catalog-menu{position:absolute;z-index:20;top:calc(100% + 6px);left:0;right:0;max-height:220px;overflow:auto;padding:6px;background:#fff;border:1px solid #c9dfef;border-radius:8px;box-shadow:0 14px 30px #195b8924}.catalog-option{display:grid;grid-template-columns:1fr 30px;gap:4px;align-items:center}.catalog-option button,.catalog-create{min-height:30px;border:0;border-radius:6px;background:transparent;color:var(--text);text-align:left;padding:0 8px}.catalog-option button:hover,.catalog-create:hover{background:var(--blue-050)}.catalog-delete{text-align:center!important;color:var(--danger)!important;font-size:18px;padding:0!important}.catalog-delete:disabled{color:#a7b5c2!important;cursor:not-allowed}.catalog-create{width:100%;color:var(--blue-800);font-weight:700}.catalog-empty{padding:8px;color:var(--muted);font-size:13px}@media(max-width:1120px){.app-shell{grid-template-columns:1fr}.sidebar{position:static;height:auto}.nav-list{grid-template-columns:repeat(3,minmax(0,1fr))}.metric-grid,.metric-grid.three,.page-grid,.split-grid{grid-template-columns:1fr}.toolbar-form{grid-template-columns:1fr 1fr}}@media(max-width:720px){.main{padding:18px 14px 30px}.topbar{align-items:flex-start;flex-direction:column}.nav-list{grid-template-columns:1fr 1fr}.toolbar-form,.bom-row,.deduction-row,.metric-grid{grid-template-columns:1fr}}
