*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0f1117;--surface:#1a1d27;--surface2:#22263a;--border:#2e3250;--accent:#4f8ef7;--accent2:#7c5cbf;--green:#34d399;--red:#f87171;--yellow:#fbbf24;--text:#e2e8f0;--muted:#8892a4;--radius:14px;--shadow:0 4px 24px #0006}html{font-size:16px}body{background:var(--bg);color:var(--text);-webkit-text-size-adjust:100%;-webkit-tap-highlight-color:transparent;min-height:100vh;font-family:Segoe UI,system-ui,-apple-system,sans-serif;overflow-x:hidden}.btn{cursor:pointer;white-space:nowrap;-webkit-tap-highlight-color:transparent;touch-action:manipulation;border:none;border-radius:10px;align-items:center;gap:6px;padding:9px 16px;font-size:.85rem;font-weight:600;text-decoration:none;transition:all .2s;display:inline-flex}.btn-primary{background:linear-gradient(135deg, var(--accent), var(--accent2));color:#fff}.btn-primary:hover,.btn-primary:active{opacity:.88;transform:translateY(-1px)}.btn-ghost{background:var(--surface2);color:var(--text);border:1px solid var(--border)}.btn-ghost:hover,.btn-ghost:active{border-color:var(--accent);color:var(--accent)}.btn-danger{color:var(--red);background:#f8717126;border:1px solid #f871714d}.btn-danger:hover,.btn-danger:active{background:#f8717140}.modal-backdrop{z-index:1000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#000000b8;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.modal-box{background:var(--surface);border:1px solid var(--border);border-radius:20px;width:100%;max-width:560px;max-height:90vh;padding:28px;position:relative;overflow-y:auto;box-shadow:0 24px 64px #000000b3}.modal-box.wide{max-width:700px}.modal-title{align-items:center;gap:8px;margin-bottom:6px;font-size:1.05rem;font-weight:700;display:flex}.modal-subtitle{color:var(--muted);margin-bottom:22px;font-size:.8rem;line-height:1.6}.modal-section-label{color:var(--muted);text-transform:uppercase;letter-spacing:.7px;margin-bottom:8px;font-size:.68rem;font-weight:700}.modal-footer{flex-wrap:wrap;justify-content:flex-end;gap:10px;margin-top:6px;display:flex}.modal-select{background:var(--surface2);border:1px solid var(--border);color:var(--text);cursor:pointer;-webkit-appearance:none;border-radius:8px;outline:none;width:100%;padding:9px 12px;font-size:.82rem}.modal-select:focus{border-color:var(--accent)}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:var(--surface)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--accent)}@media (width<=480px){.modal-backdrop{align-items:flex-end;padding:0}.modal-box{border-radius:20px 20px 0 0;width:100%;max-width:100%;max-height:92vh;padding:20px 16px 28px}.modal-box.wide{border-radius:20px 20px 0 0;max-width:100%}.modal-footer{flex-direction:column-reverse;gap:8px}.modal-footer .btn{justify-content:center;width:100%;padding:12px;font-size:.82rem}}@media (width<=768px){.btn{touch-action:manipulation;min-height:44px}.modal-select,select,input[type=text],input[type=search]{min-height:42px;font-size:16px!important}}.empty-state{color:var(--muted);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:10px;padding:40px;font-size:.82rem;display:flex}.empty-state span{font-size:2rem}body.modal-open{overflow:hidden!important}@media (width<=480px){.hide-on-mobile{display:none!important}}@media (width>=481px){.hide-on-desktop{display:none!important}}@media (width<=480px){body.drawer-open,body.modal-open{width:100%;position:fixed;overflow:hidden}.drawer-body,.expense-table-wrap,.modal-box,.spotlight-txn-list,.plu-list{-webkit-overflow-scrolling:touch;overscroll-behavior:contain}.spotlight-txn-row{border-top:none;border-bottom:1px solid var(--border);grid-template-rows:auto auto;grid-template-columns:1fr auto;gap:2px 8px;padding:10px 12px;display:grid}.spotlight-txn-payee{grid-area:1/1;font-size:.82rem;font-weight:500}.spotlight-txn-date{grid-area:2/1;font-size:.7rem}.spotlight-txn-amt{text-align:right;grid-area:1/2/3;align-self:center;font-size:.9rem}}.upload-zone-page{flex-direction:column;justify-content:center;align-items:center;min-height:calc(100vh - 63px);padding:24px 16px;display:flex}.upload-card{background:var(--surface);border:2px dashed var(--border);text-align:center;cursor:pointer;border-radius:24px;width:100%;max-width:560px;padding:44px 40px;transition:border-color .3s,background .3s}@media (width<=480px){.upload-card{border-radius:18px;padding:32px 20px}}.upload-card:hover,.upload-card.drag-over{border-color:var(--accent);background:#1e2236}.upload-icon{margin-bottom:16px;font-size:3rem;display:block}.upload-card h2{margin-bottom:10px;font-size:1.25rem}.upload-card p{color:var(--muted);margin-bottom:22px;font-size:.85rem;line-height:1.7}.upload-info-row{flex-wrap:wrap;justify-content:center;align-items:center;gap:10px;margin-top:16px;display:flex}.format-tags{flex-wrap:wrap;justify-content:center;gap:6px;display:flex}.tag{background:var(--surface2);border:1px solid var(--border);color:var(--muted);border-radius:6px;padding:3px 9px;font-size:.72rem}@media (width<=480px){.upload-zone-page{min-height:calc(100vh - 52px);padding:16px 12px}.upload-card h2{font-size:1.1rem}.upload-card p{font-size:.8rem}.upload-icon{margin-bottom:12px;font-size:2.4rem}}.currency-detected{background:#4f8ef714;border:1px solid #4f8ef740;border-radius:10px;align-items:center;gap:10px;margin-bottom:18px;padding:12px 16px;font-size:.82rem;display:flex}.currency-detected .det-icon{flex-shrink:0;font-size:1.4rem}.currency-detected .det-text{color:var(--muted);line-height:1.5}.currency-grid{grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:20px;display:grid}@media (width<=480px){.currency-grid{grid-template-columns:repeat(3,1fr);gap:6px}}.currency-btn{background:var(--surface2);border:2px solid var(--border);cursor:pointer;text-align:center;-webkit-tap-highlight-color:transparent;touch-action:manipulation;border-radius:10px;min-height:52px;padding:10px 8px;transition:all .18s}.currency-btn:hover{border-color:var(--accent)}.currency-btn.selected{border-color:var(--accent);background:#4f8ef71f}.currency-btn .cur-symbol{color:var(--text);font-size:1.1rem;font-weight:700;display:block}.currency-btn .cur-name{color:var(--muted);margin-top:2px;font-size:.62rem;display:block}@media (width<=480px){.currency-btn{padding:8px 4px}.currency-btn .cur-symbol{font-size:1rem}.currency-btn .cur-name{font-size:.58rem}}.colmap-file-subtitle{color:var(--muted);margin-bottom:14px;font-size:.78rem}.colmap-file-info{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:8px;display:flex}.colmap-filename{color:var(--text);font-size:.82rem;font-weight:700}.colmap-col-count{color:var(--muted);background:var(--surface2);border:1px solid var(--border);border-radius:10px;padding:2px 8px;font-size:.72rem}.colmap-status-chips{flex-wrap:wrap;gap:6px;margin-bottom:10px;display:flex}.colmap-chip{border-radius:20px;align-items:center;gap:4px;padding:4px 10px;font-size:.72rem;font-weight:600;display:inline-flex}.colmap-chip-found{background:#34d3991a;border:1px solid #34d39959}.colmap-chip-found .chip-check{color:var(--green)}.colmap-chip-found .chip-field{color:var(--text)}.colmap-chip-found .chip-arrow,.colmap-chip-found .chip-col{color:var(--muted);font-weight:400}.colmap-chip-missing{background:#f871711a;border:1px solid #f871714d}.colmap-chip-missing .chip-check,.colmap-chip-missing .chip-field{color:var(--red)}.chip-required{color:var(--red);opacity:.75;font-size:.62rem;font-weight:400}.colmap-chip-optional{border:1px solid var(--border);background:#8892a414}.colmap-chip-optional .chip-check,.colmap-chip-optional .chip-field{color:var(--muted)}.chip-opt-label{color:var(--muted);opacity:.7;font-size:.62rem;font-weight:400}.colmap-cols-wrap{margin-bottom:16px}.colmap-cols-toggle{color:var(--accent);cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border:none;padding:0;font-size:.72rem;text-decoration:underline}.colmap-cols-list{background:var(--surface2);border:1px solid var(--border);border-radius:8px;flex-wrap:wrap;gap:5px;margin-top:8px;padding:10px 12px;display:flex}.colmap-col-pill{color:var(--muted);background:var(--surface);border:1px solid var(--border);border-radius:6px;padding:2px 8px;font-size:.7rem}.colmap-fields-list{border:1px solid var(--border);border-radius:12px;flex-direction:column;gap:0;margin-bottom:16px;display:flex;overflow:hidden}.colmap-field-row{background:var(--surface);border-bottom:1px solid var(--border);grid-template-columns:1fr 1fr;align-items:center;gap:12px;padding:12px 14px;transition:background .15s;display:grid}.colmap-field-row:last-child{border-bottom:none}.colmap-field-row:hover{background:var(--surface2)}.colmap-field-row-dual{grid-template-columns:1fr;gap:10px}.colmap-field-meta{align-items:center;gap:10px;display:flex}.colmap-field-icon{text-align:center;flex-shrink:0;width:28px;font-size:1.2rem}.colmap-field-name{color:var(--text);align-items:center;gap:6px;font-size:.82rem;font-weight:600;display:flex}.colmap-field-desc{color:var(--muted);margin-top:1px;font-size:.7rem}.colmap-req-badge{text-transform:uppercase;letter-spacing:.4px;color:var(--accent);background:#4f8ef726;border:1px solid #4f8ef74d;border-radius:4px;padding:1px 5px;font-size:.6rem;font-weight:700}.colmap-divider{background:var(--surface2);border-bottom:1px solid var(--border);color:var(--muted);text-transform:uppercase;letter-spacing:.5px;padding:8px 14px;font-size:.68rem;font-weight:600}.colmap-dual-selects{grid-template-columns:1fr auto 1fr;align-items:end;gap:8px;display:grid}.colmap-dual-select-wrap{flex-direction:column;gap:4px;display:flex}.colmap-dual-label{color:var(--muted);text-transform:uppercase;letter-spacing:.4px;font-size:.62rem;font-weight:600}.colmap-dual-divider{color:var(--muted);text-align:center;white-space:nowrap;opacity:.7;padding-bottom:10px;font-size:.65rem}.colmap-preview-header{color:var(--text);align-items:center;gap:10px;margin-bottom:8px;font-size:.78rem;font-weight:600;display:flex}.review-table-wrap{border:1px solid var(--border);border-radius:10px;overflow:auto}@media (width<=600px){.colmap-field-row{grid-template-columns:1fr;gap:8px;padding:10px 12px}.colmap-dual-selects{grid-template-columns:1fr;gap:6px}.colmap-dual-divider{display:none}}.review-summary{color:var(--muted);margin-bottom:14px;font-size:.75rem}.review-summary strong{color:var(--text)}.filter-select{background:var(--surface2);border:1px solid var(--border);color:var(--text);cursor:pointer;-webkit-appearance:none;border-radius:8px;outline:none;padding:8px 12px;font-size:.8rem}.review-table-wrap{border:1px solid var(--border);-webkit-overflow-scrolling:touch;border-radius:10px;margin-bottom:16px;overflow:auto}.review-table{border-collapse:collapse;width:max-content;min-width:100%;font-size:.78rem}.review-table thead tr{background:var(--surface2);z-index:2;position:sticky;top:0}.review-table th{text-align:left;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;padding:9px 10px;font-size:.68rem;font-weight:600}.review-table td{border-top:1px solid var(--border);color:var(--text);white-space:nowrap;padding:7px 10px}.review-table tr.excluded-row td{opacity:.38;text-decoration:line-through}.review-table tr:hover td{background:#ffffff08}.amt-pos{color:var(--green);font-weight:600}.amt-neg{color:var(--red);font-weight:600}.excl-toggle-btn{border:1px solid var(--border);cursor:pointer;color:var(--muted);white-space:nowrap;-webkit-tap-highlight-color:transparent;touch-action:manipulation;background:0 0;border-radius:6px;min-height:36px;padding:3px 8px;font-size:.68rem;transition:all .15s}@media (width<=480px){.review-table-wrap{max-height:45vh}.review-table{font-size:.72rem}.review-table th{padding:7px 6px;font-size:.62rem}.review-table td{padding:6px}.excl-toggle-btn{padding:3px 6px;font-size:.62rem}}.app-header{border-bottom:1px solid var(--border);z-index:200;background:linear-gradient(135deg,#1a1d27 0%,#12162b 100%);justify-content:space-between;align-items:center;gap:10px;padding:14px 20px;display:flex;position:sticky;top:0}.logo{letter-spacing:-.3px;flex-shrink:0;align-items:center;gap:10px;font-size:1.1rem;font-weight:700;display:flex}.logo-icon{background:linear-gradient(135deg, var(--accent), var(--accent2));border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:1rem;display:flex}.header-right{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:8px;display:flex}.file-count-badge{background:var(--surface2);border:1px solid var(--border);color:var(--muted);white-space:nowrap;border-radius:20px;padding:4px 10px;font-size:.72rem}.header-actions{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.header-btn{padding:7px 12px;font-size:.78rem}.txn-btn-badge{background:var(--accent2);color:#fff;border-radius:10px;justify-content:center;align-items:center;min-width:18px;margin-left:2px;padding:1px 6px;font-size:.65rem;font-weight:700;display:inline-flex}.reset-label-short{display:none}@media (width<=480px){.app-header{flex-wrap:nowrap;gap:6px;padding:10px 12px}.logo span{display:none}.logo-icon{width:30px;height:30px;font-size:.9rem}.file-count-badge{padding:3px 8px;font-size:.65rem}.header-actions{gap:5px}.header-btn{padding:7px 10px;font-size:.75rem}.hide-on-mobile{display:none!important}.reset-label-full{display:none}.reset-label-short{display:inline}}@supports (padding:max(0px)){.app-header{padding-top:max(14px, env(safe-area-inset-top));padding-left:max(20px, env(safe-area-inset-left));padding-right:max(20px, env(safe-area-inset-right))}}.kpi-row{grid-template-columns:repeat(5,1fr);gap:12px;margin-bottom:16px;display:grid}@media (width<=900px){.kpi-row{grid-template-columns:repeat(3,1fr)}}@media (width<=600px){.kpi-row{grid-template-columns:repeat(2,1fr)}}@media (width<=380px){.kpi-row{grid-template-columns:1fr}}.kpi{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px 18px;position:relative;overflow:hidden}.kpi:before{content:"";height:3px;position:absolute;top:0;left:0;right:0}.kpi.income:before{background:var(--green)}.kpi.spent:before{background:var(--red)}.kpi.net:before{background:var(--accent)}.kpi.savings:before{background:var(--yellow)}.kpi.txns:before{background:var(--accent2)}.kpi-label{color:var(--muted);text-transform:uppercase;letter-spacing:.7px;margin-bottom:6px;font-size:.7rem}.kpi-value{letter-spacing:-.5px;font-size:1.4rem;font-weight:700}.kpi-value.pos{color:var(--green)}.kpi-value.neg{color:var(--red)}.kpi-value.neu{color:var(--accent)}.kpi-sub{color:var(--muted);margin-top:4px;font-size:.7rem}@media (width<=480px){.kpi-row{gap:8px;margin-bottom:12px;grid-template-columns:repeat(2,1fr)!important}.kpi{padding:12px 10px}.kpi-value{font-size:1rem}.kpi-label,.kpi-sub{font-size:.62rem}.kpi:nth-child(5){grid-column:1/-1}}.noUi-target,.noUi-target *{-webkit-touch-callout:none;-webkit-tap-highlight-color:#0000;-webkit-user-select:none;user-select:none;-ms-touch-action:none;touch-action:none;box-sizing:border-box}.noUi-target{position:relative}.noUi-base,.noUi-connects{z-index:1;width:100%;height:100%;position:relative}.noUi-connects{z-index:0;overflow:hidden}.noUi-connect,.noUi-origin{will-change:transform;z-index:1;transform-origin:0 0;width:100%;height:100%;-webkit-transform-style:preserve-3d;transform-style:flat;position:absolute;top:0;right:0}.noUi-txt-dir-rtl.noUi-horizontal .noUi-origin{left:0;right:auto}.noUi-vertical .noUi-origin{width:0;top:-100%}.noUi-horizontal .noUi-origin{height:0}.noUi-handle{backface-visibility:hidden;position:absolute}.noUi-touch-area{width:100%;height:100%}.noUi-state-tap .noUi-connect,.noUi-state-tap .noUi-origin{transition:transform .3s}.noUi-state-drag *{cursor:inherit!important}.noUi-horizontal{height:18px}.noUi-horizontal .noUi-handle{width:34px;height:28px;top:-6px;right:-17px}.noUi-vertical{width:18px}.noUi-vertical .noUi-handle{width:28px;height:34px;bottom:-17px;right:-6px}.noUi-txt-dir-rtl.noUi-horizontal .noUi-handle{left:-17px;right:auto}.noUi-target{background:#fafafa;border:1px solid #d3d3d3;border-radius:4px;box-shadow:inset 0 1px 1px #f0f0f0,0 3px 6px -5px #bbb}.noUi-connects{border-radius:3px}.noUi-draggable{cursor:ew-resize}.noUi-vertical .noUi-draggable{cursor:ns-resize}.noUi-handle{cursor:default;background:#fff;border:1px solid #d9d9d9;border-radius:3px;box-shadow:inset 0 0 1px #fff,inset 0 1px 7px #ebebeb,0 3px 6px -3px #bbb}.noUi-active{box-shadow:inset 0 0 1px #fff,inset 0 1px 7px #ddd,0 3px 6px -3px #bbb}.noUi-handle:before,.noUi-handle:after{content:"";background:#e8e7e6;width:1px;height:14px;display:block;position:absolute;top:6px;left:14px}.noUi-handle:after{left:17px}.noUi-vertical .noUi-handle:before,.noUi-vertical .noUi-handle:after{width:14px;height:1px;top:14px;left:6px}.noUi-vertical .noUi-handle:after{top:17px}[disabled] .noUi-connect{background:#b8b8b8}[disabled].noUi-target,[disabled].noUi-handle,[disabled] .noUi-handle{cursor:not-allowed}.noUi-pips,.noUi-pips *{box-sizing:border-box}.noUi-pips{color:#999;position:absolute}.noUi-value{white-space:nowrap;text-align:center;position:absolute}.noUi-value-sub{color:#ccc;font-size:10px}.noUi-marker{background:#ccc;position:absolute}.noUi-marker-sub,.noUi-marker-large{background:#aaa}.noUi-pips-horizontal{width:100%;height:80px;padding:10px 0;top:100%;left:0}.noUi-value-horizontal{transform:translate(-50%,50%)}.noUi-rtl .noUi-value-horizontal{transform:translate(50%,50%)}.noUi-marker-horizontal.noUi-marker{width:2px;height:5px;margin-left:-1px}.noUi-marker-horizontal.noUi-marker-sub{height:10px}.noUi-marker-horizontal.noUi-marker-large{height:15px}.noUi-pips-vertical{height:100%;padding:0 10px;top:0;left:100%}.noUi-value-vertical{padding-left:25px;transform:translateY(-50%)}.noUi-rtl .noUi-value-vertical{transform:translateY(50%)}.noUi-marker-vertical.noUi-marker{width:5px;height:2px;margin-top:-1px}.noUi-marker-vertical.noUi-marker-sub{width:10px}.noUi-marker-vertical.noUi-marker-large{width:15px}.noUi-tooltip{color:#000;text-align:center;white-space:nowrap;background:#fff;border:1px solid #d9d9d9;border-radius:3px;padding:5px;display:block;position:absolute}.noUi-horizontal .noUi-tooltip{bottom:120%;left:50%;transform:translate(-50%)}.noUi-vertical .noUi-tooltip{top:50%;right:120%;transform:translateY(-50%)}.noUi-horizontal .noUi-origin>.noUi-tooltip{bottom:10px;left:auto;transform:translate(50%)}.noUi-vertical .noUi-origin>.noUi-tooltip{top:auto;right:28px;transform:translateY(-18px)}.control-bar{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:16px;padding:18px 20px}.control-bar-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;margin-bottom:18px;display:flex}.control-bar-title{color:var(--muted);text-transform:uppercase;letter-spacing:.8px;font-size:.8rem;font-weight:600}.file-pill-list{flex-wrap:wrap;gap:6px;display:flex}.file-pill{background:var(--surface2);border:1px solid var(--border);color:var(--text);border-radius:20px;align-items:center;gap:5px;padding:4px 10px;font-size:.72rem;display:flex}.remove-file{color:var(--red);cursor:pointer;margin:-4px -4px -4px 2px;padding:4px;font-size:.78rem;font-weight:700;line-height:1}.slider-section{margin-bottom:18px}.slider-labels,.slider-values{color:var(--muted);justify-content:space-between;font-size:.75rem;display:flex}.slider-labels{margin-bottom:6px}.slider-values{color:var(--text);margin-top:14px;font-size:.82rem;font-weight:600}#date-slider{margin:8px 4px}.noUi-target{background:var(--surface2);box-shadow:none;border:none;height:6px}.noUi-connect{background:linear-gradient(90deg, var(--accent), var(--accent2))}.noUi-handle{border:2px solid var(--accent);cursor:grab;background:#fff;border-radius:50%;box-shadow:0 2px 8px #0006;width:22px!important;height:22px!important;top:-9px!important;right:-11px!important}.noUi-handle:active{cursor:grabbing}.noUi-handle:before,.noUi-handle:after{display:none}@media (width<=768px){.noUi-handle{width:28px!important;height:28px!important;top:-9px!important;right:-14px!important}}.bin-section{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.bin-label{color:var(--muted);white-space:nowrap;font-size:.8rem}.bin-toggle{background:var(--surface2);border:1px solid var(--border);border-radius:8px;flex-wrap:wrap;display:flex;overflow:hidden}.bin-btn{cursor:pointer;color:var(--muted);white-space:nowrap;-webkit-tap-highlight-color:transparent;touch-action:manipulation;background:0 0;border:none;min-height:36px;padding:7px 12px;font-size:.75rem;font-weight:600;transition:all .2s}.bin-btn.active{background:linear-gradient(135deg, var(--accent), var(--accent2));color:#fff}.salary-cycle-note{color:var(--accent);background:#4f8ef71a;border:1px solid #4f8ef733;border-radius:6px;padding:4px 10px;font-size:.72rem}@media (width<=480px){.control-bar{padding:12px}.control-bar-header{margin-bottom:12px}.bin-btn{padding:6px 9px;font-size:.7rem}.salary-cycle-note{padding:3px 7px;font-size:.65rem}.slider-values{font-size:.75rem}}.plu-divider{background:var(--border);height:1px;margin:16px 0}.plu-row{grid-template-columns:220px 1fr;align-items:start;gap:20px;display:grid}@media (width<=700px){.plu-row{grid-template-columns:1fr}}.plu-section-label{color:var(--muted);text-transform:uppercase;letter-spacing:.7px;margin-bottom:8px;font-size:.68rem;font-weight:700}.plu-search{background:var(--surface2);border:1px solid var(--border);width:100%;color:var(--text);box-sizing:border-box;border-radius:8px;outline:none;margin-bottom:8px;padding:7px 10px;font-size:.78rem}.plu-search:focus{border-color:var(--accent)}.plu-list{border:1px solid var(--border);-webkit-overflow-scrolling:touch;border-radius:8px;max-height:200px;margin-bottom:8px;overflow-y:auto}.plu-list-item{border-top:1px solid var(--border);cursor:pointer;color:var(--text);-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;align-items:center;gap:8px;padding:7px 10px;font-size:.78rem;transition:background .15s;display:flex}.plu-list-item:first-child{border-top:none}.plu-list-item:hover{background:var(--surface2)}.plu-list-item input[type=checkbox]{accent-color:var(--accent);flex-shrink:0}.plu-item-name{text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;overflow:hidden}.plu-item-amt{color:var(--muted);flex-shrink:0;font-size:.72rem}.plu-list-item.checked .plu-item-name{color:var(--accent);font-weight:600}.plu-list-actions{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.plu-toggle-label{color:var(--muted);cursor:pointer;align-items:center;gap:5px;margin-left:auto;font-size:.72rem;display:flex}.plu-toggle-label input{accent-color:var(--accent)}.plu-stats{background:var(--surface2);border:1px solid var(--border);border-radius:12px;margin-bottom:14px;padding:16px}.plu-stat-empty{color:var(--muted);text-align:center;padding:12px 0;font-size:.78rem}.plu-stat-grid{grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:12px;display:grid}@media (width<=480px){.plu-stat-grid{grid-template-columns:repeat(2,1fr)}}.plu-stat{text-align:center}.plu-stat-val{color:var(--text);font-size:1.15rem;font-weight:700}.plu-stat-val.neg{color:var(--red)}.plu-stat-val.pos{color:var(--green)}.plu-stat-lbl{color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin-top:3px;font-size:.65rem}.plu-stat-meta{color:var(--muted);font-size:.72rem;line-height:1.6}.plu-stat-meta strong{color:var(--text)}.plu-chart-label{color:var(--muted);text-transform:uppercase;letter-spacing:.7px;margin-bottom:8px;font-size:.68rem;font-weight:700}.plu-chart-wrap{height:160px;position:relative}.chart-grid{gap:16px;margin-bottom:16px;display:grid}.row-2{grid-template-columns:1fr 1fr}.row-1{grid-template-columns:1fr}@media (width<=900px){.row-2{grid-template-columns:1fr}}.chart-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:18px}.chart-card-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:10px;margin-bottom:16px;display:flex}.chart-title{color:var(--text);align-items:center;gap:8px;font-size:.9rem;font-weight:700;display:flex}.chart-subtitle{color:var(--muted);margin-top:3px;font-size:.72rem}.chart-wrap{width:100%;position:relative}.chart-wrap.h-300{height:300px}.chart-wrap.h-320{height:320px}.chart-wrap.h-360{height:360px}@media (width<=480px){.chart-grid{gap:10px}.chart-card{padding:12px 10px}.chart-card-header{gap:6px;margin-bottom:10px}.chart-title{font-size:.82rem}.chart-subtitle{font-size:.68rem}.chart-wrap.h-300,.chart-wrap.h-320,.chart-wrap.h-360{height:220px}}.section-gap{margin-bottom:16px}.section-divider{align-items:center;gap:16px;margin:28px 0 24px;display:flex}.section-divider-line{background:linear-gradient(90deg, transparent, var(--border), transparent);flex:1;height:1px}.section-divider-label{background:var(--surface);border:1px solid var(--border);color:var(--muted);text-transform:uppercase;letter-spacing:1px;white-space:nowrap;border-radius:20px;align-items:center;gap:8px;padding:6px 18px;font-size:.72rem;font-weight:700;display:flex;box-shadow:0 2px 12px #0000004d}.divider-dot{background:linear-gradient(135deg, var(--accent), var(--accent2));border-radius:50%;flex-shrink:0;width:6px;height:6px}@media (width<=480px){.section-divider{margin:18px 0 14px}.section-divider-label{padding:4px 12px;font-size:.65rem}.section-gap{margin-bottom:10px}}.spotlight-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:18px}.spotlight-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:16px;display:flex}.spotlight-title-group{flex:1;min-width:180px}.spotlight-badge{background:linear-gradient(135deg, var(--accent2), var(--accent));color:#fff;text-transform:uppercase;letter-spacing:.8px;border-radius:20px;align-items:center;gap:5px;margin-top:5px;padding:3px 10px;font-size:.65rem;font-weight:700;display:inline-flex}.spotlight-controls{align-items:center;gap:10px;display:flex}.spotlight-select{background:var(--surface2);border:1px solid var(--border);color:var(--text);cursor:pointer;border-radius:8px;min-width:200px;padding:6px 12px;font-size:.82rem}.spotlight-select:focus{border-color:var(--accent2);outline:none}.spotlight-kpi-row{grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:16px;display:grid}.spotlight-kpi{background:var(--surface2);border:1px solid var(--border);text-align:center;border-radius:10px;padding:12px 14px}.spotlight-kpi-label{color:var(--muted);text-transform:uppercase;letter-spacing:.6px;margin-bottom:6px;font-size:.68rem}.spotlight-kpi-value{font-size:1.2rem;font-weight:700}.spotlight-kpi-value.pos{color:var(--green)}.spotlight-kpi-value.neg{color:var(--red)}.spotlight-kpi-value.neu{color:var(--text)}.spotlight-chart-grid{grid-template-columns:1fr 1fr;gap:12px;margin-top:12px;display:grid}.spotlight-txn-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;margin-bottom:8px;display:flex}.spotlight-txn-count{color:var(--muted);font-size:.72rem}.spotlight-txn-list{border:1px solid var(--border);background:var(--surface2);border-radius:8px;max-height:280px;overflow-y:auto}.spotlight-txn-row{border-top:1px solid var(--border);align-items:center;gap:10px;padding:8px 12px;font-size:.8rem;transition:background .15s;display:flex}.spotlight-txn-row:first-child{border-top:none}.spotlight-txn-row:hover{background:var(--surface)}.spotlight-txn-payee{color:var(--text);text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;overflow:hidden}.spotlight-txn-date{color:var(--muted);white-space:nowrap;flex-shrink:0;font-size:.72rem}.spotlight-txn-amt{white-space:nowrap;flex-shrink:0;font-weight:700}.amt-pos{color:var(--green)}.amt-neg{color:var(--red)}.spotlight-empty{color:var(--muted);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:10px;padding:48px 24px;font-size:.85rem;display:flex}.spotlight-empty span{opacity:.5;font-size:2rem}@media (width<=700px){.spotlight-kpi-row{grid-template-columns:repeat(2,1fr)}.spotlight-chart-grid{grid-template-columns:1fr}}@media (width<=480px){.spotlight-card{padding:12px 10px}.spotlight-badge{display:none}.spotlight-select{width:100%;min-width:0;font-size:.78rem}.spotlight-controls{flex-direction:column;align-items:stretch;width:100%}.spotlight-kpi-row{grid-template-columns:repeat(2,1fr);gap:8px}.spotlight-kpi{padding:10px 8px}.spotlight-kpi-label{font-size:.62rem}.spotlight-kpi-value{font-size:1rem}.spotlight-chart-grid{grid-template-columns:1fr;gap:10px}.spotlight-txn-row{min-height:44px;padding:9px 10px}.spotlight-txn-payee{font-size:.78rem}.spotlight-txn-date{font-size:.68rem}.spotlight-txn-amt{font-size:.8rem}}@media (width>=381px) and (width<=480px){.spotlight-kpi-row{grid-template-columns:repeat(2,1fr)}}.drawer{-webkit-backdrop-filter:blur(18px)saturate(1.4);border-left:1px solid var(--border);z-index:501;background:#1a1d27eb;flex-direction:column;width:min(520px,55vw);height:calc(100vh - 63px);transition:transform .3s cubic-bezier(.4,0,.2,1);display:flex;position:fixed;top:63px;right:0;transform:translate(100%);box-shadow:-12px 0 48px #00000059}.drawer.open{transform:translate(0)}.drawer-open #dashboard{padding-right:min(520px,55vw);transition:padding-right .3s cubic-bezier(.4,0,.2,1)}.drawer-header{border-bottom:1px solid var(--border);background:#1a1d2799;flex-shrink:0;justify-content:space-between;align-items:center;gap:10px;padding:14px 18px;display:flex}.drawer-title{font-size:.95rem;font-weight:700}.drawer-header-right{align-items:center;gap:8px;display:flex}.drawer-count-label{color:var(--muted);white-space:nowrap;font-size:.72rem}.drawer-close{border:1px solid var(--border);background:var(--surface2);width:32px;height:32px;color:var(--text);cursor:pointer;-webkit-tap-highlight-color:transparent;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;font-size:1rem;transition:border-color .2s,color .2s;display:flex}.drawer-close:hover{border-color:var(--red);color:var(--red)}.drawer-body{-webkit-overflow-scrolling:touch;flex:1;padding:14px 18px;overflow-y:auto}.drawer-section{margin-bottom:14px}.payee-filter-wrap{-webkit-overflow-scrolling:touch;flex-wrap:wrap;gap:6px;max-height:100px;margin-bottom:12px;padding:4px 0;display:flex;overflow-y:auto}.payee-filter-chip{cursor:pointer;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;touch-action:manipulation;border:2px solid #0000;border-radius:20px;padding:4px 10px;font-size:.72rem;font-weight:600;transition:all .2s}.payee-filter-chip.active{opacity:1}.payee-filter-chip.inactive{opacity:.3}.drawer-controls{flex-direction:column;gap:8px;display:flex}.drawer-search-row{align-items:center;gap:6px;display:flex}.drawer-search-row .filter-select{flex-shrink:0;width:110px}.drawer-search-row .search-box{flex:1;min-width:0}.drawer-select-row{flex-wrap:wrap;gap:6px;display:flex}.drawer-select-row .filter-select{flex:1;min-width:80px}.drawer-bulk-row{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:6px;margin-top:4px;display:flex}.drawer-bulk-summary{color:var(--muted);font-size:.72rem}.drawer-filter-hint{color:var(--accent);margin-top:7px;font-size:.72rem}.filter-select{background:var(--surface2);border:1px solid var(--border);color:var(--text);cursor:pointer;border-radius:8px;outline:none;padding:7px 10px;font-size:.8rem}.filter-select:focus{border-color:var(--accent)}.search-box{background:var(--surface2);border:1px solid var(--border);color:var(--text);border-radius:8px;outline:none;padding:7px 10px;font-size:.8rem}.search-box:focus{border-color:var(--accent)}.expense-table-wrap{border:1px solid var(--border);-webkit-overflow-scrolling:touch;border-radius:8px;max-height:calc(100vh - 320px);overflow:auto}.txn-table{border-collapse:collapse;width:100%;font-size:.8rem}.txn-table thead tr{background:var(--surface2);z-index:2;position:sticky;top:0}.txn-table th{text-align:left;color:var(--muted);text-transform:uppercase;letter-spacing:.6px;cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap;padding:10px 12px;font-size:.68rem;font-weight:600;transition:color .15s}.txn-table th:hover,.txn-table th.sort-active{color:var(--accent)}.txn-table td{border-top:1px solid var(--border);color:var(--text);white-space:nowrap;padding:8px 12px}.txn-table tr:hover td{background:var(--surface2)}.txn-table tr.excluded-txn td{opacity:.4}.txn-table tr.excluded-txn td .payee-chip{text-decoration:line-through}.payee-chip{background:var(--surface2);border:1px solid var(--border);border-radius:6px;padding:2px 7px;font-size:.72rem;display:inline-block}.excl-badge{color:var(--red);vertical-align:middle;background:#f8717126;border:1px solid #f871714d;border-radius:4px;margin-left:4px;padding:1px 5px;font-size:.6rem;display:inline-block}.excl-toggle-btn{border:1px solid var(--border);cursor:pointer;color:var(--muted);white-space:nowrap;-webkit-tap-highlight-color:transparent;background:0 0;border-radius:6px;padding:3px 8px;font-size:.68rem;transition:all .15s}.excl-toggle-btn:hover{border-color:var(--red);color:var(--red)}.excl-toggle-btn.is-excluded{border-color:var(--green);color:var(--green)}.excl-toggle-btn.is-excluded:hover{border-color:var(--accent);color:var(--accent)}.pagination{color:var(--muted);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;margin-top:10px;font-size:.75rem;display:flex}.page-btns{flex-wrap:wrap;gap:5px;display:flex}.page-btn{background:var(--surface2);border:1px solid var(--border);color:var(--text);cursor:pointer;text-align:center;-webkit-tap-highlight-color:transparent;border-radius:6px;min-width:32px;padding:5px 10px;font-size:.75rem}.page-btn:hover,.page-btn.active{border-color:var(--accent);color:var(--accent)}.page-btn:disabled{opacity:.4;cursor:default}@media (width<=768px){.drawer{width:92vw}.drawer-open #dashboard{padding-right:0}}@media (width<=480px){.drawer{width:100vw;height:100vh;top:0}body.drawer-open{overflow:hidden}.drawer-header,.drawer-body{padding:12px 14px}.drawer-title{font-size:.88rem}.drawer-search-row .filter-select{width:95px;font-size:.78rem}.drawer-search-row .search-box{font-size:.78rem}.drawer-select-row{flex-wrap:nowrap}.drawer-select-row .filter-select{flex:1;min-width:0;padding:8px 4px;font-size:.72rem}.drawer-bulk-row{flex-direction:column;align-items:stretch}.drawer-bulk-actions{gap:6px;display:flex}.drawer-bulk-actions .btn{flex:1;justify-content:center;font-size:.72rem}.expense-table-wrap{max-height:calc(100vh - 460px)}.excl-badge{display:none}.excl-toggle-btn{min-height:44px;padding:3px 6px;font-size:.62rem}.payee-filter-chip{min-height:32px}}.chart-popup{z-index:600;background:var(--surface);border:1px solid var(--accent);pointer-events:all;border-radius:14px;min-width:220px;max-width:300px;padding:14px 16px;position:fixed;box-shadow:0 8px 32px #0009}.chart-popup-title{color:var(--text);white-space:nowrap;text-overflow:ellipsis;margin-bottom:4px;padding-right:20px;font-size:.82rem;font-weight:700;overflow:hidden}.chart-popup-meta{color:var(--muted);margin-bottom:12px;font-size:.72rem;line-height:1.5}.chart-popup-meta strong{color:var(--text)}.chart-popup-actions{flex-wrap:wrap;gap:7px;display:flex}.chart-popup-actions .btn{flex:1;justify-content:center;padding:6px 11px;font-size:.72rem}.chart-popup-close{color:var(--muted);cursor:pointer;background:0 0;border:none;padding:2px 4px;font-size:.9rem;line-height:1;position:absolute;top:8px;right:10px}.chart-popup-close:hover{color:var(--text)}@media (width<=480px){.chart-popup{max-width:none;position:fixed;inset:auto 16px 72px!important}}#mobile-bottom-nav{display:none}@media (width<=480px){#mobile-bottom-nav{z-index:300;background:var(--surface);border-top:1px solid var(--border);padding-bottom:env(safe-area-inset-bottom,0px);align-items:stretch;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -4px 20px #0000004d;display:flex!important}.mob-nav-btn{color:var(--muted);cursor:pointer;-webkit-tap-highlight-color:transparent;touch-action:manipulation;background:0 0;border:none;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:3px;min-height:56px;padding:8px 4px;transition:color .15s;display:flex}.mob-nav-btn:active{color:var(--accent);background:#4f8ef714}.mob-nav-icon{font-size:1.3rem;line-height:1}.mob-nav-label{letter-spacing:.3px;text-transform:uppercase;font-size:.58rem;font-weight:600}.mob-nav-danger{color:var(--red)}.mob-nav-danger:active{color:var(--red);background:#f8717114}}@media (width>=481px){#mobile-bottom-nav{display:none!important}}#dashboard{max-width:1600px;margin:0 auto;padding:16px}@media (width<=480px){#dashboard{padding:10px;padding-bottom:calc(56px + env(safe-area-inset-bottom,0px))}}@media (width>=481px) and (width<=768px){#dashboard{padding:12px}}
