*,: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:#888;font-size:13px}.budget-row:not(:last-child){border-bottom:.5px solid #f0ede8}.budget-row.clickable{cursor:pointer}.budget-row.clickable:active{background:#f5f4f0}.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}.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}
