:root{color-scheme:light;--ink:#0b1524;--ink-2:#1c2940;--muted:#667085;--muted-2:#98a2b3;--canvas:#f5f6f8;--surface:#ffffff;--surface-2:#fbfcfd;--line:#e7eaf0;--line-2:#eef1f5;--brand:#3651d4;--brand-ink:#2a3fae;--brand-soft:#eef1fe;--success:#15803d;--success-soft:#dcfce7;--warn:#b45309;--warn-soft:#fef3c7;--danger:#be123c;--danger-soft:#ffe4e6;--sidebar-1:#0b1524;--sidebar-2:#0f1d34;--shadow-sm:0 1px 2px rgba(11,21,36,.06),0 1px 3px rgba(11,21,36,.05);--shadow:0 12px 34px rgba(11,21,36,.10);--radius:16px;--radius-sm:12px;--radius-pill:999px;--font-display:"Space Grotesk","Inter",system-ui,sans-serif;--font-body:"Inter",system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;--font-mono:"IBM Plex Mono",ui-monospace,SFMono-Regular,Menlo,monospace}*{box-sizing:border-box}body,html{margin:0;padding:0}body{font-family:var(--font-body);color:var(--ink);background:var(--canvas);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}h1,h2,h3,p{margin:0}a{color:var(--brand);text-decoration:none;font-weight:600}a:hover{color:var(--brand-ink)}.app{display:grid;grid-template-columns:252px 1fr;min-height:100vh}.sidebar{background:linear-gradient(180deg,var(--sidebar-1),var(--sidebar-2));color:#cdd6e6;padding:22px 16px;display:flex;flex-direction:column;gap:22px;position:-webkit-sticky;position:sticky;top:0;height:100vh}.brand{display:flex;align-items:center;gap:12px;padding:4px 8px}.brand-mark{width:38px;height:38px;border-radius:11px;flex:none;display:grid;place-items:center;background:linear-gradient(135deg,#4f6bf0,#2a3fae);box-shadow:inset 0 0 0 1px rgba(255,255,255,.14),0 8px 18px rgba(54,81,212,.35);font-weight:700;font-size:17px}.brand-mark,.brand-name{color:#fff;font-family:var(--font-display)}.brand-name{font-weight:600;font-size:15px;line-height:1.15}.brand-sub{font-size:11px;letter-spacing:.14em;color:#7c89a3;margin-top:2px}.brand-sub,.nav-section{text-transform:uppercase}.nav-section{font-size:10.5px;letter-spacing:.12em;color:#5e6c86;padding:0 12px;margin:6px 0}.nav{display:flex;flex-direction:column;gap:3px}.nav-item{display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:11px;color:#b9c3d6;font-weight:600;font-size:13.5px;position:relative;transition:background .16s ease,color .16s ease}.nav-item svg{width:18px;height:18px;flex:none;opacity:.9}.nav-item:hover{background:rgba(255,255,255,.06);color:#fff}.nav-item.active{background:rgba(79,107,240,.18);color:#fff}.nav-item.active:before{content:"";position:absolute;left:-16px;top:9px;bottom:9px;width:3px;border-radius:0 3px 3px 0;background:#6d86f7}.sidebar-foot{margin-top:auto;display:flex;flex-direction:column;gap:12px}.side-user{display:flex;align-items:center;gap:10px;padding-top:14px;border-top:1px solid rgba(255,255,255,.08)}.side-avatar{width:30px;height:30px;border-radius:50%;background:#25324d;display:grid;place-items:center;color:#cdd6e6;font-weight:700;font-size:12px}.side-user-name{color:#e7edf7;font-weight:600;font-size:12.5px}.side-user small{color:#7c89a3;display:block}.logout-btn{display:flex;align-items:center;justify-content:center;gap:9px;width:100%;padding:10px 12px;border-radius:11px;font-weight:700;font-size:13px;cursor:pointer;background:rgba(255,255,255,.07);color:#e7edf7;border:1px solid rgba(255,255,255,.1);font-family:var(--font-body)}.logout-btn:hover{background:rgba(255,255,255,.12)}.logout-btn svg{width:16px;height:16px}.main{display:flex;flex-direction:column;min-width:0}.topbar{position:-webkit-sticky;position:sticky;top:0;z-index:5;background:rgba(245,246,248,.82);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:1px solid var(--line);padding:18px 30px;display:flex;align-items:center;justify-content:space-between;gap:18px}.topbar:before{content:"";position:absolute;left:0;right:0;top:0;height:3px;background:linear-gradient(90deg,#3651d4,#4f6bf0 45%,#06b6d4)}.crumbs{font-size:12.5px;color:var(--muted);display:flex;gap:7px;align-items:center}.crumbs b{color:var(--ink);font-weight:600}.page-title{font-family:var(--font-display);font-size:21px;font-weight:600;letter-spacing:-.01em;margin-top:2px}.page-sub{color:var(--muted);font-size:13px;margin-top:4px}.topbar-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.content{padding:26px 30px 56px;max-width:1480px;width:100%;margin:0 auto}.kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(208px,1fr));grid-gap:16px;gap:16px;margin-bottom:22px}.kpi{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow-sm);position:relative;overflow:hidden}.kpi:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--line-2)}.kpi.is-primary:before{background:var(--brand)}.kpi.is-success:before{background:var(--success)}.kpi.is-warn:before{background:var(--warn)}.kpi-label{font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);font-weight:600}.kpi-value{font-family:var(--font-display);font-size:27px;font-weight:600;letter-spacing:-.02em;margin-top:9px;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.kpi-hint{color:var(--muted);font-size:12.5px;margin-top:7px}.grid-2{display:grid;grid-template-columns:1fr 1fr;grid-gap:18px;gap:18px}.grid-2,.panel{margin-bottom:18px}.panel{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow-sm)}.panel-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px}.panel-head h2{font-family:var(--font-display);font-size:16px;font-weight:600;letter-spacing:-.01em}.pill{font-size:11px;font-weight:700;letter-spacing:.04em;padding:5px 10px;border-radius:var(--radius-pill);background:var(--brand-soft);color:var(--brand-ink)}.error-panel{border-color:#fecdd3;background:#fff1f2}.error-panel h2{color:var(--danger)}.error-panel .msg{color:#9f1239;font-family:var(--font-mono);font-size:12.5px;word-break:break-word;margin-top:8px}.table-wrap{overflow-x:auto;border:1px solid var(--line);border-radius:var(--radius-sm)}table{width:100%;border-collapse:separate;border-spacing:0;background:var(--surface)}thead th{background:var(--surface-2);color:var(--muted);font-size:11px;letter-spacing:.06em;text-transform:uppercase;font-weight:600;text-align:left;padding:11px 14px;border-bottom:1px solid var(--line);white-space:nowrap}tbody td{padding:12px 14px;border-bottom:1px solid var(--line-2);vertical-align:middle}tbody tr:last-child td{border-bottom:none}tbody tr:hover td{background:#f9fafc}.num{text-align:right}.money,.num{font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.money{font-weight:600;white-space:nowrap}.mono{font-family:var(--font-mono);font-size:12.5px;color:var(--ink-2)}.muted{color:var(--muted)}.main-cell,.strong{font-weight:600}.main-cell,.sub{display:block}.sub{color:var(--muted);font-size:12px}.badge{display:inline-flex;align-items:center;gap:6px;font-size:11px;font-weight:700;letter-spacing:.03em;text-transform:uppercase;padding:5px 10px;border-radius:var(--radius-pill);background:var(--line);color:var(--ink-2)}.badge:before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor;opacity:.7}.badge.paid,.badge.success{background:var(--success-soft);color:var(--success)}.badge.manual_review,.badge.pending,.badge.review{background:var(--warn-soft);color:var(--warn)}.badge.duplicate,.badge.failed{background:var(--danger-soft);color:var(--danger)}.bar-track{height:7px;background:var(--line-2);overflow:hidden;margin-top:7px}.bar-fill,.bar-track{border-radius:var(--radius-pill)}.bar-fill{height:100%;min-width:4px;background:linear-gradient(90deg,#3651d4,#06b6d4)}.btn{display:inline-flex;align-items:center;gap:8px;cursor:pointer;font-family:var(--font-body);font-weight:700;font-size:13.5px;padding:10px 15px;border-radius:var(--radius-sm);border:1px solid transparent;background:var(--brand);color:#fff;box-shadow:0 8px 16px rgba(54,81,212,.18);transition:transform .04s ease,background .16s ease}.btn svg{width:16px;height:16px}.btn:hover{background:var(--brand-ink);color:#fff}.btn:active{transform:translateY(1px)}.btn:disabled{opacity:.55;cursor:not-allowed}.btn.ghost{background:var(--surface);color:var(--ink);border-color:var(--line);box-shadow:var(--shadow-sm)}.btn.ghost:hover{background:var(--surface-2);color:var(--ink)}.btn.success{background:var(--success);box-shadow:none}.btn.success:hover{background:#126c34}.btn.small{padding:7px 11px;font-size:12.5px}input,select,textarea{font-family:var(--font-body);font-size:14px;color:var(--ink);padding:10px 12px;border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--surface);width:100%}textarea{min-height:92px;resize:vertical}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px rgba(54,81,212,.16)}label{display:block;font-size:12.5px;font-weight:600;color:var(--ink-2);margin-bottom:6px}.field{margin-bottom:14px}.filters{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin-bottom:16px}.filters .grow{flex:1 1 260px}.filters input:not(.grow input),.filters select{width:auto}.filters .grow input{width:100%}.actions{display:flex;gap:6px;flex-wrap:wrap}.empty{text-align:center;color:var(--muted);padding:30px 18px;background:var(--surface-2);border:1px dashed var(--line);border-radius:var(--radius-sm)}.empty strong{display:block;color:var(--ink-2);margin-bottom:4px}.dropzone{border:1.5px dashed #c3ccdb;border-radius:var(--radius);background:var(--surface-2);padding:30px;text-align:center;transition:border-color .16s ease,background .16s ease;cursor:pointer;display:block}.dropzone:hover{border-color:var(--brand);background:var(--brand-soft)}.dropzone .dz-icon{width:46px;height:46px;margin:0 auto 12px;color:var(--brand)}.code-line{font-family:var(--font-mono);font-size:12.5px;background:#0b1524;color:#c8d3e8;padding:12px 14px;border-radius:var(--radius-sm);word-break:break-all}.login-page{min-height:100vh;display:grid;place-items:center;padding:24px;background:radial-gradient(circle at top,rgba(54,81,212,.1),transparent 42%),var(--canvas)}.login-card{width:100%;max-width:410px;background:var(--surface);border:1px solid var(--line);border-radius:20px;padding:32px;box-shadow:var(--shadow)}.login-brand{display:inline-flex;align-items:center;gap:10px;font-weight:700;font-size:18px;color:var(--ink);margin-bottom:18px}.login-brand,.login-card h1{font-family:var(--font-display)}.login-card h1{font-size:22px;font-weight:600;margin-bottom:6px}.login-card .login-copy{color:var(--muted);font-size:13.5px;margin-bottom:22px}.login-form{display:flex;flex-direction:column;gap:14px}.login-error{background:var(--danger-soft);color:var(--danger);padding:11px 14px;border-radius:var(--radius-sm);font-weight:600;font-size:13px;margin-bottom:16px}.login-button{width:100%;justify-content:center;margin-top:4px}.flash{display:flex;align-items:center;gap:10px;background:#ecfdf5;border:1px solid #a7f3d0;color:#065f46;padding:12px 15px;border-radius:var(--radius-sm);margin-bottom:18px;font-weight:600}@media (max-width:980px){.app{grid-template-columns:1fr}.sidebar{position:static;height:auto;flex-direction:row;align-items:center;gap:14px;overflow-x:auto;padding:12px 14px}.brand-name,.brand-sub,.nav-section,.side-user{display:none}.nav{flex-direction:row}.nav-item.active:before{display:none}.sidebar-foot{margin:0;flex-direction:row}.logout-btn{width:auto}.grid-2{grid-template-columns:1fr}.content{padding:20px 16px 48px}.topbar{padding:16px}}