*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{color:#1e293b;background:#f1f5f9;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang TC,Microsoft JhengHei,sans-serif}.app{flex-direction:column;min-height:100vh;display:flex}.loading,.error{justify-content:center;align-items:center;height:100vh;font-size:1.5rem;display:flex}.error{color:#ef4444}.app-header{color:#fff;background:linear-gradient(135deg,#1e3a5f 0%,#2563eb 100%);padding:20px 32px}.header-content{justify-content:space-between;align-items:center;max-width:1400px;margin:0 auto;display:flex}.app-title{font-size:1.8rem;font-weight:700}.app-subtitle{opacity:.8;margin-top:4px;font-size:.85rem}.header-badge{background:#fff3;border-radius:8px;padding:8px 16px;font-size:.9rem}.app-main{flex:1;width:100%;max-width:1400px;margin:0 auto;padding:24px}.insights-card{background:#fff;border-left:4px solid #3b82f6;border-radius:12px;margin-bottom:20px;padding:20px 24px;box-shadow:0 1px 3px #00000014}.section-title{color:#1e293b;margin-bottom:10px;font-size:1.1rem;font-weight:700}.insights-disclaimer{color:#64748b;margin-bottom:12px;font-size:.8rem}.insights-list{flex-direction:column;gap:10px;list-style:none;display:flex}.insight-item{align-items:flex-start;gap:10px;font-size:.92rem;line-height:1.6;display:flex}.insight-icon{flex-shrink:0;margin-top:2px;font-size:1.1rem}.kpi-section{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:16px;margin-bottom:20px;display:grid}.kpi-card{background:#fff;border-radius:12px;padding:16px 20px;box-shadow:0 1px 3px #00000014}.kpi-header{align-items:center;gap:6px;margin-bottom:8px;display:flex}.kpi-icon{font-size:1.1rem}.kpi-title{color:#64748b;font-size:.78rem;font-weight:500}.kpi-value{color:#1e293b;font-size:1.4rem;font-weight:700}.kpi-sub{color:#94a3b8;margin-top:4px;font-size:.72rem}.filter-panel{background:#fff;border-radius:12px;margin-bottom:20px;padding:16px 20px;box-shadow:0 1px 3px #00000014}.filter-header{justify-content:space-between;align-items:center;margin-bottom:14px;display:flex}.filter-header h3{font-size:1rem;font-weight:600}.btn-reset{cursor:pointer;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:6px;padding:6px 14px;font-size:.85rem}.btn-reset:hover{background:#e2e8f0}.filter-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px;display:grid}.filter-group{flex-direction:column;gap:4px;display:flex}.filter-group label{color:#64748b;font-size:.78rem;font-weight:500}.filter-group input,.filter-group select{background:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;padding:6px 10px;font-size:.85rem}.filter-group input:focus,.filter-group select:focus{border-color:#0000;outline:2px solid #3b82f6}.tab-bar{flex-wrap:wrap;gap:8px;margin-bottom:16px;display:flex}.tab,.tab-active{cursor:pointer;border:none;border-radius:8px;padding:8px 20px;font-size:.9rem;font-weight:500}.tab{color:#64748b;background:#fff;box-shadow:0 1px 3px #00000014}.tab-active{color:#fff;background:#3b82f6}.chart-card{background:#fff;border-radius:12px;margin-bottom:20px;padding:20px 24px;box-shadow:0 1px 3px #00000014}.chart-title{color:#1e293b;margin-bottom:12px;font-size:1rem;font-weight:600}.chart-note{color:#94a3b8;margin-top:8px;font-size:.78rem}.chart-row{grid-template-columns:1fr 1fr;gap:20px;display:grid}@media (width<=768px){.chart-row{grid-template-columns:1fr}}.table-card{background:#fff;border-radius:12px;margin-bottom:20px;padding:20px 24px;box-shadow:0 1px 3px #00000014}.table-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.table-count{color:#64748b;font-size:.85rem}.table-wrapper{overflow-x:auto}.data-table{border-collapse:collapse;width:100%;font-size:.83rem}.data-table th{text-align:left;color:#64748b;white-space:nowrap;-webkit-user-select:none;user-select:none;background:#f8fafc;border-bottom:2px solid #e2e8f0;padding:10px 8px;font-weight:600}.data-table th:hover{background:#f1f5f9}.data-table td{vertical-align:top;border-bottom:1px solid #f1f5f9;padding:9px 8px}.row-even{background:#fff}.row-odd{background:#fafafa}.data-table tr:hover td{background:#f0f7ff}.center{text-align:center}.amount-cell{text-align:right;font-variant-numeric:tabular-nums;font-weight:500}.content-cell{text-overflow:ellipsis;white-space:nowrap;color:#475569;max-width:200px;overflow:hidden}.missing{color:#cbd5e1}.badge{border-radius:12px;padding:2px 8px;font-size:.75rem;font-weight:500;display:inline-block}.badge-blue{color:#1d4ed8;background:#dbeafe}.badge-green{color:#065f46;background:#d1fae5}.badge-orange{color:#c2410c;background:#ffedd5}.badge-purple{color:#6d28d9;background:#ede9fe}.type-tag{color:#475569;background:#f1f5f9;border-radius:4px;padding:2px 6px;font-size:.75rem}.pagination{justify-content:center;gap:6px;margin-top:16px;display:flex}.pagination button{cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:6px;padding:6px 12px;font-size:.85rem}.pagination button:disabled{opacity:.4;cursor:not-allowed}.pagination button:hover:not(:disabled){background:#f1f5f9}.page-active{color:#fff!important;background:#3b82f6!important;border-color:#3b82f6!important}.quality-card{background:#fff;border-left:4px solid #f59e0b;border-radius:12px;margin-bottom:20px;padding:20px 24px;box-shadow:0 1px 3px #00000014}.quality-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:10px;margin-bottom:12px;display:grid}.quality-item{background:#f8fafc;border-radius:8px;justify-content:space-between;align-items:center;padding:8px 12px;display:flex}.quality-label{color:#475569;font-size:.82rem}.quality-value{font-size:.85rem;font-weight:600}.quality-note{color:#92400e;background:#fffbeb;border-radius:6px;padding:8px 12px;font-size:.8rem}.quality-summary-row{grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:16px;display:grid}.quality-stat{border-radius:10px;flex-direction:column;align-items:center;gap:4px;padding:14px 16px;display:flex}.quality-stat-val{font-size:1.6rem;font-weight:700}.quality-stat-lbl{text-align:center;font-size:.78rem}.quality-stat-red{color:#b91c1c;background:#fee2e2}.quality-stat-orange{color:#c2410c;background:#ffedd5}.quality-stat-yellow{color:#92400e;background:#fef9c3}.quality-stat-green{color:#166534;background:#dcfce7}.quality-tops-row{grid-template-columns:1fr 1fr;gap:16px;margin-top:14px;margin-bottom:14px;display:grid}.quality-top-block{background:#f8fafc;border-radius:8px;padding:12px 16px}.quality-top-title{color:#334155;margin-bottom:8px;font-size:.82rem;font-weight:600}.quality-top-item{border-bottom:1px solid #e2e8f0;justify-content:space-between;align-items:center;padding:4px 0;font-size:.82rem;display:flex}.quality-top-item:last-child{border-bottom:none}.quality-top-label{color:#475569;flex:1;margin-right:8px}.quality-top-count{color:#ef4444;white-space:nowrap;font-weight:600}.quality-filter-bar{flex-wrap:wrap;align-items:center;gap:8px;padding:10px 0 14px;display:flex}.quality-filter-label{color:#475569;font-size:.82rem;font-weight:500}.quality-filter-btn{cursor:pointer;color:#374151;background:#fff;border:1px solid #d1d5db;border-radius:20px;padding:4px 12px;font-size:.8rem;transition:all .15s}.quality-filter-btn:hover{background:#f9fafb;border-color:#6b7280}.quality-filter-btn.active{color:#fff;background:#3b82f6;border-color:#3b82f6}.row-quality-error{box-shadow:inset 4px 0 #ef4444}.row-quality-warning{box-shadow:inset 4px 0 #f97316}.row-quality-notice{box-shadow:inset 4px 0 #eab308}.quality-indicator-cell{width:6px;padding:0!important}.cell-issue-high{background:#fee2e2!important}.cell-issue-medium{background:#ffedd5!important}.cell-issue-low{background:#fef9c3!important}.quality-badge{text-align:center;cursor:default;border-radius:10px;min-width:22px;padding:2px 5px;font-size:.75rem;font-weight:700;display:inline-block}.quality-badge-error{color:#b91c1c;background:#fee2e2}.quality-badge-warning{color:#c2410c;background:#ffedd5}.quality-badge-notice{color:#92400e;background:#fef9c3}.quality-badge-clean{color:#166534;background:#dcfce7}.issue-list-card{margin-top:20px}.issue-filter-bar{flex-wrap:wrap;gap:8px;padding:10px 0 14px;display:flex}.issue-search{border:1px solid #d1d5db;border-radius:6px;flex:1;min-width:220px;padding:6px 12px;font-size:.83rem}.issue-select{cursor:pointer;background:#fff;border:1px solid #d1d5db;border-radius:6px;padding:6px 10px;font-size:.83rem}.issue-table th,.issue-table td{font-size:.8rem}.issue-table code{background:#f1f5f9;border-radius:3px;padding:1px 4px;font-size:.75rem}.severity-badge{white-space:nowrap;border-radius:10px;padding:2px 7px;font-size:.75rem;font-weight:600;display:inline-block}.severity-badge-high{color:#b91c1c;background:#fee2e2}.severity-badge-medium{color:#c2410c;background:#ffedd5}.severity-badge-low{color:#92400e;background:#fef9c3}.app-footer{color:#94a3b8;text-align:center;background:#1e293b;margin-top:auto;padding:16px;font-size:.8rem}.radar-page{flex-direction:column;gap:20px;display:flex}.radar-summary{background:#fff;border-left:4px solid #3b82f6;border-radius:12px;padding:20px 24px;box-shadow:0 1px 3px #00000014}.summary-title{color:#1e293b;margin-bottom:10px;font-size:1rem;font-weight:700}.summary-list{color:#334155;flex-direction:column;gap:6px;padding-left:20px;font-size:.88rem;line-height:1.6;list-style:decimal;display:flex}.summary-warning{color:#b45309;font-weight:500}.radar-kpi-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px;display:grid}.radar-kpi{background:#fff;border-radius:10px;padding:14px 16px;box-shadow:0 1px 3px #00000014}.radar-kpi-value{font-size:1.8rem;font-weight:700;line-height:1}.radar-kpi-label{color:#475569;margin-top:4px;font-size:.8rem;font-weight:600}.radar-kpi-sub{color:#94a3b8;margin-top:2px;font-size:.7rem}.radar-table-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;display:flex}.radar-controls{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.radar-search{border:1px solid #e2e8f0;border-radius:6px;width:160px;padding:6px 12px;font-size:.85rem}.radar-select{background:#fff;border:1px solid #e2e8f0;border-radius:6px;padding:6px 10px;font-size:.85rem}.btn-export{color:#fff;cursor:pointer;background:#1e3a5f;border:none;border-radius:6px;padding:6px 14px;font-size:.85rem}.btn-export:hover{background:#2563eb}.status-badge{white-space:nowrap;border-radius:20px;padding:3px 10px;font-size:.75rem;font-weight:600;display:inline-block}.master-banner{border-radius:8px;padding:12px 16px;font-size:.88rem;line-height:1.6}.master-banner code{background:#00000014;border-radius:3px;padding:1px 4px;font-size:.82em}.master-banner--warn{color:#7c2d12;background:#fff7ed;border-left:4px solid #f97316}.master-banner--partial{color:#713f12;background:#fffbeb;border-left:4px solid #eab308}.master-banner--ok{color:#14532d;background:#f0fdf4;border-left:4px solid #22c55e}.priority-badge{white-space:nowrap;border-radius:10px;padding:2px 8px;font-size:.72rem;font-weight:700;display:inline-block}.priority-p0{color:#b91c1c;background:#fee2e2}.priority-p1{color:#c2410c;background:#ffedd5}.priority-p2{color:#92400e;background:#fef9c3}.priority-p3{color:#166534;background:#f0fdf4}.fq-status-badge{border-radius:8px;padding:2px 6px;font-size:.7rem;font-weight:600;display:inline-block}.status-pending{color:#374151;background:#f3f4f6}.status-inprogress{color:#1d4ed8;background:#dbeafe}.status-done{color:#15803d;background:#dcfce7}.status-skipped{color:#7e22ce;background:#f3e8ff}.fixtype-tag{color:#1d4ed8;white-space:nowrap;background:#eff6ff;border:1px solid #bfdbfe;border-radius:6px;padding:2px 6px;font-size:.72rem;display:inline-block}.fixqueue-card{margin-bottom:1.5rem}.fixqueue-note{color:#92400e;background:#fffbeb;border:1px solid #fde68a;border-radius:8px;margin-bottom:10px;padding:8px 14px;font-size:.82rem}.fixqueue-table td{vertical-align:top}.fixqueue-table th{background:#f3f4f6}.fixqueue-summary-block{background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;margin-bottom:14px;padding:14px 18px}.fixqueue-summary-title{color:#1e293b;margin-bottom:10px;font-size:.92rem;font-weight:700}.fixqueue-summary-row{flex-wrap:wrap;gap:10px;display:flex}.fq-level-badge{text-align:center;border-radius:8px;flex:1;min-width:60px;padding:8px 6px;font-size:.8rem;font-weight:700}.fq-level-badge span{margin-top:2px;font-size:1.05rem;display:block}.fq-p0{color:#b91c1c;background:#fee2e2}.fq-p1{color:#c2410c;background:#ffedd5}.fq-p2{color:#92400e;background:#fef9c3}.fq-p3{color:#166534;background:#f0fdf4}.fq-pending{color:#374151;background:#f3f4f6}.export-btn{color:#4338ca;cursor:pointer;white-space:nowrap;background:#eef2ff;border:1px solid #6366f1;border-radius:6px;padding:6px 14px;font-size:.82rem;font-weight:600}.export-btn:hover{background:#e0e7ff}.status-needinfo{color:#b45309;background:#fef3c7}.export-btn-template{color:#15803d;background:#f0fdf4;border-color:#16a34a;margin-left:6px}.export-btn-template:hover{background:#dcfce7}.d1-panel{background:#fff;border-left:4px solid #7c3aed;border-radius:12px;margin-bottom:20px;padding:24px;box-shadow:0 1px 3px #00000014}.d1-notice{color:#92400e;background:#fef3c7;border:1px solid #fcd34d;border-radius:8px;margin-bottom:20px;padding:12px 16px;font-size:.84rem;line-height:1.6}.d1-token-area{margin-bottom:16px}.d1-token-row{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.d1-label{color:#374151;white-space:nowrap;font-size:.85rem;font-weight:600}.d1-token-input{background:#f9fafb;border:1px solid #d1d5db;border-radius:6px;flex:1;min-width:240px;padding:8px 12px;font-size:.85rem}.d1-token-input:focus{border-color:#0000;outline:2px solid #7c3aed}.d1-token-status{color:#065f46;font-size:.85rem;font-weight:500}.d1-btn-primary{color:#fff;cursor:pointer;background:#7c3aed;border:none;border-radius:6px;padding:8px 18px;font-size:.85rem;font-weight:500}.d1-btn-primary:hover:not(:disabled){background:#6d28d9}.d1-btn-primary:disabled{opacity:.5;cursor:not-allowed}.d1-btn-clear{cursor:pointer;color:#64748b;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:6px;padding:8px 14px;font-size:.85rem}.d1-btn-clear:hover{background:#e2e8f0}.d1-btn-danger{color:#fff;cursor:pointer;background:#dc2626;border:none;border-radius:6px;padding:8px 18px;font-size:.85rem;font-weight:500}.d1-btn-danger:hover:not(:disabled){background:#b91c1c}.d1-btn-danger:disabled{opacity:.5;cursor:not-allowed}.d1-admin-section{border-top:2px dashed #fca5a5;margin-top:32px;padding-top:20px}.d1-admin-notice{color:#9a3412;background:#fff7ed;border-color:#fb923c}.d1-v0-scope-notice{color:#1e40af;background:#eff6ff;border-color:#93c5fd}.d1-admin-result{background:#f0fdf4;border:1px solid #86efac;border-radius:8px;margin-top:12px;padding:12px 16px}.d1-admin-result-title{color:#166534;margin-bottom:10px;font-weight:700}.d1-error{color:#991b1b;background:#fee2e2;border:1px solid #fca5a5;border-radius:8px;margin-bottom:16px;padding:10px 14px;font-size:.84rem}.d1-section{margin-top:20px}.d1-section-title{color:#1e293b;margin-bottom:12px;font-size:1rem;font-weight:700}.d1-health-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px;display:grid}.d1-health-card{background:#f5f3ff;border-radius:8px;flex-direction:column;gap:4px;padding:12px 16px;display:flex}.d1-hc-label{color:#6d28d9;text-transform:uppercase;letter-spacing:.04em;font-size:.75rem;font-weight:600}.d1-hc-value{color:#1e293b;font-size:1.25rem;font-weight:700}.d1-hc-small{word-break:break-all;font-size:.82rem}.d1-dq-grid{grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:10px;display:grid}.d1-dq-card{border-radius:8px;flex-direction:column;gap:4px;padding:12px 14px;display:flex}.d1-dq-card span{text-transform:uppercase;letter-spacing:.03em;font-size:.75rem;font-weight:600}.d1-dq-card strong{font-size:1.3rem;font-weight:700}.d1-dq-total{color:#5b21b6;background:#ede9fe}.d1-dq-high{color:#991b1b;background:#fee2e2}.d1-dq-medium{color:#9a3412;background:#ffedd5}.d1-dq-low{color:#854d0e;background:#fef9c3}.d1-dq-error{color:#9d174d;background:#fce7f3}.d1-dq-warning{color:#c2410c;background:#fff7ed}.d1-dq-clean{color:#065f46;background:#d1fae5}.d1-table-wrapper{overflow-x:auto}.d1-table{border-collapse:collapse;width:100%;font-size:.82rem}.d1-table th{text-align:left;color:#5b21b6;white-space:nowrap;background:#f5f3ff;border-bottom:2px solid #ddd6fe;padding:9px 10px;font-weight:600}.d1-table td{vertical-align:top;border-bottom:1px solid #f1f5f9;padding:8px 10px}.d1-table tr:hover td{background:#faf5ff}.d1-monospace{color:#475569;font-family:SFMono-Regular,Consolas,monospace;font-size:.78rem}.d1-td-center{text-align:center}.d1-td-action{color:#374151;max-width:220px}.d1-placeholder{text-align:center;color:#94a3b8;padding:40px 20px;font-size:.9rem}.purchase-form-card{background:#fff;border-radius:12px;margin-bottom:20px;padding:24px;box-shadow:0 1px 3px #00000014}.purchase-form-note{color:#64748b;margin:4px 0 20px;font-size:.82rem}.purchase-form-section{margin-bottom:20px}.purchase-form-section h4{color:#374151;margin:0 0 12px;font-size:.9rem;font-weight:600}.purchase-form-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px;display:grid}.purchase-form-field{flex-direction:column;gap:4px;display:flex}.purchase-form-field label{color:#374151;font-size:.82rem;font-weight:500}.purchase-form-field input,.purchase-form-field select{border:1px solid #e2e8f0;border-radius:6px;outline:none;padding:7px 10px;font-size:.9rem}.purchase-form-field input:focus,.purchase-form-field select:focus{border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f626}.required{color:#ef4444}.purchase-item-row{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;align-items:flex-start;gap:10px;margin-bottom:10px;padding:10px 12px;display:flex}.purchase-item-number{color:#94a3b8;min-width:18px;padding-top:8px;font-size:.8rem;font-weight:600}.purchase-item-fields{flex-wrap:wrap;flex:1;gap:8px;display:flex}.purchase-item-fields input{border:1px solid #e2e8f0;border-radius:6px;flex:1;min-width:80px;padding:6px 9px;font-size:.88rem}.purchase-item-fields input:focus{border-color:#3b82f6;outline:none}.purchase-item-select-wrap{flex-direction:column;flex:1;gap:3px;min-width:160px;display:flex}.purchase-item-select{border:1px solid #e2e8f0;border-radius:6px;padding:6px 9px;font-size:.88rem}.purchase-item-select:focus{border-color:#3b82f6;outline:none}.purchase-item-meta{color:#64748b;padding-left:2px;font-size:.75rem}.purchase-item-qty{flex:none!important;width:80px!important}.purchase-item-note{min-width:120px}.purchase-item-mode-toggle{flex-wrap:wrap;gap:6px;margin-bottom:6px;display:flex}.purchase-mode-btn{cursor:pointer;color:#475569;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:6px;padding:4px 10px;font-size:.8rem}.purchase-mode-btn:hover{background:#e2e8f0}.purchase-mode-btn--active{color:#1d4ed8;background:#dbeafe;border-color:#93c5fd;font-weight:600}.purchase-mode-btn--temp{color:#b45309}.purchase-mode-btn--temp.purchase-mode-btn--active{color:#92400e;background:#fef3c7;border-color:#fbbf24}.purchase-item-row--temp{background:#fffbeb;border-left:3px solid #fbbf24;border-radius:6px}.purchase-temp-fields{flex-direction:column;flex:1;gap:6px;min-width:220px;display:flex}.purchase-temp-name{border-radius:6px;padding:6px 9px;font-size:.88rem;border:1px solid #fbbf24!important}.purchase-temp-name:focus{outline:none;border-color:#f59e0b!important}.purchase-temp-selects{flex-wrap:wrap;gap:8px;display:flex}.purchase-temp-selects .purchase-form-field{flex:1;min-width:100px}.purchase-temp-selects .purchase-form-field label{color:#92400e;margin-bottom:2px;font-size:.78rem;display:block}.purchase-temp-selects select{border:1px solid #fbbf24;border-radius:6px;width:100%;padding:5px 8px;font-size:.85rem}.purchase-temp-warning{color:#92400e;background:#fef3c7;border:1px solid #fbbf24;border-radius:8px;margin-bottom:12px;padding:10px 14px;font-size:.87rem}.purchase-dual-field{margin-bottom:4px}.purchase-field-label{color:#374151;white-space:nowrap;font-size:.88rem;font-weight:600}.purchase-temp-inline{flex-direction:column;gap:0;margin-top:6px;display:flex}.purchase-item-remove{color:#94a3b8;cursor:pointer;background:0 0;border:none;border-radius:4px;padding:4px 6px;font-size:1rem}.purchase-item-remove:hover{color:#dc2626;background:#fee2e2}.purchase-add-item{margin-top:4px}.purchase-item-price{color:#0891b2;font-weight:600}.purchase-total-section{background:#f0fdf4;border:1px solid #bbf7d0;border-radius:8px}.purchase-total-table{border-collapse:collapse;width:100%;font-size:.88rem}.purchase-total-table td{padding:5px 8px}.purchase-total-item{color:#374151}.purchase-total-unit-price{color:#64748b;text-align:right}.purchase-total-subtotal{text-align:right;color:#0891b2;width:100px;font-weight:600}.purchase-total-footer td{border-top:1px solid #bbf7d0;padding-top:8px;font-weight:600}.purchase-total-amount{text-align:right;color:#16a34a;font-size:1.1rem}.purchase-form-actions{border-top:1px solid #f1f5f9;justify-content:flex-end;padding-top:8px;display:flex}.purchase-submit-btn{color:#fff;cursor:pointer;background:#3b82f6;border:none;border-radius:8px;padding:10px 28px;font-size:.95rem;font-weight:600}.purchase-submit-btn:hover:not(:disabled){background:#2563eb}.purchase-submit-btn:disabled{opacity:.5;cursor:not-allowed}.purchase-result{border-radius:10px;margin-top:20px;padding:16px 20px}.purchase-result-ok{background:#f0fdf4;border:1px solid #bbf7d0}.purchase-result-error{background:#fef2f2;border:1px solid #fecaca}.purchase-result-header{margin-bottom:10px;font-size:.95rem;font-weight:700}.purchase-result-row{align-items:center;gap:12px;margin-bottom:4px;display:flex}.purchase-result-label{color:#64748b;min-width:80px;font-size:.82rem;font-weight:500}.purchase-result-value{color:#111827;font-size:.9rem}.purchase-order-id{color:#1d4ed8;font-family:monospace;font-size:1rem;font-weight:700}.purchase-copy-btn{color:#fff;cursor:pointer;background:#10b981;border:none;border-radius:6px;padding:5px 14px;font-size:.83rem;font-weight:600}.purchase-copy-btn:hover{background:#059669}.purchase-line-preview{white-space:pre-wrap;color:#1e293b;background:#fff;border:1px solid #d1fae5;border-radius:8px;max-height:260px;margin-top:8px;padding:12px 14px;font-size:.83rem;line-height:1.7;overflow-y:auto}.purchase-error-code{color:#dc2626;background:#fee2e2;border-radius:4px;padding:2px 8px;font-size:.85rem}.purchase-error-list{color:#dc2626;margin:8px 0 0 16px;padding:0;font-size:.87rem;line-height:1.8}.pending-panel{max-width:900px;margin:0 auto;padding:20px}.pending-badge{color:#92400e;vertical-align:middle;background:#fef3c7;border:1px solid #fbbf24;border-radius:999px;margin-left:10px;padding:1px 10px;font-size:.75rem;font-weight:700;display:inline-block}.pending-note{color:#64748b;margin:4px 0 16px;font-size:.85rem;line-height:1.6}.pending-filter-row{flex-wrap:wrap;gap:8px;margin-bottom:18px;display:flex}.pending-filter-btn{cursor:pointer;color:#475569;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:999px;align-items:center;gap:5px;padding:5px 16px;font-size:.84rem;display:flex}.pending-filter-btn:hover{background:#e2e8f0}.pending-filter-btn--active{color:#1d4ed8;background:#dbeafe;border-color:#93c5fd;font-weight:600}.pending-filter-count{background:#e2e8f0;border-radius:999px;padding:0 7px;font-size:.75rem;font-weight:700}.pending-filter-btn--active .pending-filter-count{background:#bfdbfe}.pending-empty{color:#94a3b8;text-align:center;padding:24px 0;font-size:.9rem}.pending-list{flex-direction:column;gap:14px;display:flex}.pending-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:16px 20px;box-shadow:0 1px 4px #0000000d}.pending-card--done{opacity:.6}.pending-card-header{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:12px;display:flex}.pending-type-badge{border-radius:6px;padding:2px 10px;font-size:.77rem;font-weight:700}.pending-order-id{color:#64748b;font-family:monospace;font-size:.82rem}.pending-status-badge{margin-left:auto;font-size:.8rem;font-weight:700}.pending-created-at{color:#94a3b8;font-size:.78rem}.pending-card-body{flex-direction:column;gap:6px;margin-bottom:14px;display:flex}.pending-field{gap:10px;font-size:.87rem;display:flex}.pending-field--note{align-items:flex-start}.pending-field-label{color:#94a3b8;min-width:48px;padding-top:1px;font-size:.8rem}.pending-field-value{color:#1e293b}.pending-name{font-size:.95rem;font-weight:600}.pending-note-text{color:#64748b;word-break:break-all;font-size:.8rem}.pending-actions{border-top:1px solid #f1f5f9;flex-wrap:wrap;align-items:center;gap:8px;padding-top:12px;display:flex}.pending-btn{cursor:pointer;border:none;border-radius:7px;padding:6px 16px;font-size:.84rem;font-weight:600}.pending-btn--approve{color:#15803d;background:#dcfce7}.pending-btn--approve:hover{background:#bbf7d0}.pending-btn--reject{color:#dc2626;background:#fee2e2}.pending-btn--reject:hover{background:#fecaca}.pending-btn--rename{color:#1d4ed8;background:#eff6ff}.pending-btn--rename:hover{background:#dbeafe}.pending-rename-row{flex:1;gap:6px;min-width:200px;display:flex}.pending-rename-input{border:1px solid #e2e8f0;border-radius:6px;flex:1;padding:5px 10px;font-size:.84rem}.pending-rename-input:focus{border-color:#3b82f6;outline:none}.login-page{background:linear-gradient(135deg,#1e3a5f 0%,#2563eb 100%);justify-content:center;align-items:center;min-height:100vh;display:flex}.login-card{background:#fff;border-radius:16px;width:360px;padding:40px 36px;box-shadow:0 20px 60px #00000059}.login-header{text-align:center;margin-bottom:28px}.login-logo{margin-bottom:8px;font-size:2.4rem}.login-title{color:#1e293b;font-size:1.35rem;font-weight:700}.login-subtitle{color:#64748b;margin-top:6px;font-size:.84rem}.login-form{flex-direction:column;gap:16px;display:flex}.login-field{flex-direction:column;gap:6px;display:flex}.login-field label{color:#475569;font-size:.84rem;font-weight:600}.login-field input{border:1px solid #e2e8f0;border-radius:8px;padding:10px 14px;font-size:.95rem;transition:border-color .15s}.login-field input:focus{border-color:#0000;outline:2px solid #3b82f6}.login-btn{color:#fff;cursor:pointer;background:#2563eb;border:none;border-radius:8px;margin-top:4px;padding:12px;font-size:1rem;font-weight:600;transition:background .15s}.login-btn:hover:not(:disabled){background:#1d4ed8}.login-btn:disabled{opacity:.6;cursor:not-allowed}.login-error{color:#dc2626;background:#fef2f2;border:1px solid #fecaca;border-radius:6px;padding:8px 12px;font-size:.84rem}.login-notice{color:#92400e;text-align:center;background:#fffbeb;border:1px solid #fde68a;border-radius:6px;margin-top:16px;padding:8px 12px;font-size:.78rem}.header-user{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.header-username{opacity:.9;color:#fff;font-size:.85rem}.logout-btn{color:#fff;cursor:pointer;background:#ffffff2e;border:1px solid #fff6;border-radius:8px;padding:7px 16px;font-size:.85rem;transition:background .15s}.logout-btn:hover{background:#ffffff4d}.user-create-section{background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;margin-bottom:8px;padding:16px 20px}.user-section-label{color:#475569;margin-bottom:12px;font-size:.88rem;font-weight:600}.user-create-fields{grid-template-columns:1fr 1fr 1fr auto;align-items:end;gap:12px;display:grid}@media (width<=768px){.user-create-fields{grid-template-columns:1fr 1fr}}.user-create-btn{color:#fff;cursor:pointer;white-space:nowrap;background:#10b981;border:none;border-radius:6px;padding:8px 16px;font-size:.85rem;font-weight:600;transition:background .15s}.user-create-btn:hover:not(:disabled){background:#059669}.user-create-btn:disabled{opacity:.6;cursor:not-allowed}.user-success{color:#065f46;background:#d1fae5;border:1px solid #6ee7b7;border-radius:6px;padding:8px 12px;font-size:.84rem}.btn-delete{color:#dc2626;cursor:pointer;background:#fef2f2;border:1px solid #fecaca;border-radius:6px;padding:6px 14px;font-size:.83rem;transition:background .15s}.btn-delete:hover{background:#fee2e2}.pending-card{background:#fff;border-left:4px solid #94a3b8;border-radius:10px;overflow:hidden;box-shadow:0 1px 3px #00000014}.pending-card-header{background:#f8fafc;border-bottom:1px solid #f1f5f9;flex-wrap:wrap;align-items:center;gap:8px;padding:10px 16px;display:flex}.pending-card-body{padding:14px 16px}.pending-type-badge{letter-spacing:.02em;border-radius:20px;padding:3px 10px;font-size:.75rem;font-weight:600}.pending-status-badge{border-radius:20px;padding:3px 10px;font-size:.75rem;font-weight:600}.pending-field{flex-direction:column;gap:2px;display:flex}.pending-field-label{color:#94a3b8;text-transform:uppercase;letter-spacing:.04em;font-size:.72rem}.pending-actions{border-top:1px solid #f1f5f9;margin-top:12px;padding-top:12px}.pending-edit-btn{color:#1d4ed8;cursor:pointer;background:#eff6ff;border:1px solid #bfdbfe;border-radius:6px;padding:6px 14px;font-size:.83rem;font-weight:500;transition:background .15s}.pending-edit-btn:hover:not(:disabled){background:#dbeafe}.pending-edit-fields{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:10px;margin-top:10px;padding:12px;display:grid}.pending-approve-btn{color:#fff;cursor:pointer;background:#065f46;border:none;border-radius:6px;padding:7px 16px;font-size:.85rem;font-weight:600;transition:background .15s}.pending-approve-btn:hover:not(:disabled){background:#047857}.pending-approve-btn:disabled{opacity:.6;cursor:not-allowed}.pending-reject-btn{color:#dc2626;cursor:pointer;background:#fef2f2;border:1px solid #fecaca;border-radius:6px;padding:7px 16px;font-size:.85rem;font-weight:600;transition:background .15s}.pending-reject-btn:hover:not(:disabled){background:#fee2e2}.pending-reject-btn:disabled{opacity:.6;cursor:not-allowed}.order-list{flex-direction:column;gap:12px;display:flex}.order-card{background:#fff;border-left:4px solid #94a3b8;border-radius:10px;transition:box-shadow .15s;overflow:hidden;box-shadow:0 1px 4px #00000012}.order-card:hover{box-shadow:0 3px 10px #0000001c}.order-card-header{cursor:pointer;-webkit-user-select:none;user-select:none;background:#f8fafc;padding:12px 16px}.order-card-header:hover{background:#f1f5f9}.order-card-top{align-items:center;gap:10px;margin-bottom:4px;display:flex}.order-id{color:#475569;font-family:monospace;font-size:.82rem;font-weight:600}.order-card-meta{color:#64748b;flex-wrap:wrap;align-items:center;gap:4px;margin-bottom:4px;font-size:.84rem;display:flex}.order-meta-sep{color:#cbd5e1}.order-card-summary{color:#1e293b;margin-bottom:4px;font-size:.83rem;line-height:1.5}.order-card-expand{color:#94a3b8;text-align:right;font-size:.78rem}.order-status-badge{white-space:nowrap;border-radius:12px;padding:2px 10px;font-size:.78rem;font-weight:600;display:inline-block}.order-status-submitted{color:#92400e;background:#fef3c7}.order-status-receiving{color:#c2410c;background:#ffedd5}.order-status-confirmed{color:#1d4ed8;background:#dbeafe}.order-status-returned{color:#dc2626;background:#fee2e2}.order-status-delivered{color:#6d28d9;background:#ede9fe}.order-status-paid{color:#065f46;background:#d1fae5}.order-card-body{border-top:1px solid #f1f5f9;padding:14px 16px}.order-detail-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:8px 16px;margin-bottom:12px;display:grid}.order-detail-cell{flex-direction:column;gap:2px;font-size:.87rem;display:flex}.order-detail-cell.order-detail-full{grid-column:1/-1}.order-detail-label{color:#94a3b8;text-transform:uppercase;letter-spacing:.04em;font-size:.72rem;font-weight:600}.order-actions{border-top:1px solid #f1f5f9;flex-wrap:wrap;align-items:flex-start;gap:8px;margin-top:14px;padding-top:12px;display:flex}.order-btn{cursor:pointer;white-space:nowrap;border:none;border-radius:7px;padding:7px 16px;font-size:.85rem;font-weight:600;transition:opacity .12s,background .12s}.order-btn:disabled{opacity:.5;cursor:not-allowed}.order-btn-confirm{color:#065f46;background:#d1fae5}.order-btn-confirm:hover:not(:disabled){background:#a7f3d0}.order-btn-reject{color:#dc2626;background:#fee2e2}.order-btn-reject:hover:not(:disabled){background:#fecaca}.order-btn-deliver{color:#6d28d9;background:#ede9fe}.order-btn-deliver:hover:not(:disabled){background:#ddd6fe}.order-btn-paid{color:#1e40af;background:#dbeafe}.order-btn-paid:hover:not(:disabled){background:#bfdbfe}.order-btn-amount{color:#854d0e;background:#fef9c3;border:1px solid #fde68a}.order-btn-amount:hover:not(:disabled){background:#fef08a}.order-btn-cancel{color:#475569;background:#f1f5f9}.order-btn-cancel:hover:not(:disabled){background:#e2e8f0}.order-return-block{flex-direction:column;flex:1;gap:6px;min-width:220px;display:flex}.order-return-textarea{resize:vertical;border:1px solid #fca5a5;border-radius:6px;min-height:56px;padding:7px 10px;font-family:inherit;font-size:.85rem}.order-return-textarea:focus{border-color:#0000;outline:2px solid #ef4444}.order-return-btns{gap:8px;display:flex}.order-amount-block{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.order-amount-input{border:1px solid #fde68a;border-radius:6px;width:120px;padding:6px 10px;font-size:.85rem}.order-amount-input:focus{border-color:#0000;outline:2px solid #f59e0b}.order-payment-select{background:#fff;border:1px solid #e2e8f0;border-radius:6px;padding:6px 8px;font-size:.85rem}.order-filter-bar{flex-wrap:wrap;gap:6px;margin-bottom:16px;display:flex}.order-filter-tab{color:#64748b;cursor:pointer;white-space:nowrap;background:#f8fafc;border:1px solid #e2e8f0;border-radius:20px;align-items:center;gap:5px;padding:5px 13px;font-size:.84rem;font-weight:500;transition:background .12s,border-color .12s;display:inline-flex}.order-filter-tab:hover{background:#f1f5f9;border-color:#cbd5e1}.order-filter-count{background:#00000012;border-radius:10px;padding:0 6px;font-size:.75rem;font-weight:700;line-height:1.6}.order-filter-tab--active:not([class*=order-filter-tab--submitted]):not([class*=order-filter-tab--confirmed]):not([class*=order-filter-tab--returned]):not([class*=order-filter-tab--delivered]):not([class*=order-filter-tab--paid]){color:#1d4ed8;background:#dbeafe;border-color:#93c5fd}.order-filter-tab--active:not([class*=order-filter-tab--submitted]):not([class*=order-filter-tab--confirmed]):not([class*=order-filter-tab--returned]):not([class*=order-filter-tab--delivered]):not([class*=order-filter-tab--paid]) .order-filter-count{background:#1d4ed81f}.order-filter-tab--submitted{border-color:#fde68a}.order-filter-tab--submitted:hover{background:#fef9c3}.order-filter-tab--submitted.order-filter-tab--active{color:#854d0e;background:#fef9c3;border-color:#fcd34d}.order-filter-tab--submitted.order-filter-tab--active .order-filter-count{background:#854d0e1f}.order-filter-tab--confirmed{border-color:#93c5fd}.order-filter-tab--confirmed:hover{background:#eff6ff}.order-filter-tab--confirmed.order-filter-tab--active{color:#1d4ed8;background:#dbeafe;border-color:#93c5fd}.order-filter-tab--confirmed.order-filter-tab--active .order-filter-count{background:#1d4ed81f}.order-filter-tab--delivered{border-color:#c4b5fd}.order-filter-tab--delivered:hover{background:#f5f3ff}.order-filter-tab--delivered.order-filter-tab--active{color:#5b21b6;background:#ede9fe;border-color:#c4b5fd}.order-filter-tab--delivered.order-filter-tab--active .order-filter-count{background:#5b21b61f}.order-filter-tab--returned{border-color:#fca5a5}.order-filter-tab--returned:hover{background:#fff1f2}.order-filter-tab--returned.order-filter-tab--active{color:#991b1b;background:#fee2e2;border-color:#fca5a5}.order-filter-tab--returned.order-filter-tab--active .order-filter-count{background:#991b1b1f}.order-filter-tab--paid{border-color:#6ee7b7}.order-filter-tab--paid:hover{background:#f0fdf4}.order-filter-tab--paid.order-filter-tab--active{color:#065f46;background:#d1fae5;border-color:#6ee7b7}.order-filter-tab--paid.order-filter-tab--active .order-filter-count{background:#065f461f}.order-return-reason{color:#dc2626;background:#fff1f2;border:1px solid #fecaca;border-radius:6px;margin-top:4px;padding:5px 10px;font-size:.82rem;line-height:1.5}@media (width<=1024px){.app-main{padding:16px}.receiving-layout{flex-direction:column!important}.receiving-list-col{width:100%!important}.order-filter-row{flex-wrap:wrap}}@media (width<=768px){.app-header{padding:12px 16px}.app-title{font-size:1.3rem}.app-subtitle{font-size:.75rem}.header-content{flex-direction:column;align-items:flex-start;gap:8px}.header-user{flex-wrap:wrap;gap:6px}.app-main{padding:12px}.tab,.tab-active{padding:6px 12px;font-size:.8rem}.kpi-section{grid-template-columns:repeat(2,1fr);gap:10px}.filter-grid{grid-template-columns:1fr}.chart-card{padding:14px}.table-wrapper{-webkit-overflow-scrolling:touch;overflow-x:auto}.data-table{min-width:540px}.data-table th,.data-table td{padding:6px 8px;font-size:.78rem}.receiving-layout{flex-direction:column!important;height:auto!important}.receiving-list-col{max-height:220px;overflow-y:auto;width:100%!important}.purchase-form-grid{grid-template-columns:1fr}.purchase-item-fields{flex-direction:column}.purchase-item-qty{width:100%!important}.radar-search{width:100%}.radar-select{font-size:.82rem}.login-box{width:95vw!important;padding:24px 20px!important}}@media (width<=480px){.kpi-section{grid-template-columns:1fr}.app-title{font-size:1.1rem}.chart-card{padding:10px}}
