*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--blue: #0052FE;--blue-light: #e8f0ff;--blue-mid: rgba(0,82,254,.1);--green: #00D17F;--green-light: #e6faf3;--green-mid: rgba(0,209,127,.1);--orange: #FF7800;--orange-light: #fff3e8;--orange-mid: rgba(255,120,0,.1);--red: #e53e3e;--sidebar-bg: #f8f9fa;--sidebar-border: #e9ecef;--bg: #ffffff;--bg2: #f8f9fa;--border: #e9ecef;--border2: #dee2e6;--text: #0a0b0d;--text2: #6c757d;--text3: #adb5bd;--radius: 8px}body{background:var(--bg);color:var(--text);font-family:Inter,sans-serif;font-size:14px;line-height:1.5}.app{display:flex;min-height:100vh}.sidebar{width:240px;min-width:240px;background:var(--sidebar-bg);border-right:1px solid var(--sidebar-border);display:flex;flex-direction:column;position:fixed;top:0;left:0;height:100vh;overflow-y:auto;z-index:10}.main{margin-left:240px;flex:1;min-height:100vh}.sidebar-top{padding:24px 20px 16px;border-bottom:1px solid var(--border)}.sidebar-title{font-size:17px;font-weight:600;color:var(--text);letter-spacing:-.01em}.sidebar-sub{font-size:12px;color:var(--text2);margin-top:2px}.live-badge{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:600;color:var(--green);margin-top:12px}@keyframes pulse{0%,to{opacity:1}50%{opacity:.3}}.sidebar-section{padding:16px 20px;border-bottom:1px solid var(--border)}.sidebar-section-title{font-size:11px;font-weight:600;letter-spacing:.07em;text-transform:uppercase;color:var(--text3);margin-bottom:12px}.last-updated{font-size:11px;color:var(--text2);line-height:1.6}.nav{padding:8px 0;flex:1}.nav-item{display:flex;align-items:center;gap:8px;padding:8px 20px;cursor:pointer;font-size:13px;font-weight:500;color:var(--text2);border-left:3px solid transparent;transition:all .12s}.nav-item:hover{color:var(--text);background:#00000008}.nav-item.active{color:var(--blue);border-left-color:var(--blue);background:var(--blue-mid)}.filter-group{margin-bottom:12px}.filter-label{font-size:11px;font-weight:500;color:var(--text2);margin-bottom:4px;display:block}.filter-input{width:100%;padding:6px 10px;border:1px solid var(--border2);border-radius:6px;font-size:12px;font-family:inherit;color:var(--text);background:#fff;outline:none;transition:border-color .12s}.filter-input:focus{border-color:var(--blue)}.filter-input::placeholder{color:var(--text3)}select.filter-input{cursor:pointer}.sidebar-footer{padding:16px 20px;border-top:1px solid var(--border);margin-top:auto}.role-pill{display:inline-flex;align-items:center;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;margin-bottom:10px}.role-pill.admin{background:var(--blue-light);color:var(--blue)}.role-pill.viewer{background:var(--green-light);color:var(--green)}.logout-btn{width:100%;padding:7px;background:#fff;border:1px solid var(--border2);border-radius:6px;color:var(--text2);font-size:12px;cursor:pointer;font-family:inherit;transition:all .12s}.logout-btn:hover{background:var(--bg2);color:var(--text)}.page-header{padding:24px 32px 0}.page-title{font-size:22px;font-weight:600;letter-spacing:-.02em}.tabs{display:flex;gap:0;border-bottom:2px solid var(--border);padding:0 32px;margin-top:20px}.tab{padding:10px 18px;cursor:pointer;font-size:13px;font-weight:700;color:var(--text2);border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .12s}.tab:hover{color:var(--text)}.tab.active{color:var(--blue);border-bottom-color:var(--blue)}.content{padding:24px 32px}.metric-row{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}.metric-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:16px 20px}.metric-label{font-size:12px;color:var(--text2);font-weight:500;margin-bottom:6px}.metric-value{font-size:28px;font-weight:600;letter-spacing:-.02em;line-height:1}.metric-delta{font-size:12px;margin-top:4px;font-weight:500;display:inline-flex;align-items:center;gap:3px}.metric-delta.positive{color:var(--green)}.metric-delta.negative{color:var(--red)}.charts-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:24px}.chart-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:20px}.chart-title{font-size:13px;font-weight:600;color:var(--text);margin-bottom:16px}.table-tabs{display:flex;gap:0;border-bottom:1px solid var(--border);margin-bottom:0}.table-tab{padding:8px 16px;cursor:pointer;font-size:12px;font-weight:600;color:var(--text2);border-bottom:2px solid transparent;margin-bottom:-1px;transition:all .12s}.table-tab:hover{color:var(--text)}.table-tab.active{color:var(--blue);border-bottom-color:var(--blue)}.table-wrap{overflow-x:auto;border-radius:var(--radius);border:1px solid var(--border)}.data-table{width:100%;border-collapse:collapse;font-size:12px}.data-table th{padding:10px 12px;text-align:left;font-size:11px;font-weight:600;color:var(--text);background:var(--bg2);border-bottom:1px solid var(--border);white-space:nowrap}.data-table td{padding:9px 12px;border-bottom:1px solid var(--border);vertical-align:middle;white-space:nowrap;color:var(--text2)}.data-table tr:last-child td{border-bottom:none}.data-table tr:hover td{background:var(--bg2)}.mono{font-family:Source Code Pro,monospace;font-size:11px}.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:20px;font-size:11px;font-weight:600}.badge:before{content:"";width:5px;height:5px;border-radius:50%}.badge.completed{background:var(--green-light);color:#00915a}.badge.completed:before{background:var(--green)}.badge.failed{background:#fef2f2;color:var(--red)}.badge.failed:before{background:var(--red)}.badge.processing{background:var(--orange-light);color:#c05a00}.badge.processing:before{background:var(--orange);animation:pulse 1s infinite}.badge.pending{background:var(--bg2);color:var(--text2)}.badge.pending:before{background:var(--text3)}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;border:none;font-family:inherit;transition:all .12s}.btn-primary{background:var(--blue);color:#fff}.btn-primary:hover{background:#0041cc}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-ghost{background:#fff;color:var(--text2);border:1px solid var(--border2)}.btn-ghost:hover{background:var(--bg2);color:var(--text)}.btn-danger{background:#fef2f2;color:var(--red);border:1px solid #fecaca}.btn-danger:hover{background:#fee2e2}.btn-download{background:var(--blue-light);color:var(--blue);border:1px solid transparent;font-size:11px;padding:4px 10px}.btn-download:hover{background:#d0e4ff}.btn-download.green{background:var(--green-light);color:#00915a}.btn-download.green:hover{background:#ccf5e6}.upload-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:16px}.file-slot{border:1.5px dashed var(--border2);border-radius:8px;padding:16px;text-align:center;cursor:pointer;position:relative;transition:all .12s}.file-slot:hover{border-color:var(--blue);background:var(--blue-mid)}.file-slot.filled{border-color:var(--green);border-style:solid;background:var(--green-mid)}.file-slot input{position:absolute;top:0;right:0;bottom:0;left:0;opacity:0;cursor:pointer;width:100%;height:100%}.file-slot-icon{font-size:18px;margin-bottom:4px;pointer-events:none}.file-slot-label{font-size:11px;color:var(--text2);pointer-events:none}.file-slot-name{font-size:11px;color:var(--green);font-weight:600;margin-top:3px;pointer-events:none}.file-slot-key{font-size:10px;font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:.05em;margin-bottom:6px;pointer-events:none}.form-group{margin-bottom:14px}.form-label{display:block;font-size:12px;color:var(--text2);margin-bottom:5px;font-weight:500}.form-input{width:100%;padding:8px 12px;background:#fff;border:1px solid var(--border2);border-radius:6px;color:var(--text);font-size:13px;font-family:inherit;outline:none;transition:border-color .12s}.form-input:focus{border-color:var(--blue)}.form-input::placeholder{color:var(--text3)}.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg2)}.login-card{width:400px;background:#fff;border:1px solid var(--border);border-radius:12px;padding:36px}.login-logo-text{font-size:24px;font-weight:700;letter-spacing:-.02em;margin-bottom:4px}.login-sub{font-size:13px;color:var(--text2);margin-bottom:28px}.login-error{background:#fef2f2;border:1px solid #fecaca;color:var(--red);padding:10px 14px;border-radius:6px;font-size:13px;margin-top:12px}.alert{padding:10px 14px;border-radius:6px;font-size:13px;margin-bottom:16px}.alert.success{background:var(--green-light);color:#00915a;border:1px solid #a7f3d0}.alert.error{background:#fef2f2;color:var(--red);border:1px solid #fecaca}.alert.info{background:var(--blue-light);color:var(--blue);border:1px solid #bfdbfe}.alert.warning{background:var(--orange-light);color:#c05a00;border:1px solid #fed7aa}.empty{text-align:center;padding:48px 24px;color:var(--text3)}.match-bar{height:4px;background:var(--border);border-radius:2px;margin-top:4px;overflow:hidden}.match-fill{height:100%;border-radius:2px}.info-box{background:var(--bg2);border:1px solid var(--border);border-radius:6px;padding:10px 14px;font-size:12px;color:var(--text2)}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border2);border-radius:3px}.back-link{display:flex;align-items:center;gap:6px;padding:10px 20px 12px;font-size:12px;color:var(--text3);text-decoration:none;border-bottom:1px solid var(--border);transition:color .12s}.back-link:hover{color:var(--text2)}.live-dot{width:8px;height:8px;border-radius:50%;background:var(--green);animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.table-card{background:#fff;border:1px solid var(--border);border-radius:10px;overflow:hidden;margin-bottom:24px}.table-card-header{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;border-bottom:1px solid var(--border)}.table-card-title{font-size:13px;font-weight:600;color:var(--text)}.page-header{margin-bottom:24px}.page-title{font-size:20px;font-weight:700;color:var(--text);margin-bottom:4px}.page-sub{font-size:13px;color:var(--text2)}.summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;margin-bottom:24px}.summary-card{background:#fff;border:1px solid var(--border);border-radius:10px;padding:18px 20px}.summary-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text2);margin-bottom:8px}.summary-value{font-size:26px;font-weight:700;color:var(--text)}.summary-sub{font-size:12px;color:var(--text2);margin-top:4px}.run-tabs{display:flex;gap:0;border-bottom:2px solid var(--border);margin-bottom:24px}.run-tab{padding:10px 18px;font-size:13px;font-weight:500;background:none;border:none;cursor:pointer;border-bottom:2px solid transparent;color:var(--text2);margin-bottom:-2px}.run-tab.active{border-bottom-color:var(--blue);color:var(--blue)}.upload-zone{border:2px dashed var(--border2);border-radius:10px;padding:32px;text-align:center;cursor:pointer;transition:border-color .2s,background .2s}.upload-zone:hover,.upload-zone.drag{border-color:var(--blue);background:var(--blue-light)}.upload-zone-icon{font-size:32px;margin-bottom:12px}.upload-zone-label{font-size:14px;font-weight:600;color:var(--text);margin-bottom:4px}.upload-zone-sub{font-size:12px;color:var(--text2)}
