@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600&family=JetBrains+Mono:wght@400;500&display=swap";
:root{--bg:#09090b;--surface:#111113;--raised:#18181b;--border:#27272a;--border-2:#1c1c1f;--text:#fafafa;--text-2:#a1a1aa;--text-3:#52525b;--accent:#6366f1;--red:#ef4444;--red-bg:#ef444412;--green:#22c55e;--green-bg:#22c55e12;--amber:#f59e0b;--shadow:0 1px 3px #0006, 0 1px 2px #0000004d;--shadow-md:0 4px 6px -1px #0006, 0 2px 4px -2px #0000004d;--mono:"JetBrains Mono", monospace;--sans:"Inter", sans-serif;--radius:8px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;font-size:14px}body{background:var(--bg);color:var(--text);font-family:var(--sans);min-height:100vh;line-height:1.5}button{font-family:var(--sans);cursor:pointer}input{font-family:var(--sans)}.app{min-height:100vh}.content{flex-direction:column;gap:14px;max-width:1280px;margin:0 auto;padding:20px 20px 60px;display:flex}.header{background:var(--surface);border-bottom:1px solid var(--border);z-index:100;grid-template-columns:1fr auto 1fr;align-items:center;height:52px;padding:0 20px;display:grid;position:sticky;top:0}.logo{font-family:var(--mono);letter-spacing:.05em;color:var(--text);font-size:14px;font-weight:500}.header-center{justify-content:center;display:flex}.header-right{justify-content:flex-end;align-items:center;gap:12px;display:flex}.tab-nav{background:var(--raised);border:1px solid var(--border);border-radius:6px;align-items:center;gap:1px;padding:3px;display:flex}.tab-btn{color:var(--text-2);background:0 0;border:none;border-radius:4px;padding:5px 14px;font-size:12px;font-weight:500;transition:color .1s,background .1s}.tab-btn:hover{color:var(--text);background:#ffffff0d}.tab-active{box-shadow:var(--shadow);background:var(--surface)!important;color:var(--text)!important}.local-badge{font-family:var(--mono);color:var(--text-3);letter-spacing:.04em;font-size:10px}.file-info-bar{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);align-items:center;gap:10px;padding:8px 14px;display:flex}.file-name{font-family:var(--mono);color:var(--text-2);font-size:12px}.file-count{color:var(--text-3);font-size:11px}.upload-zone{background:var(--surface);border:1px dashed var(--border);border-radius:var(--radius);cursor:pointer;text-align:center;flex-direction:column;align-items:center;gap:14px;padding:48px 40px;transition:border-color .15s;display:flex}.upload-zone.dragging{border-color:var(--accent);background:#6366f108;border-style:solid}.upload-zone.processing{cursor:default;border-style:solid}.upload-icon{border:1px solid var(--border);width:44px;height:44px;color:var(--text-3);background:var(--raised);border-radius:8px;justify-content:center;align-items:center;transition:border-color .15s,color .15s;display:flex}.upload-zone.dragging .upload-icon{border-color:var(--accent);color:var(--accent)}.upload-text{flex-direction:column;gap:4px;display:flex}.upload-title{color:var(--text);font-size:15px;font-weight:500}.upload-subtitle{color:var(--text-3);font-size:12px}.browse-btn{background:var(--raised);border:1px solid var(--border);color:var(--text);cursor:pointer;border-radius:6px;padding:7px 20px;font-size:12px;font-weight:500;transition:border-color .15s,background .15s;display:inline-block}.browse-btn:hover{border-color:var(--text-2);background:#27272a}.bank-support{flex-wrap:wrap;justify-content:center;align-items:center;gap:6px;display:flex}.bank-support-label{color:var(--text-3);font-size:11px}.bank-tag{font-size:10px;font-family:var(--mono);color:var(--text-3);border:1px solid var(--border-2);background:var(--raised);border-radius:4px;padding:2px 7px}.demo-row{justify-content:center;display:flex}.demo-btn{color:var(--text-3);text-underline-offset:3px;background:0 0;border:none;font-size:12px;text-decoration:underline;transition:color .15s}.demo-btn:hover{color:var(--text-2)}.reset-btn{color:var(--text-3);background:0 0;border:none;font-size:12px;transition:color .15s}.reset-btn:hover{color:var(--red)}.spinner{border:2px solid var(--border);border-top-color:var(--text-2);border-radius:50%;width:20px;height:20px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.stat-cards{grid-template-columns:repeat(4,1fr);gap:10px;display:grid}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px 20px;transition:border-color .15s}.stat-card:hover{border-color:#3f3f46}.stat-label{color:var(--text-3);margin-bottom:10px;font-size:11px;font-weight:500}.stat-value{font-family:var(--mono);color:var(--text);letter-spacing:-.02em;margin-bottom:6px;font-size:26px;font-weight:500;line-height:1}.stat-sub{color:var(--text-3);font-size:11px}.charts-grid{grid-template-columns:1fr 1fr;gap:10px;display:grid}.category-chart-panel,.trend-chart-panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.panel-header{border-bottom:1px solid var(--border-2);justify-content:space-between;align-items:center;padding:14px 16px;display:flex}.panel-title{color:var(--text);font-size:13px;font-weight:500}.panel-sub{color:var(--text-3);font-size:11px;font-family:var(--mono)}.category-chart-body{align-items:center;gap:20px;padding:18px 16px;display:flex}.donut-wrapper{flex-shrink:0;width:130px;height:130px;position:relative}.donut-center{pointer-events:none;flex-direction:column;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.donut-total{font-family:var(--mono);color:var(--text);font-size:14px;font-weight:500}.donut-label{color:var(--text-3);margin-top:2px;font-size:9px}.category-legend{flex-direction:column;flex:1;gap:7px;min-width:0;display:flex}.legend-row{grid-template-columns:8px 1fr auto auto;align-items:center;gap:7px;display:grid}.legend-dot{border-radius:50%;flex-shrink:0;width:6px;height:6px}.legend-name{color:var(--text-2);white-space:nowrap;text-overflow:ellipsis;font-size:11px;overflow:hidden}.legend-bar-wrap{background:var(--raised);border-radius:2px;height:3px;position:relative;overflow:hidden}.legend-bar-fill{inset-y:0;border-radius:2px;transition:width .6s;position:absolute;left:0}.legend-val{font-family:var(--mono);color:var(--text-2);white-space:nowrap;font-size:10px}.trend-meta{align-items:center;gap:12px;display:flex}.trend-peak,.trend-avg{color:var(--text-3);font-size:11px;font-family:var(--mono)}.trend-chart-wrap{height:176px;padding:12px 16px}.dashboard-grid{grid-template-columns:1fr 360px;align-items:start;gap:10px;display:grid}.tx-panel,.anomaly-panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.entry-badge{color:var(--text-3);font-size:11px;font-family:var(--mono)}.flagged-badge{color:var(--red);font-size:11px;font-family:var(--mono)}.tx-toolbar{border-bottom:1px solid var(--border-2);flex-wrap:wrap;align-items:center;gap:8px;padding:10px 14px;display:flex}.tx-search-wrap{background:var(--raised);border:1px solid var(--border);border-radius:6px;flex:1;align-items:center;gap:6px;min-width:160px;padding:5px 10px;transition:border-color .1s;display:flex}.tx-search-wrap:focus-within{border-color:var(--text-3)}.search-icon{color:var(--text-3);flex-shrink:0}.tx-search{color:var(--text);background:0 0;border:none;outline:none;flex:1;min-width:0;font-size:12px}.tx-search::placeholder{color:var(--text-3)}.search-clear{color:var(--text-3);background:0 0;border:none;padding:0;font-size:11px;line-height:1;transition:color .1s}.search-clear:hover{color:var(--text-2)}.tx-filter-chips{flex-wrap:wrap;gap:4px;display:flex}.chip{border:1px solid var(--border);color:var(--text-3);background:0 0;border-radius:4px;padding:3px 10px;font-size:11px;transition:all .1s}.chip:hover{border-color:var(--text-3);color:var(--text-2)}.chip-active{background:var(--raised)!important;color:var(--text)!important;border-color:var(--border)!important}.chip-anomaly.chip-active{color:var(--red)!important;background:var(--red-bg)!important;border-color:#ef444430!important}.cat-filter-bar{border-bottom:1px solid var(--border-2);scrollbar-width:none;align-items:center;gap:4px;padding:7px 14px;display:flex;overflow-x:auto}.cat-filter-bar::-webkit-scrollbar{display:none}.cat-chip{color:var(--text-3);white-space:nowrap;background:0 0;border:1px solid #0000;border-radius:4px;flex-shrink:0;align-items:center;gap:4px;padding:2px 8px;font-size:11px;transition:all .1s;display:flex}.cat-chip:hover{color:var(--text-2);border-color:var(--border-2)}.cat-chip-active{border-color:var(--border)!important;color:var(--text-2)!important;background:var(--raised)!important}.cat-chip-dot{border-radius:50%;flex-shrink:0;width:5px;height:5px}.tx-table{width:100%}.tx-thead{color:var(--text-3);text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--border-2);grid-template-columns:2fr .8fr 1fr .9fr;padding:8px 14px;font-size:10px;font-weight:600;display:grid}.sort-btn{color:var(--text-3);letter-spacing:.06em;text-transform:uppercase;text-align:left;background:0 0;border:none;padding:0;font-size:10px;font-weight:600;transition:color .1s}.sort-btn:hover{color:var(--text-2)}.tx-body{max-height:460px;overflow-y:auto}.tx-body::-webkit-scrollbar{width:3px}.tx-body::-webkit-scrollbar-track{background:0 0}.tx-body::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}.tx-row{border-bottom:1px solid var(--border-2);cursor:pointer;grid-template-columns:2fr .8fr 1fr .9fr;align-items:center;padding:10px 14px;transition:background .1s;display:grid;position:relative}.tx-row:hover,.tx-row.selected-row{background:var(--raised)}.anomaly-row{background:#ef444406}.anomaly-row:before{content:"";background:var(--red);opacity:.6;width:2px;position:absolute;top:0;bottom:0;left:0}.anomaly-row:hover{background:#ef44440a}.tx-desc{flex-direction:column;gap:3px;min-width:0;display:flex}.tx-name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;align-items:center;gap:6px;font-size:12px;font-weight:500;display:flex;overflow:hidden}.anomaly-row .tx-name{color:#fca5a5}.tx-emoji{flex-shrink:0;font-size:13px;line-height:1}.tx-meta{flex-wrap:wrap;align-items:center;gap:5px;display:flex}.tx-cat-badge{border-radius:3px;width:fit-content;padding:1px 6px;font-size:9px;font-weight:500}.tx-raw{color:var(--text-3);font-size:9px;font-family:var(--mono);white-space:nowrap;text-overflow:ellipsis;max-width:150px;overflow:hidden}.tx-date{color:var(--text-3);font-size:11px;font-family:var(--mono)}.tx-amount{font-family:var(--mono);font-size:12px;font-weight:500}.tx-amount.debit{color:var(--red)}.tx-amount.credit{color:var(--green)}.tx-status{font-size:10px}.status-anomaly{color:var(--red)}.status-normal{color:var(--text-3)}.tx-empty{color:var(--text-3);justify-content:center;align-items:center;padding:36px 20px;font-size:12px;display:flex}.tx-footer{color:var(--text-3);font-size:10px;font-family:var(--mono);border-top:1px solid var(--border-2);background:#09090b;padding:9px 14px}.anomaly-list{flex-direction:column;display:flex}.anomaly-card{border-bottom:1px solid var(--border-2);padding:14px 16px;transition:background .1s}.anomaly-card:hover{background:var(--raised)}.anomaly-card-top{align-items:center;gap:7px;margin-bottom:6px;display:flex}.anomaly-rank{font-family:var(--mono);color:var(--text-3);flex-shrink:0;font-size:9px}.anomaly-type-badge{background:var(--red-bg);color:var(--red);border:1px solid #ef444420;border-radius:3px;flex:1;padding:2px 6px;font-size:9px;font-weight:600}.anomaly-sev-med .anomaly-type-badge{color:var(--amber);background:#f59e0b0f;border-color:#f59e0b20}.anomaly-sev-low .anomaly-type-badge{color:#d97706;background:#f59e0b08;border-color:#f59e0b15}.anomaly-amount{font-family:var(--mono);color:var(--red);white-space:nowrap;flex-shrink:0;font-size:12px;font-weight:600}.anomaly-merchant{color:var(--text);align-items:center;gap:6px;margin-bottom:4px;font-size:13px;font-weight:600;display:flex}.anomaly-emoji{flex-shrink:0;font-size:16px}.anomaly-raw-desc{font-family:var(--mono);color:var(--text-3);letter-spacing:.02em;margin-bottom:6px;font-size:9px}.anomaly-explanation{color:var(--text-2);margin-bottom:8px;font-size:11px;line-height:1.6}.confidence-container{align-items:center;gap:8px;display:flex}.confidence-track{background:var(--raised);border-radius:1px;flex:1;height:2px;overflow:hidden}.confidence-fill{border-radius:1px;height:100%;transition:width .6s}.confidence-label{font-family:var(--mono);color:var(--text-3);white-space:nowrap;font-size:9px}.anomaly-empty{color:var(--text-3);text-align:center;flex-direction:column;align-items:center;gap:8px;padding:32px 20px;font-size:12px;display:flex}.anomaly-empty-icon{font-size:24px}.forecast-widget{background:var(--raised);border-top:1px solid var(--border-2);padding:14px 16px 16px}.forecast-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.forecast-label{text-transform:uppercase;letter-spacing:.06em;color:var(--text-3);font-size:10px;font-weight:600}.forecast-status-badge{font-family:var(--mono);letter-spacing:.04em;border-radius:3px;padding:2px 7px;font-size:9px;font-weight:600}.forecast-balance{font-family:var(--mono);color:var(--green);letter-spacing:-.02em;margin-bottom:3px;font-size:24px;font-weight:500}.forecast-sub{color:var(--text-3);margin-bottom:10px;font-size:11px}.forecast-stats-row{grid-template-columns:repeat(3,1fr);gap:6px;margin-bottom:10px;display:grid}.forecast-stat{background:var(--surface);border:1px solid var(--border-2);border-radius:6px;padding:7px 10px}.forecast-stat-label{color:var(--text-3);margin-bottom:3px;font-size:9px;font-weight:500;display:block}.forecast-stat-val{font-family:var(--mono);color:var(--text);font-size:12px;font-weight:500}.forecast-progress{background:var(--surface);border-radius:2px;height:3px;margin-bottom:4px;overflow:hidden}.forecast-progress-fill{border-radius:2px;height:100%;transition:width .8s}.forecast-progress-labels{font-family:var(--mono);color:var(--text-3);justify-content:space-between;font-size:9px;display:flex}::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}::-webkit-scrollbar-thumb:hover{background:#3f3f46}@media (max-width:1100px){.charts-grid,.dashboard-grid{grid-template-columns:1fr}}@media (max-width:768px){.stat-cards{grid-template-columns:repeat(2,1fr)}.header{grid-template-columns:1fr 1fr}.header-center{display:none}}@media (max-width:540px){.stat-cards{grid-template-columns:1fr 1fr}.content{padding:12px 12px 48px}.tx-thead,.tx-row{grid-template-columns:1.5fr .8fr 1fr}.tx-thead span:last-child,.tx-row .tx-status{display:none}}
