:root{color:#0f172a;background:#f1f5f9;font-family:Microsoft YaHei,PingFang SC,sans-serif;font-weight:400;line-height:1.5}*{box-sizing:border-box}body{margin:0}#app{width:100vw;min-height:100vh}.layout{grid-template-columns:18% 82%;gap:12px;width:100%;min-height:100vh;padding:12px;display:grid}.card{background:#fff;border:1px solid #dbe3ef;border-radius:12px;padding:16px;box-shadow:0 6px 20px #0f172a0f}.sidebar{flex-direction:column;display:flex}.history-panels{margin-top:8px;display:block}.history-column{min-width:0}.history-title{color:#475569;font-size:13px}.sidebar-header{flex-direction:column;align-items:stretch;gap:8px;display:flex}.sidebar-user-row{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.sidebar-user-line{color:#475569;margin:0;font-size:13px}.sidebar-user-manage{min-height:28px;padding:0 10px;font-size:12px}.sidebar-user-actions{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.sidebar-user-manage.secondary{background:#64748b}.sidebar-actions{flex-wrap:wrap;gap:6px;display:flex}.sidebar-actions button{min-height:30px;padding:0 10px;font-size:12px}.main-content{flex-direction:column;gap:12px;display:flex}.history-page{min-height:calc(100vh - 24px)}.history-page-header{justify-content:space-between;align-items:center;gap:8px;display:flex}.scan-config-actions{gap:8px;display:flex}.history-page-list{max-height:calc(100vh - 130px);margin-top:10px;overflow:auto}.history-table{border-collapse:collapse;table-layout:fixed;width:100%}.history-table th,.history-table td{color:#1e293b;text-align:left;vertical-align:top;word-break:break-all;border:1px solid #dbe3ef;padding:8px 10px;font-size:14px}.history-table thead th{z-index:1;background:#f1f5f9;position:sticky;top:0}.history-table tbody tr:nth-child(2n){background:#f8fafc}.history-list-page .history-table th:first-child,.history-list-page .history-table td:first-child{width:9%;min-width:88px}.history-list-page .history-table th:nth-child(2),.history-list-page .history-table td:nth-child(2){width:10%;min-width:96px}.history-list-page .history-table th:nth-child(3),.history-list-page .history-table td:nth-child(3){width:12%;min-width:100px}.history-list-page .history-table th:nth-child(4),.history-list-page .history-table td:nth-child(4){width:8%;min-width:72px}.history-list-page .history-table th:nth-child(5),.history-list-page .history-table td:nth-child(5){width:11%;min-width:128px}.history-list-page .history-table th:nth-child(6),.history-list-page .history-table td:nth-child(6){width:50%;min-width:520px}.history-list-page .history-subtable{table-layout:fixed;width:100%}.history-list-page .history-subtable th:first-child,.history-list-page .history-subtable td:first-child{width:22%;min-width:120px}.history-list-page .history-subtable th:nth-child(2),.history-list-page .history-subtable td:nth-child(2){width:48%;min-width:200px}.history-list-page .history-subtable th:nth-child(3),.history-list-page .history-subtable td:nth-child(3){width:30%;min-width:120px}.history-list-page .history-sn-meta{max-width:none}.history-list-page .history-thumb{width:80px;height:80px}.history-query-form{grid-template-columns:repeat(6,minmax(0,1fr));align-items:end;gap:10px 12px;margin-top:12px;display:grid}.history-query-field{flex-direction:column;gap:4px;min-width:0;display:flex}.history-query-field label{color:#475569;white-space:nowrap;font-size:12px;font-weight:600}.history-query-field input{width:100%;min-width:0}.history-query-field input[type=datetime-local]{min-height:38px;padding:6px 8px;font-size:12px}.history-query-actions{grid-column:1/-1;justify-content:flex-end;align-items:center;gap:8px;display:flex}.history-query-actions button.secondary{background:#64748b}.pagination-bar{flex-direction:column;gap:10px;margin-top:12px;display:flex}.pagination-summary{color:#475569;font-size:13px}.pagination-summary strong{color:#0f172a}.pagination-size-select{background:#fff;border:1px solid #cbd5e1;border-radius:6px;margin:0 4px;padding:4px 8px;font-size:13px}.pagination-controls{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.pagination-btn{color:#334155;cursor:pointer;background:#fff;border:1px solid #cbd5e1;border-radius:6px;min-width:36px;padding:6px 10px;font-size:13px}.pagination-btn:hover:not(:disabled){color:#2563eb;border-color:#3b82f6}.pagination-btn.active{color:#fff;background:#2563eb;border-color:#2563eb}.pagination-btn:disabled{opacity:.45;cursor:not-allowed}.pagination-jump{color:#475569;align-items:center;gap:6px;margin-left:4px;font-size:13px;display:inline-flex}.pagination-jump-input{border:1px solid #cbd5e1;border-radius:6px;width:56px;padding:5px 8px;font-size:13px}@media (width<=900px){.pagination-controls{gap:4px}.pagination-jump{width:100%;margin-top:4px;margin-left:0}}@media (width<=1200px){.history-query-form{grid-template-columns:repeat(3,minmax(0,1fr))}}@media (width<=900px){.history-query-form{grid-template-columns:1fr}.history-query-actions{justify-content:flex-start}}.scan-config-table th:first-child,.scan-config-table td:first-child{width:18%}.scan-config-table th:nth-child(2),.scan-config-table td:nth-child(2){width:36%}.scan-config-table th:nth-child(3),.scan-config-table td:nth-child(3){width:22%}.scan-config-table th:nth-child(4),.scan-config-table td:nth-child(4){width:24%;min-width:168px}.scan-config-row-actions{flex-flow:row;align-items:center;gap:8px;min-width:160px;display:flex}.scan-config-row-actions button{white-space:nowrap;flex:auto;min-width:72px;min-height:34px;padding:0 12px;font-size:13px}.history-image-list{flex-wrap:wrap;gap:6px;display:flex}.history-subtable{border-collapse:collapse;width:100%}.history-subtable th,.history-subtable td{background:#fff;border:1px solid #dbe3ef;padding:6px 8px;font-size:13px}.history-subtable th{background:#eef2ff}.history-thumb{object-fit:cover;cursor:zoom-in;background:#fff;border:1px solid #dbe3ef;border-radius:6px;width:64px;height:64px}.image-preview-mask{z-index:2000;background:#0f172ac7;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.image-preview-box{max-width:min(90vw,1200px);max-height:90vh;position:relative}.image-preview-large{background:#fff;border:1px solid #cbd5e1;border-radius:10px;max-width:100%;max-height:90vh;display:block}.image-preview-close{min-height:32px;padding:0 12px;position:absolute;top:-42px;right:0}h1,h2,p{margin:0}h1{margin-bottom:12px;font-size:24px}h2{margin-bottom:10px;font-size:18px}.batch-row{grid-template-columns:110px 1fr 130px;align-items:center;gap:10px;display:grid}.batch-row-with-owner{grid-template-columns:minmax(88px,132px) 110px 1fr 130px}.owner-select-wrap{flex-direction:column;gap:2px;min-width:0;display:flex}.owner-select-label{color:#475569;font-size:12px}.owner-select-compact{color:#0f172a;background:#fff;border:1px solid #c5d1e0;border-radius:8px;width:100%;min-height:32px;padding:0 8px;font-size:12px}.top-panel .batch-row+.batch-row{margin-top:10px}input{border:1px solid #c5d1e0;border-radius:8px;width:100%;min-height:38px;padding:0 12px;font-size:14px}button{color:#fff;cursor:pointer;background:#2563eb;border:none;border-radius:8px;min-height:38px;padding:0 14px;font-size:14px}button:disabled{opacity:.5;cursor:not-allowed}.info-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-top:14px;display:grid}.info-card p{color:#334155;margin-top:6px;font-size:14px}.info-card ul{color:#334155;margin:6px 0 0;padding-left:18px;font-size:13px}.product-info-list{padding-left:0;list-style:none}.product-info-list li{border:1px solid #e2e8f0;border-radius:8px;flex-direction:column;gap:4px;margin-top:8px;padding:8px 10px;display:flex}.product-info-list li:first-child{margin-top:6px}.product-info-active{background:#f0fdf4;border-color:#22c55e}.product-info-name{color:#0f172a;font-weight:600}.product-info-meta{color:#475569;font-size:12px;font-weight:400;line-height:1.45}.scan-step{flex-direction:column;gap:6px;display:flex}.scan-step label{color:#334155;font-size:13px;font-weight:600}.scan-step-ok{color:#15803d;margin:0;font-size:13px}.scan-label-row{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:10px;display:flex}.scan-label-row label{flex:1;min-width:160px}.btn-inline-action{background:#0f766e;border-radius:8px;flex-shrink:0;min-height:32px;padding:0 12px;font-size:13px}.upload-modal-mask{z-index:2050;background:#0f172aa6;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.upload-modal-box{background:#fff;border-radius:12px;flex-direction:column;gap:10px;width:100%;max-width:440px;padding:18px 20px 16px;display:flex;box-shadow:0 20px 50px #0f172a40}.upload-modal-title{color:#0f172a;margin:0;font-size:18px;font-weight:700}.upload-modal-hint{color:#64748b;margin:0;font-size:13px;line-height:1.45}.upload-modal-field-label{color:#475569;font-size:12px;font-weight:600}.upload-modal-input{width:100%}.upload-modal-file-input{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.upload-modal-pick-btn{background:#334155;align-self:flex-start}.upload-modal-preview-wrap{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;max-height:220px;padding:8px;overflow:auto}.upload-modal-preview-img{object-fit:contain;border-radius:6px;max-width:100%;max-height:200px;margin:0 auto;display:block}.upload-modal-actions{justify-content:flex-end;gap:10px;margin-top:6px;display:flex}.upload-modal-actions button.secondary{background:#64748b}.history-sn-meta{color:#334155;word-break:break-word;max-width:220px;font-size:12px}.info-card span{color:#0f172a;font-weight:600}.quantity{flex-direction:column;justify-content:space-between;display:flex}.quantity-value{color:#16a34a;font-size:38px;font-weight:700}.bottom-panel{grid-template-columns:1fr 1fr;align-items:start;gap:12px;display:grid}.action-panel,.scan-panel{flex-direction:column;gap:10px;min-width:0;min-height:200px;display:flex}.action-panel{max-height:calc(100vh - 180px);overflow-y:auto}.camera-preview,.captured-photo{object-fit:cover;background:#0f172a;border:1px solid #dbe3ef;border-radius:8px;outline:none;flex-shrink:0;width:100%;height:min(680px,62vh);min-height:420px;max-height:min(680px,62vh)}.camera-canvas{display:none}.photo-actions{flex-shrink:0;display:block}.camera-source-select{color:#0f172a;background:#fff;border:1px solid #c5d1e0;border-radius:8px;width:100%;min-height:38px;padding:0 10px;font-size:14px}.camera-device-wrap{flex-direction:column;gap:4px;display:flex}.camera-device-label{color:#475569;font-size:12px}.camera-error{color:#dc2626;font-size:13px}.camera-tip{color:#475569;flex-shrink:0;margin:0;font-size:12px;line-height:1.4}.save-success{color:#16a34a;font-size:13px}.save-toast{z-index:2100;color:#fff;background:#16a34a;border-radius:8px;padding:10px 14px;font-size:14px;position:fixed;top:20px;right:20px;box-shadow:0 8px 24px #0f172a33}.danger{background:#ef4444}.history-list{flex-direction:column;gap:10px;max-height:520px;margin-top:6px;margin-bottom:0;display:flex;overflow-y:auto}.history-item{background:#f8fafc;border:1px solid #dbe3ef;border-radius:8px;padding:10px}.history-batch{color:#0f172a;margin-bottom:6px;font-weight:600}.history-time{color:#475569;margin-bottom:6px;font-size:12px}.history-item ul{color:#334155;margin:0;padding-left:20px;font-size:14px}.history-item li+li{margin-top:4px}.photo-btn{margin-top:0}.scan-content{color:#1e293b;word-break:break-all;background:#eef2ff;border:1px dashed #93c5fd;border-radius:8px;min-height:60px;margin-top:6px;padding:12px;font-size:14px}.device-list{background:#f8fafc;border:1px solid #dbe3ef;border-radius:8px;flex-direction:column;flex:1;min-width:0;min-height:220px;max-height:520px;padding:10px;font-size:14px;display:flex}.scan-panel{max-height:calc(100vh - 220px);overflow:hidden}.scan-panel>button{flex-shrink:0;margin-top:4px}.device-list ul{margin:8px 0 0;padding-left:20px}.device-cards{grid-template-columns:repeat(3,minmax(200px,1fr));align-content:start;gap:12px;height:calc(100% - 28px);margin-top:10px;padding-right:4px;display:grid;overflow:hidden auto}.device-card{aspect-ratio:1;box-sizing:border-box;background:#fff;border:1px solid #dbe3ef;border-radius:8px;flex-direction:column;gap:6px;width:100%;min-width:0;min-height:200px;padding:10px;display:flex;overflow:hidden}.device-code{color:#0f172a;text-overflow:ellipsis;white-space:nowrap;font-size:12px;font-weight:600;line-height:1.3;overflow:hidden}.device-product-meta{color:#64748b;text-overflow:ellipsis;white-space:nowrap;margin:0;font-size:10px;line-height:1.3;overflow:hidden}.device-image{object-fit:cover;border:1px solid #dbe3ef;border-radius:6px;flex:1;width:100%;min-height:0;display:block}.device-image-clickable{cursor:zoom-in}.device-image-clickable:hover{opacity:.92}.device-image-empty{color:#94a3b8;border:1px dashed #dbe3ef;border-radius:6px;flex:1;justify-content:center;align-items:center;font-size:12px;display:flex}.device-card .danger{width:100%;height:30px;min-height:30px;padding:0;font-size:12px}.payload-view{color:#e2e8f0;background:#0f172a;border-radius:8px;max-height:180px;margin:0;padding:10px;font-size:12px;overflow:auto}@media (width<=900px){.layout{grid-template-columns:1fr;min-height:auto}.batch-row,.batch-row-with-owner,.info-grid,.bottom-panel,.photo-actions{grid-template-columns:1fr}.device-cards{grid-template-columns:repeat(2,minmax(160px,1fr));height:calc(100% - 28px)}}.login-screen{background:linear-gradient(#f8fafc 0%,#e2e8f0 100%);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.login-card{flex-direction:column;gap:10px;width:min(100%,380px);padding:28px;display:flex}.login-card h1{color:#0f172a;margin:0;font-size:22px}.login-subtitle,.login-hint{color:#64748b;margin:0;font-size:13px}.login-error{color:#dc2626;margin:0;font-size:13px}.sidebar-actions button.secondary{background:#64748b}.user-manage-table th:first-child,.user-manage-table td:first-child{width:18%}.user-manage-table th:nth-child(2),.user-manage-table td:nth-child(2){width:22%}.user-manage-table th:nth-child(3),.user-manage-table td:nth-child(3){width:28%}
