:root{--bg: #f1f6f7;--card: #e9f1f2;--card-elevated: #ffffff;--silver: #c6dadd;--silver-soft: #dde9ea;--text: #103a52;--text-muted: #5c8290;--primary: #0e87c9;--primary-soft: #e1f1fb;--grad: linear-gradient(135deg, #0e7cc4 0%, #1796bd 48%, #1fae9e 100%);--sidebar-bg: #0b2b40;--sidebar-bg2: #103349;--sidebar-text: #9fc2cf;--sidebar-text-muted: #5c7e8c;--sidebar-border: rgba(255, 255, 255, .08);--high: #e0524e;--high-soft: #fce7e4;--med: #e0a23a;--med-soft: #fbf1de;--low: #2faf7e;--low-soft: #e1f3eb;--positive: #2faf7e;--negative: #e0524e;--radius: 12px;--shadow: 0 1px 2px rgba(13, 40, 60, .05), 0 4px 16px rgba(13, 40, 60, .08);--shadow-hover: 0 2px 6px rgba(13, 40, 60, .1), 0 8px 28px rgba(13, 40, 60, .14);--gap: 20px;--transition: .16s ease;font-family:Inter,system-ui,-apple-system,sans-serif;color:var(--text)}:root[data-theme=dark]{--bg: #0c1c27;--card: #142a37;--card-elevated: #173241;--silver: #2c4854;--silver-soft: #1f3a47;--text: #e6eef1;--text-muted: #8ba7b2;--primary-soft: #10303f;--high-soft: #3a2420;--med-soft: #3a3220;--low-soft: #16352b;--shadow: 0 1px 2px rgba(0, 0, 0, .3), 0 4px 16px rgba(0, 0, 0, .35);--shadow-hover: 0 2px 6px rgba(0, 0, 0, .4), 0 8px 28px rgba(0, 0, 0, .5)}*{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}.auth-shell{min-height:100vh;min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:24px;background:linear-gradient(160deg,var(--sidebar-bg) 0%,var(--sidebar-bg2) 100%)}.auth-card{width:100%;max-width:380px;background:var(--card-elevated);border-radius:16px;padding:32px;box-shadow:var(--shadow-hover)}.auth-logo{display:block;width:150px;margin:0 auto 10px}.auth-error{background:var(--high-soft);color:var(--high);font-size:13px;font-weight:500;padding:9px 12px;border-radius:8px;margin-bottom:12px}.auth-link{background:none;border:none;color:var(--primary);font-weight:600;cursor:pointer;font-size:13px;padding:0}.auth-notice{background:var(--low-soft);color:var(--positive);font-size:13px;font-weight:500;padding:9px 12px;border-radius:8px;margin-bottom:12px}.landing{min-height:100vh;min-height:100dvh;background:var(--bg);color:var(--text)}.landing-nav{display:flex;justify-content:space-between;align-items:center;padding:18px 32px;max-width:1080px;margin:0 auto}.landing-mark{width:30px;height:30px;border-radius:8px}.landing-hero{max-width:720px;margin:0 auto;padding:64px 24px 44px;text-align:center}.landing-title{font-size:46px;line-height:1.07;letter-spacing:-.03em;margin:0 0 18px;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}.landing-sub{font-size:17px;color:var(--text-muted);line-height:1.6;margin:0 auto 30px;max-width:600px}.landing-features{max-width:1000px;margin:0 auto;padding:12px 24px 64px;display:grid;grid-template-columns:repeat(3,1fr);gap:20px}.landing-feature{background:var(--card-elevated);border:1px solid var(--silver-soft);border-radius:12px;padding:20px;box-shadow:var(--shadow)}.landing-feature-icon{font-size:22px;color:var(--primary)}.landing-feature strong{display:block;margin:10px 0 4px;font-size:15px}.landing-feature p{margin:0;font-size:13.5px;color:var(--text-muted);line-height:1.5}.landing-footer{text-align:center;padding:24px;color:var(--text-muted);font-size:13px;border-top:1px solid var(--silver-soft)}@media(max-width:880px){.landing-features{grid-template-columns:1fr}.landing-title{font-size:33px}}.dropzone{border:2px dashed var(--silver);border-radius:var(--radius);background:var(--card-elevated);padding:48px 24px;text-align:center;cursor:pointer;transition:border-color var(--transition),background var(--transition)}.dropzone:hover,.dropzone.dragging{border-color:var(--primary);background:var(--primary-soft)}.dropzone-icon{font-size:32px;color:var(--primary)}.dropzone-title{font-size:16px;font-weight:600;margin:8px 0 2px}.bank-badge{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:700;color:var(--primary);background:var(--primary-soft);padding:5px 12px;border-radius:999px}.import-preview{max-height:52vh;overflow-y:auto;border:1px solid var(--silver-soft);border-radius:10px}.import-table{width:100%;border-collapse:collapse;font-size:13.5px}.import-table th{position:sticky;top:0;background:var(--card);text-align:left;font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);padding:9px 10px;border-bottom:1px solid var(--silver-soft)}.import-table td{padding:8px 10px;border-bottom:1px solid var(--silver-soft)}.import-table tr:last-child td{border-bottom:none}.import-cat{padding:5px 8px;border:1px solid var(--silver);border-radius:7px;background:var(--bg);font-size:13px;color:var(--text)}.verify-banner{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;background:var(--med-soft);color:var(--text);border:1px solid var(--silver-soft);border-radius:10px;padding:10px 14px;font-size:13.5px;margin-bottom:18px}.app-shell{display:flex;min-height:100vh;min-height:100dvh}.mobile-topbar{display:none}.hamburger{background:transparent;border:none;color:#fff;font-size:22px;line-height:1;padding:6px 10px;border-radius:8px}.nav-scrim{display:none}.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;flex-direction:column;align-items:center;gap:6px;margin-bottom:22px;padding:10px 6px 0}.brand-mark-img{width:118px;height:auto;display:block}.brand-wordmark{font-size:16px;font-weight:700;text-transform:uppercase;letter-spacing:.22em;padding-left:.22em;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}.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 #0e87c94d}.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:#ff9e8f;background:#e0524e1f}.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 #0e87c947}.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}.register-bal{min-width:92px;text-align:right;font-variant-numeric:tabular-nums;font-size:13.5px;font-weight:600;color:var(--text-muted);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 #c8e3ec;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:var(--card-elevated);font-size:14px;color:var(--text)}.nl-entry input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #0e87c92e}.nl-note{font-size:12.5px;color:var(--text-muted);margin-top:8px}.receipt-btn{display:inline-block;margin-top:10px;font-size:12.5px;font-weight:600;color:var(--primary);cursor:pointer;padding:6px 10px;border:1px dashed var(--silver);border-radius:8px;background:var(--card-elevated);transition:border-color var(--transition)}.receipt-btn:hover{border-color:var(--primary)}.offline-banner{position:fixed;bottom:18px;left:50%;transform:translate(-50%);z-index:60;background:var(--text);color:var(--bg);font-size:13px;font-weight:500;padding:10px 16px;border-radius:999px;box-shadow:var(--shadow-hover);display:flex;align-items:center;gap:8px;max-width:90vw}.offline-dot{width:8px;height:8px;border-radius:50%;background:var(--med)}.shortcuts-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:90;background:#081c2880;display:flex;align-items:center;justify-content:center}.shortcuts-modal{background:var(--card-elevated);border:1px solid var(--silver-soft);border-radius:14px;padding:24px;width:440px;max-width:92vw;max-height:80vh;overflow-y:auto;box-shadow:var(--shadow-hover)}.shortcuts-list{display:flex;flex-direction:column}.shortcut-row{display:flex;justify-content:space-between;align-items:center;padding:8px 2px;border-bottom:1px solid var(--silver-soft);font-size:14px}.shortcut-row:last-child{border-bottom:none}.kbd-keys{display:flex;gap:4px}kbd{display:inline-block;min-width:22px;text-align:center;font-family:inherit;font-size:12px;font-weight:600;color:var(--text);background:var(--bg);border:1px solid var(--silver);border-bottom-width:2px;border-radius:6px;padding:2px 6px}.topbar-actions{position:fixed;top:18px;right:24px;z-index:50;display:flex;align-items:center;gap:10px}.theme-toggle,.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)}.theme-toggle:hover{box-shadow:var(--shadow-hover)}.bell-wrap{position:relative}.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;z-index:50;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;align-items:stretch;border-bottom:1px solid var(--silver-soft)}.bell-item:last-child{border-bottom:none}.bell-item-main{flex:1;display:flex;gap:10px;align-items:flex-start;text-align:left;background:transparent;border:none;padding:11px 6px 11px 14px;transition:background var(--transition);min-width:0;cursor:pointer}.bell-item-main:hover{background:var(--bg)}.bell-dismiss{background:transparent;border:none;color:var(--text-muted);font-size:12px;padding:0 12px;cursor:pointer}.bell-dismiss:hover{color:var(--negative)}.bell-clear{background:transparent;border:none;color:var(--primary);font-weight:600;font-size:11.5px;letter-spacing:0;text-transform:none;cursor:pointer}.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:#081c288c;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}.mobile-topbar{display:flex;align-items:center;gap:6px;position:sticky;top:0;z-index:45;background:var(--sidebar-bg);padding:10px 14px;padding-top:calc(env(safe-area-inset-top) + 10px);padding-left:calc(env(safe-area-inset-left) + 14px);border-bottom:1px solid var(--sidebar-border)}.mobile-topbar .brand-wordmark{font-size:15px;letter-spacing:.2em}.sidebar{position:fixed;top:0;left:0;bottom:0;width:270px;max-width:84vw;height:100%;z-index:60;padding-top:calc(env(safe-area-inset-top) + 18px);padding-bottom:calc(env(safe-area-inset-bottom) + 18px);transform:translate(-100%);transition:transform .24s ease;box-shadow:0 0 40px #0006}.sidebar.open{transform:translate(0)}.nav-scrim{display:block;position:fixed;top:0;right:0;bottom:0;left:0;z-index:55;background:#0818238c;-webkit-backdrop-filter:blur(1px);backdrop-filter:blur(1px)}.nav-link{padding:12px;font-size:15.5px}.topbar-actions{top:calc(env(safe-area-inset-top) + 8px);right:calc(env(safe-area-inset-right) + 12px)}.main{padding:20px 16px calc(env(safe-area-inset-bottom) + 40px);padding-left:calc(env(safe-area-inset-left) + 16px);padding-right:calc(env(safe-area-inset-right) + 16px)}.page-head{margin-bottom:20px}.page-head h1{font-size:22px}.stat{font-size:26px}.card{padding:16px}.cols-2,.cols-3,.form-row{grid-template-columns:1fr}.bubble{max-width:90%}.app-shell input,.app-shell select,.app-shell textarea,.auth-card input,.auth-card select{font-size:16px}}
