@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";:root{--primary:#4f46e5;--primary-hover:#4338ca;--bg-main:#f1f5f9;--sidebar-bg:#111827;--sidebar-border:#1f2937;--text-main:#0f172a;--text-sub:#64748b;--text-muted:#94a3b8;--border:#e2e8f0;--white:#fff;--success:#16a34a;--warning:#d97706;--danger:#dc2626;--ai-primary:#7c3aed;--ai-secondary:#faf5ff;--ai-border:#e9d5ff}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg-main);color:var(--text-main);min-height:100vh;font-family:Inter,Segoe UI,sans-serif;font-size:13px}.btn{cursor:pointer;border:1px solid #0000;border-radius:8px;justify-content:center;align-items:center;gap:8px;padding:8px 16px;font-family:inherit;font-size:12px;font-weight:600;transition:all .2s;display:inline-flex}.btn-primary{background:var(--primary);color:var(--white)}.btn-primary:hover{background:var(--primary-hover)}.btn-outline{background:var(--white);color:#374151;border-color:var(--border)}.btn-outline:hover{background:#f8fafc}.btn-danger{color:var(--danger);background:#fef2f2;border-color:#fecaca}.btn-danger:hover{background:#fee2e2}.card{background:var(--white);border:1px solid var(--border);border-radius:12px;overflow:hidden;box-shadow:0 1px 3px #0000000d}table{border-collapse:collapse;width:100%}th{text-align:left;color:var(--text-sub);letter-spacing:.06em;text-transform:uppercase;border-bottom:1px solid var(--border);background:#f8fafc;padding:10px 12px;font-size:10px;font-weight:700}td{vertical-align:middle;border-bottom:1px solid #f8fafc;padding:12px;font-size:12px}tr:hover td{background:#fafafa}.chip{border-radius:10px;padding:3px 8px;font-size:10px;font-weight:700;display:inline-flex}.c-match,.c-clear,.c-success{color:var(--success);background:#dcfce7}.c-warn,.c-warning{color:var(--warning);background:#fffbeb}.c-block,.c-danger{color:var(--danger);background:#fef2f2}.c-ai{background:var(--ai-secondary);color:var(--ai-primary);border:1px solid var(--ai-border)}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.ai-panel{background:linear-gradient(135deg,#f0f9ff 0%,#faf5ff 100%);border:1px solid #bfdbfe;border-radius:12px;padding:16px 18px}.sidebar{background:var(--sidebar-bg);z-index:50;flex-direction:column;flex-shrink:0;width:240px;min-height:100vh;display:flex;position:sticky;top:0}.sidebar-brand{border-bottom:1px solid var(--sidebar-border);align-items:center;gap:12px;padding:24px 20px 20px;display:flex}.brand-icon{background:var(--primary);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.brand-name{color:#f9fafb;font-size:15px;font-weight:700}.brand-sub{color:var(--text-muted);margin-top:2px;font-size:11px}.sidebar-nav{flex:1;padding:20px 12px;overflow-y:auto}.nav-group{margin-bottom:16px}.nav-group-title{text-transform:uppercase;letter-spacing:.05em;color:#6b7280;margin-bottom:8px;padding:0 14px;font-size:10px;font-weight:700}.nav-item{color:#9ca3af;border-radius:8px;align-items:center;gap:12px;margin-bottom:2px;padding:10px 14px;font-size:13px;font-weight:500;text-decoration:none;transition:all .2s;display:flex}.nav-item:hover{color:#f9fafb;background:#ffffff0d}.nav-item.active{background:var(--primary);color:#fff}.nav-icon{text-align:center;justify-content:center;align-items:center;width:20px;display:flex}.sidebar-user{border-top:1px solid var(--sidebar-border);align-items:center;gap:12px;padding:16px 20px;display:flex}.user-avatar{background:var(--primary);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;font-size:11px;font-weight:700;display:flex}.user-name{color:#f9fafb;font-size:13px;font-weight:600}.user-role{color:var(--text-muted);font-size:11px}.topbar{background:var(--white);border-bottom:1px solid var(--border);z-index:40;flex-shrink:0;justify-content:space-between;align-items:center;height:64px;padding:0 24px;display:flex;position:sticky;top:0}.page-title{color:var(--text-main);font-size:18px;font-weight:700}.page-sub{color:var(--text-sub);margin-top:2px;font-size:12px}.topbar-right{align-items:center;gap:16px;display:flex}.pipeline-status-indicator{color:#166534;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:20px;align-items:center;gap:8px;padding:6px 12px;font-size:11px;font-weight:700;display:flex}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.reviewer-name{color:var(--text-sub);border:1px solid var(--border);background:#f8fafc;border-radius:8px;padding:6px 12px;font-size:11px;font-weight:500}.app-container{width:100%;min-height:100vh;display:flex}.main-content{flex-direction:column;flex:1;min-width:0;display:flex;overflow:hidden}.page-wrapper{flex:1;min-height:0;padding:24px;animation:.4s ease-out fadeIn;overflow-y:auto}.fade-in{animation:.5s ease-out fadeIn}.info-banner{background:#eff6ff;border:1px solid #bfdbfe;border-radius:12px;align-items:flex-start;gap:12px;margin-bottom:24px;padding:14px 18px;display:flex}.info-icon{color:#1e40af;flex-shrink:0;margin-top:2px}.info-text{color:#1e40af;font-size:13px;line-height:1.6}.summary-row{grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px;display:grid}.sum-box{background:var(--white);border:1px solid var(--border);border-radius:12px;padding:16px 18px;box-shadow:0 1px 2px #0000000d}.sum-val{color:var(--text-main);font-size:26px;font-weight:700}.sum-lbl{color:var(--text-sub);margin-top:4px;font-size:12px}.search-bar{align-items:center;gap:12px;margin-bottom:16px;display:flex}.search-container{flex:1;align-items:center;display:flex;position:relative}.search-icon{color:var(--text-muted);position:absolute;left:12px}.search-input{background:var(--white);border:1px solid var(--border);width:100%;color:var(--text-main);border-radius:8px;outline:none;padding:10px 12px 10px 38px;font-family:inherit;font-size:14px;transition:border-color .2s}.search-input:focus{border-color:var(--primary)}.filter-chip{background:var(--white);border:1px solid var(--border);color:#374151;cursor:pointer;border-radius:8px;padding:8px 14px;font-size:12px;font-weight:600;transition:all .2s}.filter-chip.active{color:var(--primary);background:#ede9fe;border-color:#c4b5fd}.loc-name{color:var(--text-main);font-weight:600}.check{border-radius:6px;justify-content:center;align-items:center;width:22px;height:22px;display:inline-flex}.chk-yes{color:#16a34a;background:#dcfce7;font-size:12px;font-weight:700}.chk-no{color:#cbd5e1;background:#f1f5f9;font-size:11px}.freq-chip{border-radius:12px;padding:4px 10px;font-size:11px;font-weight:600}.f-bw{color:#1d4ed8;background:#eff6ff}.f-wk{color:#7c3aed;background:#fdf4ff}.f-both{color:#b45309;background:#fef3c7}.offset-val{color:var(--text-sub);font-family:Courier New,monospace;font-size:12px;font-weight:600}.action-btn{border:1px solid var(--border);background:var(--white);color:#374151;cursor:pointer;border-radius:8px;padding:5px 12px;font-size:11px;font-weight:600;transition:all .2s}.action-btn:hover{border-color:var(--text-muted);background:#f8fafc}.dashboard-content{flex-direction:column;gap:20px;display:flex}.kpi-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.kpi-icon{border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;display:flex}.kpi-delta{border-radius:4px;padding:2px 6px;font-size:10px;font-weight:700}.delta-up{color:#16a34a;background:#dcfce7}.delta-down{color:#dc2626;background:#fef2f2}.delta-neu{color:#64748b;background:#f1f5f9}.grid-3-1{grid-template-columns:2fr 1fr;gap:20px;display:grid}.grid-1-1{grid-template-columns:1fr 1fr;gap:20px;display:grid}.dashboard-side-col{flex-direction:column;gap:20px;display:flex}.pipeline-steps{flex-direction:column;gap:12px;display:flex}.pipe-step{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;align-items:center;gap:12px;padding:12px 16px;display:flex}.pipe-step.active{background:#eff6ff;border-color:#3b82f6;box-shadow:inset 0 0 0 1px #3b82f6}.pipe-marker{color:#64748b;background:#fff;border:1px solid #e2e8f0;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;font-size:11px;font-weight:700;display:flex}.pipe-step.done .pipe-marker{color:#16a34a;background:#dcfce7;border-color:#16a34a}.pipe-step.active .pipe-marker{color:#fff;background:#3b82f6;border-color:#3b82f6}.pipe-info{flex:1}.pipe-name{color:#0f172a;font-size:12px;font-weight:600}.pipe-sub{color:#64748b;font-size:10px}.pipe-status-chip{border-radius:20px;padding:2px 8px;font-size:9px;font-weight:700}.pipe-status-chip.done{color:#16a34a;background:#dcfce7}.pipe-status-chip.active{color:#1e40af;background:#dbeafe}.pipe-status-chip.wait{color:#94a3b8;background:#f1f5f9}.status-grid{grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:20px;display:grid}.stat-box{text-align:center;background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;padding:12px 8px}.stat-val{font-size:20px;font-weight:700}.stat-lbl{color:#64748b;margin-top:2px;font-size:10px}.stat-box.match .stat-val{color:#16a34a}.stat-box.warn .stat-val{color:#d97706}.stat-box.block .stat-val{color:#dc2626}.progress-labels{color:#64748b;justify-content:space-between;margin-bottom:6px;font-size:11px;display:flex}.progress-labels .rate{color:#16a34a;font-weight:700}.progress-container{background:#f1f5f9;border-radius:4px;height:8px;overflow:hidden}.progress-fill{background:#16a34a;border-radius:4px;height:100%}.alert-list{flex-direction:column;gap:10px;display:flex}.alert-item{border:1px solid #0000;border-radius:10px;gap:12px;padding:10px 14px;display:flex}.alert-item.red{background:#fef2f2;border-color:#fecaca}.alert-item.yellow{background:#fffbeb;border-color:#fde68a}.alert-item.blue{background:#eff6ff;border-color:#bfdbfe}.alert-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px;margin-top:4px}.red .alert-dot{background:#ef4444}.yellow .alert-dot{background:#f59e0b}.blue .alert-dot{background:#3b82f6}.alert-title{color:#111827;font-size:11px;font-weight:700}.alert-detail{color:#374151;margin-top:2px;font-size:10px}.alert-time{color:#94a3b8;margin-top:4px;font-size:9px}.source-table{border-collapse:collapse;width:100%}.source-table th{text-align:left;color:#64748b;text-transform:uppercase;background:#f8fafc;padding:10px 16px;font-size:10px;font-weight:700}.source-table td{border-bottom:1px solid #f1f5f9;padding:12px 16px;font-size:12px}.mini-progress{background:#f1f5f9;border-radius:3px;width:60px;height:6px}.mini-fill{border-radius:3px;height:100%}.status-badge{border-radius:20px;padding:2px 8px;font-size:10px;font-weight:700}.chart-area{align-items:flex-end;gap:8px;height:100px;margin-bottom:16px;display:flex}.chart-bar-wrapper{flex-direction:column;flex:1;align-items:center;gap:6px;display:flex}.chart-bar{background:#c7d2fe;border-radius:4px 4px 0 0;width:100%;transition:all .3s}.chart-bar.active{background:#4f46e5}.chart-label{color:#94a3b8;font-size:10px}.active+.chart-label{color:#4f46e5;font-weight:700}.trend-stats{grid-template-columns:1fr 1fr;gap:12px;display:grid}.trend-stat-box{background:#f8fafc;border-radius:12px;padding:12px 16px}.ts-val{color:#0f172a;font-size:18px;font-weight:700}.ts-val.green{color:#16a34a}.ts-lbl{color:#64748b;margin-top:2px;font-size:10px}.f-chk{color:#16a34a;font-weight:700}.status-pill{border-radius:12px;padding:4px 10px;font-size:11px;font-weight:600}.s-c{color:#166534;background:#f0fdf4;border:1px solid #bbf7d0}.s-r{color:#92400e;background:#fffbeb;border:1px solid #fef3c7}.btn-view{color:#64748b;background:#f8fafc;border:1px solid #e2e8f0;padding:4px 12px;font-size:11px}.btn-view:hover{background:#f1f5f9;border-color:#cbd5e1}.discovery-banner{background:#eff6ff;border:1px solid #bfdbfe;border-radius:12px;align-items:center;gap:16px;margin-bottom:24px;padding:16px;display:flex}.db-icon{color:#3b82f6;flex-shrink:0}.db-text{color:#1e40af;font-size:13px;line-height:1.5}.discovery-banner.polling-active{background:#f0f9ff;border-color:#0ea5e9;position:relative}.polling-pulse{background:#0ea5e9;border-radius:50%;width:8px;height:8px;animation:2s infinite ripple;position:absolute;top:10px;right:10px}@keyframes ripple{0%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(3)}}.row-arrival{animation:.5s ease-out forwards slideInRight}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.count-animate{animation:.3s ease-out countUp;display:inline-block}@keyframes countUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.polling-placeholder{background:#f8fafc;font-style:italic}.processing-container{background:0 0;justify-content:center;align-items:center;min-height:400px;display:flex}.processing-card{background:#fff;border:1px solid #e2e8f0;border-radius:16px;width:100%;max-width:600px;padding:32px;position:relative;overflow:hidden;box-shadow:0 10px 25px -5px #0000001a,0 8px 10px -6px #0000001a}.scanner-line{opacity:.5;z-index:10;background:linear-gradient(90deg,#0000,#3b82f6,#0000);width:100%;height:2px;animation:3s linear infinite scan;position:absolute;top:0;left:0}@keyframes scan{0%{top:0}to{top:100%}}.p-header{align-items:center;gap:20px;margin-bottom:24px;display:flex}.p-icon{color:#3b82f6;background:#f1f5f9;border-radius:12px;justify-content:center;align-items:center;width:64px;height:64px;display:flex}.p-title{color:#0f172a;font-size:18px;font-weight:700}.p-subtitle{color:#64748b;margin-top:4px;font-size:13px}.p-status-grid{grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:24px;display:grid}.p-status-item{background:#f8fafc;border:1px solid #f1f5f9;border-radius:8px;flex-direction:column;gap:4px;padding:12px;display:flex}.p-lbl{text-transform:uppercase;color:#94a3b8;letter-spacing:.05em;font-size:11px;font-weight:600}.p-val{align-items:center;gap:6px;font-size:13px;font-weight:600;display:flex}.p-progress-wrapper{margin-bottom:24px}.p-progress-bar{background:#f1f5f9;border-radius:4px;height:8px;margin-bottom:8px;overflow:hidden}.p-progress-fill{background:#3b82f6;border-radius:4px;height:100%;transition:width .1s linear}.p-progress-labels{color:#64748b;justify-content:space-between;font-size:12px;font-weight:600;display:flex}.p-pulse-log{color:#10b981;background:#0f172a;border-radius:8px;min-height:100px;padding:16px;font-family:JetBrains Mono,Courier New,monospace;font-size:11px}.log-line{opacity:.8;margin-bottom:4px;animation:.3s ease-out typeIn}@keyframes typeIn{0%{opacity:0;transform:translate(-4px)}to{opacity:.8;transform:translate(0)}}.glow{color:#34d399;text-shadow:0 0 10px #34d39980;font-weight:700}.pulse{animation:2s ease-in-out infinite pulse}@keyframes pulse{0%{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(1.05)}to{opacity:1;transform:scale(1)}}.modal-overlay{z-index:1000;background:#0006;justify-content:center;align-items:center;padding:40px;display:flex;position:fixed;inset:0}.modal-content{background:var(--white);border-radius:16px;flex-direction:column;width:100%;max-width:900px;max-height:85vh;display:flex;overflow:hidden;box-shadow:0 10px 25px -5px #0000001a,0 8px 10px -6px #0000001a}.modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.modal-title-group{align-items:center;gap:12px;display:flex}.modal-icon{background:var(--ai-secondary);width:36px;height:36px;color:var(--ai-primary);border-radius:8px;justify-content:center;align-items:center;display:flex}.modal-title{color:var(--text-main);font-size:16px;font-weight:700}.modal-sub{color:var(--text-sub);font-size:12px}.close-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:6px;padding:4px;transition:all .2s}.close-btn:hover{color:var(--text-main);background:#f1f5f9}.modal-body{background:#fcfcfc;flex:1;padding:24px;overflow-y:auto}.table-preview-wrapper{border:1px solid var(--border);border-radius:12px;overflow:hidden}.preview-table{border-collapse:collapse;width:100%;font-size:11px}.preview-table th{text-align:left;border-bottom:1px solid var(--border);background:#f8fafc;padding:10px 12px}.preview-table td{border-bottom:1px solid #f8fafc;padding:8px 12px;font-family:Courier New,monospace}.preview-footer-note{color:var(--text-muted);text-align:center;background:#f8fafc;padding:10px 12px;font-size:11px}.code-preview{color:#f8fafc;white-space:pre-wrap;word-break:break-all;background:#1e293b;border-radius:12px;padding:16px;font-family:Courier New,monospace;font-size:12px;line-height:1.5}.modal-footer{border-top:1px solid var(--border);background:#f8fafc;justify-content:space-between;align-items:center;padding:16px 24px;display:flex}.footer-info{gap:8px;display:flex}.info-tag{color:#475569;text-transform:uppercase;background:#e2e8f0;border-radius:6px;padding:4px 8px;font-size:10px;font-weight:700}.footer-actions{gap:12px;display:flex}.kpi-row{grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px;display:grid}.kpi{background:var(--white);border:1px solid var(--border);border-radius:12px;padding:20px;box-shadow:0 1px 2px #0000000d}.kpi-val{margin-bottom:4px;font-size:32px;font-weight:700}.kpi-lbl{color:var(--text-sub);font-size:13px;font-weight:600}.kpi-sub{color:var(--text-muted);margin-top:4px;font-size:11px}.ai-header{align-items:center;gap:12px;margin-bottom:12px;display:flex}.ai-icon{color:#fff;background:linear-gradient(135deg,#4f46e5,#7c3aed);border-radius:10px;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.ai-title{color:var(--text-main);font-size:14px;font-weight:700}.ai-sub{color:var(--text-sub);font-size:11px}.ai-body{color:#374151;font-size:13px;line-height:1.7}.hl-g{color:#16a34a;font-weight:600}.hl-y{color:#d97706;font-weight:600}.hl-r{color:#dc2626;font-weight:600}.main-grid{grid-template-columns:1fr 340px;gap:20px;margin-top:24px;margin-bottom:80px;display:grid}.row-block{background:#fff8f8}.loc{color:var(--text-main);font-weight:700}.lid{color:var(--text-muted);font-size:10px}.delta{font-family:Courier New,monospace;font-size:12px;font-weight:700}.d-ok{color:#16a34a}.d-w{color:#d97706}.d-b{color:#dc2626}.act-link{color:var(--primary);cursor:pointer;background:0 0;border:none;padding:0;font-size:12px;font-weight:600;text-decoration:underline}.side-col{flex-direction:column;gap:20px;display:flex}.completeness-grid{grid-template-columns:1fr 1fr;gap:12px;padding:16px;display:grid}.sys-stat{background:#f8fafc;border:1px solid #f1f5f9;border-radius:10px;padding:12px}.sys-name{color:var(--text-sub);font-size:11px;font-weight:600}.sys-count{margin-top:4px;font-size:14px;font-weight:700}.sys-sub{color:var(--text-muted);margin-top:2px;font-size:10px}.event-box{background:#faf5ff;border:1px solid #e9d5ff;border-radius:10px;padding:12px}.event-title{color:#6d28d9;font-size:12px;font-weight:700}.event-sub{color:#7c3aed;margin-top:4px;font-size:11px;line-height:1.4}.bottom-bar{background:var(--white);border-top:1px solid var(--border);z-index:60;justify-content:space-between;align-items:center;padding:16px 24px;display:flex;position:fixed;bottom:0;left:240px;right:0;box-shadow:0 -2px 10px #0000000d}.bb-info{color:var(--text-sub);max-width:500px;font-size:12px}.bb-actions{gap:12px;display:flex}.status-header{margin-bottom:24px}.active-batch-info{color:#1d4ed8;background:#eff6ff;border:1px solid #bfdbfe;border-radius:10px;align-items:center;gap:12px;padding:10px 18px;font-size:13px;font-weight:700;display:flex}.spinner{animation:1s linear infinite spin}.batches-list{flex-direction:column;gap:12px;padding:16px;display:flex}.load-batch{background:#f8fafc;border-left:4px solid #0000;border-radius:10px;padding:16px;transition:all .2s}.lb-done{border-color:var(--success);background:#f0fdf4}.lb-active{border-color:var(--primary);background:#eff6ff}.lb-wait{border-color:var(--border);background:#f8fafc}.batch-header{align-items:flex-start;gap:12px;margin-bottom:12px;display:flex}.batch-num{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;font-size:11px;font-weight:700;display:flex}.bn-done{color:var(--success);background:#dcfce7}.bn-active{background:var(--primary);color:#fff}.bn-wait{color:var(--text-muted);background:#f1f5f9}.batch-title{color:var(--text-main);font-size:14px;font-weight:700}.batch-sub{color:var(--text-sub);margin-top:4px;font-size:12px}.files-row{flex-wrap:wrap;gap:8px;margin-top:8px;display:flex}.file-tag{border-radius:6px;padding:4px 10px;font-size:11px;font-weight:600}.ft-done{color:var(--success);background:#dcfce7}.ft-active{color:var(--primary);background:#ede9fe}.ft-wait{color:var(--text-muted);background:#f1f5f9}.balance-note{color:var(--text-sub);align-items:center;gap:8px;margin-top:12px;font-size:12px;display:flex}.bn-ok{color:var(--success)}.bn-w{color:var(--warning)}.bn-dot{background:var(--text-muted);border-radius:50%;width:4px;height:4px}.progress-section{border-top:1px solid #f1f5f9;padding:20px 16px}.card-subtitle{color:var(--text-main);margin-bottom:12px;font-size:13px;font-weight:700}.progress-track{grid-template-columns:repeat(2,1fr);gap:8px;display:grid}.pt-item{border:1px solid var(--border);background:#fff;border-radius:8px;justify-content:space-between;align-items:center;gap:12px;padding:10px 12px;font-size:12px;display:flex}.pt-loc{color:var(--text-main);font-weight:600}.pt-status{border-radius:12px;padding:3px 8px;font-size:10px;font-weight:700}.pts-done{color:var(--success);background:#dcfce7}.pts-active{color:var(--primary);background:#ede9fe}.pts-wait{color:var(--text-muted);background:#f1f5f9}.rule-list{flex-direction:column;gap:12px;padding:12px;display:flex}.rule-item{color:#374151;gap:12px;font-size:12px;line-height:1.5;display:flex}.rule-num{width:20px;height:20px;color:var(--primary);background:#ede9fe;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:10px;font-weight:700;display:flex}.alert-card{border-left:4px solid var(--danger);background:#fff8f8}.alert-content{color:#374151;font-size:12px;line-height:1.6}.tab{color:var(--text-sub);cursor:pointer;padding:12px 4px;font-size:14px;font-weight:600;transition:all .2s;position:relative}.tab.active{color:var(--primary)}.tab.active:after{content:"";background:var(--primary);height:2px;position:absolute;bottom:-1px;left:0;right:0}.exc-list{flex-direction:column;gap:16px;margin-top:16px;display:flex}.exc{background:var(--white);border:1px solid var(--border);border-radius:12px;padding:20px;transition:all .2s}.exc.is-block{border-left:4px solid var(--danger)}.exc.is-warn{border-left:4px solid var(--warning)}.exc.is-auto{border-left:4px solid var(--success)}.exc-top{align-items:center;gap:12px;margin-bottom:8px;display:flex}.sev-badge{text-transform:uppercase;border-radius:6px;padding:4px 8px;font-size:10px;font-weight:700}.sev-block{color:var(--danger);background:#fef2f2;border:1px solid #fecaca}.sev-warn{color:var(--warning);background:#fffbeb;border:1px solid #fde68a}.sev-auto{color:var(--success);background:#f0fdf4;border:1px solid #bbf7d0}.exc-title{color:var(--text-main);font-size:15px;font-weight:700}.exc-loc{color:var(--primary)}.exc-detail{color:#374151;margin-bottom:12px;font-size:13px;line-height:1.6}.ai-box{background:#faf5ff;border:1px solid #e9d5ff;border-radius:10px;margin-bottom:16px;padding:12px 14px}.ai-label{color:#7c3aed;margin-bottom:4px;font-size:11px;font-weight:700}.ai-text{color:#374151;font-size:12px;line-height:1.6}.exc-actions{gap:12px;display:flex}.btn-sm{cursor:pointer;border:1px solid #0000;border-radius:8px;align-items:center;gap:6px;padding:6px 12px;font-size:12px;font-weight:600;transition:all .2s;display:inline-flex}.btn-resolve{color:#16a34a;background:#dcfce7}.btn-view{color:#1d4ed8;background:#eff6ff}.btn-override{color:#d97706;background:#fffbeb;border-color:#fde68a}.pass-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.pass-title-group{align-items:center;gap:12px;display:flex}.pass-title{color:var(--text-main);font-size:16px;font-weight:700}.pass-badge{border-radius:12px;padding:4px 12px;font-size:11px;font-weight:700}.pass1-badge{color:#1d4ed8;background:#eff6ff}.pass2-badge{color:#7c3aed;background:#faf5ff}.savings-banner{background:linear-gradient(135deg,#f0fdf4,#dcfce7);border:1px solid #bbf7d0;border-radius:12px;align-items:center;gap:16px;margin-bottom:24px;padding:16px 20px;display:flex}.sv-icon{color:#166534;flex-shrink:0}.sv-text{color:#166534;font-size:13px;line-height:1.6}.sv-text strong{font-size:15px;font-weight:700}.flag-chip{color:#7c3aed;white-space:nowrap;background:#faf5ff;border:1px solid #e9d5ff;border-radius:6px;padding:4px 8px;font-size:10px;font-weight:700}.val-big{font-family:Courier New,monospace;font-size:13px;font-weight:700}.v-r{color:var(--danger)}.v-y{color:var(--warning)}.ai-diag{color:#374151;max-width:450px;font-size:12px;line-height:1.6}.ai-mark{color:#7c3aed;font-weight:700}.row-hold{background:snow}.action-approve{color:#16a34a;background:#dcfce7}.action-hold{color:#dc2626;background:#fef2f2}.action-approve:hover{background:#bbf7d0}.action-hold:hover{background:#fecaca}.emp-name{color:var(--text-main);font-weight:700}.loc-id{color:var(--text-muted);margin-top:2px;font-size:10px}.tl-items-list{flex-direction:column;gap:12px;padding-left:48px;display:flex;position:relative}.tl-item{gap:16px;display:flex;position:relative}.tl-indicator{flex-direction:column;align-items:center;width:30px;display:flex;position:absolute;top:0;bottom:-12px;left:-48px}.tl-dot{z-index:2;border:2px solid var(--border);background:#fff;border-radius:50%;justify-content:center;align-items:center;width:30px;height:30px;display:flex;box-shadow:0 2px 4px #0000000d}.tl-line{background:var(--border);z-index:1;flex:1;width:2px}.tl-item:last-child .tl-line{display:none}.td-approve{border-color:var(--success);color:var(--success);background:#f0fdf4}.td-warn{border-color:var(--warning);color:var(--warning);background:#fffbeb}.td-ai{border-color:var(--ai-primary);color:var(--ai-primary);background:var(--ai-secondary)}.td-flag{border-color:var(--danger);color:var(--danger);background:#fff8f8}.td-info{color:#3b82f6;background:#eff6ff;border-color:#3b82f6}.tl-body{flex:1;padding:16px 20px}.tl-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.tl-action{color:var(--text-main);font-size:14px;font-weight:700}.tl-time{color:var(--text-muted);font-family:Courier New,monospace;font-size:11px}.tl-detail{color:#374151;font-size:13px;line-height:1.6}.tl-footer{border-top:1px solid #f8fafc;justify-content:space-between;align-items:center;margin-top:14px;padding-top:12px;display:flex}.tl-user{color:var(--text-sub);align-items:center;gap:8px;font-size:12px;display:flex}.usr-avatar{color:#475569;background:#e2e8f0;border-radius:50%;justify-content:center;align-items:center;width:22px;height:22px;font-size:9px;font-weight:700;display:flex}.tl-tags{gap:6px;display:flex}.tag{border-radius:6px;padding:3px 8px;font-size:10px;font-weight:700}.tag-stage{color:#1d4ed8;background:#eff6ff}.tag-loc{color:#16a34a;background:#f0fdf4}.tag-system{color:#7c3aed;background:#faf5ff}.filter-row{align-items:center;gap:12px;margin-bottom:24px;display:flex}.alert-banner-ca{color:#d97706;background:#fffbeb;border:1px solid #fde68a;border-radius:12px;align-items:center;gap:12px;margin-bottom:24px;padding:12px 18px;font-size:13px;font-weight:700;display:flex}.row-ca{background:snow}.emp-flex{align-items:flex-end;gap:8px;display:flex}.eid{color:var(--text-muted);padding-bottom:2px;font-size:10px}.loc-small{color:var(--text-sub);font-size:11px;line-height:1.4}.state-ca{color:var(--danger);font-weight:700}.state-std{color:var(--text-sub)}.font-mono{font-family:Courier New,monospace;font-size:12px}.btn-action{cursor:pointer;border:none;border-radius:8px;padding:4px 10px;font-size:10px;font-weight:700;transition:all .2s}.action-ca{color:var(--danger);background:#fef2f2;border:1px solid #fecaca}.action-std{color:var(--success);background:#dcfce7}.compliance-grid{grid-template-columns:1fr 1fr;gap:20px;margin-top:24px;display:grid}.compliance-body{color:#374151;padding:0 20px 20px;font-size:13px;line-height:1.6}.compliance-alert{color:#374151;background:#fef2f2;border:1px solid #fecaca;border-radius:10px;margin-bottom:12px;padding:12px}.compliance-alert-union{color:#374151;background:#faf5ff;border:1px solid #e9d5ff;border-radius:10px;margin-bottom:12px;padding:12px}.compliance-body ul{flex-direction:column;gap:6px;padding-left:20px;display:flex}.completion-banner{color:#fff;background:linear-gradient(135deg,#1e3a5f,#2d1b69);border-radius:12px;justify-content:space-between;align-items:center;margin-bottom:24px;padding:24px;display:flex;box-shadow:0 4px 12px #0000001a}.cb-left{align-items:center;gap:20px;display:flex}.cb-icon{color:#4ade80;justify-content:center;align-items:center;display:flex}.cb-title{color:#fff;font-size:18px;font-weight:700}.cb-sub{color:#a5b4fc;margin-top:4px;font-size:13px}.cb-right{text-align:right}.cb-time{color:#fff;font-size:24px;font-weight:700}.cb-tl{color:#a5b4fc;margin-top:4px;font-size:11px}.narrative-box{background:linear-gradient(135deg,#f0fdf4,#eff6ff);border:1px solid #bbf7d0;margin-bottom:24px;padding:24px}.narr-icon{color:#fff;background:linear-gradient(135deg,#4f46e5,#16a34a);border-radius:10px;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.narr-title{color:#0f172a;font-size:14px;font-weight:700}.narr-sub{color:#64748b;margin-top:2px;font-size:11px}.narr-body{color:#1e3a2f;font-size:13px;line-height:1.8}.narr-body strong{color:#0f172a}.narr-body .hl{color:#4f46e5;font-weight:700}.reports-grid{grid-template-columns:repeat(2,1fr);gap:12px;display:grid}.report-item{background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;align-items:center;gap:12px;padding:12px 14px;transition:all .2s;display:flex}.report-item:hover{background:#fff;border-color:#cbd5e1;box-shadow:0 2px 4px #0000000d}.ri-icon-box{color:#64748b;background:#fff;border:1px solid #e2e8f0;border-radius:8px;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.ri-info{flex:1}.ri-name{color:#0f172a;font-size:12px;font-weight:600}.ri-sub{color:#64748b;font-size:10px}.ri-status{margin-top:4px;font-size:10px;font-weight:700}.rs-done{color:#16a34a}.rs-arch{color:#4f46e5}.btn-icon{color:#94a3b8;cursor:pointer;background:0 0;border:none;border-radius:6px;padding:8px}.btn-icon:hover{color:#4f46e5;background:#f1f5f9}.tabs-container{border-bottom:1px solid #e2e8f0;margin-bottom:20px}.tabs{gap:8px;display:flex}.tab{color:#64748b;cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;align-items:center;gap:6px;padding:10px 16px;font-size:13px;font-weight:600;transition:all .2s;display:flex}.tab:hover{color:#4f46e5}.tab.active{color:#4f46e5;border-bottom-color:#4f46e5}.settings-content{max-width:800px}.form-grid{grid-template-columns:1fr 1fr;gap:20px;margin-bottom:24px;display:grid}.form-group{flex-direction:column;gap:6px;display:flex}.form-group label{color:#0f172a;font-size:12px;font-weight:700}.form-group select,.form-group input[type=text],.form-group input[type=number],.form-group input[type=time]{border:1px solid #e2e8f0;border-radius:8px;outline:none;padding:8px 12px;font-family:inherit;font-size:13px}.form-group select:focus,.form-group input:focus{border-color:#4f46e5;box-shadow:0 0 0 2px #4f46e51a}.form-group small{color:#94a3b8;font-size:10px}.input-with-unit{align-items:center;gap:8px;display:flex}.input-with-unit input{flex:1}.input-with-unit span{color:#64748b;font-size:11px;font-weight:600}.ai-notice{color:#1e40af;background:#eff6ff;border:1px solid #bfdbfe;border-radius:8px;align-items:center;gap:10px;margin-bottom:20px;padding:12px;font-size:11px;display:flex}.form-actions{border-top:1px solid #f1f5f9;justify-content:flex-end;padding-top:16px;display:flex}.profile-row{align-items:center;gap:16px;display:flex}.avatar-large{color:#fff;background:linear-gradient(135deg,#4f46e5,#7c3aed);border-radius:50%;justify-content:center;align-items:center;width:64px;height:64px;font-size:24px;font-weight:700;display:flex}.p-name{color:#0f172a;font-size:18px;font-weight:700}.p-role{color:#64748b;margin-top:2px;font-size:12px}.p-status{margin-top:6px}
