*,: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}input,select,button,textarea{font-family:inherit}a,button,input,select,textarea,label,[role=button]{touch-action:manipulation}.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{padding:20px 16px 28px;padding-bottom:calc(28px + env(safe-area-inset-bottom,0px));border-radius:20px 20px 0 0;width:100%;max-width:100%;max-height:92dvh}.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}}.drawer-body,.plu-panel-body,.expense-table-wrap,.spotlight-txn-list,.plu-list,.review-table-wrap,.payee-filter-wrap{-webkit-overflow-scrolling:touch;overscroll-behavior-y:contain;overflow-y:scroll}@media (height<=500px) and (orientation:landscape){.app-header{min-height:48px!important;padding:8px 16px!important}.h-320{height:200px}.chart-wrap.h-300{height:180px}.modal-backdrop{align-items:center;padding:8px}.modal-box{border-radius:16px;max-width:560px;max-height:90dvh}.modal-box.wide{border-radius:16px;max-width:700px}.mobile-bottom-nav{display:none!important}.spotlight-accordion{margin-top:8px}}@media (width<=480px){.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}}.masarif-logo{letter-spacing:-.3px;flex-shrink:0;align-items:center;gap:10px;font-weight:700;display:flex}.masarif-logo-icon{color:#fbbf24;background:#0f1117;border:1px solid #2e3250;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;font-family:Amiri,Noto Naskh Arabic,Traditional Arabic,Arabic Typesetting,serif;font-weight:700;line-height:1;display:flex;position:relative;overflow:hidden}.masarif-meem{z-index:2;position:relative}.masarif-chart-bg{opacity:.18;z-index:1;pointer-events:none;width:100%;height:100%;position:absolute;inset:0}.masarif-logo-name{color:var(--text)}.masarif-logo--sm .masarif-logo-icon{border-radius:8px;width:30px;height:30px;font-size:1.05rem}.masarif-logo--sm .masarif-logo-name{font-size:1rem}.masarif-logo--md .masarif-logo-icon{border-radius:10px;width:34px;height:34px;font-size:1.2rem}.masarif-logo--md .masarif-logo-name{font-size:1.1rem}.masarif-logo--lg{flex-direction:column;align-items:center;gap:16px}.masarif-logo--lg .masarif-logo-icon{border-width:1.5px;border-radius:22px;width:80px;height:80px;font-size:3.2rem}.masarif-logo--lg .masarif-logo-name{letter-spacing:1px;font-size:1.8rem}.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-logo-wrap{justify-content:center;margin-bottom:20px;display:flex}.upload-cancel-btn{color:var(--muted);margin-top:10px;font-size:.82rem}.upload-cancel-btn:hover{color:var(--text)}.upload-credit{color:var(--muted);opacity:.6;margin-top:24px;font-size:.72rem;font-style:italic}.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-wrap{border:1px solid var(--border);scrollbar-width:thin;scrollbar-color:var(--border) transparent;border-radius:10px;max-height:220px;margin-bottom:20px;padding:8px;overflow:hidden auto}.currency-grid-wrap::-webkit-scrollbar{width:6px}.currency-grid-wrap::-webkit-scrollbar-track{background:0 0}.currency-grid-wrap::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.currency-grid{grid-template-columns:repeat(4,1fr);gap:8px;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:10px;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}.review-pagination{color:var(--muted);justify-content:space-between;align-items:center;margin-top:8px;font-size:.72rem;display:flex}.page-btn:hover{border-color:var(--accent);color:var(--accent)}.dedup-banner{border-radius:8px;margin-bottom:10px;padding:9px 12px;font-size:.76rem;line-height:1.45}.dedup-banner-ok{color:var(--green);background:#34d39914;border:1px solid #34d3994d}.dedup-banner-warn{color:var(--yellow);background:#fbbf241a;border:1px solid #fbbf2459}.dedup-banner-info{color:var(--accent);background:#4f8ef714;border:1px solid #4f8ef74d}.dedup-summary-line{margin-bottom:2px}.dedup-info-btn{color:inherit;cursor:pointer;opacity:.75;-webkit-tap-highlight-color:transparent;vertical-align:middle;background:0 0;border:1px solid;border-radius:50%;padding:1px 4px;font-size:.7rem;line-height:1;transition:opacity .15s}.dedup-info-btn:hover{opacity:1}.dedup-info-box{color:var(--text);background:#00000040;border:1px solid #fbbf2433;border-radius:8px;margin-top:8px;padding:10px 12px;font-size:.72rem;line-height:1.55}.dedup-info-box ul{margin:6px 0;padding-left:18px}.dedup-info-box li{margin-bottom:3px}.dedup-show-more-btn{border:1px dashed var(--border);color:var(--accent);cursor:pointer;text-align:center;-webkit-tap-highlight-color:transparent;background:0 0;border-radius:6px;width:100%;margin-top:6px;padding:6px 12px;font-size:.72rem}.dedup-show-more-btn:hover{border-color:var(--accent)}.dedup-show-less-btn{color:var(--muted);margin-top:2px}.dedup-row-serial{color:var(--muted);text-align:right;align-self:center;padding-right:4px;font-size:.65rem;font-weight:600}.dedup-banner-toggle{color:inherit;cursor:pointer;text-align:left;-webkit-tap-highlight-color:transparent;background:0 0;border:none;padding:0;font-size:.76rem}.dedup-banner-toggle:hover{opacity:.8}.dedup-auto-list{flex-direction:column;gap:4px;margin-top:8px;display:flex}.dedup-bulk-row{gap:6px;margin-bottom:6px;display:flex}.dedup-auto-row{opacity:.8;border-top:1px solid #4f8ef726;grid-template-columns:24px 130px 90px 1fr 1fr auto;gap:8px;padding:3px 0;font-size:.72rem;display:grid}.dedup-flagged-list{flex-direction:column;gap:10px;margin-top:10px;display:flex}.dedup-flagged-group{border:1px solid #fbbf2433;border-radius:6px;overflow:hidden}.dedup-flagged-group-label{text-transform:uppercase;letter-spacing:.5px;color:var(--muted);background:#0003;padding:4px 8px;font-size:.65rem;font-weight:700}.dedup-flagged-row{align-items:center;opacity:1!important;border-top:1px solid #fbbf241f!important;grid-template-columns:24px 52px 130px 90px 1fr 1fr auto!important;padding:5px 8px!important}.dedup-row-kept{background:#34d3990d}.dedup-row-excl{background:#f871710d;opacity:.65!important}.dedup-row-existing{background:#4f8ef70d;opacity:.7!important}.dedup-row-badge{text-transform:uppercase;letter-spacing:.4px;white-space:nowrap;border-radius:4px;padding:2px 5px;font-size:.6rem;font-weight:700}.dedup-row-kept .dedup-row-badge{color:var(--green);background:#34d39926}.dedup-row-excl .dedup-row-badge{color:var(--red);background:#f8717126}.dedup-row-existing .dedup-row-badge{color:var(--accent);background:#4f8ef726}.review-table tr.near-dupe-row td{border-left:2px solid #fbbf2480}@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}}.ug-backdrop{z-index:502;background:#00000073;animation:.2s ug-fade-in;position:fixed;inset:0}@keyframes ug-fade-in{0%{opacity:0}to{opacity:1}}.ug-panel{-webkit-backdrop-filter:blur(18px)saturate(1.4);border-left:1px solid var(--border);z-index:503;background:#1a1d27f7;flex-direction:column;width:min(420px,90vw);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 #0006}.ug-panel.open{transform:translate(0)}.ug-header{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:14px 18px;display:flex}.ug-title{font-size:.95rem;font-weight:700}.ug-close{border:1px solid var(--border);background:var(--surface2);width:32px;height:32px;color:var(--text);cursor:pointer;-webkit-tap-highlight-color:transparent;touch-action:manipulation;border-radius:8px;justify-content:center;align-items:center;font-size:1rem;transition:border-color .2s,color .2s;display:flex}.ug-close:hover{border-color:var(--red);color:var(--red)}.ug-body{overscroll-behavior-y:contain;-webkit-overflow-scrolling:touch;flex:1;padding:18px;overflow-y:scroll}.ug-section{margin-bottom:22px}.ug-section-title{color:var(--accent);margin-bottom:8px;font-size:.85rem;font-weight:700}.ug-list{flex-direction:column;gap:7px;margin:0;padding:0;list-style:none;display:flex}.ug-list li{color:var(--text);padding-left:14px;font-size:.78rem;line-height:1.5;position:relative}.ug-list li:before{content:"·";color:var(--muted);position:absolute;left:0}@media (width<=480px){.ug-panel{width:100vw;height:100dvh;padding-top:env(safe-area-inset-top,0px);top:0}.ug-body{padding-bottom:calc(18px + env(safe-area-inset-bottom,0px))}}.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}.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}.masarif-logo-name{display:none}.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}}.header-guide-btn{width:32px;height:32px;color:var(--muted);border-color:var(--border);border-radius:50%;flex-shrink:0;padding:0;font-size:.85rem;font-weight:700}.header-guide-btn:hover{color:var(--accent);border-color:var(--accent)}@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}}.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-backdrop{z-index:500;background:#00000073;animation:.2s drawer-fade-in;position:fixed;inset:0}@keyframes drawer-fade-in{0%{opacity:0}to{opacity: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}.filter-pills-row{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.filter-pill{color:var(--accent);background:#4f8ef71f;border:1px solid #4f8ef766;border-radius:20px;align-items:center;gap:4px;padding:3px 8px 3px 10px;font-size:.72rem;display:inline-flex}.filter-pill-label{white-space:nowrap}.filter-pill-remove{color:var(--accent);cursor:pointer;opacity:.7;-webkit-tap-highlight-color:transparent;background:0 0;border:none;padding:0 2px;font-size:.65rem;line-height:1;transition:opacity .15s}.filter-pill-remove:hover{opacity:1}.filter-mode-btn{border:1px solid var(--border);background:var(--surface2);letter-spacing:.5px;cursor:pointer;-webkit-tap-highlight-color:transparent;min-width:36px;color:var(--muted);border-radius:20px;justify-content:center;align-items:center;padding:3px 8px;font-size:.65rem;font-weight:700;transition:all .15s;display:inline-flex}.filter-mode-btn.and{border-color:var(--green);color:var(--green);background:#34d39914}.filter-mode-btn.or{border-color:var(--yellow);color:var(--yellow);background:#fbbf2414}.filter-mode-btn:hover{opacity:.8}.filter-clear-btn{color:var(--muted);padding:4px 10px;font-size:.7rem}.filter-add-btn{color:var(--accent);border-color:#4f8ef759;padding:6px 12px;font-size:.75rem}.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}}@media (width<=480px){.drawer{width:100vw;height:100dvh;padding-top:env(safe-area-inset-top,0px);top:0}body.drawer-open{overflow:hidden}.drawer-header{padding:12px 14px}.drawer-body{padding:12px 14px;padding-bottom:calc(12px + env(safe-area-inset-bottom,0px))}.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}}.charts-loading{min-height:200px;color:var(--muted);justify-content:center;align-items:center;font-size:.82rem;display:flex}#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}}.spotlight-accordion{border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);margin-top:28px;overflow:hidden}.spotlight-accordion-header{background:var(--surface);cursor:pointer;border:none;justify-content:space-between;align-items:center;width:100%;padding:16px 20px;transition:background .2s;display:flex}.spotlight-accordion-header:hover{background:var(--surface2)}.spotlight-accordion-title{color:var(--text);align-items:center;gap:10px;font-size:.95rem;font-weight:700;display:flex}.spotlight-accordion-sub{color:var(--muted);letter-spacing:.5px;font-size:.72rem;font-weight:500}.spotlight-accordion-chevron{color:var(--accent);letter-spacing:.5px;text-transform:uppercase;font-size:.72rem;font-weight:700}@media (width<=480px){.spotlight-accordion{margin-top:18px}.spotlight-accordion-header{padding:14px}.spotlight-accordion-sub{display:none}}
