:root{--color-bg: #eef2f7;--color-bg-soft: #f6f8fb;--color-surface: #ffffff;--color-surface-soft: #f8fafc;--color-text: #172033;--color-text-strong: #0f172a;--color-muted: #667085;--color-muted-soft: #98a2b3;--color-line: #d8e0ea;--color-line-soft: #e8eef5;--color-brand: #2563eb;--color-brand-hover: #1d4ed8;--color-brand-soft: #eff6ff;--color-info: #0f6b9a;--color-info-soft: #e8f5fb;--color-success: #15803d;--color-success-soft: #ecfdf3;--color-warning: #b7791f;--color-warning-soft: #fff7e6;--color-danger: #d92d20;--color-danger-soft: #fff1f0;--color-sidebar: #161d2b;--color-sidebar-active: #22304a;--radius-xs: 4px;--radius-sm: 6px;--radius-md: 8px;--shadow-soft: 0 1px 2px rgba(23, 32, 51, .06);--shadow-pop: 0 18px 42px rgba(23, 32, 51, .18);--focus-ring: 0 0 0 3px rgba(37, 99, 235, .16);--sidebar-width: 238px;--topbar-height: 68px}*{box-sizing:border-box}html{min-height:100%}body{min-height:100vh;margin:0;color:var(--color-text);background:var(--color-bg);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Microsoft YaHei,sans-serif;font-size:14px;line-height:1.5;letter-spacing:0;text-rendering:optimizeLegibility}button,input,select,textarea{font:inherit}button,input,select,textarea,a{-webkit-tap-highlight-color:transparent}button{color:inherit}input,select,textarea{width:100%;min-width:0;color:var(--color-text);background:var(--color-surface);border:1px solid var(--color-line);border-radius:var(--radius-sm);outline:none;transition:border-color .16s ease,box-shadow .16s ease,background .16s ease}input:focus,select:focus,textarea:focus,button:focus-visible,.file-btn:focus-within{border-color:var(--color-brand);box-shadow:var(--focus-ring)}input::placeholder,textarea::placeholder{color:var(--color-muted-soft)}input:disabled,select:disabled,textarea:disabled,button:disabled{cursor:not-allowed}.login-page{min-height:100vh;display:grid;place-items:center;padding:24px;background:linear-gradient(135deg,#2563eb14,#14b8a614),var(--color-bg)}.login-panel{width:392px;max-width:100%;padding:28px;border:1px solid var(--color-line-soft);border-radius:var(--radius-md);background:#fffffff5;box-shadow:var(--shadow-pop)}.login-brand{display:flex;align-items:center;gap:12px;margin-bottom:24px;padding-bottom:20px;border-bottom:1px solid var(--color-line-soft)}.login-field{display:grid;gap:7px;margin-top:14px;color:var(--color-muted);font-size:13px;font-weight:650}.login-field input{height:42px;padding:0 12px}.login-btn{width:100%;height:42px;display:inline-flex;align-items:center;justify-content:center;margin-top:20px;border:1px solid var(--color-brand);border-radius:var(--radius-sm);background:var(--color-brand);color:#fff;font-weight:750;cursor:pointer;transition:background .16s ease,border-color .16s ease,transform .16s ease}.login-btn:hover{background:var(--color-brand-hover);border-color:var(--color-brand-hover)}.login-btn:active{transform:translateY(1px)}.login-error,.alert{border:1px solid #f1b8b3;border-radius:var(--radius-sm);background:var(--color-danger-soft);color:var(--color-danger);font-size:13px;font-weight:650}.login-error{margin-top:12px;padding:10px 12px}.admin-shell{min-height:100vh;display:grid;grid-template-columns:var(--sidebar-width) minmax(0,1fr)}.sidebar{min-width:0;color:#d7dfeb;background:var(--color-sidebar);border-right:1px solid rgba(0,0,0,.18)}.brand{height:var(--topbar-height);display:flex;align-items:center;gap:12px;padding:0 18px;border-bottom:1px solid rgba(255,255,255,.08)}.brand-mark{width:36px;height:36px;flex:0 0 auto;display:grid;place-items:center;border-radius:var(--radius-md);background:#2563eb;color:#fff;font-weight:850;box-shadow:0 8px 20px #2563eb47}.brand-title{color:#fff;font-size:15px;font-weight:800;line-height:1.2}.brand-title.dark{color:var(--color-text-strong)}.brand-subtitle{margin-top:3px;color:#8f9bb0;font-size:12px;line-height:1.2}.menu{display:grid;gap:4px;padding:12px 10px}.menu-item{width:100%;min-width:0;height:42px;display:flex;align-items:center;gap:10px;padding:0 12px;border:0;border-radius:var(--radius-sm);background:transparent;color:#cbd5e1;cursor:pointer;text-align:left;transition:background .16s ease,color .16s ease}.menu-item:hover{background:#ffffff12;color:#fff}.menu-item.active{color:#fff;background:var(--color-sidebar-active);box-shadow:inset 3px 0 #38bdf8}.menu-icon{width:24px;height:24px;flex:0 0 auto;display:grid;place-items:center;border-radius:var(--radius-sm);background:#ffffff14;font-size:13px;font-weight:800;line-height:1}.menu-label{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.main{min-width:0}.topbar{min-height:var(--topbar-height);display:flex;align-items:center;justify-content:space-between;gap:18px;padding:0 24px;border-bottom:1px solid var(--color-line-soft);background:#fffffff0;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.crumb{color:var(--color-muted-soft);font-size:12px;line-height:1.2}.topbar h1{margin:4px 0 0;color:var(--color-text-strong);font-size:21px;font-weight:820;line-height:1.2}.top-actions{display:flex;align-items:center;gap:10px}.operator{height:34px;display:inline-flex;align-items:center;gap:8px;max-width:220px;padding:0 12px;border:1px solid var(--color-line-soft);border-radius:18px;background:var(--color-surface-soft);color:#475467;font-size:13px;white-space:nowrap}.operator-dot{width:7px;height:7px;flex:0 0 auto;border-radius:50%;background:var(--color-success)}.page{display:grid;gap:16px;padding:22px 24px 28px}.stats-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}.stat-card,.toolbar,.panel{border:1px solid var(--color-line-soft);border-radius:var(--radius-md);background:var(--color-surface);box-shadow:var(--shadow-soft)}.stat-card{min-height:118px;display:grid;align-content:space-between;gap:18px;padding:16px}.stat-label{color:var(--color-muted);font-size:13px;font-weight:720}.stat-value{color:var(--color-text-strong);font-size:30px;font-weight:850;line-height:1;font-variant-numeric:tabular-nums}.stat-hint{margin-top:8px;color:var(--color-muted-soft);font-size:12px}.toolbar{min-height:62px;display:flex;align-items:center;flex-wrap:wrap;gap:10px;padding:12px}.search{width:min(300px,100%)}.select{width:132px}.search,.select,.key-input{height:36px;padding:0 12px}.primary-btn,.ghost-btn,.danger-btn,.file-btn{min-width:74px;height:36px;display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:0 13px;border-radius:var(--radius-sm);font-weight:720;line-height:1;white-space:nowrap;cursor:pointer;transition:background .16s ease,border-color .16s ease,color .16s ease,box-shadow .16s ease}.primary-btn,.file-btn{border:1px solid var(--color-brand);background:var(--color-brand);color:#fff}.primary-btn:hover,.file-btn:hover{border-color:var(--color-brand-hover);background:var(--color-brand-hover)}.primary-btn:disabled{border-color:#9bb9f7;background:#9bb9f7;color:#fff}.ghost-btn{border:1px solid var(--color-line);background:#fff;color:#344054}.ghost-btn:hover{border-color:#b8c4d4;background:var(--color-surface-soft)}.danger-btn{border:1px solid #f0b4af;background:var(--color-danger-soft);color:var(--color-danger)}.danger-btn:hover{border-color:#e98179;background:#ffe4e1}.danger-btn:disabled{border-color:var(--color-line);background:#f2f4f7;color:var(--color-muted-soft)}.alert{padding:10px 12px}.panel{min-width:0}.table-panel{overflow:hidden}.panel-head{min-height:56px;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 16px;border-bottom:1px solid var(--color-line-soft)}.panel-title,.panel h2{margin:0;color:var(--color-text-strong);font-size:16px;font-weight:800;line-height:1.25}.panel-subtitle{margin-top:3px;color:var(--color-muted-soft);font-size:12px}.panel-badge{min-width:44px;height:26px;display:inline-flex;align-items:center;justify-content:center;padding:0 9px;border-radius:13px;background:var(--color-brand-soft);color:var(--color-brand-hover);font-size:12px;font-weight:760;white-space:nowrap}.table-wrap{position:relative;overflow-x:auto}.data-table,table{width:100%;min-width:860px;border-collapse:collapse}th,td{height:48px;padding:0 14px;border-bottom:1px solid var(--color-line-soft);text-align:left;vertical-align:middle;white-space:nowrap}th{height:42px;color:#475467;background:#f7f9fc;font-size:13px;font-weight:780}td{color:#344054}tbody tr{transition:background .14s ease}tbody tr:hover{background:#fbfdff}tbody tr.selected{background:#eef6ff}.select-col{width:48px;text-align:center}.select-col input[type=checkbox]{width:16px;height:16px;accent-color:var(--color-brand)}.name-cell{color:var(--color-text-strong);font-weight:760}.num-cell,.time-cell{font-variant-numeric:tabular-nums}.truncate-cell{max-width:280px;overflow:hidden;text-overflow:ellipsis}.actions-cell{min-width:142px}.row-actions{display:inline-flex;align-items:center;flex-wrap:nowrap;gap:10px}.link-btn{min-width:0;height:28px;display:inline-flex;align-items:center;padding:0;border:0;background:transparent;color:var(--color-brand-hover);font-weight:760;cursor:pointer;white-space:nowrap}.link-btn:hover{color:var(--color-brand)}.link-btn.danger{color:var(--color-danger)}.link-btn:disabled{color:var(--color-muted-soft)}.status,.stock-pill{min-width:52px;height:24px;display:inline-flex;align-items:center;justify-content:center;padding:0 9px;border-radius:12px;font-size:12px;font-weight:760;line-height:1;white-space:nowrap}.status.on,.status.success,.stock-pill{background:var(--color-success-soft);color:var(--color-success)}.status.info{background:var(--color-info-soft);color:var(--color-info)}.status.warning,.stock-pill.warn{background:var(--color-warning-soft);color:var(--color-warning)}.status.danger,.stock-pill.danger{background:var(--color-danger-soft);color:var(--color-danger)}.status.off,.status.neutral{background:#f2f4f7;color:var(--color-muted)}.num-in{color:var(--color-success);font-weight:760}.num-out{color:var(--color-danger);font-weight:760}.table-empty{min-height:120px;display:flex;align-items:center;justify-content:center;padding:24px;color:var(--color-muted);font-size:13px;font-weight:650;background:#fbfcfe}.table-wrap.is-loading .table-empty:before{content:"";width:16px;height:16px;margin-right:8px;border:2px solid #c7d2e4;border-top-color:var(--color-brand);border-radius:50%;animation:spin .8s linear infinite}.empty-panel{min-height:280px;display:grid;align-content:center;gap:8px;padding:28px}.empty-panel p{margin:0;color:var(--color-muted)}.dialog-mask{position:fixed;top:0;right:0;bottom:0;left:0;z-index:20;display:flex;align-items:center;justify-content:center;padding:24px;background:#0f172a6b}.dialog{width:700px;max-width:min(100%,700px);max-height:calc(100vh - 48px);display:flex;flex-direction:column;overflow:hidden;border:1px solid var(--color-line-soft);border-radius:var(--radius-md);background:var(--color-surface);box-shadow:var(--shadow-pop)}.dialog-small{width:440px;max-width:min(100%,440px)}.dialog-head,.dialog-foot{flex:0 0 auto;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:16px 18px;border-bottom:1px solid var(--color-line-soft)}.dialog-foot{justify-content:flex-end;border-top:1px solid var(--color-line-soft);border-bottom:0;background:#fbfcfe}.dialog-head h2{margin:0;color:var(--color-text-strong);font-size:17px;font-weight:820;line-height:1.25}.icon-btn{width:32px;height:32px;flex:0 0 auto;display:grid;place-items:center;border:1px solid transparent;border-radius:var(--radius-sm);background:transparent;color:var(--color-muted);font-size:22px;line-height:1;cursor:pointer}.icon-btn:hover{border-color:var(--color-line-soft);background:var(--color-surface-soft);color:var(--color-text)}.form-grid{flex:1 1 auto;min-height:0;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;padding:18px;overflow-y:auto}.form-grid.one-col{grid-template-columns:1fr}.form-grid label{min-width:0;display:grid;gap:7px;color:var(--color-muted);font-size:13px;font-weight:650}.form-grid input,.form-grid select,.form-grid textarea{min-height:36px;padding:0 10px}.form-grid textarea{min-height:78px;padding:9px 10px;resize:vertical}.span-2{grid-column:span 2}.field-title{margin-bottom:7px;color:var(--color-muted);font-size:13px;font-weight:650}.image-upload-row{display:flex;align-items:center;flex-wrap:wrap;gap:10px;min-height:36px}.file-btn{position:relative;width:fit-content;-webkit-user-select:none;user-select:none}.file-btn input{position:absolute;top:0;right:0;bottom:0;left:0;opacity:0;cursor:pointer}.upload-state{min-width:0;color:var(--color-muted-soft);font-size:12px}.image-preview{display:grid;grid-template-columns:96px minmax(0,1fr);gap:12px;align-items:center;margin-top:10px;padding:10px;border:1px solid var(--color-line-soft);border-radius:var(--radius-sm);background:#fbfcfe}.image-preview img{width:96px;height:96px;object-fit:cover;border:1px solid var(--color-line);border-radius:var(--radius-sm);background:var(--color-surface-soft)}.form-note{margin:14px 18px 0;padding:10px 12px;border:1px solid var(--color-line-soft);border-radius:var(--radius-sm);background:var(--color-surface-soft);color:var(--color-muted)}.detail-grid{flex:1 1 auto;min-height:0;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;padding:18px 18px 0;overflow-y:auto}.detail-grid div{min-width:0;padding:10px 12px;border:1px solid var(--color-line-soft);border-radius:var(--radius-sm);background:#fbfcfe}.detail-grid span{display:block;margin-bottom:4px;color:var(--color-muted-soft);font-size:12px}.detail-grid strong{display:block;color:var(--color-text);font-size:14px;font-weight:760;line-height:1.45;overflow-wrap:anywhere}.remark-form{flex:0 0 auto;padding-top:14px}@keyframes spin{to{transform:rotate(360deg)}}@media (max-width: 1120px){.stats-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width: 900px){:root{--sidebar-width: 72px}.brand{justify-content:center;padding:0}.brand>div:not(.brand-mark),.menu-label{display:none}.menu-item{justify-content:center;padding:0}.topbar{padding:0 16px}.top-actions{display:none}.page{padding:16px}.toolbar{align-items:stretch}.search,.select,.primary-btn,.ghost-btn,.danger-btn{width:100%}.form-grid,.detail-grid{grid-template-columns:1fr}.span-2{grid-column:auto}.image-preview{grid-template-columns:1fr}}@media (max-width: 560px){.admin-shell{grid-template-columns:1fr}.sidebar{position:sticky;top:0;z-index:10}.brand{height:56px}.menu{grid-auto-flow:column;grid-auto-columns:minmax(48px,1fr);overflow-x:auto;padding:8px}.menu-item{height:38px}.topbar{min-height:62px}.topbar h1{font-size:19px}.page{gap:12px;padding:12px}.stats-grid{grid-template-columns:1fr}.panel-head{align-items:flex-start;flex-direction:column}.panel-badge{align-self:flex-start}.dialog-mask{align-items:stretch;padding:12px}.dialog,.dialog-small{width:100%;max-width:100%;max-height:calc(100vh - 24px)}.dialog-head,.dialog-foot,.form-grid,.detail-grid{padding-left:14px;padding-right:14px}.dialog-foot{flex-wrap:wrap}.dialog-foot .ghost-btn,.dialog-foot .primary-btn{flex:1 1 120px}.login-page{padding:16px}.login-panel{padding:22px}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;scroll-behavior:auto!important;transition-duration:.01ms!important}}
