:root{--navy: #1a1a2e;--navy-light: #252540;--navy-mid: #2e2e50;--cream: #f5f0e8;--cream-dark: #ede8df;--amber: #e8a838;--amber-light: #f2c46a;--green: #4caf82;--red: #e05c5c;--text: #1a1a2e;--text-muted: #6b6b8a;--border: #ddd8ce;--card-bg: #ffffff;--page-bg: #f5f0e8;--radius: 12px;--radius-lg: 20px;--shadow: 0 2px 12px rgba(26,26,46,.08);--shadow-lg: 0 8px 32px rgba(26,26,46,.14);--font-serif: "DM Serif Display", Georgia, serif;--font-sans: "DM Sans", system-ui, sans-serif;--nav-height: 64px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-text-size-adjust:100%}body{font-family:var(--font-sans);background:var(--page-bg);color:var(--text);min-height:100dvh;overflow-x:hidden}h1,h2,h3{font-family:var(--font-serif);font-weight:400}a{color:inherit;text-decoration:none}button{font-family:var(--font-sans);cursor:pointer;border:none;background:none}input,select,textarea{font-family:var(--font-sans);font-size:1rem}.card{background:var(--card-bg);border-radius:var(--radius);box-shadow:var(--shadow);padding:1.25rem}.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.65rem 1.25rem;border-radius:8px;font-weight:500;font-size:.95rem;transition:all .15s ease}.btn-primary{background:var(--navy);color:var(--cream)}.btn-primary:hover{background:var(--navy-light)}.btn-amber{background:var(--amber);color:var(--navy)}.btn-amber:hover{background:var(--amber-light)}.btn-ghost{background:transparent;color:var(--text-muted);border:1.5px solid var(--border)}.btn-ghost:hover{background:var(--cream-dark)}.amount-positive{color:var(--green);font-weight:500}.amount-negative{color:var(--red);font-weight:500}.amount-neutral{color:var(--text-muted)}.page-container{max-width:680px;margin:0 auto;padding:1.5rem 1rem calc(var(--nav-height) + 2rem)}.bottom-nav{position:fixed;bottom:0;left:0;right:0;height:var(--nav-height);background:var(--navy);display:flex;align-items:stretch;z-index:100;padding-bottom:env(safe-area-inset-bottom)}.bottom-nav a{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;color:#f5f0e873;font-size:.7rem;font-weight:500;letter-spacing:.03em;transition:color .15s;padding-top:4px}.bottom-nav a.active,.bottom-nav a:hover{color:var(--amber)}.bottom-nav svg{width:22px;height:22px}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem}.page-header h1{font-size:1.9rem;line-height:1.1;color:var(--navy)}.field{display:flex;flex-direction:column;gap:.35rem;margin-bottom:1rem}.field label{font-size:.8rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em}.field input,.field select{padding:.7rem .9rem;border:1.5px solid var(--border);border-radius:8px;background:#fff;color:var(--text);transition:border-color .15s;width:100%}.field input:focus,.field select:focus{outline:none;border-color:var(--navy)}@keyframes spin{to{transform:rotate(360deg)}}.spinner{width:36px;height:36px;border:3px solid var(--border);border-top-color:var(--navy);border-radius:50%;animation:spin .7s linear infinite;margin:2rem auto}.month-nav{display:flex;align-items:center;gap:.75rem;background:var(--card-bg);border-radius:var(--radius);padding:.6rem 1rem;box-shadow:var(--shadow);margin-bottom:1.25rem}.month-nav span{flex:1;text-align:center;font-family:var(--font-serif);font-size:1.15rem}.month-nav button{width:32px;height:32px;border-radius:6px;display:flex;align-items:center;justify-content:center;color:var(--text-muted);transition:background .15s,color .15s}.month-nav button:hover{background:var(--cream-dark);color:var(--navy)}.progress-bar{height:6px;background:var(--cream-dark);border-radius:99px;overflow:hidden;margin-top:.4rem}.progress-bar-fill{height:100%;border-radius:99px;transition:width .4s ease}.tx-list{display:flex;flex-direction:column;gap:.5rem}.tx-row{background:var(--card-bg);border-radius:var(--radius);padding:.9rem 1rem;display:flex;align-items:center;gap:.85rem;box-shadow:var(--shadow);cursor:pointer;transition:box-shadow .15s,transform .1s;-webkit-tap-highlight-color:transparent}.tx-row:active{transform:scale(.99);box-shadow:none}.tx-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.15rem;flex-shrink:0}.tx-info{flex:1;min-width:0}.tx-payee{font-weight:500;font-size:.95rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tx-meta{font-size:.78rem;color:var(--text-muted);margin-top:2px}.tx-amount{font-weight:600;font-size:.95rem;white-space:nowrap}.empty-state{text-align:center;padding:3rem 1rem;color:var(--text-muted)}.empty-state p{font-size:.95rem;margin-top:.5rem}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#1a1a2e80;z-index:200;display:flex;align-items:flex-end;justify-content:center;animation:fadeIn .15s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-sheet{background:var(--card-bg);border-radius:var(--radius-lg) var(--radius-lg) 0 0;padding:1.5rem 1.25rem 2.5rem;width:100%;max-width:680px;max-height:90dvh;overflow-y:auto;animation:slideUp .22s ease}@keyframes slideUp{0%{transform:translateY(60px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-handle{width:36px;height:4px;background:var(--border);border-radius:99px;margin:0 auto 1.25rem}.modal-title{font-size:1.4rem;margin-bottom:1.25rem}
