*,:after,:before{box-sizing:border-box}body,html{margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:#f6f6f7;color:#111}button,select{font:inherit}.shell{min-height:100vh}.header{background:#0c3546;color:#fff;padding:24px 36px 20px}.header-top{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:18px;flex-wrap:wrap}.header h1{color:#ccc;font-size:14px;font-weight:400;margin:-10px 0 0}.header-title{display:flex;flex-direction:column}.header-card-name{color:#fffd;margin:0;padding-top:6px;padding-bottom:20px;font-size:28px;font-weight:700}.month-selector{display:none}.ghost-button{border:0;background:#777;color:#fff;margin-top:-24px;border-radius:0 0 8px 8px;padding:5px 12px;cursor:pointer;max-width:80px}.ghost-button:hover{background:#f90}.header-cards{display:flex;gap:16px;flex-wrap:wrap;justify-content:center}.stat{background:#1b627e;border-radius:12px;padding:12px 18px;min-width:220px}.stat:hover{background:#f90}.stat-clickable{cursor:pointer}.stat-active{background:#2c8aaf}.stat-label{color:#eee;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;margin-bottom:18px}.stat-value{font-size:26px;font-weight:700}.stat-value.accent{color:#fff}.stat-sub{margin-top:12px;color:#eee;font-size:12px}.tabs{gap:8px;margin-bottom:20px;padding:0 36px;background:#fff;position:-webkit-sticky;position:sticky;top:0;z-index:100;box-shadow:0 4px 12px rgba(0,0,0,.06)}.nav-tab,.tabs{display:flex;align-items:center;font-size:15px}.nav-tab{border:0;border-bottom:3px solid transparent;background:transparent;color:#aaaaaa;padding:14px 8px 12px;font-weight:600;cursor:pointer;white-space:nowrap;gap:4px}.nav-tab.active{color:#111;border-bottom:5px solid #111}.nav-tab:hover:not(.active){color:#444}.nav-tab-chevron{width:16px;height:16px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;flex-shrink:0}.nav-tab-year{gap:2px}.nav-tab-year .nav-tab-chevron{display:none}.nav-month-tabs{display:none;align-items:center;gap:4px;overflow-x:auto}.nav-month-selector{display:flex;align-items:center;position:relative}.nav-month-selector select{appearance:none;-webkit-appearance:none;-moz-appearance:none;background:transparent;border:0;border-bottom:3px solid transparent;border-radius:0;color:#7b7b7b;padding:14px 22px 12px 8px;font-weight:600;font-size:15px;cursor:pointer;min-width:0}.nav-month-selector .nav-tab-chevron{position:absolute;right:2px;pointer-events:none}.nav-month-selector.active select,.nav-month-selector:has(select:focus) select{color:#111;border-bottom:5px solid #111}.nav-month-selector.active .nav-tab-chevron,.nav-month-selector:has(select:focus) .nav-tab-chevron{color:#111}@media (min-width:1360px){.nav-month-tabs{display:flex}.nav-month-selector{display:none}}.content{padding:28px 36px 40px}@media (min-width:761px){.content.content-monthly{max-width:50%;margin-left:auto;margin-right:auto}}.section-title{margin:0 0 24px;color:#666;font-size:14px;font-weight:700;text-transform:uppercase;letter-spacing:.05em}.section-title:not(:first-child){margin-top:40px}.section-heading{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px}.section-heading-spaced{margin-top:40px}.section-heading .section-title{margin:0}.filter-pills{display:flex;flex-wrap:wrap;gap:8px;margin-top:0;margin-bottom:20px}.filter-pill{display:inline-flex;align-items:center;gap:6px;padding:5px 12px;border:none;border-radius:20px;color:#fff;font-size:12px;font-weight:500;cursor:pointer}.filter-pill-x{font-size:15px;line-height:1;opacity:.7}.filter-icon-button{position:relative;width:36px;height:36px;margin-right:6px;border:0;border-radius:999px;background:#4ea7ca;color:#fff;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 1px 2px rgba(15,23,42,.06)}.filter-icon-button:hover{background:#f90}.filter-icon-button.active{border-color:#0c3546;background:#0c3546;color:#fff;margin-bottom:-50px}.filter-icon{width:20px;height:20px;fill:none;stroke:currentColor;stroke-linecap:round;stroke-linejoin:round;stroke-width:2}.filter-count{position:absolute;top:-6px;right:-6px;min-width:20px;height:20px;padding:0 6px;border-radius:999px;background:#f90;color:#fff;font-size:11px;font-weight:700;line-height:20px;text-align:center;box-shadow:0 6px 14px rgba(15,23,42,.18)}.cat-list{display:flex;flex-direction:column;margin-left:-10px;margin-right:-10px;padding-left:10px;padding-right:10px}.cat-row{display:flex;align-items:center;gap:12px;padding:12px 0;border-bottom:1px solid #e5e5e5;cursor:pointer}.cat-row:last-child{border-bottom:none}.cat-row:hover{background:#fff8}.cat-row.active,.cat-row:hover{margin-top:-1px;margin-left:-10px;margin-right:-10px;padding-left:10px;padding-right:10px;border-top:1px solid #e5e5e5}.cat-row.active{background:#fff}.cat-dot{display:inline-block;width:8px;height:8px;border-radius:999px;flex-shrink:0}.annual-table .cat-dot{margin-right:12px}.cat-name{font-size:16px;font-weight:500;flex:1 1;color:#111}.cat-pct{font-size:14px;color:#888;font-weight:500;width:60px;text-align:center}.cat-amount{font-size:15px;font-weight:500;text-align:right;min-width:100px}.cat-view-toggle{display:flex;gap:0;border:1px solid #ddd;border-radius:999px;overflow:hidden;flex-shrink:0}.cat-view-btn{background:transparent;border:none;padding:5px 14px;font-size:12px;font-weight:600;color:#888;cursor:pointer;text-transform:uppercase;letter-spacing:.03em;transition:background .15s,color .15s}.cat-view-btn:not(:last-child){border-right:1px solid #ddd}.cat-view-btn.active{background:#77c0dd;color:#fff}.cat-view-btn:not(.active):hover{background:#f0f0f0}.cat-chart-wrap{display:flex;flex-direction:column;align-items:center;gap:16px}.cat-chart-legend{display:flex;flex-wrap:wrap;justify-content:center;gap:8px 20px;max-width:768px}.cat-chart-legend-item{display:flex;align-items:center;gap:6px;cursor:pointer;transition:opacity .15s;padding:4px 0}.cat-chart-legend-item:hover{opacity:1!important}.cat-chart-legend-item.active{font-weight:600}.cat-chart-legend-name{font-size:13px;color:#333}.cat-chart-legend-pct{font-size:12px;color:#888}.table-wrap{overflow-x:auto}.annual-table,.tx-table{width:100%;border-collapse:collapse;background:#fff;border-radius:12px;overflow:hidden}.annual-table th,.tx-table th{background:#77c0dd;color:#fff;padding:11px 14px;text-align:left;font-size:11px;text-transform:uppercase;letter-spacing:.06em;white-space:nowrap}.annual-table td:first-child{font-weight:500;width:200px}.annual-table td:not(:first-child),.annual-table th:not(:first-child){text-align:right}.annual-cat-pct,.annual-cat-pct-col{text-align:left!important;width:80px}.tx-table th.sortable{cursor:pointer}.tx-table th.sortable:hover{background:#418ead}.tx-table th.sort-active{background:#4ea7ca}.sort-chevron{display:inline-block;vertical-align:middle;margin-left:3px;color:#fff;transition:transform .2s ease}.annual-table td,.tx-table td{padding:11px 14px;border-bottom:1px solid #f0f0f0;white-space:nowrap;vertical-align:middle}.annual-table tr:last-child td,.tx-table tr:last-child td{border-bottom:none}tr:hover td{background:#fafafa}.amount-cell,.amount-head,.tx-table th.amount-head{text-align:right}.amount-cell{font-weight:500;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.amount-cell.negative,.tx-card-amount.negative{color:#0f8f4b}.rule-tag{margin-left:6px;color:#a7a7a7;font-size:11px}.cat-select{border:0;border-radius:999px;padding:6px 12px;font-size:12px;font-weight:600;max-width:100%}.tx-cards{display:none}.tx-card{background:#fff;border-radius:12px;padding:14px 16px;cursor:pointer;border:2px solid transparent;transition:box-shadow .15s ease,border-color .15s ease}.tx-card:hover{border-color:#ccc}.tx-card:focus-visible{outline:none;border-color:#1a1a1a;box-shadow:0 0 0 3px rgba(26,26,26,.08)}.tx-card+.tx-card{margin-top:10px}.tx-card-top{display:flex;justify-content:space-between;gap:12px;align-items:baseline}.tx-card-merchant{font-weight:500;min-width:0}.tx-card-amount{font-weight:500;flex-shrink:0;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.tx-card-bottom{display:flex;align-items:center;gap:8px;color:#888;font-size:12px;margin:10px 0 0}.tx-card-cat{display:inline-flex;align-items:center;border:0;border-radius:999px;padding:2px 8px;font-size:10px;font-weight:700;line-height:1.2}.filter-overlay{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;padding:24px;background:rgba(0,0,0,.42);z-index:1050;animation:sheetOverlayFadeIn .18s ease-out}.filter-overlay.hidden{display:none}.filter-panel{width:min(100%,460px);max-height:min(80vh,680px);overflow:hidden;display:flex;flex-direction:column;background:#fff;border-radius:18px;box-shadow:0 24px 60px rgba(0,0,0,.24);animation:sheetSlideUp .45s cubic-bezier(.22,1,.36,1)}.filter-panel-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:20px 20px 12px;border-bottom:1px solid #f0f0f0}.filter-title{font-size:18px;font-weight:700}.filter-subtitle{margin:6px 0 10px;color:#111;font-size:13px}.filter-close{border:0;background:transparent;color:#6b7280;font-size:28px;line-height:1;cursor:pointer}.filter-list{display:flex;flex-direction:column;gap:10px;overflow-y:auto;padding:15px 20px 30px 15px}.filter-option{display:grid;grid-template-columns:auto auto 1fr auto;align-items:center;grid-gap:12px;gap:12px;border:0;border-radius:6px;padding:9px;cursor:pointer}.filter-option:hover{background:#f5f5f5}.filter-option.active{background:#f5f5e5}.filter-option input{width:16px;height:16px;margin:0;accent-color:#1a1a1a}.filter-option-dot{width:10px;height:10px;border-radius:999px}.filter-option-name{min-width:0;font-weight:500}.filter-option-total{color:#6b7280;font-size:13px;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.filter-actions{display:flex;justify-content:flex-end;gap:10px;padding:16px 20px 20px;border-top:1px solid #f0f0f0}.filter-primary,.filter-secondary{border-radius:10px;padding:10px 14px;font-weight:700;cursor:pointer}.filter-secondary{border:1px solid #d1d5db;background:#fff;color:#111}.filter-primary{border:0;background:#f90;color:#fff}.filter-primary:hover{background:#f70}.filter-secondary:hover{background:#f0f0f0}.sheet-overlay{position:fixed;inset:0;display:flex;align-items:flex-end;justify-content:center;background:rgba(0,0,0,.42);z-index:1100;animation:sheetOverlayFadeIn .18s ease-out}.sheet-overlay.hidden{display:none}.sheet{width:min(100%,480px);max-height:80vh;overflow-y:auto;background:#fff;border-radius:18px 18px 0 0;padding:12px 20px 28px;box-shadow:0 -18px 48px rgba(0,0,0,.18);animation:sheetSlideUp .45s cubic-bezier(.22,1,.36,1)}.sheet-handle{width:38px;height:4px;border-radius:999px;background:#d1d5db;margin:0 auto 14px}.sheet-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:20px}.sheet-title{font-size:18px;font-weight:700}.sheet-close{border:0;background:transparent;color:#6b7280;font-size:28px;line-height:1;cursor:pointer}.sheet-summary{display:flex;flex-direction:column;gap:4px;padding:12px 14px;border-radius:12px;background:#f5f5f5;color:#4b5563;font-size:15px;margin-bottom:14px}.sheet-summary strong{color:#111}.sheet-options{display:flex;flex-direction:column;gap:8px}.sheet-option{display:flex;align-items:center;gap:10px;width:100%;border:0;border-radius:12px;background:#fff;padding:9px 14px;text-align:left;cursor:pointer;font-weight:500;color:#111;-webkit-text-fill-color:#111}.sheet-option:hover{background:#f4f4f4}.sheet-option.active{outline:2px solid #ddd}.sheet-option-dot{width:12px;height:12px;border-radius:999px;flex-shrink:0}@keyframes sheetOverlayFadeIn{0%{opacity:0}to{opacity:1}}@keyframes sheetSlideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.annual-table .total-row td{font-weight:600;background:#fff;border-top:2px solid #ddd}.year-total-cell{font-weight:600}.dash{color:#c0c0c0}.annual-cat-pct{color:#888;font-size:15px;font-weight:400}.annual-line-chart{background:#fff;border-radius:12px;padding:20px 8px 12px;margin-bottom:20px}.annual-mobile{display:none}.annual-acc{border-bottom:1px solid #e5e5e5}.annual-acc:last-child,.annual-acc:nth-last-child(2){border-bottom:none}.annual-acc-header{display:flex;align-items:center;gap:12px;width:100%;padding:12px 0;border:none;background:none;color:#111;cursor:pointer;font:inherit;text-align:left}.annual-acc-name{flex:1 1;font-size:16px;font-weight:500}.annual-acc-pct{font-size:14px;color:#888;font-weight:500;width:60px;text-align:center}.annual-acc-total{font-size:15px;font-weight:500;white-space:nowrap;min-width:100px;text-align:right}.annual-acc-chevron{color:#999;flex-shrink:0;transition:transform .3s ease}.annual-acc-chevron.expanded{transform:rotate(180deg)}.annual-acc-body-wrap{display:grid;grid-template-rows:0fr;transition:grid-template-rows .3s ease}.annual-acc-body-wrap.expanded{grid-template-rows:1fr}.annual-acc-body{overflow:hidden;padding:0}.annual-acc-body-wrap.expanded .annual-acc-body{padding:0 0 10px}.annual-acc-row{display:flex;justify-content:space-between;padding:7px 0;border-top:1px solid #e5e5e5;font-size:15px}.annual-acc-row:last-child{padding-bottom:20px}.annual-acc-month{color:#666;font-size:16px;margin-left:21px}.annual-acc-month-value{font-weight:400;color:#666;padding-right:21px}.annual-acc-footer{border-bottom:none;margin-top:20px}.annual-acc-footer .annual-acc-header{cursor:default;padding:15px 21px;background:#fff;border-radius:8px}.annual-acc-footer .annual-acc-total,.annual-acc-total-label{font-weight:700}.rule-toast{position:fixed;left:50%;bottom:50px;transform:translateX(-50%);display:flex;align-items:center;gap:12px;max-width:650px;width:calc(100% - 48px);background:#0c3546;color:#fff;padding:14px 16px;border-radius:12px;box-shadow:0 18px 40px rgba(0,0,0,.2);z-index:1000}.rule-toast-overlay{position:fixed;inset:0;z-index:999}.rule-toast.hidden{display:none}.rule-toast-text{font-size:15px}.btn-no,.btn-yes{border-radius:8px;padding:8px 12px;cursor:pointer;white-space:nowrap}.btn-yes{border:0;background:#f80;color:#fff;font-weight:600}.btn-yes:hover{background:#f60}.btn-no{border:2px solid #4b5563;background:transparent;color:#d1d5db}.btn-no:hover{background:#4b5563;color:#fff}.btn-no:disabled,.btn-yes:disabled{cursor:wait;opacity:.7}.empty-state,.error-banner{background:#fff;border-radius:12px;padding:16px}.error-banner{border:1px solid #fecaca;color:#b91c1c;margin-bottom:18px}.auth-shell{height:100vh;height:100dvh;overflow:hidden;display:grid;place-items:center;padding:24px;background:#0c3546}.auth-card{width:min(100%,420px);margin-top:-140px;padding:28px}.auth-copy{margin-bottom:30px}.auth-kicker{margin:0;color:#f90;font-size:15px;font-weight:700;text-transform:none;letter-spacing:0}.auth-copy h1{margin:0 0 8px;font-size:32px;color:#ddd}.auth-form{display:flex;flex-direction:column;gap:12px}.auth-label{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:#aaa}.auth-input{width:100%;border:0;border-radius:12px;padding:12px 14px;font-size:16px;background:#fff}.auth-input:focus{outline:none;border-color:#1a1a1a}.auth-input-wrapper{position:relative}.auth-input-wrapper .auth-input{padding-right:42px}.auth-eye{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;padding:0;cursor:pointer;color:#aaa;display:flex;align-items:center}.auth-eye:hover{color:#555}.auth-button{border:0;border-radius:12px;background:#418ead;color:#fff;padding:12px 14px;font-weight:700;cursor:pointer}.auth-button:hover{background:#f90}.auth-button:disabled{opacity:.65;cursor:wait}.auth-error{margin:0;color:#f90;font-size:13px}.auth-actions{display:flex;gap:10px}.auth-actions .auth-button{flex:1 1}.auth-demo-button{background:#92b792;color:#fff}.auth-demo-button:hover{background:#759275}.demo-badge{display:inline-block;background:#f80;color:#ffffff;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;padding:2px 10px 3px;border-radius:999px;margin-top:-5px;margin-left:8px;vertical-align:middle}.auth-shell footer p a{color:#f90}.app-footer{padding:32px 16px 24px;font-size:13px;color:#fff;line-height:1.15;text-align:center}.app-footer p{margin:0;color:#666}.app-footer-fixed p{color:#ccc}.app-footer-dark{color:#777}.app-footer-link{color:#f90;text-decoration:none;font-weight:600}.app-footer-link:hover{color:#f90;border-bottom:1px solid #f90}.app-footer-update{color:#f90}.app-footer-fixed{position:fixed;bottom:0;left:0;width:100%}@media (max-width:760px){.content,.header{padding-left:16px;padding-right:16px}.tabs{padding:0 16px}.stat{min-width:0;width:100%}.stat:hover{background:#1b627e}.stat-active:hover{background:#2c8aaf}.cat-row,.stat-clickable{cursor:default}.cat-row{pointer-events:none}.cat-row:hover{margin-top:0;margin-left:0;margin-right:0;padding-left:0;padding-right:0;border-top:none}.cat-row:hover,.filter-option:hover{background:none}.filter-primary:hover{background:#f90}.filter-secondary:hover{background:#fff}.sheet-option:hover{background:none}.tx-table{display:none}.tx-cards{display:block}.annual-desktop{display:none}.annual-mobile{display:block}.tx-card:hover{border-color:transparent}.tx-card-bottom{color:#000;font-size:13px}.tx-card-cat{font-size:12px;padding:3px 8px}.filter-overlay{align-items:flex-end;padding:0}.filter-panel{width:100%;max-height:80vh;border-radius:18px 18px 0 0}.filter-actions{display:grid;grid-template-columns:1fr 1fr}.filter-primary,.filter-secondary,.sheet{width:100%}.rule-toast{left:16px;right:16px;bottom:16px;width:auto;transform:none;flex-direction:column;align-items:stretch}.auth-card{padding:22px}}