*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--accent:#534ab7;--page-bg:#f5f4f0;--green-600:#3b6d11;--amber-600:#854f0b;--coral-600:#993c1d}html,body{width:100%;min-height:100vh;overflow-x:hidden}body{background:var(--page-bg);color:#1a1a1a;-webkit-font-smoothing:antialiased;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}#root{width:100%;min-height:100vh}.app{background:var(--page-bg);max-width:480px;min-height:100vh;margin:0 auto}.app-header{z-index:10;background:#fff;border-bottom:.5px solid #e0ddd6;padding:1rem 1.25rem .875rem;position:sticky;top:0}.header-row{justify-content:space-between;align-items:center;display:flex}.header-title{color:#1a1a1a;font-size:17px;font-weight:600}.header-period{color:#888;font-size:13px}.header-right{align-items:center;gap:.5rem;display:flex}.pending-badge{color:var(--accent);white-space:nowrap;background:#edeaf8;border-radius:20px;padding:3px 10px;font-size:12px;font-weight:600}.refresh-btn{cursor:pointer;color:#aaa;background:0 0;border:none;align-items:center;padding:2px;display:flex}.signin-wrap{flex-direction:column;justify-content:center;align-items:center;min-height:80vh;display:flex}.signin-card{text-align:center;background:#fff;border-radius:16px;width:90%;max-width:360px;padding:2rem;box-shadow:0 2px 16px #00000014}.signin-title{color:var(--accent);margin-bottom:.5rem;font-size:20px;font-weight:700}.signin-prompt{color:#666;margin-bottom:1.25rem}.bottom-nav{z-index:50;background:#fff;border-top:.5px solid #e0ddd6;width:100%;max-width:480px;height:56px;display:flex;position:fixed;bottom:0;left:50%;transform:translate(-50%)}.nav-tab{cursor:pointer;color:#aaa;background:0 0;border:none;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:3px;padding:0;display:flex}.nav-tab.active{color:var(--accent)}.nav-icon{width:22px;height:22px}.nav-tab-label{letter-spacing:.1px;font-size:10px;font-weight:500}.content-area{padding:1rem 1rem 72px}.placeholder-msg{color:#666;text-align:center;padding:2rem 0}.filter-bar{scrollbar-width:none;background:#fff;border-bottom:.5px solid #e0ddd6;flex-shrink:0;gap:8px;margin:-1rem -1rem .75rem;padding:.75rem 1rem;display:flex;overflow-x:auto}.filter-bar::-webkit-scrollbar{display:none}.filter-pill{cursor:pointer;white-space:nowrap;color:#444;background:0 0;border:1.5px solid #ddd;border-radius:20px;flex-shrink:0;padding:4px 14px;font-size:14px;font-weight:500}.filter-pill.active{background:var(--accent);border-color:var(--accent);color:#fff}.txn-section-label{color:#aaa;letter-spacing:.6px;padding:0 0 .5rem;font-size:11px;font-weight:600}.budget-card{background:#fff;border:.5px solid #e0ddd6;border-radius:12px;margin-bottom:.625rem;overflow:hidden}.budget-head-strip{background:#edeaf8;border-bottom:.5px solid #f0ede8;padding:.6rem 1rem .5rem}.budget-row-cat{color:var(--accent);text-transform:uppercase;letter-spacing:.4px;font-size:13px;font-weight:500}.budget-row{align-items:center;gap:10px;padding:.75rem 1rem;display:flex}.budget-row-label{flex:1;min-width:0}.budget-row-subcat{color:#1a1a1a;font-size:14px;font-weight:500}.budget-bar-wrap{flex-shrink:0;width:72px}.budget-bar-track{background:#ece9e3;border-radius:3px;height:5px;overflow:hidden}.budget-bar-fill{border-radius:3px;height:100%;transition:width .3s}.budget-bar-fill.healthy{background:var(--green-600)}.budget-bar-fill.warning{background:var(--amber-600)}.budget-bar-fill.overspent{background:var(--coral-600)}.budget-remaining{text-align:right;flex-shrink:0;min-width:60px;font-size:15px;font-weight:500}.budget-remaining.healthy{color:var(--green-600)}.budget-remaining.warning{color:var(--amber-600)}.budget-remaining.overspent{color:var(--coral-600)}.budget-head-row{justify-content:space-between;align-items:center;display:flex}.budget-head-remaining{font-size:14px;font-weight:500}.budget-head-remaining.healthy{color:var(--green-600)}.budget-head-remaining.overspent{color:var(--coral-600)}.budget-food-note{color:#b8860b;align-items:center;gap:.25rem;font-size:13px;display:inline-flex}.budget-row:not(:last-child){border-bottom:.5px solid #f0ede8}.budget-row.clickable{cursor:pointer}.budget-row.clickable:active{background:#f5f4f0}.ui-overlay{z-index:250;background:var(--page-bg);flex-direction:column;display:flex;position:fixed;inset:0}.ui-header{background:#fff;border-bottom:.5px solid #e0ddd6;flex-shrink:0;align-items:center;gap:.875rem;padding:1rem 1.25rem .875rem;display:flex}.ui-x-btn{color:var(--accent);cursor:pointer;background:0 0;border:none;flex-shrink:0;padding:0;font-size:18px;line-height:1}.ui-header-titles{flex-direction:column;gap:.125rem;display:flex}.ui-title{color:#1a1a1a;font-size:17px;font-weight:600}.ui-subtitle{color:var(--accent);opacity:.75;font-size:12px}.ui-content{flex:1;padding:1rem;overflow-y:auto}.ui-paycheck-card{background:#fff;border:1.5px solid #e0ddd6;border-radius:10px;margin-bottom:.75rem;padding:.625rem 1rem .75rem;transition:border-color .15s}.ui-paycheck-card:focus-within{border-color:var(--accent)}.ui-paycheck-label{color:var(--accent);margin-bottom:.25rem;font-size:12px;font-weight:500;display:block}.ui-paycheck-row{align-items:center;gap:.25rem;display:flex}.ui-dollar{color:#999;flex-shrink:0;font-size:20px}.ui-paycheck-input{color:#1a1a1a;background:0 0;border:none;outline:none;flex:1;min-width:0;padding:0 .25rem;font-size:20px}.ui-remove-btn{color:#ccc;cursor:pointer;background:0 0;border:none;flex-shrink:0;padding:0 .125rem;font-size:15px;line-height:1}.ui-add-btn{width:100%;color:var(--accent);cursor:pointer;background:0 0;border:1.5px dashed #c8c4be;border-radius:10px;margin-bottom:1rem;padding:.875rem;font-size:15px;display:block}.ui-total-row{justify-content:space-between;align-items:center;padding:0 .25rem;display:flex}.ui-total-label{color:#1a1a1a;font-size:16px;font-weight:700}.ui-total-amount{color:#1a1a1a;font-size:16px;font-weight:600}.ui-footer{padding:1rem;padding-bottom:max(1rem, env(safe-area-inset-bottom));background:var(--page-bg);flex-shrink:0}.ui-save-btn{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:12px;width:100%;padding:1rem;font-size:16px;font-weight:600}.ui-save-btn:disabled{opacity:.4;cursor:default}.th-overlay{z-index:250;background:var(--page-bg);flex-direction:column;display:flex;position:fixed;inset:0}.th-header{background:#fff;border-bottom:.5px solid #e0ddd6;flex-shrink:0;align-items:center;gap:.75rem;padding:1rem 1.25rem .875rem;display:flex}.th-x-btn{color:var(--accent);cursor:pointer;background:0 0;border:none;padding:0;font-size:18px;line-height:1}.th-title{color:#1a1a1a;font-size:17px;font-weight:600}.th-content{flex:1;padding:1rem;overflow-y:auto}.th-date-card{color:#1a1a1a;cursor:pointer;text-align:left;background:#fff;border:none;border-radius:12px;justify-content:space-between;align-items:center;width:100%;margin-bottom:.5rem;padding:1rem 1.25rem;font-size:15px;font-weight:500;display:flex}.th-chevron{color:#aaa;font-size:20px}.th-helper{color:#888;text-align:center;margin-bottom:1rem;font-size:13px}.th-group{border-radius:12px;margin-bottom:1rem;padding:1rem}.th-group.vb{background:#fce9ec}.th-group.cp{background:#e8edf8}.th-group-label{letter-spacing:.08em;margin-bottom:.75rem;font-size:11px;font-weight:700}.th-group-label.vb{color:#8b1a3a}.th-group-label.cp{color:#1a3a8b}.th-row{background:#fff;border-left:3px solid #0000;border-radius:8px;justify-content:space-between;align-items:center;margin-top:.5rem;padding:.75rem 1rem;font-size:14px;display:flex}.th-row.vb{border-left-color:#d08090}.th-row.cp{border-left-color:#7090c0}.overlay{background:var(--page-bg);z-index:100;flex-direction:column;display:flex;position:fixed;inset:0}.overlay-header{background:#fff;border-bottom:.5px solid #e0ddd6;flex-shrink:0;align-items:center;gap:.75rem;padding:1rem 1.25rem .875rem;display:flex}.overlay-back{color:var(--accent);cursor:pointer;background:0 0;border:none;padding:0;font-size:22px;line-height:1}.overlay-title{color:#1a1a1a;font-size:17px;font-weight:600}.overlay-filter-bar{background:#fff;border-bottom:.5px solid #e0ddd6;flex-shrink:0;padding:.625rem 1rem}.filter-toggle{background:#ece9e3;border-radius:8px;gap:2px;padding:3px;display:inline-flex}.filter-btn{color:#666;cursor:pointer;background:0 0;border:none;border-radius:6px;padding:.3rem .875rem;font-size:14px;font-weight:500}.filter-btn.active{color:#1a1a1a;background:#fff;box-shadow:0 1px 3px #0000001f}.overlay-list{flex:1;padding:.75rem 1rem 5rem;overflow-y:auto}.txn-card{background:#fff;border:.5px solid #e0ddd6;border-radius:10px;align-items:center;gap:12px;margin-bottom:.5rem;padding:.75rem 1rem;display:flex}.txn-left{flex:1;min-width:0}.txn-where{color:#1a1a1a;white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:500;overflow:hidden}.txn-meta{color:#888;white-space:nowrap;text-overflow:ellipsis;margin-top:2px;font-size:12px;overflow:hidden}.txn-amount{text-align:right;flex-shrink:0;font-size:15px;font-weight:500}.txn-amount.purchase{color:var(--coral-600)}.txn-amount.refund{color:var(--green-600)}.txn-card.clickable{cursor:pointer}.txn-card.clickable:active{background:#f9f8f6}.paw-overlay{z-index:200;background:#0006;flex-direction:column;justify-content:flex-end;display:flex;position:fixed;inset:0}.paw-sheet{background:#fff;border-radius:20px 20px 0 0;padding-bottom:2rem;overflow:hidden}.paw-item{cursor:pointer;width:100%;color:var(--accent);text-align:left;background:0 0;border:none;align-items:center;gap:1rem;padding:1rem 1.5rem;font-size:16px;font-weight:500;display:flex}.paw-divider{background:#f0ede8;height:.5px;margin:0 1.5rem}.paw-cancel{color:#888;cursor:pointer;background:0 0;border:none;border-top:.5px solid #e0ddd6;width:100%;margin-top:.5rem;padding:1rem;font-size:16px;display:block}.cat-overlay{z-index:200;background:#0006;flex-direction:column;justify-content:flex-end;display:flex;position:fixed;inset:0}.cat-sheet{background:#fff;border-radius:20px 20px 0 0;max-height:90vh;padding:0 1.25rem 2rem;overflow-y:auto}.cat-handle{background:#ddd;border-radius:2px;width:36px;height:4px;margin:10px auto 16px}.cat-header{justify-content:space-between;align-items:center;margin-bottom:.5rem;display:flex}.cat-merchant{color:#1a1a1a;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;margin-right:.75rem;font-size:16px;font-weight:600;overflow:hidden}.cat-cancel{color:#555;cursor:pointer;background:0 0;border:1.5px solid #ddd;border-radius:8px;flex-shrink:0;padding:4px 12px;font-size:13px}.cat-amount{margin-bottom:1.25rem;font-size:22px;font-weight:700}.cat-amount.purchase{color:var(--coral-600)}.cat-amount.refund{color:var(--green-600)}.cat-form{flex-direction:column;gap:.875rem;display:flex}.cat-field{flex-direction:column;gap:4px;display:flex}.cat-field-label{color:#888;font-size:12px;font-weight:500}.cat-optional{color:#aaa;font-weight:400}.cat-required{color:var(--coral-600)}.cat-input,.cat-select{color:#1a1a1a;appearance:none;background:#fff;border:1.5px solid #ddd;border-radius:10px;outline:none;width:100%;padding:.6rem .75rem;font-size:15px}.cat-input:focus,.cat-select:focus{border-color:var(--accent)}.cat-select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%23888' d='M1 1l5 5 5-5'/%3E%3C/svg%3E");background-position:right .75rem center;background-repeat:no-repeat;padding-right:2rem}.cat-readonly{color:#555;background:#f5f4f0;border-radius:10px;padding:.6rem .75rem;font-size:15px}.cat-actions{gap:.75rem;margin-top:1.25rem;display:flex}.cat-split-btn{color:#444;cursor:pointer;background:0 0;border:1.5px solid #ddd;border-radius:12px;flex-shrink:0;align-items:center;gap:6px;padding:.75rem 1.25rem;font-size:15px;font-weight:500;display:flex}.cat-ready-btn{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:12px;flex:1;padding:.75rem;font-size:15px;font-weight:600}.cat-ready-btn:disabled{opacity:.4;cursor:default}.split-view{background:var(--page-bg);z-index:300;flex-direction:column;display:flex;position:fixed;inset:0}.split-header{background:#fff;border-bottom:.5px solid #e0ddd6;flex-shrink:0;align-items:center;gap:.75rem;padding:1rem 1.25rem .875rem;display:flex}.split-back{color:var(--accent);cursor:pointer;background:0 0;border:none;flex-shrink:0;padding:0;font-size:22px;line-height:1}.split-header-text{min-width:0}.split-merchant{color:#1a1a1a;white-space:nowrap;text-overflow:ellipsis;font-size:16px;font-weight:600;overflow:hidden}.split-meta{color:#888;margin-top:2px;font-size:12px}.split-remaining-bar{background:#fff;border:.5px solid #e0ddd6;border-radius:12px;flex-shrink:0;justify-content:space-between;align-items:center;margin:.875rem 1rem 0;padding:.75rem 1rem;display:flex}.split-remaining-label{color:#555;font-size:14px}.split-remaining-zero{color:var(--green-600);font-size:16px;font-weight:700}.split-remaining-nonzero{color:var(--coral-600);font-size:16px;font-weight:700}.split-scroll{flex:1;padding:.875rem 1rem 0;overflow-y:auto}.split-card{background:#fff;border:.5px solid #e0ddd6;border-radius:12px;margin-bottom:.625rem;overflow:hidden}.split-card-header{cursor:pointer;align-items:center;gap:.625rem;padding:.75rem 1rem;display:flex}.split-badge{width:22px;height:22px;color:var(--accent);background:#edeaf8;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:12px;font-weight:700;display:flex}.split-card-label{color:#555;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;font-size:14px;overflow:hidden}.split-card-amount{color:#555;flex-shrink:0;font-size:14px;font-weight:500}.split-card-amount.purchase{color:var(--coral-600)}.split-chevron{color:#aaa;flex-shrink:0;font-size:12px}.split-card-body{border-top:.5px solid #f0ede8;flex-direction:column;gap:.875rem;padding:0 1rem 1rem;display:flex}.split-delete{cursor:pointer;color:#aaa;text-align:left;background:0 0;border:none;margin-top:.25rem;padding:0;font-size:13px}.split-actions{background:var(--page-bg);border-top:.5px solid #e0ddd6;flex-direction:column;flex-shrink:0;gap:.5rem;padding:.75rem 1rem 2rem;display:flex}.split-add-btn{color:#666;cursor:pointer;background:0 0;border:2px dashed #ccc;border-radius:12px;width:100%;padding:.75rem;font-size:15px;font-weight:500}.split-ready-btn{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:12px;width:100%;padding:.75rem;font-size:15px;font-weight:600}.split-ready-btn:disabled{opacity:.4;cursor:default}.discard-overlay{z-index:400;background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.discard-modal{background:#fff;border-radius:16px;width:90%;max-width:320px;padding:1.5rem}.discard-title{color:#1a1a1a;margin-bottom:.625rem;font-size:17px;font-weight:700}.discard-body{color:#555;margin-bottom:1.25rem;font-size:14px;line-height:1.5}.discard-actions{gap:.75rem;display:flex}.discard-keep{color:#444;cursor:pointer;background:0 0;border:1.5px solid #ddd;border-radius:10px;flex:1;padding:.75rem;font-size:15px;font-weight:500}.discard-confirm{background:var(--coral-600);color:#fff;cursor:pointer;border:none;border-radius:10px;flex:1;padding:.75rem;font-size:15px;font-weight:600}.toast{bottom:calc(var(--nav-height) + 12px);color:#fff;white-space:nowrap;z-index:9999;pointer-events:none;background:#333;border-radius:20px;padding:10px 18px;font-size:14px;position:fixed;left:50%;transform:translate(-50%)}.toast-error{background:#c0392b}
