body{font-family:Inter,system-ui,-apple-system,sans-serif}.sidebar{background:var(--sidebar-bg,#1e1b4b);flex-direction:column;flex-shrink:0;width:230px;min-height:100vh;padding:20px 12px;transition:width .22s;display:flex;overflow:hidden}.sidebar--collapsed{width:64px}.sidebar-logo{white-space:nowrap;align-items:center;margin-bottom:12px;padding:8px 10px;display:flex}.sidebar-logo-mark,.sidebar-logo-badge{flex-shrink:0;display:block}.sidebar-logo-mark{width:28px;height:28px}.sidebar-logo-badge{width:138px;height:40px}.sidebar--collapsed .sidebar-logo{justify-content:center;padding:8px 0}.sidebar-toggle{color:#6366f1;cursor:pointer;background:0 0;border:none;border-radius:8px;justify-content:center;align-self:flex-start;align-items:center;margin:0 2px 16px;padding:6px;transition:background .15s,color .15s;display:flex}.sidebar-toggle:hover{color:#a5b4fc;background:#ffffff12}.sidebar--collapsed .sidebar-toggle{align-self:center;margin:0 auto 16px}.sidebar-nav{flex-direction:column;flex:1;gap:2px;display:flex}.nav-item{color:#a5b4fc;white-space:nowrap;border-radius:10px;align-items:center;gap:11px;padding:11px 12px;font-size:.88rem;font-weight:500;text-decoration:none;transition:background .15s,color .15s;display:flex;position:relative}.nav-item:hover{color:#e0e7ff;background:#ffffff12}.nav-item.active{color:#fff;background:#4f46e5;font-weight:600}.nav-item.active:before{content:"";background:#818cf8;border-radius:0 3px 3px 0;width:3px;height:60%;position:absolute;top:50%;left:-12px;transform:translateY(-50%)}.sidebar--collapsed .nav-item{justify-content:center;padding:11px}.sidebar--collapsed .nav-item.active:before{display:none}.sidebar-footer{border-top:1px solid #ffffff14;align-items:center;gap:10px;margin-top:8px;padding:14px 10px 6px;display:flex}.sidebar--collapsed .sidebar-footer{flex-direction:column;align-items:center;gap:8px;padding:14px 4px 6px}.avatar{color:#fff;letter-spacing:.02em;background:#4f46e5;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:.75rem;font-weight:700;display:flex}.sidebar-user-info{flex-direction:column;flex:1;gap:1px;min-width:0;display:flex}.sidebar-user-name{color:#e0e7ff;text-overflow:ellipsis;white-space:nowrap;font-size:.82rem;font-weight:600;overflow:hidden}.sidebar-user-email{color:#6366f1;text-overflow:ellipsis;white-space:nowrap;font-size:.68rem;overflow:hidden}.sidebar-theme{color:#6366f1;cursor:pointer;background:0 0;border:none;border-radius:7px;flex-shrink:0;align-items:center;padding:6px;transition:background .15s,color .15s;display:flex}.sidebar-theme:hover{color:#a5b4fc;background:#ffffff12}.sidebar-logout{color:#6366f1;cursor:pointer;background:0 0;border:none;border-radius:7px;flex-shrink:0;align-items:center;padding:6px;transition:background .15s,color .15s;display:flex}.sidebar-logout:hover{color:#f87171;background:#ef444426}.sidebar-profile-link{border-radius:10px;flex-shrink:0;transition:opacity .15s;display:flex}.sidebar-profile-link:hover{opacity:.8}@media (width<=768px){.sidebar{z-index:200;height:100dvh;transition:transform .25s;position:fixed;top:0;left:0;overflow-y:auto;transform:translate(-100%);width:260px!important}.sidebar.mobile-open{transform:translate(0)}.sidebar-toggle{display:none}.sidebar .nav-item{justify-content:flex-start;padding:13px 14px;font-size:.95rem}.sidebar-footer{flex-direction:row;align-items:center}}.ob-overlay{z-index:1000;background:var(--modal-overlay);justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.ob-card{background:var(--bg-card);box-shadow:var(--shadow-lg);border-radius:24px;flex-direction:column;width:100%;max-width:540px;max-height:90vh;display:flex;overflow-y:auto}.ob-progress{background:var(--border);border-radius:4px 4px 0 0;height:4px;overflow:hidden}.ob-progress-fill{background:linear-gradient(90deg,#4f46e5,#6366f1);height:100%;transition:width .35s}.ob-body{flex:1;padding:36px 40px 32px}.ob-dots{justify-content:center;gap:6px;margin-bottom:28px;display:flex}.ob-dot{background:var(--border);border-radius:50%;width:8px;height:8px;transition:background .2s,width .2s}.ob-dot.active{background:#6366f1;border-radius:4px;width:22px}.ob-dot.done{background:#6366f1}.ob-welcome-icon{text-align:center;margin-bottom:16px;font-size:3rem}.ob-title{color:var(--text);text-align:center;margin-bottom:8px;font-size:1.45rem;font-weight:700}.ob-sub{color:var(--text-muted);text-align:center;margin-bottom:28px;font-size:.92rem;line-height:1.55}.ob-steps-list{flex-direction:column;gap:10px;margin-bottom:32px;display:flex}.ob-step-item{background:var(--bg-subtle);border-radius:10px;align-items:center;gap:12px;padding:12px 16px;display:flex}.ob-step-emoji{flex-shrink:0;font-size:1.2rem}.ob-step-text{color:var(--text-secondary);font-size:.88rem;font-weight:500}.ob-section-title{color:var(--text);margin-bottom:6px;font-size:1.2rem;font-weight:700}.ob-section-sub{color:var(--text-muted);margin-bottom:20px;font-size:.87rem;line-height:1.5}.ob-field{flex-direction:column;gap:6px;margin-bottom:14px;display:flex}.ob-label{color:var(--text-secondary);font-size:.82rem;font-weight:600}.ob-input{border:1.5px solid var(--border);background:var(--bg-input);color:var(--text);border-radius:10px;outline:none;padding:10px 12px;font-size:.93rem;transition:border-color .15s}.ob-input:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.ob-field-err{color:#dc2626;font-size:.78rem}.ob-type-grid{grid-template-columns:repeat(3,1fr);gap:8px;display:grid}.ob-type-btn{border:1.5px solid var(--border);background:var(--bg-subtle);cursor:pointer;color:var(--text-secondary);border-radius:10px;flex-direction:column;align-items:center;gap:4px;padding:10px 6px;font-size:.78rem;font-weight:500;transition:border-color .15s,background .15s;display:flex}.ob-type-btn:hover{border-color:#6366f1}.ob-type-btn.active{color:#6366f1;background:#6366f10f;border-color:#6366f1}.ob-cat-grid{grid-template-columns:repeat(2,1fr);gap:8px;margin-bottom:4px;display:grid}.ob-cat-item{border:1.5px solid var(--border);cursor:pointer;background:var(--bg-subtle);border-radius:10px;align-items:center;gap:10px;padding:10px 12px;transition:border-color .15s,background .15s;display:flex}.ob-cat-item.selected{background:#6366f10f;border-color:#6366f1}.ob-cat-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.ob-cat-name{color:var(--text-secondary);flex:1;font-size:.83rem;font-weight:500}.ob-cat-check{border:1.5px solid var(--border);border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;width:16px;height:16px;transition:background .15s,border-color .15s;display:flex}.ob-cat-item.selected .ob-cat-check{color:#fff;background:#6366f1;border-color:#6366f1}.ob-cat-section-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin:12px 0 6px;font-size:.75rem;font-weight:700}.ob-plan-grid{flex-direction:column;gap:14px;margin-bottom:8px;display:flex}.ob-plan-row{align-items:center;gap:12px;display:flex}.ob-plan-label{color:var(--text-secondary);flex-shrink:0;align-items:center;gap:6px;width:110px;font-size:.85rem;font-weight:600;display:flex}.ob-plan-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.ob-plan-input{border:1.5px solid var(--border);text-align:center;background:var(--bg-input);width:70px;color:var(--text);border-radius:8px;outline:none;padding:8px 10px;font-size:.9rem;font-weight:600}.ob-plan-input:focus{border-color:#6366f1}.ob-plan-sum{text-align:center;border-radius:6px;margin-top:4px;padding:4px 10px;font-size:.82rem;font-weight:600}.ob-plan-sum.ok{color:#16a34a;background:#f0fdf4}.ob-plan-sum.err{color:#dc2626;background:#fef2f2}.ob-presets{flex-wrap:wrap;gap:8px;margin-bottom:16px;display:flex}.ob-preset-btn{border:1.5px solid var(--border);cursor:pointer;background:var(--bg-subtle);color:var(--text-secondary);border-radius:8px;padding:5px 12px;font-size:.8rem;font-weight:600;transition:border-color .15s}.ob-preset-btn:hover{color:#6366f1;border-color:#6366f1}.ob-done-icon{text-align:center;margin-bottom:16px;font-size:3.5rem}.ob-done-list{flex-direction:column;gap:8px;margin:20px 0 28px;display:flex}.ob-done-item{color:var(--text-secondary);align-items:center;gap:10px;font-size:.87rem;display:flex}.ob-done-check{background:#6366f1;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;display:flex}.ob-footer{justify-content:space-between;align-items:center;gap:12px;padding:0 40px 28px;display:flex}.ob-btn-skip{color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:8px;font-size:.84rem}.ob-btn-skip:hover{color:var(--text);text-decoration:underline}.ob-btn-back{border:1.5px solid var(--border);cursor:pointer;background:var(--bg-subtle);color:var(--text-secondary);border-radius:10px;padding:10px 20px;font-size:.9rem;font-weight:600}.ob-btn-back:hover{color:#6366f1;border-color:#6366f1}.ob-btn-next{color:#fff;cursor:pointer;background:linear-gradient(135deg,#4f46e5,#6366f1);border:none;border-radius:10px;padding:10px 28px;font-size:.9rem;font-weight:600;transition:opacity .15s}.ob-btn-next:disabled{opacity:.6;cursor:not-allowed}.ob-btn-next:not(:disabled):hover{opacity:.88}.ob-spacer{flex:1}.ob-error{color:#dc2626;text-align:center;margin-top:8px;font-size:.82rem}@media (width<=560px){.ob-body{padding:24px 20px 20px}.ob-footer{padding:0 20px 20px}.ob-cat-grid{grid-template-columns:1fr}.ob-type-grid{grid-template-columns:repeat(2,1fr)}}.auth-page{min-height:100vh;display:flex}.auth-brand{background:linear-gradient(145deg,#1e1b4b 0%,#312e81 40%,#4f46e5 100%);flex-direction:column;flex:1;justify-content:center;align-items:center;padding:60px 48px;display:none;position:relative;overflow:hidden}@media (width>=860px){.auth-brand{display:flex}}.auth-brand:before{content:"";background:radial-gradient(circle,#6366f140 0%,#0000 70%);border-radius:50%;width:500px;height:500px;position:absolute;top:-120px;right:-120px}.auth-brand:after{content:"";background:radial-gradient(circle,#8b5cf633 0%,#0000 70%);border-radius:50%;width:400px;height:400px;position:absolute;bottom:-100px;left:-100px}.brand-logo{z-index:1;align-items:center;gap:14px;margin-bottom:48px;display:flex}.brand-badge{width:220px;height:66px;display:block}.brand-headline{color:#fff;text-align:center;z-index:1;margin-bottom:16px;font-size:2rem;font-weight:700;line-height:1.25}.brand-sub{color:#c7d2fe;text-align:center;z-index:1;max-width:320px;margin-bottom:48px;font-size:1rem;line-height:1.6}.brand-features{z-index:1;flex-direction:column;gap:14px;width:100%;max-width:320px;display:flex}.brand-feature{background:#ffffff14;border:1px solid #ffffff1f;border-radius:12px;align-items:center;gap:12px;padding:12px 16px;display:flex}.brand-feature-icon{flex-shrink:0;font-size:1.25rem}.brand-feature-text{color:#e0e7ff;font-size:.88rem;font-weight:500}.auth-panel{background:var(--bg);flex:1;justify-content:center;align-items:center;min-height:100vh;padding:40px 24px;display:flex}.auth-card{background:var(--bg-card);box-shadow:var(--shadow-md);border:1px solid var(--border);border-radius:20px;flex-direction:column;gap:10px;width:100%;max-width:400px;padding:44px 40px;display:flex}.auth-card-logo{align-items:center;margin-bottom:6px;display:flex}.auth-wordmark{width:180px;height:34px;display:block}@media (width<=859px){.auth-wordmark{width:168px;height:32px}}.auth-title{color:var(--text);letter-spacing:-.02em;margin:0 0 2px;font-size:1.55rem;font-weight:700}.auth-subtitle{color:var(--text-muted);margin:0 0 16px;font-size:.9rem}.auth-divider{background:var(--border-soft);height:1px;margin:4px 0}.auth-card label{color:var(--text-secondary);margin-bottom:-4px;font-size:.82rem;font-weight:600}.input-wrapper{align-items:center;display:flex;position:relative}.input-icon{color:var(--text-light);pointer-events:none;display:flex;position:absolute;left:12px}.auth-card input{border:1.5px solid var(--border);background:var(--bg-input);width:100%;color:var(--text);border-radius:10px;outline:none;padding:11px 12px 11px 38px;font-size:.93rem;transition:border-color .15s,box-shadow .15s}.auth-card input:focus{background:var(--bg-card);border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.auth-error{color:#dc2626;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;align-items:center;gap:8px;margin:0;padding:10px 14px;font-size:.84rem;display:flex}.field-error{color:#dc2626;margin-top:-6px;font-size:.78rem}.btn-primary{color:#fff;cursor:pointer;letter-spacing:.01em;background:linear-gradient(135deg,#4f46e5 0%,#6366f1 100%);border:none;border-radius:10px;margin-top:10px;padding:13px;font-size:.95rem;font-weight:600;transition:opacity .15s,transform .1s}.btn-primary:hover{opacity:.92}.btn-primary:active{transform:scale(.99)}.auth-switch{text-align:center;color:var(--text-muted);margin-top:4px;font-size:.85rem}.auth-switch a{color:#4f46e5;font-weight:600;text-decoration:none}.auth-switch a:hover{text-decoration:underline}.dashboard{flex-direction:column;gap:20px;max-width:1100px;padding:32px;display:flex}.notif-panel{background:var(--bg-card);border:1.5px solid var(--border);box-shadow:var(--shadow-sm);border-radius:12px;overflow:hidden}.notif-header{background:var(--bg-hover);border-bottom:1px solid var(--border-soft);justify-content:space-between;align-items:center;padding:10px 16px;display:flex}.notif-title{color:var(--text-secondary);align-items:center;gap:6px;font-size:.78rem;font-weight:700;display:flex}.notif-dismiss{color:var(--text-light);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:2px 6px;font-size:.85rem}.notif-dismiss:hover{background:var(--bg-hover);color:var(--text-secondary)}.notif-list{margin:0;padding:0;list-style:none}.notif-item{border-bottom:1px solid var(--border-soft);align-items:flex-start;gap:8px;padding:9px 16px;font-size:.82rem;display:flex}.notif-item:last-child{border-bottom:none}.notif-item:before{content:"●";flex-shrink:0;margin-top:5px;font-size:.5rem}.notif-item.error,.notif-item.error:before{color:#dc2626}.notif-item.warn{color:#d97706}.notif-item.warn:before{color:#f59e0b}.notif-item.info{color:#2563eb}.notif-item.info:before{color:#3b82f6}.notif-item.success,.notif-item.success:before{color:#16a34a}.period-selector{align-items:center;gap:8px;margin-top:6px;display:flex}.period-btn{border:1.5px solid var(--border);background:var(--bg-card);width:28px;height:28px;color:var(--text-secondary);cursor:pointer;border-radius:8px;justify-content:center;align-items:center;transition:all .15s;display:flex}.period-btn:hover:not(:disabled){color:#6366f1;border-color:#6366f1}.period-btn:disabled{opacity:.35;cursor:not-allowed}.period-label{color:var(--text-secondary);text-transform:capitalize;text-align:center;min-width:160px;font-size:.9rem;font-weight:600}.budget-cats-box{background:var(--bg-card);box-shadow:var(--shadow-sm);border-radius:14px;flex-direction:column;gap:16px;padding:20px 22px;display:flex}.budget-cats-box h3{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em;margin:0;font-size:.75rem;font-weight:700}.budget-cats-list{flex-direction:column;gap:14px;display:flex}.budget-cat-row{flex-direction:column;gap:5px;display:flex}.budget-cat-header{justify-content:space-between;align-items:center;display:flex}.budget-cat-name{color:var(--text-secondary);align-items:center;gap:7px;font-size:.85rem;font-weight:500;display:flex}.budget-cat-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.budget-cat-values{align-items:center;gap:4px;font-size:.82rem;font-weight:600;display:flex}.budget-sep{color:var(--text-light)}.budget-limit{color:var(--text-light);font-weight:500}.budget-pct-label{align-self:flex-end;font-size:.7rem;font-weight:700}.budget-badge{border-radius:10px;align-items:center;gap:3px;padding:1px 7px;font-size:.68rem;font-weight:700;display:inline-flex}.budget-badge.over{color:#dc2626;background:#fee2e2}.budget-badge.warn{color:#d97706;background:#fef3c7}.dash-loading{justify-content:center;align-items:center;height:60vh;display:flex}@keyframes spin{to{transform:rotate(360deg)}}.dash-header{justify-content:space-between;align-items:center;display:flex}.dash-greeting{color:var(--text);margin:0;font-size:1.5rem;font-weight:700}.dash-subtitle{color:var(--text-muted);margin:4px 0 0;font-size:.9rem}.btn-add{color:#fff;cursor:pointer;white-space:nowrap;background:#6366f1;border:none;border-radius:10px;align-items:center;gap:6px;padding:10px 18px;font-size:.9rem;font-weight:600;transition:background .15s,transform .1s;display:flex}.btn-add:hover{background:#4f46e5;transform:translateY(-1px)}.btn-add:active{transform:translateY(0)}.cards{grid-template-columns:repeat(3,1fr);gap:16px;display:grid}.card{background:var(--bg-card);box-shadow:var(--shadow-sm);border-top:3px solid #0000;border-radius:14px;flex-direction:column;gap:8px;padding:20px 22px;display:flex}.card.income{border-top-color:#16a34a}.card.expense{border-top-color:#dc2626}.card.positive{border-top-color:#6366f1}.card.negative{border-top-color:#dc2626}.card-top{justify-content:space-between;align-items:center;display:flex}.card-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;font-size:.75rem;font-weight:700}.card-icon{opacity:.5}.income-icon{color:#16a34a}.expense-icon{color:#dc2626}.wallet-icon{color:#6366f1}.card-value{color:var(--text);font-size:1.6rem;font-weight:700;line-height:1}.income-value{color:#16a34a}.expense-value{color:#dc2626}.positive .balance-value{color:#4f46e5}.negative .balance-value{color:#dc2626}.trend-badge{border-radius:20px;align-items:center;gap:4px;width:fit-content;padding:3px 8px;font-size:.7rem;font-weight:600;display:inline-flex}.trend-good{color:#16a34a;background:#dcfce7}.trend-bad{color:#dc2626;background:#fee2e2}.budget-box{background:var(--bg-card);box-shadow:var(--shadow-sm);border-radius:14px;flex-direction:column;gap:10px;padding:20px 22px;display:flex}.budget-header{color:var(--text-muted);justify-content:space-between;align-items:center;font-size:.85rem;font-weight:500;display:flex}.budget-pct{font-size:.9rem;font-weight:700}.budget-bar-bg{background:var(--bg-hover);border-radius:99px;height:10px;overflow:hidden}.budget-bar-fill{border-radius:99px;height:100%;transition:width .6s,background .3s}.budget-labels{color:var(--text-light);justify-content:space-between;font-size:.72rem;display:flex}.dash-grid{grid-template-columns:1fr 1fr;gap:16px;display:grid}.chart-box{background:var(--bg-card);box-shadow:var(--shadow-sm);border-radius:14px;padding:20px 22px}.chart-box h3{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em;margin:0 0 14px;font-size:.75rem;font-weight:700}.pie-legend{flex-direction:column;gap:7px;margin-top:14px;display:flex}.legend-item{align-items:center;gap:8px;font-size:.82rem;display:flex}.legend-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.legend-name{color:var(--text-secondary);text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.legend-val{color:var(--text);font-weight:600}.recent-box{background:var(--bg-card);box-shadow:var(--shadow-sm);border-radius:14px;padding:20px 22px}.recent-header{justify-content:space-between;align-items:center;margin-bottom:14px;display:flex}.recent-box h3{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em;margin:0;font-size:.75rem;font-weight:700}.tx-list{flex-direction:column;margin:0;padding:0;list-style:none;display:flex}.tx-item{border-bottom:1px solid var(--border-soft);justify-content:space-between;align-items:center;padding:11px 0;display:flex}.tx-item:last-child{border-bottom:none}.tx-left{align-items:center;gap:12px;min-width:0;display:flex}.tx-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.tx-desc{color:var(--text);text-overflow:ellipsis;white-space:nowrap;max-width:160px;font-size:.88rem;font-weight:500;display:block;overflow:hidden}.tx-meta{color:var(--text-light);margin-top:2px;font-size:.72rem;display:block}.tx-amount{white-space:nowrap;margin-left:8px;font-size:.9rem;font-weight:700}.empty-state{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:8px;min-height:200px;padding:32px 16px;display:flex}.empty-state p{color:var(--text-muted);margin:0;font-size:.9rem;font-weight:500}.empty-state small{color:var(--text-light);font-size:.78rem}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.modal-header h2{color:var(--text);margin:0;font-size:1.1rem;font-weight:700}.quick-form{flex-direction:column;gap:12px;display:flex}.form-input{border:1.5px solid var(--border);width:100%;color:var(--text);box-sizing:border-box;background:var(--bg-input);border-radius:9px;outline:none;padding:10px 12px;font-family:inherit;font-size:.9rem;transition:border-color .15s}.form-error{color:#dc2626;margin-top:-8px;font-size:.75rem}@media (width<=768px){.dashboard{gap:14px;padding:16px}.cards,.dash-grid{grid-template-columns:1fr}.dash-header{flex-direction:column;align-items:flex-start;gap:12px}.btn-add{justify-content:center;width:100%}}.forecast-box{background:var(--bg-card);border:1px solid var(--border);box-shadow:var(--shadow-sm);border-radius:14px;padding:20px 22px}.forecast-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.forecast-title{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;align-items:center;gap:6px;font-size:.82rem;font-weight:700;display:flex}.forecast-badge{border-radius:99px;padding:3px 10px;font-size:.72rem;font-weight:700}.forecast-badge.ok{color:#15803d;background:#dcfce7}.forecast-badge.over{color:#b91c1c;background:#fee2e2}.forecast-cols{grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:16px;display:grid}.forecast-col{flex-direction:column;gap:4px;display:flex}.fc-label{color:var(--text-light);text-transform:uppercase;letter-spacing:.05em;font-size:.72rem;font-weight:700}.fc-value{color:var(--text);font-size:1.1rem;font-weight:700}.fc-value.income{color:#16a34a}.fc-value.expense{color:#dc2626}.fc-sub{color:var(--text-light);font-size:.72rem}.forecast-cats{border-top:1px solid var(--border-soft);padding-top:14px}.forecast-cats-label{color:var(--text-light);text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px;font-size:.72rem;font-weight:700;display:block}.forecast-cats-list{flex-direction:column;gap:6px;display:flex}.forecast-cat-item{align-items:center;gap:8px;font-size:.8rem;display:flex}.fcat-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.fcat-name{color:var(--text-secondary);flex:1;font-weight:500}.fcat-avg{color:var(--text-muted);text-align:right;min-width:80px}.fcat-cur{color:var(--text);text-align:right;min-width:80px;font-weight:600}@media (width<=600px){.forecast-cols{grid-template-columns:1fr;gap:10px}}.tx-page{flex-direction:column;gap:20px;max-width:900px;padding:32px;display:flex}.tx-header{justify-content:space-between;align-items:flex-start;display:flex}.tx-header h1{color:var(--text);font-size:1.5rem;font-weight:700}.tx-subtitle{color:var(--text-muted);margin-top:4px;font-size:.85rem}.tx-subtitle .pos{color:#16a34a;font-weight:600}.tx-subtitle .neg{color:#dc2626;font-weight:600}.header-actions{align-items:center;gap:8px;display:flex}.btn-secondary{background:var(--bg-card);color:var(--text-secondary);border:1.5px solid var(--border);cursor:pointer;white-space:nowrap;border-radius:10px;align-items:center;gap:6px;padding:10px 16px;font-size:.9rem;font-weight:600;transition:all .15s;display:flex}.btn-secondary:hover:not(:disabled){color:#6366f1;border-color:#6366f1}.btn-secondary:disabled{opacity:.4;cursor:not-allowed}.tx-toolbar{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.filter-tabs{background:var(--bg-card);box-shadow:var(--shadow-sm);border-radius:10px;gap:4px;padding:4px;display:flex}.filter-tab{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:7px;padding:7px 16px;font-size:.85rem;font-weight:500;transition:all .15s}.filter-tab:hover{background:var(--bg-hover);color:var(--text-secondary)}.filter-tab.active{color:#fff;background:#6366f1;font-weight:600}.search-wrap{flex:1;min-width:180px;position:relative}.search-icon{color:var(--text-light);pointer-events:none;position:absolute;top:50%;left:10px;transform:translateY(-50%)}.search-input{border:1.5px solid var(--border);background:var(--bg-card);width:100%;color:var(--text);border-radius:9px;outline:none;padding:9px 12px 9px 32px;font-family:inherit;font-size:.88rem;transition:border-color .15s}.search-input:focus{border-color:#6366f1}.tx-list-card{background:var(--bg-card);box-shadow:var(--shadow-sm);border-radius:14px;overflow:hidden}.tx-list{margin:0;padding:0;list-style:none}.tx-row{border-bottom:1px solid var(--border-soft);align-items:center;gap:14px;padding:14px 20px;transition:background .1s;display:flex}.tx-row:last-child{border-bottom:none}.tx-row:hover{background:var(--bg-hover)}.tx-icon-wrap{flex-shrink:0}.tx-type-icon{display:block}.tx-type-icon.income{color:#16a34a}.tx-type-icon.expense{color:#dc2626}.tx-info{flex:1;min-width:0}.tx-desc{color:var(--text);text-overflow:ellipsis;white-space:nowrap;font-size:.9rem;font-weight:500;display:block;overflow:hidden}.tx-meta{align-items:center;gap:8px;margin-top:3px;display:flex}.tx-date{color:var(--text-light);font-size:.72rem}.cat-pill{border-radius:10px;padding:2px 8px;font-size:.7rem;font-weight:600;display:inline-block}.cat-pill.no-cat{background:var(--bg-hover);color:var(--text-light)}.tx-amount{white-space:nowrap;margin-left:auto;padding-right:8px;font-size:.95rem;font-weight:700}.tx-amount.income{color:#16a34a}.tx-amount.expense{color:#dc2626}.tx-actions{flex-shrink:0;align-items:center;gap:4px;display:flex}.delete-confirm span{color:#dc2626;white-space:nowrap;font-size:.75rem;font-weight:600}.empty-state{flex-direction:column;justify-content:center;align-items:center;gap:8px;padding:48px 16px;display:flex}.empty-icon{font-size:2.5rem}.empty-state p{color:var(--text-muted);font-size:.9rem;font-weight:500}.type-btn{background:var(--bg-input);color:var(--text-muted);cursor:pointer;border:2px solid #0000;border-radius:10px;justify-content:center;align-items:center;gap:6px;padding:10px;font-size:.88rem;font-weight:600;transition:all .15s;display:flex}.type-btn:hover{background:var(--bg-hover)}.type-btn.active.expense{color:#dc2626;background:#fee2e2;border-color:#dc2626}.type-btn.active.income{color:#16a34a;background:#dcfce7;border-color:#16a34a}.form-input{border:1.5px solid var(--border);width:100%;color:var(--text);background:var(--bg-input);box-sizing:border-box;resize:none;border-radius:9px;outline:none;padding:10px 12px;font-family:inherit;font-size:.9rem;transition:border-color .15s}.btn-submit.expense{background:#dc2626}.btn-submit.income{background:#16a34a}.btn-submit.undefined,.btn-submit{background:#6366f1}.recurring-toggle{background:var(--bg-input);border:1.5px solid var(--border);border-radius:10px;padding:12px 14px}.recurring-label{color:var(--text-secondary);cursor:pointer;align-items:center;gap:8px;font-size:.88rem;font-weight:600;display:flex}.recurring-label input[type=checkbox]{accent-color:#6366f1;width:16px;height:16px}.recurring-badge{color:#7c3aed;background:#ede9fe;border-radius:10px;align-items:center;gap:3px;padding:1px 6px;font-size:.65rem;font-weight:700;display:inline-flex}@media (width<=640px){.tx-page{gap:14px;padding:16px}.tx-header{flex-direction:column;gap:12px}.header-actions{width:100%}.header-actions .btn-secondary{flex:1;justify-content:center}.btn-primary{justify-content:center;width:100%}.form-row{grid-template-columns:1fr}.tx-toolbar{flex-direction:column;align-items:stretch}.filter-tabs{justify-content:center}.tx-row{gap:10px;padding:12px 14px}.tx-amount{font-size:.88rem}.delete-confirm span{display:none}.confirm-yes,.confirm-no{padding:4px 10px}}.installment-badge{color:#7c3aed;background:#ede9fe;border-radius:20px;align-items:center;gap:3px;padding:2px 7px;font-size:.7rem;font-weight:600;display:inline-flex}.import-modal{width:96vw;max-width:760px}.import-upload-area{border:2px dashed var(--border);text-align:center;color:var(--text-muted);border-radius:12px;flex-direction:column;align-items:center;gap:12px;padding:40px 20px;display:flex}.import-upload-icon{color:#6366f1;opacity:.6}.import-upload-area p{color:var(--text-secondary);margin:0;font-size:.95rem}.import-upload-area small{color:var(--text-light);font-size:.8rem}.import-error{color:#dc2626;align-items:center;gap:4px;font-size:.85rem;display:flex}.import-preview{flex-direction:column;gap:12px;display:flex}.import-preview-header{color:var(--text-muted);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;font-size:.85rem;display:flex}.import-cat-select{align-items:center;gap:8px;display:flex}.import-cat-select select{border:1px solid var(--border);background:var(--bg-card);color:var(--text);border-radius:6px;padding:4px 8px;font-size:.85rem}.import-table-wrap{border:1px solid var(--border-soft);border-radius:8px;max-height:360px;overflow-y:auto}.import-table{border-collapse:collapse;width:100%;font-size:.85rem}.import-table th{background:var(--bg-hover);text-align:left;color:var(--text-secondary);padding:8px 12px;font-weight:600;position:sticky;top:0}.import-table td{border-top:1px solid var(--border-soft);color:var(--text);padding:8px 12px}.import-table .row-deselected{opacity:.4}.import-desc{text-overflow:ellipsis;white-space:nowrap;max-width:260px;overflow:hidden}.import-type{border-radius:20px;padding:2px 8px;font-size:.75rem;font-weight:600}.import-type.income{color:#16a34a;background:#dcfce7}.import-type.expense{color:#dc2626;background:#fee2e2}.import-amount.income{color:#16a34a;font-weight:600}.import-amount.expense{color:#dc2626;font-weight:600}.import-actions{justify-content:flex-end;gap:8px;display:flex}.import-done{text-align:center;flex-direction:column;align-items:center;gap:12px;padding:40px 20px;display:flex}.import-done-icon{color:#16a34a}.import-done h3{color:var(--text);margin:0;font-size:1.2rem}.field-hint{color:#6366f1;margin-top:4px;font-size:.75rem;display:block}.cat-page{flex-direction:column;gap:28px;max-width:900px;padding:32px;display:flex}.cat-header{justify-content:space-between;align-items:flex-start;display:flex}.cat-header h1{color:var(--text);font-size:1.5rem;font-weight:700}.cat-subtitle{color:var(--text-muted);margin-top:4px;font-size:.85rem}.cat-section{flex-direction:column;gap:12px;display:flex}.section-header{align-items:center;gap:8px;display:flex}.cat-section h2{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;font-size:.75rem;font-weight:700}.section-count{background:var(--bg-hover);color:var(--text-muted);border-radius:10px;padding:1px 7px;font-size:.7rem;font-weight:700}.section-empty{background:var(--bg-card);color:var(--text-light);border:1.5px dashed var(--border);border-radius:12px;align-items:center;gap:8px;padding:20px;font-size:.85rem;display:flex;box-shadow:0 1px 3px #0000000a}.cat-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:10px;display:grid}.cat-card{background:var(--bg-card);box-shadow:var(--shadow-sm);border-left:4px solid #0000;border-radius:12px;align-items:center;gap:12px;padding:14px 16px;transition:transform .15s,box-shadow .15s;display:flex}.cat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.cat-icon-circle{border-radius:9px;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;display:flex}.cat-name-group{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.cat-name{color:var(--text-secondary);word-break:break-word;font-size:.88rem;font-weight:500}.cat-budget-label{color:var(--text-light);font-size:.7rem;font-weight:500}.cat-actions{gap:2px;display:flex}.act-btn{width:28px;height:28px;color:var(--text-light);cursor:pointer;background:0 0;border:none;border-radius:7px;justify-content:center;align-items:center;transition:all .15s;display:flex}.delete-confirm{align-items:center;gap:3px;display:flex}.delete-confirm span{color:#dc2626;font-size:.7rem;font-weight:600}.confirm-yes{color:#dc2626;background:#fee2e2;width:auto;padding:0 6px;font-size:.68rem;font-weight:700}.confirm-yes:hover{color:#dc2626!important;background:#fca5a5!important}.confirm-no{background:var(--bg-hover);color:var(--text-muted);width:auto;padding:0 6px;font-size:.68rem;font-weight:700}.confirm-no:hover{background:var(--border)!important;color:var(--text-secondary)!important}.modal-card{background:var(--bg-card);width:100%;max-width:400px;box-shadow:var(--shadow-lg);border-radius:16px;margin:16px;padding:28px;animation:.2s slideUp}.field-hint{color:var(--text-light);font-size:.72rem;font-weight:400}.type-toggle{grid-template-columns:1fr 1fr;gap:8px;display:grid}.type-btn-cat{background:var(--bg-input);color:var(--text-muted);cursor:pointer;border:2px solid #0000;border-radius:10px;justify-content:center;align-items:center;padding:10px;font-size:.88rem;font-weight:600;transition:all .15s;display:flex}.type-btn-cat:hover{background:var(--bg-hover)}.type-btn-cat.active-expense{color:#dc2626;background:#fee2e2;border-color:#dc2626}.type-btn-cat.active-income{color:#16a34a;background:#dcfce7;border-color:#16a34a}.color-preview-row{align-items:center;gap:8px;margin-bottom:4px;display:flex}.color-preview-dot{border-radius:50%;flex-shrink:0;width:20px;height:20px}.color-preview-hex{color:var(--text-muted);font-family:monospace;font-size:.78rem}.color-palette{flex-wrap:wrap;gap:8px;display:flex}.color-swatch.selected{border-color:var(--text);box-shadow:0 0 0 2px var(--bg-card) inset;transform:scale(1.1)}@media (width<=640px){.cat-page{gap:20px;padding:16px}.cat-header{flex-direction:column;gap:12px}.btn-primary{justify-content:center;width:100%}.cat-grid{grid-template-columns:1fr}.cat-card{padding:12px 14px}}.reports-page{flex-direction:column;gap:20px;max-width:960px;padding:32px;display:flex}.reports-loading{justify-content:center;align-items:center;height:60vh;display:flex}.reports-header{justify-content:space-between;align-items:flex-start;display:flex}.reports-header h1{color:var(--text);margin:0;font-size:1.5rem;font-weight:700}.reports-subtitle{color:var(--text-muted);margin-top:4px;font-size:.85rem}.print-btn{background:var(--bg-hover);color:var(--text-secondary);cursor:pointer;border:none;border-radius:10px;align-items:center;gap:6px;padding:8px 16px;font-size:.82rem;font-weight:600;transition:background .15s;display:flex}.print-btn:hover{background:var(--border)}.reports-tabs{background:var(--bg-hover);border-radius:12px;gap:4px;padding:4px;display:flex}.reports-tab{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:9px;flex:1;padding:8px 14px;font-size:.82rem;font-weight:600;transition:background .15s,color .15s}.reports-tab.active{background:var(--bg-card);color:#4f46e5;box-shadow:0 1px 4px #00000014}.stat-cards{grid-template-columns:repeat(4,1fr);gap:14px;display:grid}.stat-card{background:var(--bg-card);box-shadow:var(--shadow-sm);border-radius:14px;flex-direction:column;gap:6px;padding:18px 20px;display:flex}.stat-icon{color:#6366f1}.stat-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;font-size:.72rem;font-weight:700}.stat-sub{align-items:center;gap:4px;font-size:.72rem;font-weight:600;display:flex}.chart-card{background:var(--bg-card);box-shadow:var(--shadow-sm);border-radius:14px;padding:22px 24px}.chart-card-header{justify-content:space-between;align-items:center;margin-bottom:18px;display:flex}.chart-card-header h3{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin:0;font-size:.85rem;font-weight:700}.chart-legend-manual{color:var(--text-muted);align-items:center;font-size:.78rem;font-weight:500;display:flex}.legend-dot-line{vertical-align:middle;border-radius:2px;width:10px;height:3px;margin-right:5px;display:inline-block}.chart-tooltip{background:#1e293b;border-radius:10px;padding:10px 14px;box-shadow:0 8px 24px #0003}.tooltip-label{color:#94a3b8;text-transform:capitalize;margin:0 0 6px;font-size:.75rem;font-weight:600}.chart-tooltip p{margin:2px 0;font-size:.82rem;font-weight:600}.highlights{grid-template-columns:1fr 1fr;gap:14px;display:grid}.highlight-card{background:var(--bg-card);box-shadow:var(--shadow-sm);border-top:3px solid #0000;border-radius:14px;flex-direction:column;gap:4px;padding:20px 22px;display:flex}.highlight-card.best{border-top-color:#16a34a}.highlight-card.worst{border-top-color:#dc2626}.highlight-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;font-size:.72rem;font-weight:700}.highlight-month{color:var(--text-secondary);text-transform:capitalize;font-size:.95rem;font-weight:600}.highlight-card.best .highlight-value{color:#16a34a;font-size:1.4rem;font-weight:700}.highlight-card.worst .highlight-value{color:#dc2626;font-size:1.4rem;font-weight:700}.annual-controls{align-items:center;gap:12px;display:flex}.year-btn{background:var(--bg-hover);cursor:pointer;width:32px;height:32px;color:var(--text-secondary);border:none;border-radius:8px;justify-content:center;align-items:center;font-size:1.1rem;font-weight:700;transition:background .15s;display:flex}.year-btn:hover:not(:disabled){background:var(--border)}.year-btn:disabled{opacity:.4;cursor:not-allowed}.year-display{color:var(--text);text-align:center;min-width:48px;font-size:1.1rem;font-weight:700}.heatmap-grid{grid-template-columns:repeat(6,1fr);gap:8px;display:grid}.heatmap-cell{cursor:default;border-radius:10px;flex-direction:column;align-items:center;gap:4px;padding:12px 10px;transition:transform .1s;display:flex}.heatmap-cell:hover{transform:scale(1.04)}.heatmap-label{color:var(--text-secondary);text-transform:capitalize;font-size:.75rem;font-weight:700}.heatmap-value{color:var(--text);font-size:.78rem;font-weight:600}.heatmap-legend{color:var(--text-muted);align-items:center;gap:4px;margin-top:12px;font-size:.72rem;font-weight:500;display:flex}.heat-swatch{border-radius:3px;width:18px;height:12px;display:inline-block}.top-categories{flex-direction:column;gap:10px;display:flex}.top-cat-row{align-items:center;gap:10px;display:flex}.top-cat-rank{color:var(--text-light);width:24px;font-size:.78rem;font-weight:700}.top-cat-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.top-cat-name{color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;flex-shrink:0;width:130px;font-size:.85rem;font-weight:600;overflow:hidden}.top-cat-bar-wrap{background:var(--bg-hover);border-radius:99px;flex:1;height:8px;overflow:hidden}.top-cat-bar{border-radius:99px;height:100%;transition:width .6s}.top-cat-value{color:var(--text);text-align:right;width:90px;font-size:.82rem;font-weight:700}.cat-trend-controls{align-items:center;gap:12px;display:flex}.cat-trend-label{color:var(--text-muted);font-size:.82rem;font-weight:600}.cat-trend-select{background:var(--bg-card);border:1.5px solid var(--border);color:var(--text);cursor:pointer;border-radius:10px;outline:none;padding:7px 12px;font-size:.85rem;font-weight:500}.cat-trend-select:focus{border-color:#6366f1}.cat-color-dot{border-radius:50%;flex-shrink:0;width:12px;height:12px}.nw-cards{grid-template-columns:2fr 1fr 1fr 1fr;gap:14px;display:grid}.nw-card{background:var(--bg-card);box-shadow:var(--shadow-sm);border-radius:14px;flex-direction:column;gap:6px;padding:20px;display:flex}.nw-card.primary{color:#fff;background:linear-gradient(135deg,#4f46e5 0%,#7c3aed 100%)}.nw-card.primary .nw-label{color:#ffffffbf}.nw-card.primary .nw-value{color:#fff;font-size:1.4rem}.nw-card.primary .nw-sub{color:#fff9}.nw-icon{color:#ffffffe6}.nw-icon-sm{color:#6366f1}.nw-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:.72rem;font-weight:700}.nw-value{color:var(--text);font-size:1.2rem;font-weight:700}.nw-sub{color:var(--text-light);font-size:.72rem;font-weight:500}.nw-pct-badge{color:#16a34a;background:#f0fdf4;border-radius:20px;padding:3px 10px;font-size:.8rem;font-weight:700}.nw-progress-wrap{flex-direction:column;gap:8px;display:flex}.nw-progress-bar{background:var(--bg-hover);border-radius:99px;height:14px;overflow:hidden}.nw-progress-fill{background:linear-gradient(90deg,#4f46e5,#7c3aed);border-radius:99px;height:100%;transition:width .8s}.nw-progress-labels{color:var(--text-muted);justify-content:space-between;font-size:.75rem;font-weight:500;display:flex}.nw-insight{border-radius:10px;margin-top:16px;padding:12px 16px;font-size:.85rem}.nw-insight-success{color:#16a34a;font-weight:600}.nw-insight-info{color:var(--text)}.nw-insight-warn{color:#d97706;font-weight:600}.empty-state{text-align:center;color:var(--text-light);padding:60px 0;font-size:.9rem}@media print{.reports-tabs,.print-btn,.annual-controls{display:none}.reports-page{gap:16px;max-width:100%;padding:0}.chart-card,.stat-card,.nw-card,.highlight-card{box-shadow:none;break-inside:avoid;border:1px solid #e2e8f0}body{background:#fff}}@media (width<=900px){.nw-cards{grid-template-columns:1fr 1fr}}@media (width<=768px){.reports-page{gap:14px;padding:16px}.stat-cards{grid-template-columns:1fr 1fr}.highlights{grid-template-columns:1fr}.heatmap-grid{grid-template-columns:repeat(4,1fr)}.nw-cards{grid-template-columns:1fr 1fr}.reports-tabs{gap:2px}.reports-tab{padding:7px 8px;font-size:.75rem}}@media (width<=480px){.stat-cards{grid-template-columns:1fr}.heatmap-grid{grid-template-columns:repeat(3,1fr)}.nw-cards{grid-template-columns:1fr}}.plan-page{flex-direction:column;gap:24px;width:100%;max-width:900px;padding:32px;display:flex}.plan-loading{justify-content:center;align-items:center;height:60vh;display:flex}.plan-header h1{color:var(--text);font-size:1.5rem;font-weight:700}.plan-subtitle{color:var(--text-muted);margin-top:4px;font-size:.85rem}.plan-section{background:var(--bg-card);box-shadow:var(--shadow-sm);border-radius:14px;flex-direction:column;gap:16px;padding:22px 24px;display:flex}.plan-section h2{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em;margin:0;font-size:.8rem;font-weight:700}.plan-hint{color:var(--text-muted);margin:-8px 0 0;font-size:.82rem}.preset-grid{grid-template-columns:repeat(4,1fr);gap:10px;display:grid}.preset-btn{background:var(--bg-input);cursor:pointer;border:2px solid #0000;border-radius:12px;flex-direction:column;justify-content:center;align-items:center;gap:3px;padding:14px 10px;transition:all .15s;display:flex}.preset-btn:hover{background:#f0f0ff;border-color:#c7d2fe}.preset-btn.active{background:#eef2ff;border-color:#6366f1}.preset-label{color:var(--text);font-size:1rem;font-weight:700}.preset-desc{color:var(--text-muted);font-size:.72rem}.pct-header{justify-content:space-between;align-items:center;display:flex}.pct-total{font-size:.82rem;font-weight:700}.pct-total.ok{color:#16a34a}.pct-total.err{color:#dc2626}.pct-bars-preview{border-radius:99px;gap:2px;height:10px;display:flex;overflow:hidden}.pct-bar{border-radius:2px;height:100%;transition:width .3s}.pct-inputs{flex-direction:column;gap:12px;display:flex}.pct-input-row{align-items:center;gap:10px;display:flex}.pct-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.pct-label{color:var(--text-secondary);flex-shrink:0;width:110px;font-size:.85rem;font-weight:500}.pct-slider{flex:1;min-width:0;height:4px}.pct-number{border:1.5px solid var(--border);text-align:center;background:var(--bg-card);width:54px;color:var(--text);border-radius:8px;outline:none;padding:5px 8px;font-family:inherit;font-size:.88rem}.pct-number:focus{border-color:#6366f1}.pct-sym{color:var(--text-muted);font-size:.82rem}.btn-save{color:#fff;cursor:pointer;background:#6366f1;border:none;border-radius:10px;justify-content:center;align-items:center;gap:6px;padding:11px;font-family:inherit;font-size:.9rem;font-weight:700;transition:opacity .15s,background .15s;display:flex}.btn-save:not(:disabled):hover{background:#4f46e5}.section-title-row{justify-content:space-between;align-items:center;display:flex}.income-ref{color:var(--text-muted);font-size:.82rem}.income-ref strong{color:var(--text)}.buckets-grid{grid-template-columns:repeat(3,1fr);gap:14px;display:grid}.bucket-card{border:1px solid var(--border);background:var(--bg-card);border-top:3px solid #0000;border-radius:12px;flex-direction:column;gap:12px;padding:16px;display:flex}.bucket-header{justify-content:space-between;align-items:flex-start;gap:8px;display:flex}.bucket-title{align-items:center;gap:10px;display:flex}.bucket-icon{border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.bucket-label{color:var(--text);font-size:.88rem;font-weight:700;display:block}.bucket-desc{color:var(--text-light);margin-top:1px;font-size:.7rem;display:block}.bucket-badge{white-space:nowrap;border-radius:10px;flex-shrink:0;align-items:center;gap:3px;padding:2px 8px;font-size:.68rem;font-weight:700;display:inline-flex}.bucket-badge.over{color:#dc2626;background:#fee2e2}.bucket-badge.warn{color:#d97706;background:#fef3c7}.bucket-badge.ok{color:#16a34a;background:#dcfce7}.bucket-values{gap:0;display:flex}.bucket-values>div{flex-direction:column;flex:1;align-items:center;gap:2px;display:flex}.val-divider{background:var(--border-soft);width:1px;margin:0 4px}.val-label{color:var(--text-light);text-transform:uppercase;font-size:.68rem;font-weight:600}.val-amount{font-size:.82rem;font-weight:700}.val-amount.neutral{color:var(--text-secondary)}.bucket-bar-bg{background:var(--bg-hover);border-radius:99px;height:6px;overflow:hidden}.bucket-bar-fill{border-radius:99px;height:100%;transition:width .5s,background .3s}.bucket-pct-label{font-size:.68rem;font-weight:600}.no-income-banner{color:#92400e;background:#fef3c7;border-radius:12px;align-items:center;gap:10px;padding:14px 18px;font-size:.85rem;font-weight:500;display:flex}.unassigned-banner{color:#92400e;background:#fef3c7;border-radius:10px;align-items:flex-start;gap:8px;padding:10px 14px;font-size:.8rem;font-weight:500;display:flex}.unassigned-banner span{overflow-wrap:break-word;word-break:break-word;min-width:0}.cat-assign-list{flex-direction:column;gap:8px;display:flex}.cat-assign-row{background:var(--bg-input);border:1px solid var(--border-soft);border-radius:10px;justify-content:space-between;align-items:center;gap:12px;padding:10px 14px;display:flex}.cat-assign-info{flex:1;align-items:center;gap:9px;min-width:0;display:flex}.cat-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.cat-assign-name{color:var(--text-secondary);font-size:.88rem;font-weight:500}.bucket-tag{background:var(--bg-hover);color:var(--text-muted);border:1.5px solid var(--border);cursor:pointer;white-space:nowrap;border-radius:20px;padding:5px 12px;font-size:.75rem;font-weight:600;transition:all .15s}.bucket-tag:hover{color:#6366f1;border-color:#6366f1}.bucket-select{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.bucket-opt{background:var(--bg-hover);color:var(--text-secondary);border:1.5px solid var(--border);cursor:pointer;border-radius:8px;padding:5px 10px;font-size:.75rem;font-weight:600;transition:all .15s}.bucket-opt:hover{color:#6366f1;background:#e0e7ff;border-color:#6366f1}.bucket-opt.selected{color:#6366f1;background:#eef2ff;border-color:#6366f1}.bucket-opt.cancel{color:#dc2626}.bucket-opt.cancel:hover{background:#fee2e2;border-color:#dc2626}.empty-hint{color:var(--text-light);text-align:center;padding:16px;font-size:.82rem}@media (width<=768px){.plan-page{gap:16px;padding:16px}.preset-grid{grid-template-columns:1fr 1fr}.buckets-grid{grid-template-columns:1fr}.pct-label{width:90px}}.goals-page{flex-direction:column;gap:24px;max-width:900px;padding:32px;display:flex}.goals-header{justify-content:space-between;align-items:flex-start;display:flex}.goals-header h1{color:var(--text);font-size:1.5rem;font-weight:700}.goals-subtitle{color:var(--text-muted);margin-top:4px;font-size:.85rem}.btn-primary{color:#fff;cursor:pointer;white-space:nowrap;background:#6366f1;border:none;border-radius:10px;align-items:center;gap:6px;padding:10px 18px;font-size:.9rem;font-weight:600;transition:background .15s,transform .1s;display:flex}.btn-primary:hover{background:#4f46e5;transform:translateY(-1px)}.goals-empty{color:var(--text-light);flex-direction:column;align-items:center;gap:10px;padding:60px 16px;display:flex}.goals-empty p{font-size:.9rem;font-weight:500}.btn-empty-add{background:var(--bg-hover);color:#6366f1;cursor:pointer;border:none;border-radius:8px;align-items:center;gap:4px;margin-top:4px;padding:8px 14px;font-size:.82rem;font-weight:600;transition:background .15s;display:flex}.btn-empty-add:hover{background:#e0e7ff}.goals-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px;display:grid}.goal-card{background:var(--bg-card);box-shadow:var(--shadow-sm);border-top:3px solid var(--goal-color,#6366f1);border-radius:16px;flex-direction:column;gap:12px;padding:20px;transition:box-shadow .15s;display:flex}.goal-card:hover{box-shadow:var(--shadow-md)}.goal-card.done{opacity:.85}.goal-card-top{justify-content:space-between;align-items:flex-start;display:flex}.goal-icon-wrap{border-radius:12px;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.goal-icon{font-size:1.4rem}.goal-actions{gap:4px;display:flex}.act-btn{width:28px;height:28px;color:var(--text-light);cursor:pointer;background:0 0;border:none;border-radius:7px;justify-content:center;align-items:center;font-size:.72rem;font-weight:700;transition:background .15s,color .15s;display:flex}.act-btn:hover{background:var(--bg-hover);color:#6366f1}.act-btn.danger:hover{color:#dc2626;background:#fee2e2}.act-btn.confirm-yes{color:#dc2626;background:#fee2e2;width:auto;padding:0 8px}.act-btn.confirm-yes:hover{background:#fca5a5}.act-btn.confirm-no{background:var(--bg-hover);color:var(--text-muted);width:auto;padding:0 8px}.act-btn.confirm-no:hover{background:var(--border)}.del-confirm{gap:4px;display:flex}.goal-name{color:var(--text);margin:0;font-size:1rem;font-weight:700}.goal-amounts{align-items:baseline;gap:4px;display:flex}.goal-saved{font-size:1.25rem;font-weight:700}.goal-sep{color:var(--text-light);font-size:.9rem}.goal-target{color:var(--text-muted);font-size:.85rem}.goal-bar-bg{background:var(--bg-hover);border-radius:99px;height:8px;overflow:hidden}.goal-bar-fill{border-radius:99px;height:100%;transition:width .4s}.goal-bar-labels{justify-content:space-between;margin-top:-4px;display:flex}.goal-pct{font-size:.75rem;font-weight:700}.goal-deadline{color:var(--text-light);font-size:.72rem}.goal-suggest{color:var(--text-muted);background:var(--bg-input);border-radius:8px;align-items:center;gap:5px;padding:6px 10px;font-size:.75rem;display:flex}.btn-contribute{cursor:pointer;text-align:center;background:0 0;border:1.5px solid;border-radius:9px;padding:8px 12px;font-size:.82rem;font-weight:600;transition:background .15s}.btn-contribute:hover{background:color-mix(in srgb, var(--goal-color) 10%, transparent)}.contrib-row{align-items:center;gap:6px;display:flex}.contrib-input{border:1.5px solid var(--border);background:var(--bg-input);color:var(--text);border-radius:8px;outline:none;flex:1;padding:7px 10px;font-family:inherit;font-size:.85rem}.contrib-input:focus{border-color:#6366f1}.contrib-panel{flex-direction:column;gap:6px;display:flex}.contrib-balance-hint{color:var(--text-muted);background:var(--bg-subtle);border-radius:8px;flex-wrap:wrap;align-items:center;gap:6px;padding:7px 10px;font-size:.78rem;display:flex}.contrib-balance-hint strong{color:var(--text-secondary)}.contrib-shortcuts{gap:6px;margin-left:auto;display:flex}.contrib-shortcut{border:1.5px solid var(--border);cursor:pointer;background:var(--bg-card);color:#6366f1;border-radius:6px;padding:3px 8px;font-size:.75rem;font-weight:600;transition:background .15s,border-color .15s}.contrib-shortcut:hover{background:#6366f114;border-color:#6366f1}.contrib-loading{color:var(--text-light);padding:0 2px;font-size:.75rem}.modal-overlay{background:var(--modal-overlay);-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:100;justify-content:center;align-items:center;animation:.15s fadeIn;display:flex;position:fixed;inset:0}.modal-card{background:var(--bg-card);width:100%;max-width:460px;box-shadow:var(--shadow-lg);border-radius:16px;max-height:90vh;margin:16px;padding:28px;animation:.2s slideUp;overflow-y:auto}.btn-icon{cursor:pointer;color:var(--text-muted);background:0 0;border:none;border-radius:6px;align-items:center;padding:4px;transition:background .15s;display:flex}.modal-form{flex-direction:column;gap:14px;display:flex}.optional{color:var(--text-light);font-weight:400}.form-row{grid-template-columns:1fr 1fr;gap:12px;display:grid}.icon-picker{flex-wrap:wrap;gap:6px;display:flex}.icon-opt{background:var(--bg-input);cursor:pointer;border:2px solid #0000;border-radius:8px;justify-content:center;align-items:center;width:36px;height:36px;font-size:1.1rem;transition:all .12s;display:flex}.icon-opt:hover{background:#e0e7ff}.icon-opt.active{background:#ede9fe;border-color:#6366f1}.color-opt{cursor:pointer;border:3px solid #0000;border-radius:50%;width:28px;height:28px;transition:transform .12s,border-color .12s}.color-opt:hover{transform:scale(1.15)}.color-opt.active{border-color:var(--text);transform:scale(1.2)}.btn-submit{color:#fff;cursor:pointer;border:none;border-radius:10px;margin-top:4px;padding:12px;font-family:inherit;font-size:.95rem;font-weight:700;transition:opacity .15s,transform .1s}.btn-submit:not(:disabled):hover{opacity:.9;transform:translateY(-1px)}@media (width<=640px){.goals-page{gap:16px;padding:16px}.goals-header{flex-direction:column;gap:12px}.btn-primary{justify-content:center;width:100%}.goals-grid,.form-row{grid-template-columns:1fr}}.profile-page{flex-direction:column;gap:24px;max-width:800px;padding:32px;display:flex}.profile-header h1{color:var(--text);font-size:1.5rem;font-weight:700}.profile-subtitle{color:var(--text-muted);margin-top:4px;font-size:.85rem}.profile-alert{border-radius:10px;align-items:center;gap:10px;padding:12px 16px;font-size:.88rem;font-weight:500;display:flex}.profile-alert.success{color:#166534;background:#dcfce7}.profile-alert.error{color:#991b1b;background:#fee2e2}.alert-close{cursor:pointer;opacity:.6;background:0 0;border:none;margin-left:auto;font-size:.8rem}.alert-close:hover{opacity:1}.profile-avatar-row{background:var(--bg-card);box-shadow:var(--shadow-sm);border-radius:14px;align-items:center;gap:16px;padding:20px 24px;display:flex}.profile-avatar{color:#fff;background:linear-gradient(135deg,#6366f1,#8b5cf6);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:56px;height:56px;font-size:1.3rem;font-weight:700;display:flex}.profile-name{color:var(--text);font-size:1rem;font-weight:700}.profile-email{color:var(--text-muted);margin-top:2px;font-size:.85rem}.profile-grid{grid-template-columns:1fr 1fr;gap:16px;display:grid}.profile-card,.profile-section{background:var(--bg-card);box-shadow:var(--shadow-sm);border-radius:14px;padding:24px}.profile-card-header{color:var(--text-muted);align-items:center;gap:8px;margin-bottom:20px;display:flex}.profile-card-header h2{color:var(--text);font-size:.95rem;font-weight:700}.profile-form{flex-direction:column;gap:14px;display:flex}.field{flex-direction:column;gap:5px;display:flex}.field label{color:var(--text-secondary);font-size:.8rem;font-weight:600}.field-err{color:#dc2626;font-size:.73rem}.form-input{border:1.5px solid var(--border);width:100%;color:var(--text);background:var(--bg-input);box-sizing:border-box;border-radius:9px;outline:none;padding:10px 12px;font-family:inherit;font-size:.9rem;transition:border-color .15s}.form-input:focus{background:var(--bg-card);border-color:#6366f1}.btn-save{color:#fff;cursor:pointer;background:#6366f1;border:none;border-radius:10px;justify-content:center;align-items:center;gap:8px;margin-top:4px;padding:11px;font-family:inherit;font-size:.9rem;font-weight:700;transition:background .15s,transform .1s;display:flex}.btn-save:hover:not(:disabled){background:#4f46e5;transform:translateY(-1px)}.btn-save:disabled{opacity:.6;cursor:not-allowed}.profile-info-card{padding:16px 24px}.profile-info-label{color:var(--text-light);text-transform:uppercase;letter-spacing:.05em;font-size:.78rem;font-weight:600}.profile-info-value{color:var(--text-secondary);margin-top:4px;font-size:.95rem;font-weight:600}@media (width<=640px){.profile-page{gap:16px;padding:16px}.profile-grid{grid-template-columns:1fr}}.admin-page{flex-direction:column;gap:24px;max-width:1100px;padding:32px;display:flex}.admin-header{justify-content:space-between;align-items:flex-start;display:flex}.admin-title{color:var(--text);align-items:center;gap:10px;margin:0 0 4px;font-size:1.4rem;font-weight:700;display:flex}.admin-sub{color:var(--text-muted);margin:0;font-size:.88rem}.btn-refresh{background:var(--bg-hover);border:1px solid var(--border);cursor:pointer;color:var(--text-muted);border-radius:8px;padding:8px;transition:background .15s;display:flex}.btn-refresh:hover{background:var(--border);color:var(--text-secondary)}.admin-stats{grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:14px;display:grid}.admin-stat{background:var(--bg-card);border:1px solid var(--border);border-radius:14px;flex-direction:column;gap:4px;padding:20px;display:flex}.stat-value{color:var(--text);font-size:1.8rem;font-weight:700}.stat-label{color:var(--text-muted);font-size:.78rem;font-weight:500}.admin-stat.green .stat-value{color:#16a34a}.admin-stat.purple .stat-value{color:#7c3aed}.admin-stat.blue .stat-value{color:#2563eb}.admin-card,.admin-table-wrap{background:var(--bg-card);border:1px solid var(--border);border-radius:14px;overflow:hidden}.admin-table{border-collapse:collapse;width:100%;font-size:.875rem}.admin-table thead tr{background:var(--bg-hover);border-bottom:1px solid var(--border)}.admin-table th{text-align:left;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;padding:12px 16px;font-size:.75rem;font-weight:600}.admin-table td{border-bottom:1px solid var(--border-soft);color:var(--text-secondary);padding:13px 16px}.admin-table tbody tr:last-child td{border-bottom:none}.admin-table tbody tr:hover td{background:var(--bg-hover)}.row-inactive td{opacity:.55}.td-id{color:var(--text-light);width:40px;font-size:.8rem}.td-name{color:var(--text);font-weight:600}.td-email{color:var(--text-muted)}.td-date{color:var(--text-light);white-space:nowrap;font-size:.82rem}.badge{border-radius:99px;padding:3px 10px;font-size:.75rem;font-weight:600;display:inline-flex}.badge-active{color:#16a34a;background:#dcfce7}.badge-inactive{background:var(--bg-hover);color:var(--text-light)}.badge-admin{color:#7c3aed;background:#ede9fe}.badge-user{background:var(--bg-hover);color:var(--text-muted)}.td-actions{flex-wrap:wrap;gap:8px;display:flex}.btn-action{cursor:pointer;border:1px solid #0000;border-radius:7px;align-items:center;gap:5px;padding:5px 12px;font-size:.78rem;font-weight:600;transition:opacity .15s;display:inline-flex}.btn-action:hover{opacity:.8}.btn-activate{color:#16a34a;background:#dcfce7;border-color:#bbf7d0}.btn-deactivate{color:#dc2626;background:#fee2e2;border-color:#fecaca}.btn-promote{color:#7c3aed;background:#ede9fe;border-color:#ddd6fe}.btn-demote{background:var(--bg-hover);color:var(--text-muted);border-color:var(--border)}.admin-loading{text-align:center;color:var(--text-light);padding:40px;font-size:.9rem}.admin-error{text-align:center;color:#dc2626;background:#fef2f2;border-radius:8px;margin:16px;padding:40px;font-size:.9rem}.accounts-page{flex-direction:column;gap:24px;max-width:960px;padding:32px;display:flex}.accounts-loading{justify-content:center;align-items:center;height:60vh;display:flex}.loading-spinner{border:3px solid var(--border);border-top-color:#6366f1;border-radius:50%;width:40px;height:40px;animation:.7s linear infinite spin}.accounts-header{justify-content:space-between;align-items:flex-start;display:flex}.accounts-header h1{color:var(--text);font-size:1.5rem;font-weight:700}.accounts-subtitle{color:var(--text-muted);margin-top:4px;font-size:.85rem}.btn-new-account{color:#fff;cursor:pointer;background:#4f46e5;border:none;border-radius:10px;align-items:center;gap:7px;padding:9px 18px;font-size:.85rem;font-weight:600;transition:background .15s;display:flex}.btn-new-account:hover{background:#3730a3}.total-balance-card{color:#fff;background:linear-gradient(135deg,#1e1b4b,#4f46e5);border-radius:16px;flex-direction:column;gap:6px;padding:24px 28px;display:flex}.tbc-label{text-transform:uppercase;letter-spacing:.06em;color:#ffffffb3;font-size:.75rem;font-weight:700}.tbc-value{letter-spacing:-.02em;font-size:2.2rem;font-weight:800}.tbc-sub{color:#fff9;font-size:.8rem}.accounts-grid{grid-template-columns:repeat(3,1fr);gap:16px;display:grid}.account-card{background:var(--bg-card);border:1px solid var(--border);box-shadow:var(--shadow-sm);border-top:3px solid #6366f1;border-radius:14px;flex-direction:column;gap:6px;padding:20px;transition:box-shadow .15s;display:flex}.account-card:hover{box-shadow:var(--shadow-md)}.ac-top{justify-content:space-between;align-items:center;margin-bottom:4px;display:flex}.ac-icon-wrap{border-radius:10px;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.ac-actions{gap:4px;display:flex}.ac-btn{cursor:pointer;color:var(--text-light);background:0 0;border:none;border-radius:7px;padding:5px;transition:background .12s,color .12s}.ac-btn:hover{background:var(--bg-hover);color:var(--text-secondary)}.ac-btn.danger:hover{color:#dc2626;background:#fee2e2}.ac-info{flex-direction:column;gap:2px;display:flex}.ac-name{color:var(--text);font-size:1rem;font-weight:700}.ac-type{color:var(--text-muted);font-size:.75rem;font-weight:500}.ac-balance{letter-spacing:-.02em;margin-top:4px;font-size:1.4rem;font-weight:800}.ac-initial{color:var(--text-light);font-size:.72rem}.ac-tx-count{color:var(--text-light);font-size:.72rem;font-weight:500}.accounts-empty{text-align:center;color:var(--text-light);flex-direction:column;align-items:center;gap:10px;padding:60px 20px;display:flex}.accounts-empty p{color:var(--text-muted);font-size:1rem;font-weight:600}.accounts-empty small{font-size:.82rem}.modal-overlay{background:var(--modal-overlay);z-index:1000;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-card{background:var(--bg-card);width:100%;max-width:420px;box-shadow:var(--shadow-lg);border-radius:18px;padding:28px}.modal-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.modal-header h2{color:var(--text);font-size:1.1rem;font-weight:700}.account-form{flex-direction:column;gap:10px;display:flex}.form-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:.78rem;font-weight:700}.form-input{background:var(--bg-input);border:1.5px solid var(--border);width:100%;color:var(--text);border-radius:10px;outline:none;padding:9px 12px;font-size:.9rem;transition:border-color .15s}.form-input:focus{border-color:#6366f1}.form-error{color:#dc2626;font-size:.75rem;font-weight:500}.color-picker{flex-wrap:wrap;gap:8px;display:flex}.color-swatch{cursor:pointer;border:2px solid #0000;border-radius:50%;width:26px;height:26px;transition:transform .1s,border-color .1s}.color-swatch:hover{transform:scale(1.15)}.color-swatch.selected{border-color:var(--text);transform:scale(1.15)}.btn-submit{color:#fff;cursor:pointer;border:none;border-radius:10px;width:100%;margin-top:6px;padding:11px;font-size:.9rem;font-weight:700;transition:opacity .15s}.btn-submit:hover{opacity:.85}.btn-submit:disabled{opacity:.6;cursor:not-allowed}.btn-icon{cursor:pointer;color:var(--text-muted);background:0 0;border:none;border-radius:8px;align-items:center;padding:6px;display:flex}.btn-icon:hover{background:var(--bg-hover)}.confirm-modal{text-align:center;flex-direction:column;gap:14px;display:flex}.confirm-modal h3{color:var(--text);font-size:1.1rem;font-weight:700}.confirm-modal p{color:var(--text-muted);font-size:.87rem;line-height:1.5}.confirm-actions{justify-content:center;gap:10px;margin-top:4px;display:flex}.btn-cancel{background:var(--bg-hover);color:var(--text-secondary);cursor:pointer;border:none;border-radius:10px;padding:9px 20px;font-size:.85rem;font-weight:600}.btn-cancel:hover{background:var(--border)}.btn-confirm-danger{color:#fff;cursor:pointer;background:#dc2626;border:none;border-radius:10px;padding:9px 20px;font-size:.85rem;font-weight:600}.btn-confirm-danger:hover{background:#b91c1c}@media (width<=768px){.accounts-page{padding:16px}.accounts-grid{grid-template-columns:1fr 1fr}}@media (width<=480px){.accounts-grid{grid-template-columns:1fr}}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);color:var(--text);font-family:Inter,system-ui,sans-serif;transition:background .2s,color .2s}:root{--bg:#f8fafc;--bg-card:#fff;--bg-hover:#f1f5f9;--bg-input:#f8fafc;--bg-subtle:#f1f5f9;--border:#e2e8f0;--border-soft:#f1f5f9;--text:#1e293b;--text-secondary:#334155;--text-muted:#64748b;--text-light:#94a3b8;--sidebar-bg:#1e1b4b;--shadow-sm:0 1px 3px #0000000f, 0 4px 12px #0000000a;--shadow-md:0 4px 16px #0000001a;--shadow-lg:0 20px 60px #00000026;--modal-overlay:#0f172a80}[data-theme=dark]{--bg:#0f172a;--bg-card:#1e293b;--bg-hover:#293548;--bg-input:#0f172a;--bg-subtle:#293548;--border:#334155;--border-soft:#293548;--text:#f1f5f9;--text-secondary:#cbd5e1;--text-muted:#94a3b8;--text-light:#64748b;--sidebar-bg:#080f1e;--shadow-sm:0 1px 3px #0006, 0 4px 12px #00000040;--shadow-md:0 4px 16px #00000080;--shadow-lg:0 20px 60px #0009;--modal-overlay:#000000b3}.app-layout{min-height:100dvh;display:flex}.app-main{background:var(--bg);flex:1;min-width:0;overflow-y:auto}.app-page-wrap{width:100%}.app-page-wrap>*{margin-left:auto;margin-right:auto}.app-brand-strip{border-bottom:1px solid var(--border-soft);background:radial-gradient(circle at 100% 0,#1d4ed81f,#0000 38%),radial-gradient(circle at 0,#38bdf81a,#0000 32%);align-items:center;gap:18px;padding:24px 28px 10px;display:flex}.app-brand-strip__media{flex-shrink:0}.app-brand-strip__badge{width:164px;height:48px;display:block}.app-brand-strip__content{flex-direction:column;gap:6px;max-width:760px;display:flex}.app-brand-strip__eyebrow{letter-spacing:.12em;text-transform:uppercase;color:#1d4ed8;font-size:.72rem;font-weight:700;line-height:1}.app-brand-strip__title{color:var(--text);font-size:1.15rem;font-weight:800;line-height:1.3}.app-brand-strip__text{color:var(--text-muted);font-size:.92rem;line-height:1.55}.loading-screen{height:100vh;color:var(--text-muted);justify-content:center;align-items:center;font-size:1rem;display:flex}.sidebar-backdrop{z-index:199;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#00000080;display:none;position:fixed;inset:0}.sidebar-backdrop.open{display:block}.mobile-menu-btn{z-index:201;background:var(--bg-card);border:1.5px solid var(--border);cursor:pointer;width:40px;height:40px;color:var(--text);box-shadow:var(--shadow-md);border-radius:10px;justify-content:center;align-items:center;display:none;position:fixed;top:14px;left:14px}@media (width<=768px){.mobile-menu-btn{display:flex}.app-main{padding-top:0}.app-brand-strip{flex-direction:column;align-items:flex-start;gap:12px;padding:64px 18px 12px}.app-brand-strip__badge{width:150px;height:44px}.app-brand-strip__title{font-size:1rem}.app-brand-strip__text{font-size:.88rem}}[data-theme=dark] .card,[data-theme=dark] .chart-box,[data-theme=dark] .recent-box,[data-theme=dark] .budget-box,[data-theme=dark] .budget-cats-box,[data-theme=dark] .forecast-box,[data-theme=dark] .highlights,[data-theme=dark] .highlight-card,[data-theme=dark] .stat-card,[data-theme=dark] .chart-card,[data-theme=dark] .account-card,[data-theme=dark] .nw-card:not(.primary),[data-theme=dark] .goal-card,[data-theme=dark] .cat-card,[data-theme=dark] .feature-list-card,[data-theme=dark] .top-categories,[data-theme=dark] .flow,[data-theme=dark] .flow-step,[data-theme=dark] .stack-card,[data-theme=dark] .screen-card,[data-theme=dark] .endpoint-table,[data-theme=dark] .endpoint-table th,[data-theme=dark] .security-item,[data-theme=dark] .annual-controls,[data-theme=dark] .feature-card{background:var(--bg-card);border-color:var(--border);color:var(--text)}[data-theme=dark] .modal-card,[data-theme=dark] .confirm-modal{background:var(--bg-card);color:var(--text)}[data-theme=dark] .modal-overlay{background:var(--modal-overlay)}[data-theme=dark] .app-brand-strip{border-color:var(--border);background:radial-gradient(circle at 100% 0,#38bdf824,#0000 40%),radial-gradient(circle at 0,#1d4ed82e,#0000 34%)}[data-theme=dark] .app-brand-strip__eyebrow{color:#7dd3fc}[data-theme=dark] .modal-header h2,[data-theme=dark] .modal-header h3{color:var(--text)}[data-theme=dark] .notif-panel{background:var(--bg-card);border-color:var(--border)}[data-theme=dark] .notif-header{background:var(--bg-hover);border-color:var(--border)}[data-theme=dark] .notif-title{color:var(--text-muted)}[data-theme=dark] .notif-item{border-color:var(--border-soft)}[data-theme=dark] input:not([type=checkbox]):not([type=radio]):not([type=color]),[data-theme=dark] select,[data-theme=dark] textarea,[data-theme=dark] .form-input,[data-theme=dark] .cat-trend-select,[data-theme=dark] .cat-trend-select option{background:var(--bg-input)!important;color:var(--text)!important;border-color:var(--border)!important}[data-theme=dark] input::placeholder,[data-theme=dark] textarea::placeholder{color:var(--text-light)}[data-theme=dark] .btn-icon,[data-theme=dark] .period-btn,[data-theme=dark] .year-btn,[data-theme=dark] .print-btn,[data-theme=dark] .btn-cancel,[data-theme=dark] .btn-empty-add,[data-theme=dark] .ac-btn:not(.danger){background:var(--bg-hover);color:var(--text-muted);border-color:var(--border)}[data-theme=dark] .btn-icon:hover,[data-theme=dark] .period-btn:hover:not(:disabled),[data-theme=dark] .year-btn:hover:not(:disabled),[data-theme=dark] .print-btn:hover,[data-theme=dark] .btn-empty-add:hover{background:var(--border);color:var(--text)}[data-theme=dark] .type-btn{background:var(--bg-hover);color:var(--text-muted);border-color:#0000}[data-theme=dark] .type-btn:hover{background:var(--border)}[data-theme=dark] h1,[data-theme=dark] h2,[data-theme=dark] h3,[data-theme=dark] .dash-greeting,[data-theme=dark] .card-value,[data-theme=dark] .stat-value,[data-theme=dark] .nw-value,[data-theme=dark] .ac-balance,[data-theme=dark] .highlight-value,[data-theme=dark] .highlight-month,[data-theme=dark] .year-display,[data-theme=dark] .fc-value,[data-theme=dark] .tx-desc,[data-theme=dark] .legend-val,[data-theme=dark] .budget-cat-name,[data-theme=dark] .top-cat-name,[data-theme=dark] .top-cat-value,[data-theme=dark] .fcat-cur,[data-theme=dark] .ac-name,[data-theme=dark] .tbc-value,[data-theme=dark] .section-title,[data-theme=dark] .period-label,[data-theme=dark] .forecast-title,[data-theme=dark] .forecast-title{color:var(--text)}[data-theme=dark] .card-label,[data-theme=dark] .stat-label,[data-theme=dark] .nw-label,[data-theme=dark] .nw-sub,[data-theme=dark] .ac-type,[data-theme=dark] .ac-initial,[data-theme=dark] .ac-tx-count,[data-theme=dark] .tbc-sub,[data-theme=dark] .highlight-label,[data-theme=dark] .section-desc,[data-theme=dark] .chart-card-header h3,[data-theme=dark] .chart-card-header,[data-theme=dark] .budget-cats-box h3,[data-theme=dark] .chart-box h3,[data-theme=dark] .recent-box h3,[data-theme=dark] .accounts-subtitle,[data-theme=dark] .reports-subtitle,[data-theme=dark] .fc-label,[data-theme=dark] .forecast-cats-label,[data-theme=dark] .fcat-avg,[data-theme=dark] .tx-meta,[data-theme=dark] .legend-name,[data-theme=dark] .budget-header,[data-theme=dark] .budget-labels,[data-theme=dark] .budget-limit,[data-theme=dark] .budget-sep,[data-theme=dark] .fcat-name,[data-theme=dark] .ac-tx-count,[data-theme=dark] .cat-trend-label,[data-theme=dark] .stack-card p,[data-theme=dark] .screen-card p,[data-theme=dark] .feature-card p,[data-theme=dark] .security-item p,[data-theme=dark] .empty-state p,[data-theme=dark] .empty-state small,[data-theme=dark] .text-muted{color:var(--text-muted)}[data-theme=dark] .tx-item,[data-theme=dark] .forecast-cats,[data-theme=dark] .budget-cat-row+.budget-cat-row{border-color:var(--border-soft)}[data-theme=dark] .budget-bar-bg,[data-theme=dark] .nw-progress-bar,[data-theme=dark] .top-cat-bar-wrap,[data-theme=dark] .reports-tabs{background:var(--bg-hover)}[data-theme=dark] .reports-tab{color:var(--text-muted)}[data-theme=dark] .reports-tab.active{background:var(--bg-card);color:#818cf8}[data-theme=dark] .heatmap-legend{color:var(--text-muted)}[data-theme=dark] .endpoint-table th{background:var(--bg-hover);color:var(--text-muted)}[data-theme=dark] .endpoint-table td{color:var(--text-secondary);border-color:var(--border)}[data-theme=dark] .endpoint-table tr:hover td{background:var(--bg-hover)}[data-theme=dark] .color-swatch.selected{border-color:var(--text)}[data-theme=dark] .admin-card,[data-theme=dark] .admin-stat{background:var(--bg-card);border-color:var(--border)}[data-theme=dark] .admin-table th{background:var(--bg-hover);color:var(--text-muted)}[data-theme=dark] .admin-table td{border-color:var(--border);color:var(--text)}[data-theme=dark] .admin-table tr:hover td{background:var(--bg-hover)}[data-theme=dark] .profile-card,[data-theme=dark] .profile-section,[data-theme=dark] .auth-card,[data-theme=dark] .plan-card,[data-theme=dark] .plan-section{background:var(--bg-card);border-color:var(--border)}[data-theme=dark] .goal-card{background:var(--bg-card)}[data-theme=dark] .goal-progress-bg{background:var(--bg-hover)}[data-theme=dark] .cat-card{background:var(--bg-card)}[data-theme=dark] ::-webkit-scrollbar{width:6px}[data-theme=dark] ::-webkit-scrollbar-track{background:var(--bg)}[data-theme=dark] ::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}@media (width<=768px){.dashboard,.reports-page,.accounts-page,.goals-page,.categories-page,.admin-page,.profile-page,.planning-page{gap:14px;padding:64px 16px 16px}.modal-card{border-radius:16px;max-width:calc(100vw - 24px);margin:12px;padding:20px}.stat-cards,.accounts-grid,.screen-grid,.stack-grid,.security-grid,.nw-cards,.feature-grid{grid-template-columns:1fr 1fr}.cards,.dash-grid,.highlights,.forecast-cols{grid-template-columns:1fr}.dash-header,.accounts-header,.reports-header{flex-direction:column;align-items:flex-start;gap:10px}.btn-add,.btn-new-account{justify-content:center;width:100%}.endpoint-table{font-size:.75rem}table{display:block;overflow-x:auto}.reports-tabs{flex-wrap:wrap}.reports-tab{padding:7px 10px;font-size:.75rem}.heatmap-grid{grid-template-columns:repeat(4,1fr)}.forecast-cat-item{flex-wrap:wrap}.fcat-avg,.fcat-cur{min-width:0}}@media (width<=480px){.stat-cards,.nw-cards,.feature-grid,.screen-grid,.stack-grid{grid-template-columns:1fr}.heatmap-grid{grid-template-columns:repeat(3,1fr)}.accounts-grid,.security-grid{grid-template-columns:1fr}}
