:root{--bg:#f5f7fb;--surface:#ffffff;--surface-muted:#f0f4f8;--text:#17202a;--muted:#64748b;--line:#d9e2ec;--primary:#0f766e;--primary-strong:#115e59;--danger:#b91c1c;--warning:#b45309;--success:#047857;--focus:#2563eb;--shadow:0 14px 30px rgba(15,23,42,0.08)}*{box-sizing:border-box}body,html{margin:0;min-height:100%}body{background:var(--bg);color:var(--text);font-family:Microsoft YaHei,PingFang SC,Noto Sans SC,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;letter-spacing:0}a{color:inherit;text-decoration:none}button,input,select,textarea{font:inherit}button{cursor:pointer}.app-shell{min-height:100vh;display:grid;grid-template-columns:248px minmax(0,1fr)}.sidebar{background:#102a43;color:#f8fafc;padding:24px 18px;position:-webkit-sticky;position:sticky;top:0;min-height:100vh}.brand{display:flex;flex-direction:column;gap:4px;padding:0 8px 22px;border-bottom:1px solid rgba(255,255,255,.16)}.brand strong{font-size:22px}.brand span{color:#bcccdc;font-size:13px}.nav{display:grid;grid-gap:6px;gap:6px;margin-top:18px}.nav a,.nav button{width:100%;border:0;color:#e2e8f0;background:transparent;display:flex;gap:10px;align-items:center;border-radius:8px;padding:11px 12px;text-align:left;min-height:44px}.nav a:hover,.nav button:hover{background:rgba(255,255,255,.1)}.main{min-width:0;padding:28px}.page-header{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:22px}.page-header h1{margin:0 0 6px;font-size:30px;line-height:1.2}.page-header p{color:var(--muted);margin:0}.stack{display:grid;grid-gap:18px;gap:18px}.grid{display:grid;grid-template-columns:repeat(12,minmax(0,1fr));grid-gap:16px;gap:16px}.span-1{grid-column:span 1}.span-2{grid-column:span 2}.span-3{grid-column:span 3}.span-4{grid-column:span 4}.span-6{grid-column:span 6}.span-8{grid-column:span 8}.span-12{grid-column:span 12}.card{box-shadow:var(--shadow)}.card,.section{background:var(--surface);border:1px solid var(--line);border-radius:8px;padding:18px}.card h2,.section h2{margin:0 0 14px;font-size:20px}.metric{display:grid;grid-gap:8px;gap:8px}.metric span{color:var(--muted);font-size:14px}.metric strong{font-size:28px}.toolbar{gap:10px}.batch-import-panel,.toolbar{display:flex;flex-wrap:wrap;align-items:flex-end}.batch-import-panel{gap:12px;padding:14px 0 16px;margin-bottom:18px;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}.batch-import-copy{flex:1 1 220px}.batch-import-copy h3{margin:0 0 4px;font-size:16px}.batch-import-copy p{margin:0;color:var(--muted);font-size:14px}.batch-import-form{display:flex;flex:2 1 420px;flex-wrap:wrap;gap:10px;align-items:flex-end}.batch-import-file{flex:1 1 260px}.form-grid{display:grid;grid-template-columns:repeat(12,minmax(0,1fr));grid-gap:14px;gap:14px;align-items:flex-end}.field{display:grid;grid-gap:7px;gap:7px}.field label{color:var(--muted);font-size:14px}.field input,.field select,.field textarea{width:100%;min-height:44px;border:1px solid var(--line);border-radius:8px;padding:10px 12px;background:#fff;color:var(--text)}.field textarea{resize:vertical;min-height:84px}.field input:focus,.field select:focus,.field textarea:focus{outline:2px solid var(--focus);outline-offset:1px}.button,.icon-button{border:1px solid transparent;border-radius:8px;background:var(--primary);color:white;min-height:44px;padding:10px 14px;gap:8px;font-weight:650;white-space:nowrap}.button,.icon-action-button,.icon-button{display:inline-flex;align-items:center;justify-content:center}.icon-action-button{width:36px;min-width:36px;height:36px;min-height:36px;border:1px solid var(--line);border-radius:8px;background:var(--surface);color:var(--primary);padding:0;flex:0 0 auto}.icon-action-button:hover{background:var(--surface-muted)}.icon-action-button.edit{color:var(--success);border-color:#a7f3d0}.icon-action-button.danger{color:var(--danger);border-color:#fecaca}.icon-action-button:disabled{cursor:wait;opacity:.65}.button:hover,.icon-button:hover{background:var(--primary-strong)}.button.secondary{background:var(--surface);color:var(--text);border-color:var(--line)}.button.secondary:hover{background:var(--surface-muted)}.button.danger{background:var(--danger)}.button.danger:hover{background:#991b1b}.button:disabled{cursor:wait;opacity:.65}.table-wrap{overflow-x:auto;border:1px solid var(--line);border-radius:8px}table{width:100%;border-collapse:collapse;background:var(--surface)}td,th{padding:12px 11px;border-bottom:1px solid var(--line);text-align:left;vertical-align:top}th{background:var(--surface-muted);color:#334155;font-weight:700;white-space:nowrap}td{min-width:112px}tr:last-child td{border-bottom:0}.table-action-cell{min-width:92px;white-space:nowrap}.table-action-cell>.row-actions{flex-wrap:nowrap}.compact-action-cell{width:96px;min-width:96px}.compact-action-cell>.row-actions{flex-wrap:nowrap}.master-data-name-cell{min-width:160px}.master-data-edit-cell{background:#f8fafc}.product-inventory-summary,.product-price-summary{min-width:220px;max-width:360px}.product-edit-row td{border-bottom:1px solid var(--line)}.product-edit-cell{background:#f8fafc;padding:16px}.product-edit-form{align-items:flex-end}.status{display:inline-flex;align-items:center;min-height:28px;padding:4px 9px;border-radius:999px;font-size:13px;font-weight:700}.status.ok{color:var(--success);background:#d1fae5}.status.warn{color:var(--warning);background:#fef3c7}.status.off{color:#475569;background:#e2e8f0}.message{border-radius:8px;padding:12px 14px;border:1px solid var(--line);background:var(--surface);margin-bottom:16px}.message.success{border-color:#6ee7b7;background:#ecfdf5;color:var(--success)}.message.error{border-color:#fecaca;background:#fef2f2;color:var(--danger)}.action-message{margin:0 0 12px}.form-grid>.action-message,.section.stack>.action-message{grid-column:1/-1}.inline-form>.action-message,.row-actions>.action-message,.toolbar>.action-message{flex-basis:100%}.inline-form{align-items:flex-end}.inline-form,.row-actions{display:flex;flex-wrap:wrap;gap:8px}.muted{color:var(--muted)}.login-page{min-height:100vh;display:grid;place-items:center;padding:24px;background:#e6f2f0}.login-panel{width:min(420px,100%);background:white;border:1px solid var(--line);border-radius:8px;box-shadow:var(--shadow);padding:28px}.login-panel h1{margin:0 0 8px}.login-panel p{color:var(--muted);margin:0 0 22px}.sales-row{display:grid;grid-template-columns:minmax(220px,2fr) minmax(120px,1fr) minmax(96px,1fr) minmax(96px,.8fr) minmax(96px,.8fr) minmax(150px,1.2fr) 48px;grid-gap:10px;gap:10px;align-items:flex-end}.nonstandard-consumption{border-top:1px solid var(--line);padding-top:16px}.subsection-heading{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:10px}.subsection-heading h3{margin:0;font-size:16px}.nonstandard-sales-row{display:grid;grid-template-columns:minmax(220px,2fr) minmax(96px,.8fr) minmax(120px,1fr) minmax(96px,.8fr) minmax(150px,1.2fr) minmax(180px,1.4fr) 48px;grid-gap:10px;gap:10px;align-items:flex-end}.sales-product-name{min-height:44px;display:grid;grid-gap:4px;gap:4px;align-content:center;border:1px solid var(--line);border-radius:8px;padding:9px 12px;background:var(--surface-muted)}.sales-product-name span{color:var(--muted);font-size:13px}.sales-product-name strong{font-size:15px}.sales-calculated{min-height:44px;display:grid;grid-gap:4px;gap:4px;align-content:center;border:1px solid var(--line);border-radius:8px;padding:9px 12px;background:#fff}.sales-calculated span{color:var(--muted);font-size:13px}.sales-calculated strong{font-size:15px}.checkbox-group{border:1px solid var(--line);border-radius:8px;padding:12px;margin:0}.checkbox-group legend{color:var(--muted);font-size:14px;padding:0 6px}.checkbox-list{display:flex;flex-wrap:wrap;gap:10px}.checkbox-list label{min-height:36px;display:inline-flex;gap:7px;align-items:center;border:1px solid var(--line);border-radius:8px;padding:7px 10px;background:#fff}.price-option-fieldset .stack,.recipe-fieldset .stack{gap:10px}.price-option-row,.recipe-row{display:grid;grid-template-columns:minmax(240px,2fr) minmax(160px,1fr) 48px;grid-gap:10px;gap:10px;align-items:flex-end}.price-option-add-button,.recipe-add-button{justify-self:start}.totals{display:flex;gap:18px;flex-wrap:wrap;color:var(--muted)}.totals strong{color:var(--text)}details{display:grid;grid-gap:10px;gap:10px}summary{cursor:pointer;color:var(--primary);font-weight:700;min-height:32px}@media (max-width:980px){.app-shell{display:block}.sidebar{position:static;min-height:auto}.nav{grid-template-columns:repeat(2,minmax(0,1fr))}.main{padding:20px}.span-1,.span-2,.span-3,.span-4,.span-6,.span-8{grid-column:span 12}.nonstandard-sales-row,.price-option-row,.recipe-row,.sales-row{grid-template-columns:1fr}}@media (max-width:640px){.page-header{display:grid}.form-grid,.nav{grid-template-columns:1fr}.field,.span-1,.span-12,.span-2,.span-3,.span-4,.span-6,.span-8{grid-column:auto}.main{padding:16px}}