:root{--primary:#4f46e5;--primary-light:#818cf8;--bg:#f8fafc;--card-bg:#fff;--border:#e2e8f0;--text:#334155;--text-light:#64748b;--text-heading:#0f172a;--danger:#ef4444;--warning:#f59e0b;--success:#22c55e;--info:#06b6d4;color:var(--text);background:var(--bg);font-family:Segoe UI,system-ui,-apple-system,sans-serif;font-size:14px;line-height:1.5}*{box-sizing:border-box;margin:0;padding:0}body{margin:0}#root{width:100%;max-width:100%;min-height:100vh}.app{flex-direction:column;min-height:100vh;display:flex}.app-header{color:#fff;z-index:100;background:linear-gradient(135deg,#4f46e5,#7c3aed);padding:16px 24px;position:sticky;top:0;box-shadow:0 2px 8px #00000026}.header-content{justify-content:space-between;align-items:center;max-width:1400px;margin:0 auto;display:flex}.header-content h1{color:#fff;margin:0;font-size:20px;font-weight:600}.header-right{align-items:center;gap:12px;display:flex}.version{opacity:.8;white-space:nowrap;background:#ffffff26;border-radius:12px;padding:4px 10px;font-size:12px}.app-main{flex:1;width:100%;max-width:1400px;margin:0 auto;padding:20px}.app-footer{text-align:center;color:var(--text-light);border-top:1px solid var(--border);padding:16px;font-size:12px}.card{background:var(--card-bg);border:1px solid var(--border);border-radius:12px;margin-bottom:20px;overflow:hidden;box-shadow:0 1px 3px #0000000d}.card-header{border-bottom:1px solid var(--border);background:#f8fafc;justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.card-header h2{color:var(--text-heading);margin:0;font-size:16px;font-weight:600}.error-card{color:#dc2626;background:#fef2f2;border-color:#fca5a5;padding:16px 20px}.stats-card{padding:12px 20px}.stats-row{color:var(--text-light);gap:24px;font-size:13px;display:flex}.badge{background:var(--primary);color:#fff;border-radius:10px;padding:2px 10px;font-size:12px;font-weight:500;display:inline-block}.badge-red{color:#dc2626;background:#fef2f2;border:1px solid #fca5a5}.badge-yellow{color:#d97706;background:#fffbeb;border:1px solid #fcd34d}.badge-orange{color:#ea580c;background:#fff7ed;border:1px solid #fdba74}.badge-gray{color:#64748b;background:#f1f5f9;border:1px solid #cbd5e1}.batch-drop-zone{text-align:center;cursor:pointer;background:#f8f7ff;border:2px dashed #818cf8;border-radius:12px;margin:16px 20px 0;padding:24px;transition:all .2s}.batch-drop-zone:hover{background:#eef2ff;border-color:#6366f1}.batch-drop-zone.drag-over{background:#e0e7ff;border-style:solid;border-color:#4f46e5}.batch-drop-zone.has-files{border-color:var(--success);background:#f0fdf4;border-style:solid}.batch-drop-content{flex-direction:column;align-items:center;gap:6px;display:flex}.batch-drop-icon{font-size:28px}.batch-drop-text{color:var(--text-heading);font-size:14px;font-weight:600}.batch-drop-hint{color:var(--text-light);font-size:11px}.auto-detect-log{flex-direction:column;gap:4px;margin:10px 20px 0;display:flex}.detect-entry{border-radius:6px;align-items:center;gap:6px;padding:4px 10px;font-size:12px;display:flex}.detect-entry.ok{color:#16a34a;background:#f0fdf4}.detect-entry.unknown{color:#d97706;background:#fffbeb}.detect-icon{font-weight:700}.detect-file{color:var(--text-heading);text-overflow:ellipsis;white-space:nowrap;max-width:250px;font-weight:500;overflow:hidden}.detect-arrow{color:var(--text-light)}.detect-target{font-weight:500}.progress-section{padding:12px 20px}.progress-bar-container{background:#e2e8f0;border-radius:4px;width:100%;height:8px;overflow:hidden}.progress-bar-fill{background:linear-gradient(90deg,#4f46e5,#7c3aed);border-radius:4px;height:100%;transition:width .3s}.progress-info{justify-content:space-between;margin-top:6px;font-size:12px;display:flex}.progress-step{color:var(--text-light)}.progress-percent{color:var(--primary);font-weight:600}.file-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px;padding:16px 20px;display:grid}.file-drop-zone{text-align:center;cursor:pointer;border:2px dashed #cbd5e1;border-radius:10px;padding:16px;transition:all .2s}.file-drop-zone:hover{border-color:var(--primary-light);background:#f8fafc}.file-drop-zone.drag-over{border-color:var(--primary);background:#eef2ff}.file-drop-zone.uploaded{border-color:var(--success);background:#f0fdf4;border-style:solid}.file-drop-content{flex-direction:column;align-items:center;gap:6px;display:flex}.file-icon{width:36px;height:36px;color:var(--primary);background:#eef2ff;border-radius:50%;justify-content:center;align-items:center;font-size:16px;display:flex}.uploaded .file-icon{color:var(--success);background:#dcfce7}.file-label{color:var(--text-heading);font-size:13px;font-weight:600}.file-desc{color:var(--text-light);font-size:11px}.file-name{color:var(--success);word-break:break-all;font-size:11px;font-weight:500}.required{color:var(--danger);margin-left:2px}.file-btn{color:var(--primary);cursor:pointer;background:#eef2ff;border:1px solid #c7d2fe;border-radius:6px;margin-top:4px;padding:4px 12px;font-size:12px;transition:background .2s}.file-btn:hover{background:#e0e7ff}.upload-actions{border-top:1px solid var(--border);align-items:center;gap:12px;padding:12px 20px;display:flex}.btn-primary{color:#fff;background:var(--primary);cursor:pointer;border:none;border-radius:8px;padding:8px 24px;font-size:14px;font-weight:600;transition:background .2s}.btn-primary:hover{background:#4338ca}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.hint{color:var(--text-light);font-size:12px}.summary-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:12px;margin-bottom:20px;display:grid}.summary-card{background:var(--card-bg);border:1px solid var(--border);text-align:center;border-top:3px solid;border-radius:10px;padding:14px}.summary-value{font-size:24px;font-weight:700}.summary-label{color:var(--text-light);margin-top:2px;font-size:12px}.summary-sub{color:#a855f7;margin-top:2px;font-size:11px;font-weight:600}.order-mode-card{background:linear-gradient(135deg,#fefffe 0%,#f5f3ff 100%);border:1px solid #c7d2fe;padding:16px 20px}.order-mode-row{flex-wrap:wrap;align-items:center;gap:24px;display:flex}.order-mode-left{align-items:center;gap:12px;display:flex}.order-mode-label{color:var(--text-heading);white-space:nowrap;font-size:13px;font-weight:600}.order-mode-toggle{border:1px solid #cbd5e1;border-radius:8px;display:flex;overflow:hidden}.mode-btn{color:var(--text-light);cursor:pointer;white-space:nowrap;background:#fff;border:none;padding:6px 16px;font-size:13px;font-weight:500;transition:all .2s}.mode-btn:first-child{border-right:1px solid #cbd5e1}.mode-btn.active{color:#fff;background:linear-gradient(135deg,#4f46e5,#7c3aed);font-weight:600}.mode-btn:not(.active):hover{background:#f8fafc}.order-mode-comparison{flex:1;align-items:center;gap:12px;display:flex}.comparison-item{flex-direction:column;align-items:center;gap:2px;display:flex}.comparison-label{color:var(--text-light);font-size:11px}.comparison-value{color:#94a3b8;font-variant-numeric:tabular-nums;font-size:18px;font-weight:700}.comparison-value.active-value{color:#4f46e5}.comparison-arrow{color:#cbd5e1;font-size:18px}.comparison-diff{flex-direction:column;align-items:center;gap:2px;display:flex}.diff-badge{color:var(--text-light);background:#f1f5f9;border-radius:10px;padding:2px 8px;font-size:12px;font-weight:600}.diff-badge.up{color:#b45309;background:#fef3c7}.diff-detail{color:var(--text-light);white-space:nowrap;font-size:10px}.order-mode-note{color:#6366f1;background:#6366f10f;border-radius:6px;margin-top:10px;padding:8px 12px;font-size:12px}.table-controls{flex-direction:column;gap:10px;padding:12px 20px;display:flex}.control-row{gap:10px;display:flex}.search-input{border:1px solid var(--border);border-radius:8px;outline:none;flex:1;padding:8px 12px;font-size:13px}.search-input:focus{border-color:var(--primary-light);box-shadow:0 0 0 3px #6366f11a}.filter-select{border:1px solid var(--border);background:#fff;border-radius:8px;min-width:150px;padding:8px 12px;font-size:13px}.color-legend{flex-wrap:wrap;gap:6px;display:flex}.legend-item{border-radius:4px;padding:2px 8px;font-size:11px;font-weight:500}.table-wrapper{max-height:70vh;overflow:auto}.eval-table{border-collapse:collapse;white-space:nowrap;width:100%;font-size:12px}.eval-table thead{z-index:10;position:sticky;top:0}.eval-table th{color:var(--text-heading);border-bottom:2px solid var(--border);text-align:left;background:#f1f5f9;padding:8px 10px;font-size:11px;font-weight:600}.eval-table td{border-bottom:1px solid #f1f5f9;padding:6px 10px}.eval-table tbody tr:hover{background:#f8fafc!important}.mono{font-family:Consolas,monospace;font-size:12px}.num{text-align:right;font-variant-numeric:tabular-nums}.num.negative{color:var(--danger);font-weight:600}.num.highlight{color:var(--primary);font-weight:600}.num.air{color:#0ea5e9}.num.sea{color:#06b6d4}.name-cell{text-overflow:ellipsis;max-width:180px;overflow:hidden}.style-cell{text-overflow:ellipsis;max-width:120px;overflow:hidden}.barcode-cell{text-overflow:ellipsis;max-width:130px;color:var(--text-light);font-size:11px;overflow:hidden}.ai-suggestion-cell{white-space:nowrap;text-overflow:ellipsis;max-width:160px;overflow:hidden}.ai-tip{text-overflow:ellipsis;white-space:nowrap;border-radius:4px;max-width:150px;padding:1px 6px;font-size:10px;font-weight:500;display:inline-block;overflow:hidden}.ai-tip.warn{color:#b45309;background:#fffbeb;border:1px solid #fcd34d}.ai-tip.up{color:#047857;background:#ecfdf5;border:1px solid #6ee7b7}.ai-tip.down{color:#b91c1c;background:#fef2f2;border:1px solid #fca5a5}.ai-tip.info{color:#0369a1;background:#f0f9ff;border:1px solid #7dd3fc}.card-header-actions{align-items:center;gap:10px;display:flex}.btn-export-table{color:var(--primary);cursor:pointer;white-space:nowrap;background:#eef2ff;border:1px solid #c7d2fe;border-radius:6px;padding:4px 12px;font-size:12px;font-weight:500;transition:background .2s}.btn-export-table:hover{background:#e0e7ff}.btn-column-picker{color:var(--text);border:1px solid var(--border);cursor:pointer;white-space:nowrap;background:#fff;border-radius:6px;padding:4px 12px;font-size:12px;font-weight:500;transition:all .2s}.btn-column-picker:hover{border-color:var(--primary-light);background:#f8fafc}.column-picker{border-bottom:1px solid var(--border);background:#fafbfc;padding:12px 20px}.column-picker-header{color:var(--text-heading);justify-content:space-between;align-items:center;margin-bottom:10px;font-size:13px;font-weight:600;display:flex}.column-picker-reset{color:var(--primary);cursor:pointer;background:#eef2ff;border:1px solid #c7d2fe;border-radius:4px;padding:2px 10px;font-size:11px}.column-picker-reset:hover{background:#e0e7ff}.column-picker-grid{grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:4px 12px;display:grid}.column-picker-item{color:var(--text);cursor:pointer;align-items:center;gap:6px;padding:3px 0;font-size:12px;display:flex}.column-picker-item:hover{color:var(--primary)}.column-picker-item input[type=checkbox]{width:14px;height:14px;accent-color:var(--primary)}.qty-input{text-align:right;border:1px solid #cbd5e1;border-radius:4px;width:70px;padding:4px 6px;font-family:Consolas,monospace;font-size:12px}.qty-input:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 2px #6366f126}.pagination{border-top:1px solid var(--border);justify-content:center;align-items:center;gap:8px;padding:12px;font-size:13px;display:flex}.pagination button{border:1px solid var(--border);cursor:pointer;background:#fff;border-radius:6px;padding:4px 10px;font-size:12px}.pagination button:hover:not(:disabled){background:#f1f5f9}.pagination button:disabled{opacity:.4;cursor:not-allowed}.export-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px;padding:16px 20px;display:grid}.export-btn{border:1px solid var(--border);cursor:pointer;background:#fff;border-radius:10px;flex-direction:column;align-items:center;gap:6px;padding:16px;transition:all .2s;display:flex}.export-btn:hover{border-color:var(--primary-light);background:#eef2ff;transform:translateY(-1px);box-shadow:0 4px 12px #00000014}.export-btn.air{border-left:3px solid #0ea5e9}.export-btn.sea{border-left:3px solid #06b6d4}.export-icon{font-size:24px}.export-label{color:var(--text-heading);font-size:13px;font-weight:600}.export-count{color:var(--text-light);font-size:11px}.btn-vendor-mgr{cursor:pointer;color:#ffffffe6;white-space:nowrap;background:#ffffff1a;border:1px solid #ffffff4d;border-radius:6px;padding:4px 10px;font-size:11px;transition:all .2s}.btn-vendor-mgr:hover{background:#fff3;border-color:#ffffff80}.vendor-overlay{z-index:1000;background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.vendor-modal{background:#fff;border-radius:14px;width:520px;max-width:90vw;max-height:80vh;overflow:hidden;box-shadow:0 20px 60px #0000004d}.vendor-modal-header{border-bottom:1px solid var(--border);background:#f8fafc;justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.vendor-modal-header h3{margin:0;font-size:16px;font-weight:600}.vendor-close{color:var(--text-light);cursor:pointer;background:0 0;border:none;padding:0 4px;font-size:22px;line-height:1}.vendor-close:hover{color:var(--danger)}.vendor-modal-body{max-height:60vh;padding:16px 20px;overflow-y:auto}.vendor-section{margin-bottom:16px}.vendor-section-title{color:var(--text-heading);margin-bottom:8px;font-size:13px;font-weight:600}.vendor-chip-list{flex-wrap:wrap;gap:6px;display:flex}.vendor-chip{border-radius:16px;align-items:center;gap:4px;padding:4px 10px;font-size:12px;font-weight:500;display:inline-flex}.vendor-chip.default{color:var(--text);background:#f1f5f9;border:1px solid #e2e8f0}.vendor-chip.custom{color:#4f46e5;background:#eef2ff;border:1px solid #c7d2fe}.vendor-chip-remove{color:#94a3b8;cursor:pointer;background:0 0;border:none;padding:0;font-size:14px;line-height:1}.vendor-chip-remove:hover{color:var(--danger)}.vendor-empty{color:var(--text-light);font-size:12px;font-style:italic}.vendor-add-row{gap:8px;margin-top:12px;display:flex}.vendor-add-input{border:1px solid var(--border);border-radius:8px;outline:none;flex:1;padding:8px 12px;font-size:13px}.vendor-add-input:focus{border-color:var(--primary-light);box-shadow:0 0 0 3px #6366f11a}.vendor-add-btn{color:#fff;background:var(--primary);cursor:pointer;border:none;border-radius:8px;padding:8px 16px;font-size:13px;font-weight:600}.vendor-add-btn:disabled{opacity:.4;cursor:not-allowed}.new-vendor-dialog{width:480px}.vendor-detect-desc{color:var(--text);margin-bottom:12px;font-size:13px;line-height:1.6}.vendor-detect-list{flex-direction:column;gap:8px;margin-bottom:16px;display:flex}.vendor-detect-item{border:1px solid var(--border);cursor:pointer;border-radius:8px;align-items:center;gap:8px;padding:8px 12px;transition:background .15s;display:flex}.vendor-detect-item:hover{background:#f8fafc}.vendor-detect-item input[type=checkbox]{width:16px;height:16px;accent-color:var(--primary)}.vendor-detect-name{color:var(--text-heading);font-size:13px;font-weight:600}.vendor-detect-count{color:var(--text-light);margin-left:auto;font-size:12px}.vendor-detect-actions{justify-content:flex-end;gap:10px;display:flex}.btn-secondary{color:var(--text);border:1px solid var(--border);cursor:pointer;background:#fff;border-radius:8px;padding:8px 18px;font-size:13px;font-weight:500}.btn-secondary:hover{background:#f8fafc}.api-key-setting{align-items:center;gap:8px;display:flex}.api-key-header{align-items:center;display:flex}.api-key-status{align-items:center;gap:6px;display:flex}.status-dot{border-radius:50%;width:8px;height:8px;display:inline-block}.status-dot.connected{background:#22c55e;box-shadow:0 0 6px #22c55e80}.status-dot.disconnected{background:#94a3b8}.status-text{color:#ffffffe6;white-space:nowrap;font-size:12px}.api-key-form{align-items:center;gap:6px;display:flex}.api-key-input{color:#fff;background:#ffffff1a;border:1px solid #ffffff4d;border-radius:6px;outline:none;width:200px;padding:4px 8px;font-size:11px}.api-key-input::placeholder{color:#ffffff80}.api-key-input:focus{background:#ffffff26;border-color:#fff9}.api-key-actions{gap:4px;display:flex}.btn-toggle-key,.btn-save-key,.btn-clear-key{cursor:pointer;border:1px solid #ffffff4d;border-radius:4px;padding:3px 8px;font-size:11px;transition:all .2s}.btn-toggle-key{color:#ffffffb3;background:0 0}.btn-save-key{color:#86efac;background:#22c55e33;border-color:#22c55e66}.btn-save-key:hover{background:#22c55e4d}.btn-save-key:disabled{opacity:.4;cursor:not-allowed}.btn-clear-key{color:#fca5a5;background:#ef444426;border-color:#ef44444d}.btn-clear-key:hover{background:#ef444440}.api-key-hint{color:#ffffff80;font-size:10px;display:none}.api-key-connected{align-items:center;gap:6px;display:flex}.masked-key{color:#ffffff80;font-family:Consolas,monospace;font-size:10px}.ai-panel{background:linear-gradient(135deg,#fefffe 0%,#f0f4ff 100%);border:1px solid #c7d2fe}.ai-panel-header{background:linear-gradient(135deg,#eef2ff,#e0e7ff)!important;border-bottom-color:#c7d2fe!important}.ai-panel-header h2{align-items:center;gap:8px;display:flex}.ai-icon{font-size:20px}.ai-badge{color:#fff!important;background:linear-gradient(135deg,#4f46e5,#7c3aed)!important;border:none!important}.ai-quick-actions{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px;padding:16px 20px;display:grid}.ai-action-btn{cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:10px;flex-direction:column;align-items:center;gap:4px;padding:14px 10px;transition:all .2s;display:flex}.ai-action-btn:hover{background:#f5f3ff;border-color:#818cf8;transform:translateY(-1px);box-shadow:0 4px 12px #6366f11f}.ai-action-btn.active{background:#eef2ff;border-color:#4f46e5;box-shadow:0 0 0 2px #4f46e526}.ai-action-btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.ai-action-icon{font-size:22px}.ai-action-label{color:var(--text-heading);font-size:13px;font-weight:600}.ai-action-desc{color:var(--text-light);font-size:10px}.ai-result-area{border-top:1px solid #e2e8f0;min-height:100px;padding:16px 20px}.ai-loading{color:var(--text-light);justify-content:center;align-items:center;gap:10px;padding:30px;font-size:14px;display:flex}.ai-loading-spinner{border:3px solid #e2e8f0;border-top-color:#4f46e5;border-radius:50%;width:20px;height:20px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.ai-result-content{max-height:500px;padding-right:8px;overflow-y:auto}.ai-result-content::-webkit-scrollbar{width:6px}.ai-result-content::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}.ai-h2{color:var(--text-heading);margin:12px 0 6px;font-size:16px;font-weight:700}.ai-h3{color:var(--text-heading);margin:10px 0 4px;font-size:14px;font-weight:700}.ai-h4{color:#4f46e5;margin:8px 0 4px;font-size:13px;font-weight:600}.ai-p{margin:4px 0;font-size:13px;line-height:1.6}.ai-list{margin:4px 0 8px;padding-left:20px;font-size:13px;line-height:1.6}.ai-list li{margin-bottom:3px}.ai-table-wrapper{margin:8px 0;overflow-x:auto}.ai-table{border-collapse:collapse;width:100%;font-size:11px}.ai-table th{text-align:left;white-space:nowrap;background:#f1f5f9;border:1px solid #e2e8f0;padding:5px 8px;font-size:10px;font-weight:600}.ai-table td{white-space:nowrap;border:1px solid #f1f5f9;padding:4px 8px}.ai-table tbody tr:hover{background:#f8fafc}.ai-chat-section{border-top:1px solid #e2e8f0;padding:16px 20px}.ai-chat-title{color:var(--text-heading);margin-bottom:10px;font-size:14px;font-weight:600}.ai-chat-history{flex-direction:column;gap:10px;max-height:400px;margin-bottom:12px;display:flex;overflow-y:auto}.ai-chat-msg{align-items:flex-start;gap:8px;display:flex}.ai-chat-msg.user{flex-direction:row-reverse}.ai-chat-avatar{flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:18px;display:flex}.ai-chat-bubble{border-radius:12px;max-width:85%;padding:10px 14px;font-size:13px;line-height:1.5}.ai-chat-msg.user .ai-chat-bubble{color:#fff;background:#4f46e5;border-bottom-right-radius:4px}.ai-chat-msg.ai .ai-chat-bubble{background:#fff;border:1px solid #e2e8f0;border-bottom-left-radius:4px}.ai-chat-input-row{gap:8px;display:flex}.ai-chat-input{border:1px solid #cbd5e1;border-radius:10px;outline:none;flex:1;padding:10px 14px;font-size:13px;transition:border-color .2s}.ai-chat-input:focus{border-color:#818cf8;box-shadow:0 0 0 3px #6366f11a}.btn-send{color:#fff;cursor:pointer;white-space:nowrap;background:linear-gradient(135deg,#4f46e5,#7c3aed);border:none;border-radius:10px;padding:10px 20px;font-size:13px;font-weight:600;transition:opacity .2s}.btn-send:hover{opacity:.9}.btn-send:disabled{opacity:.4;cursor:not-allowed}.ai-chat-suggestions{flex-wrap:wrap;gap:6px;margin-top:10px;display:flex}.ai-suggestion-chip{color:var(--text-light);cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:16px;padding:4px 10px;font-size:11px;transition:all .2s}.ai-suggestion-chip:hover{color:#4f46e5;background:#f5f3ff;border-color:#818cf8}.ai-suggestion-chip:disabled{opacity:.4;cursor:not-allowed}@media (width<=768px){.file-grid{grid-template-columns:1fr 1fr}.summary-grid{grid-template-columns:repeat(3,1fr)}.control-row{flex-direction:column}.export-grid{grid-template-columns:1fr 1fr}.ai-quick-actions{grid-template-columns:repeat(2,1fr)}.header-right{flex-direction:column;gap:4px}.api-key-input{width:150px}.ai-chat-suggestions{display:none}}
