@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";:root{--bg-primary:#0f1115;--bg-secondary:#161920;--bg-card:#1a1d23;--bg-card-hover:#1f2229;--bg-input:#1e2128;--border-color:#ffffff0f;--border-hover:#ffffff1f;--text-primary:#e8e8ea;--text-secondary:#9a9ba0;--text-muted:#5e5f65;--accent:#5bb5a2;--accent-soft:#5bb5a226;--accent-hover:#4da393;--success:#6cceb5;--success-bg:#6cceb51a;--danger:#e07878;--danger-bg:#e0787814;--warning:#e0c068;--warning-bg:#e0c06814;--info:#78a8d8;--info-bg:#78a8d814;--chart-1:#6cceb5;--chart-2:#f0d68a;--chart-3:#e8a0b4;--chart-4:#8bc5a3;--chart-5:#a8c8e8;--chart-6:#c8a8d8;--chart-7:#d8b888;--chart-8:#88b8b0;--radius:12px;--radius-lg:16px;--radius-xl:20px;--radius-full:9999px;--shadow-sm:0 1px 3px #0003;--shadow-md:0 4px 12px #00000040;--shadow-lg:0 8px 24px #0000004d;--transition:all .25s ease;--transition-fast:all .15s ease}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{background:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif}body:before{content:"";pointer-events:none;z-index:0;background-image:url("data:image/svg+xml,%3Csvg width='800' height='800' viewBox='0 0 800 800' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' stroke='rgba(255,255,255,0.025)' stroke-width='1'%3E%3Ccircle cx='400' cy='400' r='100'/%3E%3Ccircle cx='400' cy='400' r='160'/%3E%3Ccircle cx='400' cy='400' r='230'/%3E%3Ccircle cx='400' cy='400' r='310'/%3E%3Ccircle cx='400' cy='400' r='400'/%3E%3Ccircle cx='150' cy='650' r='80'/%3E%3Ccircle cx='150' cy='650' r='140'/%3E%3Ccircle cx='150' cy='650' r='210'/%3E%3Ccircle cx='700' cy='150' r='90'/%3E%3Ccircle cx='700' cy='150' r='160'/%3E%3Ccircle cx='700' cy='150' r='240'/%3E%3C/g%3E%3C/svg%3E");background-position:50%;background-size:cover;width:100%;height:100%;position:fixed;top:0;left:0}#root{z-index:1;position:relative}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--text-muted);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}.app-layout{min-height:100vh;display:flex}.main-content{flex:1;min-height:100vh;margin-left:250px;padding:28px 36px}.sidebar{background:var(--bg-card);border-right:1px solid var(--border-color);z-index:100;flex-direction:column;width:250px;height:100vh;padding:24px 14px;display:flex;position:fixed;top:0;left:0}.sidebar-logo{align-items:center;gap:12px;margin-bottom:36px;padding:8px 12px;display:flex}.sidebar-logo .logo-icon{background:var(--accent);border-radius:var(--radius);justify-content:center;align-items:center;width:38px;height:38px;font-size:18px;display:flex}.sidebar-logo h1{color:var(--text-primary);letter-spacing:-.3px;font-size:17px;font-weight:600}.sidebar-nav{flex-direction:column;flex:1;gap:2px;display:flex}.nav-link{color:var(--text-muted);transition:var(--transition);cursor:pointer;text-align:left;background:0 0;border:none;border-radius:10px;align-items:center;gap:12px;width:100%;padding:11px 14px;font-size:14px;font-weight:500;text-decoration:none;display:flex}.nav-link:hover{color:var(--text-secondary);background:#ffffff08}.nav-link.active{background:var(--accent-soft);color:var(--accent)}.nav-link .nav-icon{flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;display:flex}.sidebar-footer{border-top:1px solid var(--border-color);margin-top:auto;padding-top:14px}.user-info{align-items:center;gap:10px;padding:8px 12px;display:flex}.user-avatar{border-radius:var(--radius-full);background:var(--accent);color:#0f1115;justify-content:center;align-items:center;width:34px;height:34px;font-size:13px;font-weight:600;display:flex}.user-name{color:var(--text-primary);font-size:13px;font-weight:600}.user-email{color:var(--text-muted);font-size:11px}.card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);transition:var(--transition);padding:24px}.card:hover{border-color:var(--border-hover)}.card-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.card-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:.6px;font-size:13px;font-weight:600}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:14px;margin-bottom:24px;display:grid}.stat-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);transition:var(--transition);padding:22px;position:relative}.stat-card:hover{border-color:var(--border-hover)}.stat-icon{margin-bottom:10px;font-size:22px}.stat-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.4px;margin-bottom:6px;font-size:12px;font-weight:500}.stat-value{letter-spacing:-.5px;color:var(--text-primary);font-size:26px;font-weight:600}.stat-value.positive{color:var(--success)}.stat-value.negative{color:var(--danger)}.stat-change{border-radius:var(--radius-full);align-items:center;gap:4px;margin-top:8px;padding:3px 8px;font-size:11px;font-weight:600;display:inline-flex}.stat-change.up{background:var(--success-bg);color:var(--success)}.stat-change.down{background:var(--danger-bg);color:var(--danger)}.charts-grid{grid-template-columns:repeat(auto-fit,minmax(360px,1fr));gap:16px;margin-bottom:24px;display:grid}.chart-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:24px}.chart-card h3{color:var(--text-primary);margin-bottom:20px;font-size:15px;font-weight:600}.insights-section{margin-bottom:24px}.insights-grid{grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:10px;display:grid}.insight-card{border:1px solid var(--border-color);color:var(--text-secondary);transition:var(--transition);background:#ffffff05;border-radius:10px;align-items:flex-start;gap:10px;padding:14px 18px;font-size:13px;line-height:1.6;display:flex}.insight-card:hover{border-color:var(--border-hover);background:#ffffff09}.insight-icon{flex-shrink:0;font-size:18px}.table-container{overflow-x:auto}table{border-collapse:separate;border-spacing:0 6px;width:100%}th{text-align:left;color:var(--text-muted);text-transform:uppercase;letter-spacing:.6px;padding:10px 16px;font-size:11px;font-weight:600}td{color:var(--text-secondary);background:#ffffff05;padding:14px 16px;font-size:14px}tr td:first-child{border-radius:10px 0 0 10px}tr td:last-child{border-radius:0 10px 10px 0}tr:hover td{background:#ffffff0a}.amount-positive{color:var(--success);font-weight:600}.amount-negative{color:var(--danger);font-weight:600}.category-badge{border-radius:var(--radius-full);align-items:center;gap:5px;padding:4px 10px;font-size:12px;font-weight:500;display:inline-flex}.category-Food{color:#d8a860;background:#e0a0581f}.category-Transport{color:#88b8e0;background:#78a8d81f}.category-Shopping{color:#c0a0d0;background:#b48cc81f}.category-Entertainment{color:#e08898;background:#e0788c1f}.category-Bills{color:#d8c068;background:#e0c0681f}.category-Health{color:#6cceb5;background:#6cceb51f}.category-Education{color:#80b8c8;background:#78b4c81f}.category-Salary{color:#6cceb5;background:#6cceb51f}.category-Transfer,.category-Other{color:#9a9ba0;background:#9a9ba01f}.btn{cursor:pointer;transition:var(--transition);border:1px solid #0000;border-radius:10px;justify-content:center;align-items:center;gap:8px;padding:10px 20px;font-family:inherit;font-size:13px;font-weight:600;display:inline-flex}.btn-primary{background:var(--accent);color:#0f1115;border:none}.btn-primary:hover{background:var(--accent-hover)}.btn-secondary{color:var(--text-secondary);border:1px solid var(--border-color);background:#ffffff0a}.btn-secondary:hover{color:var(--text-primary);background:#ffffff12}.btn-danger{background:var(--danger-bg);color:var(--danger);border:1px solid #e0787826}.btn-danger:hover{background:#e0787826}.btn-sm{padding:6px 12px;font-size:12px}.btn-icon{border:1px solid var(--border-color);color:var(--text-muted);cursor:pointer;transition:var(--transition);background:#ffffff08;border-radius:8px;padding:7px}.btn-icon:hover{background:var(--danger-bg);color:var(--danger);border-color:#e0787826}.form-group{margin-bottom:18px}.form-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.3px;margin-bottom:6px;font-size:12px;font-weight:500;display:block}.form-input,.form-select{background:var(--bg-input);border:1px solid var(--border-color);width:100%;color:var(--text-primary);transition:var(--transition);border-radius:10px;outline:none;padding:11px 14px;font-family:inherit;font-size:14px}.form-input:focus,.form-select:focus{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-soft)}.form-input::placeholder{color:var(--text-muted)}.form-select option{background:var(--bg-secondary);color:var(--text-primary)}.form-row{grid-template-columns:1fr 1fr;gap:14px;display:grid}.auth-container{justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.auth-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);width:100%;max-width:420px;box-shadow:var(--shadow-lg);padding:40px}.auth-header{text-align:center;margin-bottom:32px}.auth-header .logo-icon{background:var(--accent);border-radius:var(--radius-lg);justify-content:center;align-items:center;width:52px;height:52px;margin:0 auto 16px;font-size:26px;display:flex}.auth-header h2{margin-bottom:6px;font-size:22px;font-weight:600}.auth-header p{color:var(--text-muted);font-size:14px}.auth-form .btn-primary{width:100%;margin-top:8px;padding:13px;font-size:14px}.auth-footer{text-align:center;color:var(--text-muted);margin-top:24px;font-size:13px}.auth-footer a{color:var(--accent);font-weight:600;text-decoration:none}.auth-footer a:hover{text-decoration:underline}.auth-error{background:var(--danger-bg);color:var(--danger);text-align:center;border:1px solid #e0787826;border-radius:10px;margin-bottom:16px;padding:11px 14px;font-size:13px}.progress-bar-container{margin-top:12px}.progress-info{justify-content:space-between;margin-bottom:6px;font-size:12px;display:flex}.progress-info .spent{color:var(--text-secondary)}.progress-info .limit{color:var(--text-muted)}.progress-bar{border-radius:var(--radius-full);background:#ffffff0a;width:100%;height:6px;overflow:hidden}.progress-fill{border-radius:var(--radius-full);height:100%;transition:width 1s}.progress-fill.safe{background:var(--success)}.progress-fill.warning{background:var(--warning)}.progress-fill.danger{background:var(--danger)}.budgets-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px;display:grid}.budget-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);transition:var(--transition);padding:20px}.budget-card:hover{border-color:var(--border-hover)}.budget-header{justify-content:space-between;align-items:center;margin-bottom:4px;display:flex}.budget-category{font-size:15px;font-weight:600}.budget-percentage{font-size:22px;font-weight:600}.page-header{justify-content:space-between;align-items:center;margin-bottom:28px;display:flex}.page-title{letter-spacing:-.5px;font-size:26px;font-weight:600}.page-subtitle{color:var(--text-muted);margin-top:4px;font-size:13px}.modal-overlay{-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:1000;background:#0000008c;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.modal{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-xl);width:100%;max-width:460px;box-shadow:var(--shadow-lg);padding:32px;animation:.3s slideUp}.modal h3{margin-bottom:24px;font-size:18px;font-weight:600}.modal-actions{justify-content:flex-end;gap:10px;margin-top:24px;display:flex}.pagination{justify-content:center;align-items:center;gap:8px;margin-top:24px;display:flex}.pagination button{border:1px solid var(--border-color);color:var(--text-secondary);cursor:pointer;transition:var(--transition);background:#ffffff08;border-radius:10px;padding:8px 16px;font-family:inherit;font-size:13px;font-weight:500}.pagination button:hover:not(:disabled){background:var(--accent-soft);border-color:var(--accent);color:var(--accent)}.pagination button:disabled{opacity:.3;cursor:not-allowed}.pagination .page-info{color:var(--text-muted);padding:0 12px;font-size:13px}.loading-container{color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;padding:60px 20px;display:flex}.spinner{border:2px solid var(--border-color);border-top-color:var(--accent);border-radius:50%;width:36px;height:36px;margin-bottom:16px;animation:.8s linear infinite spin}.empty-state{text-align:center;color:var(--text-muted);padding:60px 20px}.empty-state .empty-icon{margin-bottom:14px;font-size:40px}.empty-state p{margin-bottom:20px;font-size:14px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:.35s forwards fadeInUp}.fade-in-delay-1{opacity:0;animation-delay:40ms}.fade-in-delay-2{opacity:0;animation-delay:80ms}.fade-in-delay-3{opacity:0;animation-delay:.12s}.fade-in-delay-4{opacity:0;animation-delay:.16s}@media (width<=768px){.sidebar{display:none}.main-content{margin-left:0;padding:16px}.stats-grid{grid-template-columns:1fr 1fr}.charts-grid,.form-row{grid-template-columns:1fr}}@media (width<=480px){.stats-grid{grid-template-columns:1fr}}.recharts-text{fill:var(--text-muted)!important;font-family:Inter,sans-serif!important;font-size:11px!important}.recharts-cartesian-grid-horizontal line,.recharts-cartesian-grid-vertical line{stroke:#ffffff08!important}.recharts-tooltip-wrapper .recharts-default-tooltip{background:var(--bg-card)!important;border:1px solid var(--border-color)!important;box-shadow:var(--shadow-md)!important;border-radius:10px!important}.recharts-tooltip-item{color:var(--text-primary)!important;font-size:13px!important}.recharts-tooltip-label{color:var(--text-secondary)!important;font-weight:600!important}.donut-center-text{fill:var(--text-primary);font-family:Inter,sans-serif}.donut-center-total{fill:var(--text-primary);font-size:28px;font-weight:600}.donut-center-label{fill:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:12px;font-weight:500}
