*{margin:0;padding:0;box-sizing:border-box}:root{--bg-base: #0d1117;--bg-elevated: #161c2b;--bg-subtle: #1c2438;--bg-hover: rgba(255, 255, 255, .04);--border: rgba(255, 255, 255, .07);--border-strong: rgba(255, 255, 255, .14);--text-primary: #e2e8f0;--text-secondary: #94a3b8;--text-muted: #475569;--green-300: #6ee7b7;--green-400: #34d399;--green-500: #10b981;--green-600: #059669;--green-700: #047857;--red-400: #f87171;--red-500: #ef4444;--red-600: #dc2626;--amber-400: #fbbf24;--amber-500: #f59e0b;--amber-600: #d97706;--gray-400: #94a3b8;--gray-500: #64748b;--color-income: var(--green-400);--color-expense: var(--red-400);--color-investment: var(--amber-400);--color-balance-pos: var(--green-400);--color-balance-neg: var(--red-400);--card-bg: var(--bg-elevated);--navbar-bg: #0d1117;--navbar-border: rgba(255, 255, 255, .07);--navbar-text: var(--text-primary);--input-bg: var(--bg-subtle);--input-border: var(--border-strong);--input-focus-border: var(--green-500);--input-text: var(--text-primary);--input-placeholder: var(--text-muted);--table-header-bg: rgba(255, 255, 255, .03);--table-row-hover: rgba(255, 255, 255, .03);--table-border: rgba(255, 255, 255, .06);--tooltip-bg: #1c2438;--tooltip-border: rgba(255, 255, 255, .1);--tooltip-text: var(--text-primary);--mom-positive-bg: rgba(52, 211, 153, .12);--mom-positive-color: var(--green-400);--mom-negative-bg: rgba(248, 113, 113, .12);--mom-negative-color: var(--red-400);--mom-neutral-bg: rgba(71, 85, 105, .25);--mom-neutral-color: var(--text-muted);--insight-positive-bg: rgba(52, 211, 153, .06);--insight-positive-border: rgba(52, 211, 153, .14);--insight-negative-bg: rgba(248, 113, 113, .06);--insight-negative-border: rgba(248, 113, 113, .14);--insight-warning-bg: rgba(251, 191, 36, .06);--insight-warning-border: rgba(251, 191, 36, .14);--insight-neutral-bg: var(--bg-hover);--insight-neutral-border: var(--border);--tab-active-bg: rgba(16, 185, 129, .1);--tab-active-color: var(--green-400);--tab-active-border: var(--green-500);--tab-hover-bg: var(--bg-hover);--tab-hover-color: var(--text-secondary);--badge-bg: rgba(16, 185, 129, .12);--badge-color: var(--green-400);--section-divider: var(--border);--auth-card-bg: rgba(22, 28, 43, .96);--auth-card-border: rgba(255, 255, 255, .1);--error-bg: rgba(248, 113, 113, .08);--error-border: rgba(248, 113, 113, .2);--error-color: var(--red-400);--radius: 10px;--radius-lg: 14px;--transition: .2s ease}[data-theme=light]{--bg-base: #f1f5f9;--bg-elevated: #ffffff;--bg-subtle: #f8fafc;--bg-hover: rgba(0, 0, 0, .03);--border: rgba(0, 0, 0, .08);--border-strong: rgba(0, 0, 0, .14);--text-primary: #1e293b;--text-secondary: #64748b;--text-muted: #94a3b8;--green-300: #6ee7b7;--green-400: #059669;--green-500: #047857;--green-600: #065f46;--green-700: #064e3b;--red-400: #e11d48;--red-500: #be123c;--red-600: #9f1239;--amber-400: #d97706;--amber-500: #b45309;--amber-600: #92400e;--gray-400: #94a3b8;--gray-500: #64748b;--color-income: #059669;--color-expense: #e11d48;--color-investment: #d97706;--color-balance-pos: #059669;--color-balance-neg: #e11d48;--card-bg: #ffffff;--navbar-bg: #ffffff;--navbar-border: rgba(0, 0, 0, .08);--navbar-text: #1e293b;--input-bg: #ffffff;--input-border: rgba(0, 0, 0, .14);--input-focus-border: #059669;--input-text: #1e293b;--input-placeholder: #94a3b8;--table-header-bg: rgba(0, 0, 0, .02);--table-row-hover: rgba(5, 150, 105, .04);--table-border: rgba(0, 0, 0, .06);--tooltip-bg: #ffffff;--tooltip-border: rgba(0, 0, 0, .1);--tooltip-text: #1e293b;--mom-positive-bg: rgba(5, 150, 105, .1);--mom-positive-color: #047857;--mom-negative-bg: rgba(225, 29, 72, .08);--mom-negative-color: #be123c;--mom-neutral-bg: rgba(0, 0, 0, .05);--mom-neutral-color: #94a3b8;--insight-positive-bg: rgba(5, 150, 105, .05);--insight-positive-border: rgba(5, 150, 105, .15);--insight-negative-bg: rgba(225, 29, 72, .05);--insight-negative-border: rgba(225, 29, 72, .14);--insight-warning-bg: rgba(217, 119, 6, .05);--insight-warning-border: rgba(217, 119, 6, .15);--insight-neutral-bg: #f8fafc;--insight-neutral-border: rgba(0, 0, 0, .08);--tab-active-bg: rgba(5, 150, 105, .08);--tab-active-color: #047857;--tab-active-border: #059669;--tab-hover-bg: rgba(0, 0, 0, .03);--tab-hover-color: #64748b;--badge-bg: rgba(5, 150, 105, .1);--badge-color: #047857;--section-divider: rgba(0, 0, 0, .06);--auth-card-bg: rgba(255, 255, 255, .96);--auth-card-border: rgba(255, 255, 255, .7);--error-bg: #fef2f2;--error-border: #fecaca;--error-color: #e11d48}html{color-scheme:dark}[data-theme=light]{color-scheme:light}body{font-family:Inter,Outfit,system-ui,-apple-system,sans-serif;background:var(--bg-base);color:var(--text-primary);min-height:100vh;-webkit-font-smoothing:antialiased;transition:background-color var(--transition),color var(--transition)}.glass-card{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius-lg);transition:border-color var(--transition)}.glass-card:hover{border-color:var(--border-strong)}.auth-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#14532d,#15803d 40%,#22c55e);padding:1rem;position:relative;overflow:hidden}.auth-container:before{content:"";position:absolute;width:400px;height:400px;border-radius:50%;background:#ffffff0d;top:-100px;right:-100px}.auth-container:after{content:"";position:absolute;width:300px;height:300px;border-radius:50%;background:#ffffff0a;bottom:-80px;left:-80px}.auth-card{background:var(--auth-card-bg);border:1px solid var(--auth-card-border);border-radius:var(--radius-lg);padding:2.5rem;width:100%;max-width:420px;position:relative;z-index:1}.auth-card h1{text-align:center;color:var(--green-500);margin-bottom:.25rem;font-size:1.75rem;letter-spacing:-.02em}.auth-card .subtitle{text-align:center;color:var(--text-muted);margin-bottom:1.75rem;font-size:.9rem}.form-group{margin-bottom:1rem}.form-group label{display:block;font-size:.82rem;font-weight:600;color:var(--text-secondary);margin-bottom:.4rem;letter-spacing:.01em}.form-group input,.form-group select{width:100%;padding:.7rem .9rem;border:1px solid var(--input-border);border-radius:var(--radius);font-size:.92rem;font-family:inherit;background:var(--input-bg);color:var(--input-text);transition:border-color var(--transition),box-shadow var(--transition);outline:none}.form-group input:focus,.form-group select:focus{border-color:var(--input-focus-border);box-shadow:0 0 0 3px #10b9811f}.form-group input::placeholder{color:var(--input-placeholder)}.form-group select option{background:var(--bg-elevated);color:var(--text-primary)}.btn{display:inline-flex;align-items:center;justify-content:center;padding:.65rem 1.25rem;border:none;border-radius:var(--radius);font-size:.88rem;font-weight:600;font-family:inherit;cursor:pointer;transition:all var(--transition);gap:.4rem;letter-spacing:.01em}.btn:active{transform:scale(.97)}.btn-primary{background:var(--green-500);color:#fff;width:100%}.btn-primary:hover{background:var(--green-600);transform:translateY(-1px)}.btn-primary:active{transform:translateY(0) scale(.98)}.btn-sm{padding:.4rem .8rem;font-size:.78rem;border-radius:8px}.btn-danger{background:var(--red-500);color:#fff}.btn-danger:hover{background:var(--red-600)}.btn-outline{background:transparent;border:1px solid var(--border-strong);color:var(--text-secondary)}.btn-outline:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--border-strong)}.btn-green-outline{background:#10b98114;border:1px solid rgba(16,185,129,.25);color:var(--color-income)}.btn-green-outline:hover{background:#10b98124;border-color:#10b98166}.auth-link{text-align:center;margin-top:1.5rem;font-size:.85rem;color:var(--text-muted)}.auth-link a{color:var(--green-500);text-decoration:none;font-weight:600;transition:color var(--transition)}.auth-link a:hover{color:var(--green-400);text-decoration:underline}.error-msg{background:var(--error-bg);color:var(--error-color);padding:.65rem .9rem;border-radius:var(--radius);font-size:.84rem;margin-bottom:1rem;border:1px solid var(--error-border);font-weight:500}.navbar{background:var(--navbar-bg);color:var(--navbar-text);padding:0 2rem;height:64px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--navbar-border);position:sticky;top:0;z-index:50;transition:background-color var(--transition),border-color var(--transition)}.navbar-brand{display:flex;align-items:center;gap:.6rem}.navbar-logo-img{height:32px;width:auto;object-fit:contain}.navbar h1{font-size:1.05rem;font-weight:700;letter-spacing:-.02em;color:var(--text-primary)}.navbar-right{display:flex;align-items:center;gap:.75rem}.navbar-user-info{display:flex;align-items:center;gap:.4rem;font-size:.84rem;color:var(--text-secondary);font-weight:500}.navbar-user{font-size:.84rem;color:var(--text-secondary)}.btn-theme-toggle{display:flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:8px;border:1px solid var(--border-strong);background:transparent;color:var(--text-secondary);cursor:pointer;transition:all var(--transition);flex-shrink:0}.btn-theme-toggle:hover{color:var(--text-primary);background:var(--bg-hover);border-color:var(--border-strong)}.btn-logout{display:flex;align-items:center;gap:.4rem;background:transparent;border:1px solid var(--border-strong);color:var(--text-secondary);padding:.4rem .85rem;border-radius:8px;cursor:pointer;font-size:.8rem;font-weight:600;font-family:inherit;transition:all var(--transition)}.btn-logout:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--border-strong)}.navbar-right button:not(.btn-logout):not(.btn-theme-toggle){background:transparent;border:1px solid var(--border-strong);color:var(--text-secondary);padding:.4rem .9rem;border-radius:var(--radius);cursor:pointer;font-size:.8rem;font-weight:500;font-family:inherit;transition:all var(--transition)}.navbar-right button:not(.btn-logout):not(.btn-theme-toggle):hover{background:var(--bg-hover);color:var(--text-primary)}.main-content{max-width:1240px;margin:0 auto;padding:2rem 2rem 3rem}.summary-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:1.75rem}.summary-card-v2{padding:1.25rem 1.4rem}.sc-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem}.sc-icon{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:8px;background:var(--bg-hover);color:var(--text-secondary);flex-shrink:0}.sc-label{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);flex:1}.sc-value{font-size:1.5rem;font-weight:700;letter-spacing:-.02em;font-variant-numeric:tabular-nums;margin-bottom:.25rem}.sc-total{font-size:.74rem;color:var(--text-muted);font-weight:500}.mom-badge{font-size:.69rem;font-weight:700;padding:.18rem .5rem;border-radius:99px;white-space:nowrap;letter-spacing:.01em}.mom-positive{background:var(--mom-positive-bg);color:var(--mom-positive-color)}.mom-negative{background:var(--mom-negative-bg);color:var(--mom-negative-color)}.mom-neutral{background:var(--mom-neutral-bg);color:var(--mom-neutral-color)}.charts-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:1rem;margin-bottom:1.75rem}.chart-card{padding:1.5rem}.chart-card h3{font-size:.95rem;font-weight:700;color:var(--text-primary);letter-spacing:-.01em}.chart-subtitle{font-size:.76rem;color:var(--text-muted);margin-top:.15rem;margin-bottom:1.25rem;font-weight:500}.chart-wrapper{margin-top:.25rem}.chart-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1rem}.chart-header h3{margin:0}.chart-header .chart-subtitle{margin-bottom:0}.period-selector{display:flex;gap:.25rem;background:var(--bg-subtle);border-radius:8px;padding:.2rem;border:1px solid var(--border);flex-shrink:0}.period-btn{padding:.3rem .6rem;border:none;border-radius:6px;background:transparent;color:var(--text-muted);font-size:.72rem;font-weight:600;font-family:inherit;cursor:pointer;transition:all var(--transition);white-space:nowrap}.period-btn:hover{color:var(--text-secondary);background:var(--bg-hover)}.period-btn.active{background:var(--green-500);color:#fff;box-shadow:0 1px 3px #10b9814d}.chart-tooltip{background:var(--tooltip-bg);border:1px solid var(--tooltip-border);border-radius:8px;padding:.65rem .85rem;font-size:.82rem;line-height:1.55;color:var(--tooltip-text)}.chart-tooltip-label{font-weight:700;color:var(--text-primary);margin-bottom:.2rem}.doughnut-layout{display:flex;align-items:center;gap:1rem}.doughnut-chart{position:relative;flex:0 0 240px}.doughnut-center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;pointer-events:none}.doughnut-total{display:block;font-size:.92rem;font-weight:700;color:var(--text-primary)}.doughnut-label{display:block;font-size:.68rem;color:var(--text-muted);font-weight:600;text-transform:uppercase;letter-spacing:.05em}.category-legend{flex:1;display:flex;flex-direction:column;gap:.5rem}.legend-item{display:flex;align-items:center;gap:.5rem;font-size:.82rem}.legend-dot{width:8px;height:8px;border-radius:3px;flex-shrink:0}.legend-name{flex:1;color:var(--text-secondary);font-weight:500}.legend-value{font-weight:600;color:var(--text-primary);font-variant-numeric:tabular-nums}.legend-percent{font-size:.7rem;color:var(--text-muted);font-weight:600;min-width:32px;text-align:right}.insights-card{padding:1.5rem;margin-bottom:1.75rem}.insights-card h3{font-size:.95rem;font-weight:700;color:var(--text-primary)}.insights-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:.55rem}.insight-item{display:flex;align-items:flex-start;gap:.6rem;padding:.7rem .85rem;border-radius:var(--radius);font-size:.84rem;line-height:1.45;border:1px solid transparent;transition:transform var(--transition)}.insight-item:hover{transform:translate(3px)}.insight-icon{flex-shrink:0;margin-top:1px;color:var(--text-secondary)}.insight-text{color:var(--text-secondary);font-weight:500}.insight-positive{background:var(--insight-positive-bg);border-color:var(--insight-positive-border)}.insight-negative{background:var(--insight-negative-bg);border-color:var(--insight-negative-border)}.insight-warning{background:var(--insight-warning-bg);border-color:var(--insight-warning-border)}.insight-neutral{background:var(--insight-neutral-bg);border-color:var(--insight-neutral-border)}.tabs{display:flex;gap:0;margin-bottom:1rem;background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.tab-btn{flex:1;padding:.8rem;border:none;background:transparent;font-size:.87rem;font-weight:600;font-family:inherit;cursor:pointer;color:var(--text-muted);transition:all var(--transition);border-bottom:2px solid transparent;letter-spacing:.01em}.tab-btn:hover{color:var(--tab-hover-color);background:var(--tab-hover-bg)}.tab-btn.active{color:var(--tab-active-color);border-bottom-color:var(--tab-active-border);background:var(--tab-active-bg)}.section-card{overflow:hidden}.section-header{display:flex;align-items:center;justify-content:space-between;padding:1.1rem 1.5rem;border-bottom:1px solid var(--section-divider)}.section-header h2{font-size:.95rem;font-weight:700;color:var(--text-primary);letter-spacing:-.01em}.data-table{width:100%;border-collapse:collapse}.data-table th{text-align:left;padding:.65rem 1.25rem;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);background:var(--table-header-bg);border-bottom:1px solid var(--table-border)}.data-table td{padding:.75rem 1.25rem;font-size:.87rem;border-bottom:1px solid var(--table-border);color:var(--text-secondary);transition:background-color var(--transition)}.data-table tr:last-child td{border-bottom:none}.data-table tbody tr:hover td{background:var(--table-row-hover)}.data-table .amount{font-weight:700;font-variant-numeric:tabular-nums;letter-spacing:-.01em;color:var(--text-primary)}.data-table .amount.positive{color:var(--color-income)}.data-table .amount.negative{color:var(--color-expense)}.data-table .actions{display:flex;gap:.4rem;justify-content:flex-end}.empty-state{text-align:center;padding:3rem 1rem;color:var(--text-muted);font-size:.9rem;font-weight:500}.badge{display:inline-block;padding:.2rem .55rem;border-radius:999px;font-size:.71rem;font-weight:600;background:var(--badge-bg);color:var(--badge-color);letter-spacing:.01em}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;display:flex;align-items:center;justify-content:center;z-index:100;padding:1rem;animation:fadeIn .18s ease}.modal{background:var(--card-bg);border:1px solid var(--border-strong);border-radius:var(--radius-lg);padding:2rem;width:100%;max-width:480px;animation:slideUp .22s ease}.modal h2{margin-bottom:1.25rem;color:var(--text-primary);font-size:1.1rem;letter-spacing:-.01em}.modal-actions{display:flex;gap:.75rem;justify-content:flex-end;margin-top:1.5rem}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(10px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.mom-table-container{margin-top:.75rem}.mom-table{width:100%;border-collapse:separate;border-spacing:0 .4rem}.mom-table th{padding:.4rem 1rem;font-size:.69rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);text-align:left}.mom-table td{padding:.85rem 1rem;background:var(--bg-hover);border-top:1px solid var(--border);border-bottom:1px solid var(--border);font-size:.87rem;color:var(--text-secondary)}.mom-table tr td:first-child{border-left:1px solid var(--border);border-top-left-radius:8px;border-bottom-left-radius:8px;font-weight:600;color:var(--text-primary)}.mom-table tr td:last-child{border-right:1px solid var(--border);border-top-right-radius:8px;border-bottom-right-radius:8px}.mom-trend-up{color:var(--color-income);font-weight:700}.mom-trend-down{color:var(--color-expense);font-weight:700}@media(max-width:1024px){.charts-grid{grid-template-columns:1fr}.summary-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.main-content{padding:1rem}.navbar{padding:0 1rem}.navbar-user-info .navbar-user{display:none}.doughnut-layout{flex-direction:column}.doughnut-chart{flex:0 0 auto}.data-table th,.data-table td{padding:.6rem .75rem;font-size:.8rem}.insights-list{grid-template-columns:1fr}}@media(max-width:480px){.summary-grid{grid-template-columns:1fr}.tabs{flex-wrap:wrap}.sc-value{font-size:1.25rem}.navbar-user-info{display:none}}.budgets-panel{padding:1.5rem}.budgets-panel-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.budgets-title{font-size:1rem;font-weight:700;color:var(--text-primary);letter-spacing:-.01em;margin:0 0 .2rem}.budgets-subtitle{font-size:.78rem;color:var(--text-muted);font-weight:500}.budgets-alert{color:var(--amber-500);font-weight:600}.budgets-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.85rem}.budget-card{padding:1rem 1.1rem;display:flex;flex-direction:column;gap:.65rem;transition:border-color var(--transition),box-shadow var(--transition)}.budget-card.budget-over{border-color:#ef444459;box-shadow:0 0 0 1px #ef44441f}.budget-card-header{display:flex;align-items:center;justify-content:space-between;gap:.75rem}.budget-category-info{display:flex;align-items:center;gap:.5rem;flex:1;min-width:0}.budget-category-icon{font-size:1.1rem;flex-shrink:0}.budget-category-name{font-size:.88rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.budget-input-group{display:flex;align-items:center;gap:.35rem;flex-shrink:0}.budget-value-btn{background:var(--bg-subtle);border:1px solid var(--border);border-radius:7px;color:var(--text-primary);font-size:.82rem;font-weight:700;font-family:inherit;padding:.3rem .65rem;cursor:pointer;transition:all var(--transition);white-space:nowrap}.budget-value-btn:hover{border-color:var(--green-500);color:var(--green-500)}.budget-value-empty{color:var(--text-muted);font-weight:500;font-size:.78rem;border-style:dashed}.budget-value-empty:hover{border-color:var(--green-500);color:var(--green-500);border-style:solid}.budget-input{width:100px;padding:.3rem .55rem;border:1px solid var(--green-500);border-radius:7px;background:var(--bg-subtle);color:var(--text-primary);font-size:.82rem;font-weight:600;font-family:inherit;outline:none;box-shadow:0 0 0 3px #10b9811f}.budget-delete-btn{background:transparent;border:none;color:var(--text-muted);font-size:1.1rem;line-height:1;cursor:pointer;padding:.1rem .3rem;border-radius:4px;transition:color var(--transition)}.budget-delete-btn:hover{color:var(--red-400)}.budget-progress-track{height:6px;background:var(--bg-subtle);border-radius:99px;overflow:hidden;border:1px solid var(--border)}.budget-progress-fill{height:100%;border-radius:99px;transition:width .5s ease,background .3s ease;min-width:2px}.budget-stats{display:flex;align-items:center;gap:.4rem;font-size:.74rem;flex-wrap:wrap}.budget-stat-spent{color:var(--text-muted)}.budget-stat-spent strong{color:var(--text-secondary)}.budget-stat-sep{color:var(--border-strong)}.budget-stat-remaining{color:var(--green-500);font-weight:600}.budget-stat-remaining.over{color:var(--red-400)}.budget-stat-percent{margin-left:auto;font-weight:700;color:var(--text-muted)}.budget-no-meta{font-size:.74rem;color:var(--text-muted);font-style:italic}@media(max-width:768px){.budgets-grid{grid-template-columns:1fr}.budget-input{width:80px}}
