:root{--bg: #f6f5fb;--card: #efedf7;--card-elevated: #ffffff;--silver: #d9d4e8;--silver-soft: #e8e4f2;--text: #221f3d;--text-muted: #817c9c;--primary: #c0309a;--primary-soft: #f8e6f3;--grad: linear-gradient(135deg, #5b4bb0 0%, #a3389e 52%, #ec2d6f 100%);--sidebar-bg: #14112e;--sidebar-bg2: #211c40;--sidebar-text: #b9b3d2;--sidebar-text-muted: #6f6a8e;--sidebar-border: rgba(255, 255, 255, .07);--high: #e23a63;--high-soft: #fce4ea;--med: #e0a23a;--med-soft: #fbf1de;--low: #2faf7e;--low-soft: #e1f3eb;--positive: #2faf7e;--negative: #e23a63;--radius: 12px;--shadow: 0 1px 2px rgba(34, 31, 61, .05), 0 4px 16px rgba(34, 31, 61, .07);--shadow-hover: 0 2px 6px rgba(34, 31, 61, .09), 0 8px 28px rgba(34, 31, 61, .12);--gap: 20px;--transition: .16s ease;font-family:Inter,system-ui,-apple-system,sans-serif;color:var(--text)}*{box-sizing:border-box}html,body,#root{margin:0;min-height:100%}body{background:var(--bg);-webkit-font-smoothing:antialiased}a{color:inherit;text-decoration:none}h1,h2,h3{margin:0;font-weight:600;letter-spacing:-.01em}button{font-family:inherit;cursor:pointer}input,select{font-family:inherit}.app-shell{display:flex;min-height:100vh}.sidebar{width:240px;flex-shrink:0;background:var(--sidebar-bg);border-right:1px solid var(--sidebar-border);padding:24px 18px;position:sticky;top:0;height:100vh;display:flex;flex-direction:column;gap:6px;overflow-y:auto}.brand{display:flex;align-items:center;justify-content:center;margin-bottom:20px;padding:0 6px}.brand-logo{width:100%;max-width:168px;height:auto;display:block;border-radius:10px}.nav-link{display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:9px;color:var(--sidebar-text);font-size:14.5px;font-weight:500;transition:background var(--transition),color var(--transition)}.nav-link:hover{background:#ffffff0f;color:#fff}.nav-link.active{background:var(--grad);color:#fff;font-weight:600;box-shadow:0 4px 14px #ec2d6f52}.nav-link.active .nav-icon{color:#fff}.nav-icon{font-size:16px;width:20px;text-align:center}.nav-group{display:contents}.nav-group-title{font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--sidebar-text-muted);padding:16px 12px 2px}.sidebar-footer{margin-top:auto;padding-top:12px;border-top:1px solid var(--sidebar-border)}.reset-link{width:100%;background:transparent;border:none;text-align:left;color:var(--sidebar-text-muted)}.reset-link:hover{color:#ff6f9a;background:#ec2d6f1a}.reset-confirm .muted{color:var(--sidebar-text-muted)}.reset-confirm{padding:4px 10px 2px}.main{flex:1;padding:36px 44px 64px;max-width:1180px;width:100%;margin:0 auto}.page-head{margin-bottom:28px}.page-head h1{font-size:26px}.page-head p{margin:6px 0 0;color:var(--text-muted);font-size:14.5px}.grid{display:grid;gap:var(--gap)}.cols-2{grid-template-columns:repeat(2,1fr)}.cols-3{grid-template-columns:repeat(3,1fr)}.card{background:var(--card-elevated);border:1px solid var(--silver-soft);border-radius:var(--radius);padding:22px;box-shadow:var(--shadow);transition:box-shadow var(--transition),transform var(--transition)}.card-title{font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:14px}.stat{font-size:30px;font-weight:700;letter-spacing:-.02em}.stat-sub{font-size:13px;color:var(--text-muted);margin-top:4px}.positive{color:var(--positive)}.negative{color:var(--negative)}.field{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}.field label{font-size:12.5px;font-weight:600;color:var(--text-muted)}.field input,.field select{padding:9px 11px;border:1px solid var(--silver);border-radius:8px;background:var(--bg);font-size:14px;color:var(--text);transition:border var(--transition),box-shadow var(--transition)}.field input:focus,.field select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-soft)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}.btn{border:none;border-radius:8px;padding:10px 16px;font-size:14px;font-weight:600;background:var(--grad);color:#fff;transition:filter var(--transition),transform var(--transition),box-shadow var(--transition)}.btn:hover{filter:brightness(1.06);box-shadow:0 4px 14px #ec2d6f47}.btn:active{transform:translateY(1px)}.btn-ghost{background:transparent;color:var(--text-muted);border:1px solid var(--silver)}.btn-ghost:hover{color:var(--text);background:var(--bg);filter:none}.btn-sm{padding:6px 10px;font-size:12.5px}.row{display:flex;align-items:center;gap:14px;padding:13px 4px;border-bottom:1px solid var(--silver-soft)}.row:last-child{border-bottom:none}.row-main{flex:1;min-width:0}.row-name{font-weight:600;font-size:14.5px}.row-meta{font-size:12.5px;color:var(--text-muted);margin-top:2px}.row-amount{font-weight:700;font-size:15px;white-space:nowrap}.priority-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0}.badge{display:inline-flex;align-items:center;gap:5px;font-size:11.5px;font-weight:600;padding:3px 9px;border-radius:999px}.badge-high{background:var(--high-soft);color:var(--high)}.badge-med{background:var(--med-soft);color:var(--med)}.badge-low{background:var(--low-soft);color:var(--low)}.badge-review{background:var(--med-soft);color:var(--med)}.icon-btn{background:transparent;border:none;color:var(--text-muted);font-size:14px;padding:4px 7px;border-radius:6px;transition:background var(--transition),color var(--transition)}.icon-btn:hover{background:var(--bg);color:var(--negative)}.icon-btn.edit:hover{color:var(--primary)}.txn-edit{flex-wrap:wrap;gap:8px}.txn-edit input,.txn-edit select{padding:7px 9px;border:1px solid var(--silver);border-radius:7px;background:var(--bg);font-size:13.5px;color:var(--text)}.txn-edit input:focus,.txn-edit select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-soft)}.txn-edit-name{flex:1 1 140px;min-width:120px}.txn-edit-amount{width:96px}.nl-entry{background:var(--primary-soft);border:1px solid #f0d6ea;border-radius:10px;padding:14px}.nl-entry label{display:block;font-size:12.5px;font-weight:600;color:var(--primary);margin-bottom:8px}.nl-entry input{flex:1;padding:9px 11px;border:1px solid var(--silver);border-radius:8px;background:#fff;font-size:14px;color:var(--text)}.nl-entry input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #c0309a2e}.nl-note{font-size:12.5px;color:var(--text-muted);margin-top:8px}.bell-wrap{position:fixed;top:18px;right:24px;z-index:50}.bell-btn{position:relative;width:42px;height:42px;border-radius:50%;border:1px solid var(--silver-soft);background:var(--card-elevated);box-shadow:var(--shadow);font-size:18px;display:flex;align-items:center;justify-content:center;transition:box-shadow var(--transition)}.bell-btn:hover{box-shadow:var(--shadow-hover)}.bell-badge{position:absolute;top:-3px;right:-3px;min-width:18px;height:18px;padding:0 5px;border-radius:9px;background:var(--med);color:#fff;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center}.bell-badge.high{background:var(--high)}.bell-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:49}.bell-panel{position:absolute;top:50px;right:0;width:344px;max-width:88vw;background:var(--card-elevated);border:1px solid var(--silver-soft);border-radius:12px;box-shadow:var(--shadow-hover);overflow:hidden}.bell-head{padding:12px 14px;font-weight:700;font-size:12.5px;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);border-bottom:1px solid var(--silver-soft)}.bell-empty{padding:26px;text-align:center;color:var(--text-muted);font-size:14px}.bell-list{max-height:62vh;overflow-y:auto}.bell-item{display:flex;gap:10px;align-items:flex-start;width:100%;text-align:left;background:transparent;border:none;padding:11px 14px;border-bottom:1px solid var(--silver-soft);transition:background var(--transition)}.bell-item:last-child{border-bottom:none}.bell-item:hover{background:var(--bg)}.bell-dot{width:8px;height:8px;border-radius:50%;margin-top:5px;flex-shrink:0}.sev-high{background:var(--high)}.sev-med{background:var(--med)}.sev-low{background:var(--low)}.bell-icon{font-size:15px;line-height:1.2}.bell-text{display:flex;flex-direction:column;gap:2px;min-width:0}.bell-title{font-size:13.5px;font-weight:600;color:var(--text)}.bell-detail{font-size:12px;color:var(--text-muted)}.celebrate-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;background:#16142e8c;display:flex;align-items:center;justify-content:center;overflow:hidden}.celebrate-card{position:relative;z-index:2;background:var(--card-elevated);border-radius:16px;padding:32px 36px;text-align:center;max-width:380px;box-shadow:var(--shadow-hover);animation:pop .24s ease}@keyframes pop{0%{transform:scale(.85);opacity:0}to{transform:scale(1);opacity:1}}.celebrate-emoji{font-size:52px;line-height:1;margin-bottom:8px}.confetti{position:absolute;top:0;right:0;bottom:0;left:0;z-index:1;pointer-events:none}.confetti span{position:absolute;top:-16px;width:9px;height:14px;border-radius:2px;opacity:.9;animation-name:confetti-fall;animation-timing-function:linear;animation-iteration-count:infinite}@keyframes confetti-fall{0%{transform:translateY(-16px) rotate(0);opacity:1}to{transform:translateY(105vh) rotate(720deg);opacity:.25}}.nospend-grid{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.nospend-cell{width:22px;height:22px;border-radius:5px;display:inline-block}.nospend-cell.good{background:var(--low)}.nospend-cell.spent{background:var(--silver-soft);border:1px solid var(--silver)}.section-label{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:700;margin:22px 0 8px}.empty{text-align:center;color:var(--text-muted);padding:28px;font-size:14px}.tip{display:flex;gap:12px;padding:14px;border-radius:10px;background:var(--bg);border:1px solid var(--silver-soft);margin-bottom:12px}.tip-icon{font-size:18px}.tip-body strong{display:block;font-size:14px;margin-bottom:2px}.tip-body span{font-size:13px;color:var(--text-muted);line-height:1.45}.tip-warn{background:var(--high-soft);border-color:#f3c7cc}.tip-ok{background:var(--low-soft);border-color:#c4e6d4}.progress{height:10px;background:var(--silver-soft);border-radius:999px;overflow:hidden;margin:10px 0}.progress-fill{height:100%;background:var(--grad);border-radius:999px;transition:width .4s ease}.chat-window{display:flex;flex-direction:column;gap:14px;min-height:320px;max-height:52vh;overflow-y:auto;padding:6px 2px}.bubble{max-width:78%;padding:12px 15px;border-radius:14px;font-size:14px;line-height:1.5;white-space:pre-wrap}.bubble-user{align-self:flex-end;background:var(--primary);color:#fff;border-bottom-right-radius:4px}.bubble-ai{align-self:flex-start;background:var(--card);color:var(--text);border-bottom-left-radius:4px}.chat-input{display:flex;gap:10px;margin-top:16px}.chat-input input{flex:1;padding:11px 14px;border:1px solid var(--silver);border-radius:10px;background:var(--bg);font-size:14px}.chat-input input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-soft)}.suggestion{font-size:12.5px;padding:7px 12px;border-radius:999px;border:1px solid var(--silver);background:var(--bg);color:var(--text-muted);transition:all var(--transition)}.suggestion:hover{border-color:var(--primary);color:var(--primary)}.muted{color:var(--text-muted);font-size:13px}.flex{display:flex}.between{justify-content:space-between}.items-center{align-items:center}.gap-8{gap:8px}.gap-12{gap:12px}.wrap{flex-wrap:wrap}.mt-16{margin-top:16px}.mt-24{margin-top:24px}@media(max-width:880px){.app-shell{flex-direction:column}.sidebar{width:100%;height:auto;position:static;flex-direction:row;flex-wrap:wrap;align-items:center;padding:14px 16px;gap:4px}.brand{margin-bottom:0;margin-right:auto}.nav-group-title{display:none}.main{padding:24px 18px 48px}.cols-2,.cols-3,.form-row{grid-template-columns:1fr}.bubble{max-width:90%}}
