:root{font-family:Microsoft YaHei,PingFang SC,Segoe UI,Arial,sans-serif;color:#20242b;background:#f5f7fa;font-synthesis:none;text-rendering:optimizeLegibility;--accent: #176b55;--accent-dark: #10543f;--border: #dce2e8;--muted: #697382;--panel: #ffffff;--soft: #eef3f1;--danger: #b42318;--warning: #b54708;--blue: #175cd3;--radius: 8px}*{box-sizing:border-box}body{margin:0;min-width:1180px;background:#f5f7fa}button,input,select{font:inherit}button{cursor:pointer}.mono{font-family:JetBrains Mono,Cascadia Mono,Consolas,monospace;font-variant-numeric:tabular-nums}.login-page{min-height:100dvh;display:grid;place-items:center;padding:48px;background:linear-gradient(120deg,rgba(23,107,85,.08),transparent 42%),#f5f7fa}.login-panel{width:min(980px,100%);display:grid;grid-template-columns:1.1fr 420px;gap:48px;align-items:center;padding:48px;background:var(--panel);border:1px solid var(--border);border-radius:12px;box-shadow:0 18px 44px #1c263114}.login-panel h1,.topbar h1,.section-title h2{margin:0;letter-spacing:0}.login-panel h1{font-size:34px;line-height:1.18}.login-copy{margin:18px 0 0;color:var(--muted);line-height:1.8}.eyebrow{margin:0 0 8px;color:var(--accent);font-size:12px;font-weight:700}.login-form{display:grid;gap:16px}label{display:grid;gap:8px;color:#333b46;font-size:14px}input,select{height:40px;border:1px solid var(--border);border-radius:var(--radius);padding:0 12px;background:#fff;color:#20242b}input:focus,select:focus{border-color:var(--accent);outline:3px solid rgba(23,107,85,.12)}.form-hint{margin:0;color:var(--muted);font-size:13px}.form-error{margin:0;color:var(--danger);font-size:13px}.app-shell{min-height:100dvh;display:grid;grid-template-columns:236px 1fr}.sidebar{background:#17212b;color:#f7fafc;padding:22px 16px}.brand-mark{display:flex;align-items:center;gap:12px;padding:8px 8px 24px;border-bottom:1px solid rgba(255,255,255,.12)}.brand-mark strong,.brand-mark span{display:block}.brand-mark span{color:#aab6c4;font-size:12px}.nav-list{display:grid;gap:6px;margin-top:18px}.nav-list button{display:flex;align-items:center;gap:10px;height:42px;padding:0 12px;border:0;border-radius:var(--radius);color:#d8e0e8;background:transparent;text-align:left}.nav-list button.active,.nav-list button:hover{background:#ffffff1a;color:#fff}.workspace{min-width:0;padding:24px}.topbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.topbar h1{font-size:24px}.user-box,.actions{display:flex;align-items:center;gap:10px}.role-chip{height:26px;display:inline-flex;align-items:center;padding:0 9px;border-radius:999px;font-size:12px;font-weight:700}.role-purchaser{color:#176b55;background:#e7f4ef}.role-operator{color:#175cd3;background:#eff6ff}.role-auditor{color:#b54708;background:#fff4e5}.toast{margin-bottom:14px;padding:11px 14px;border:1px solid #b7dccd;border-radius:var(--radius);color:#10543f;background:#eef8f3;font-size:14px}.page-grid{display:grid;gap:16px}.page-grid.two-column{grid-template-columns:minmax(0,1fr) 380px;align-items:start}.metric-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.metric,.content-panel{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius)}.metric{display:grid;gap:8px;padding:18px}.metric span,.metric small{color:var(--muted)}.metric strong{font-size:28px}.content-panel{padding:18px}.section-title{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:16px}.section-title.compact{align-items:flex-start}.section-title h2{font-size:20px}.section-title h3,.detail-panel h3{margin:0;font-size:16px}.primary-button,.secondary-button,.ghost-button,.danger-button{display:inline-flex;align-items:center;justify-content:center;gap:7px;min-height:36px;border-radius:var(--radius);padding:0 13px;border:1px solid transparent;transition:transform .15s ease,background .15s ease,border-color .15s ease}.primary-button:active,.secondary-button:active,.ghost-button:active,.danger-button:active{transform:translateY(1px)}.primary-button{color:#fff;background:var(--accent)}.primary-button:hover{background:var(--accent-dark)}.secondary-button{color:#26313d;background:#fff;border-color:var(--border)}.ghost-button{color:#344054;background:transparent;border-color:var(--border)}.danger-button{color:#fff;background:var(--danger)}.full{width:100%}.search-bar{display:flex;justify-content:space-between;gap:12px;margin-bottom:14px}.search-bar label{position:relative;flex:1}.search-bar label svg{position:absolute;left:12px;bottom:11px;color:var(--muted)}.search-bar input{width:100%;padding-left:38px}.table-wrap{overflow:auto;border:1px solid var(--border);border-radius:var(--radius)}table{width:100%;border-collapse:collapse;min-width:860px}th,td{padding:12px;border-bottom:1px solid var(--border);text-align:left;white-space:nowrap;font-size:14px}th{color:#485466;background:#f8fafc;font-weight:700}tr:last-child td{border-bottom:0}.product-thumb{width:54px;height:42px;object-fit:cover;border-radius:6px;border:1px solid var(--border)}.link-button,.link-danger{border:0;background:transparent;padding:0;color:var(--blue)}.link-danger{color:var(--danger)}.row-actions{display:flex;align-items:center;gap:10px}.status-tag{display:inline-flex;align-items:center;height:24px;padding:0 8px;border-radius:999px;font-size:12px;font-weight:700}.status-enabled,.status-approved{color:#067647;background:#ecfdf3}.status-pending{color:var(--blue);background:#eff6ff}.status-rejected{color:var(--danger);background:#fef3f2}.status-disabled,.status-draft{color:#475467;background:#f2f4f7}.detail-panel{position:sticky;top:24px;display:grid;gap:14px}.detail-image{width:100%;aspect-ratio:16 / 9;object-fit:cover;border:1px solid var(--border);border-radius:var(--radius)}.info-row{display:grid;gap:5px}.info-row span{color:var(--muted);font-size:13px}.info-row strong{color:#20242b;font-size:14px;line-height:1.55}.divider{height:1px;background:var(--border);margin:4px 0}.todo-list,.mini-list,.attachment-list,.timeline{display:grid;gap:10px}.dashboard-actions{display:flex;gap:10px;margin-top:14px}.todo-row,.mini-row,.attachment-row,.review-card{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px;border:1px solid var(--border);border-radius:var(--radius);background:#fbfcfd}.mini-row>div,.attachment-row>div,.review-card>div:first-child{display:grid;gap:4px}.mini-row span,.attachment-row span,.review-card span{color:var(--muted);font-size:13px}.audit-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px}.empty-state{min-height:110px;display:grid;place-items:center;gap:8px;color:var(--muted);border:1px dashed var(--border);border-radius:var(--radius);background:#fbfcfd}.timeline-item{display:grid;grid-template-columns:18px 1fr;gap:10px}.timeline-dot{width:10px;height:10px;margin-top:5px;border-radius:50%;background:var(--accent)}.timeline-item p{margin:4px 0 0;color:var(--muted)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;padding:24px;background:#17212b75}.modal-panel{width:min(720px,100%);max-height:calc(100dvh - 48px);overflow:auto;padding:20px;background:#fff;border:1px solid var(--border);border-radius:10px;box-shadow:0 24px 70px #1c263147}.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.form-grid.single{grid-template-columns:1fr}.span-2{grid-column:span 2}textarea{min-height:84px;resize:vertical;border:1px solid var(--border);border-radius:var(--radius);padding:10px 12px;font:inherit}textarea:focus{border-color:var(--accent);outline:3px solid rgba(23,107,85,.12)}.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:16px}.error-box{display:grid;gap:4px;margin-bottom:14px;padding:10px 12px;border:1px solid #fecdca;border-radius:var(--radius);color:var(--danger);background:#fef3f2;font-size:13px}.error-box p{margin:0}.import-result{display:grid;grid-template-columns:30px 1fr;gap:12px;padding:14px;border:1px solid var(--border);border-radius:var(--radius);background:#fbfcfd}.import-result p{margin:6px 0 0;color:var(--muted);line-height:1.6}.import-result ul{margin:10px 0 0;padding-left:18px;color:var(--danger);line-height:1.7}.import-upload{display:grid;gap:14px}.file-field{display:grid;gap:8px}.file-field input[type=file]{width:100%;border:1px dashed var(--border);border-radius:8px;padding:12px;background:#f8fafc}@media(max-width:1200px){body{min-width:0}.app-shell,.page-grid.two-column,.login-panel{grid-template-columns:1fr}.sidebar{display:none}.metric-strip{grid-template-columns:repeat(2,1fr)}.detail-panel{position:static}}
