@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";:root{--color-bg-primary:#f8f9fc;--color-bg-secondary:#fff;--color-bg-tertiary:#f1f3f9;--color-bg-hover:#eef0f6;--color-bg-glass:#ffffffb8;--color-bg-overlay:#0f172a66;--color-text-primary:#0f172a;--color-text-secondary:#475569;--color-text-tertiary:#94a3b8;--color-text-inverse:#fff;--color-border:#e2e8f0;--color-border-light:#f1f5f9;--color-accent:#6366f1;--color-accent-hover:#4f46e5;--color-accent-light:#6366f11a;--color-accent-glow:#6366f140;--color-success:#10b981;--color-success-light:#10b9811a;--color-danger:#ef4444;--color-danger-light:#ef44441a;--color-warning:#f59e0b;--color-warning-light:#f59e0b1a;--color-info:#3b82f6;--color-info-light:#3b82f61a;--shadow-sm:0 1px 2px #0000000a;--shadow-md:0 4px 12px #0000000f;--shadow-lg:0 8px 30px #00000014;--shadow-xl:0 20px 60px #0000001a;--shadow-glow:0 0 20px var(--color-accent-glow);--space-1:.25rem;--space-2:.5rem;--space-3:.75rem;--space-4:1rem;--space-5:1.25rem;--space-6:1.5rem;--space-8:2rem;--space-10:2.5rem;--space-12:3rem;--space-16:4rem;--radius-sm:6px;--radius-md:10px;--radius-lg:14px;--radius-xl:20px;--radius-full:9999px;--sidebar-width:260px;--sidebar-collapsed:72px;--transition-fast:.15s ease;--transition-base:.25s ease;--transition-slow:.4s cubic-bezier(.4, 0, .2, 1)}[data-theme=dark]{--color-bg-primary:#0b0f1a;--color-bg-secondary:#111827;--color-bg-tertiary:#1a2035;--color-bg-hover:#1e293b;--color-bg-glass:#111827cc;--color-bg-overlay:#0009;--color-text-primary:#f1f5f9;--color-text-secondary:#94a3b8;--color-text-tertiary:#64748b;--color-text-inverse:#0f172a;--color-border:#1e293b;--color-border-light:#1a2035;--color-accent-light:#6366f126;--shadow-sm:0 1px 2px #0003;--shadow-md:0 4px 12px #0000004d;--shadow-lg:0 8px 30px #00000059;--shadow-xl:0 20px 60px #0006}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px}body{background:var(--color-bg-primary);color:var(--color-text-primary);min-height:100vh;transition:background var(--transition-base), color var(--transition-base);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.6}#root{min-height:100vh}a{color:inherit;text-decoration:none}button{cursor:pointer;font-family:inherit;font-size:inherit;color:inherit;background:0 0;border:none}input,select,textarea{font-family:inherit;font-size:inherit;color:inherit}table{border-collapse:collapse;width:100%}img{max-width:100%;height:auto}ul,ol{list-style:none}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--color-text-tertiary);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-text-secondary)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-16px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes spin{to{transform:rotate(360deg)}}.animate-fade-in{animation:fadeIn var(--transition-base) ease both}.animate-fade-in-up{animation:fadeInUp var(--transition-slow) ease both}.animate-slide-in{animation:slideInRight var(--transition-slow) ease both}.animate-scale-in{animation:scaleIn var(--transition-base) ease both}.stagger>*{animation:.5s both fadeInUp}.stagger>:first-child{animation-delay:0s}.stagger>:nth-child(2){animation-delay:60ms}.stagger>:nth-child(3){animation-delay:.12s}.stagger>:nth-child(4){animation-delay:.18s}.stagger>:nth-child(5){animation-delay:.24s}.stagger>:nth-child(6){animation-delay:.3s}.stagger>:nth-child(7){animation-delay:.36s}.stagger>:nth-child(8){animation-delay:.42s}.sr-only{clip:rect(0, 0, 0, 0);border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.text-center{text-align:center}.text-right{text-align:right}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.gap-1{gap:var(--space-1)}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.gap-6{gap:var(--space-6)}.gap-8{gap:var(--space-8)}.grid{display:grid}.grid-2{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}@media (width<=1200px){.grid-4{grid-template-columns:repeat(2,1fr)}}@media (width<=768px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}.w-full{width:100%}.mt-4{margin-top:var(--space-4)}.mt-6{margin-top:var(--space-6)}.mb-4{margin-bottom:var(--space-4)}.mb-6{margin-bottom:var(--space-6)}.p-4{padding:var(--space-4)}.p-6{padding:var(--space-6)}h1,h2,h3,h4{color:var(--color-text-primary);font-weight:700;line-height:1.2}h1{font-size:1.875rem}h2{font-size:1.5rem}h3{font-size:1.125rem}h4{font-size:1rem}.page-header{margin-bottom:var(--space-8);justify-content:space-between;align-items:center;display:flex}.page-header h1{letter-spacing:-.02em;font-size:1.75rem;font-weight:800}.page-subtitle{color:var(--color-text-secondary);margin-top:var(--space-1);font-size:.875rem}.amount{font-variant-numeric:tabular-nums;font-weight:600}.amount-positive{color:var(--color-success)}.amount-negative{color:var(--color-danger)}.card{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-6);transition:all var(--transition-base);position:relative;overflow:hidden}.card:before{content:"";background:linear-gradient(90deg, transparent, var(--color-accent-glow), transparent);opacity:0;height:1px;transition:opacity var(--transition-base);position:absolute;top:0;left:0;right:0}.card:hover:before{opacity:1}.card-glass{background:var(--color-bg-glass);-webkit-backdrop-filter:blur(16px)}.card-accent{border-color:var(--color-accent);box-shadow:var(--shadow-glow)}.card-clickable{cursor:pointer}.card-clickable:hover{box-shadow:var(--shadow-lg);border-color:var(--color-accent);transform:translateY(-2px)}.card-header{margin-bottom:var(--space-4);justify-content:space-between;align-items:center;display:flex}.card-title{color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em;font-size:.875rem;font-weight:500}.card-value{letter-spacing:-.02em;margin-top:var(--space-2);font-size:1.75rem;font-weight:800}.card-footer{align-items:center;gap:var(--space-2);margin-top:var(--space-3);color:var(--color-text-secondary);font-size:.813rem;display:flex}.btn{justify-content:center;align-items:center;gap:var(--space-2);border-radius:var(--radius-md);transition:all var(--transition-fast);white-space:nowrap;padding:.625rem 1.25rem;font-size:.875rem;font-weight:500;display:inline-flex;position:relative;overflow:hidden}.btn:active{transform:scale(.97)}.btn-primary{background:var(--color-accent);color:#fff;box-shadow:0 2px 8px var(--color-accent-glow)}.btn-primary:hover{background:var(--color-accent-hover);box-shadow:0 4px 16px var(--color-accent-glow);transform:translateY(-1px)}.btn-secondary{background:var(--color-bg-tertiary);color:var(--color-text-primary);border:1px solid var(--color-border)}.btn-secondary:hover{background:var(--color-bg-hover);border-color:var(--color-accent)}.btn-danger{background:var(--color-danger);color:#fff}.btn-danger:hover{background:#dc2626;transform:translateY(-1px)}.btn-ghost{color:var(--color-text-secondary);background:0 0}.btn-ghost:hover{background:var(--color-bg-hover);color:var(--color-text-primary)}.btn-sm{padding:.375rem .875rem;font-size:.813rem}.btn-lg{padding:.875rem 1.75rem;font-size:1rem}.btn-icon{width:36px;height:36px;padding:.5rem}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.form-group{gap:var(--space-2);flex-direction:column;display:flex}.form-label{color:var(--color-text-secondary);font-size:.813rem;font-weight:500}.form-input{background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-md);width:100%;color:var(--color-text-primary);transition:all var(--transition-fast);outline:none;padding:.625rem .875rem}.form-input:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-light);background:var(--color-bg-secondary)}.form-input::placeholder{color:var(--color-text-tertiary)}.form-input-error{border-color:var(--color-danger)}.form-error{color:var(--color-danger);font-size:.75rem}.form-row{gap:var(--space-4);grid-template-columns:1fr 1fr;display:grid}@media (width<=600px){.form-row{grid-template-columns:1fr}}.form-select{background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-md);width:100%;color:var(--color-text-primary);transition:all var(--transition-fast);appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='%2394a3b8' viewBox='0 0 16 16'%3E%3Cpath d='M4.5 6l3.5 4 3.5-4z'/%3E%3C/svg%3E");background-position:right .75rem center;background-repeat:no-repeat;outline:none;padding:.625rem 2.5rem .625rem .875rem}.form-select:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-light)}.modal-overlay{background:var(--color-bg-overlay);z-index:1000;padding:var(--space-4);justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.modal{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-8);width:100%;max-width:520px;max-height:90vh;box-shadow:var(--shadow-xl);animation:.25s scaleIn;overflow-y:auto}.modal-header{margin-bottom:var(--space-6);justify-content:space-between;align-items:center;display:flex}.modal-title{font-size:1.25rem;font-weight:700}.modal-close{border-radius:var(--radius-md);width:32px;height:32px;color:var(--color-text-tertiary);transition:all var(--transition-fast);justify-content:center;align-items:center;display:flex}.modal-close:hover{background:var(--color-bg-hover);color:var(--color-text-primary)}.modal-actions{justify-content:flex-end;gap:var(--space-3);margin-top:var(--space-6);display:flex}.table-container{border:1px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-bg-secondary);overflow-x:auto}.table{border-collapse:collapse;width:100%}.table th{text-align:left;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-tertiary);background:var(--color-bg-tertiary);border-bottom:1px solid var(--color-border);padding:.75rem 1rem;font-size:.75rem;font-weight:600}.table td{border-bottom:1px solid var(--color-border-light);padding:.875rem 1rem;font-size:.875rem}.table tr:last-child td{border-bottom:none}.table tr:hover td{background:var(--color-bg-hover)}.table-actions{gap:var(--space-1);display:flex}.badge{align-items:center;gap:var(--space-1);border-radius:var(--radius-full);padding:.25rem .625rem;font-size:.75rem;font-weight:500;display:inline-flex}.badge-success{background:var(--color-success-light);color:var(--color-success)}.badge-danger{background:var(--color-danger-light);color:var(--color-danger)}.badge-warning{background:var(--color-warning-light);color:var(--color-warning)}.badge-info{background:var(--color-info-light);color:var(--color-info)}.badge-accent{background:var(--color-accent-light);color:var(--color-accent)}.layout{min-height:100vh;display:flex}.sidebar{width:var(--sidebar-width);background:var(--color-bg-secondary);border-right:1px solid var(--color-border);z-index:100;transition:all var(--transition-base);flex-direction:column;display:flex;position:fixed;top:0;bottom:0;left:0}.sidebar-header{padding:var(--space-6);align-items:center;gap:var(--space-3);display:flex}.sidebar-logo{background:linear-gradient(135deg, var(--color-accent), #8b5cf6);border-radius:var(--radius-md);color:#fff;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.sidebar-brand{letter-spacing:-.02em;font-size:1.125rem;font-weight:700}.sidebar-nav{padding:0 var(--space-3);gap:var(--space-1);flex-direction:column;flex:1;display:flex}.sidebar-link{align-items:center;gap:var(--space-3);padding:.625rem var(--space-3);border-radius:var(--radius-md);color:var(--color-text-secondary);transition:all var(--transition-fast);font-size:.875rem;font-weight:500;display:flex;position:relative}.sidebar-link:hover{background:var(--color-bg-hover);color:var(--color-text-primary)}.sidebar-link.active{background:var(--color-accent-light);color:var(--color-accent)}.sidebar-link.active:before{content:"";background:var(--color-accent);border-radius:var(--radius-full);width:3px;height:20px;position:absolute;top:50%;left:0;transform:translateY(-50%)}.sidebar-section{padding:var(--space-4) var(--space-3) var(--space-2);text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-tertiary);font-size:.688rem;font-weight:600}.sidebar-footer{padding:var(--space-4) var(--space-3);border-top:1px solid var(--color-border)}.sidebar-user{align-items:center;gap:var(--space-3);padding:var(--space-3);border-radius:var(--radius-md);transition:all var(--transition-fast);display:flex}.sidebar-user:hover{background:var(--color-bg-hover)}.sidebar-avatar{border-radius:var(--radius-full);background:linear-gradient(135deg, var(--color-accent), #8b5cf6);color:#fff;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:.875rem;font-weight:600;display:flex}.sidebar-user-info{flex:1;min-width:0}.sidebar-user-name{white-space:nowrap;text-overflow:ellipsis;font-size:.875rem;font-weight:600;overflow:hidden}.sidebar-user-email{color:var(--color-text-tertiary);white-space:nowrap;text-overflow:ellipsis;font-size:.75rem;overflow:hidden}.main-content{margin-left:var(--sidebar-width);padding:var(--space-8);min-height:100vh;transition:margin-left var(--transition-base);flex:1}.sidebar-toggle{top:var(--space-4);left:var(--space-4);z-index:101;border-radius:var(--radius-md);background:var(--color-bg-secondary);border:1px solid var(--color-border);width:40px;height:40px;box-shadow:var(--shadow-md);justify-content:center;align-items:center;display:none;position:fixed}@media (width<=768px){.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0)}.sidebar-toggle{display:flex}.main-content{padding:var(--space-4);padding-top:calc(var(--space-4) + 56px);margin-left:0}}.kpi-grid{gap:var(--space-4);grid-template-columns:repeat(4,1fr);display:grid}@media (width<=1200px){.kpi-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=600px){.kpi-grid{grid-template-columns:1fr}}.kpi-card{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-5);transition:all var(--transition-base);position:relative;overflow:hidden}.kpi-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.kpi-icon{border-radius:var(--radius-md);width:40px;height:40px;margin-bottom:var(--space-3);justify-content:center;align-items:center;display:flex}.kpi-label{color:var(--color-text-secondary);font-size:.813rem;font-weight:500}.kpi-value{margin-top:var(--space-1);letter-spacing:-.02em;font-size:1.5rem;font-weight:800}.kpi-change{align-items:center;gap:var(--space-1);margin-top:var(--space-2);border-radius:var(--radius-full);padding:.125rem .5rem;font-size:.75rem;font-weight:500;display:inline-flex}.progress-bar{background:var(--color-bg-tertiary);border-radius:var(--radius-full);width:100%;height:8px;overflow:hidden}.progress-fill{border-radius:var(--radius-full);height:100%;transition:width var(--transition-slow);background:var(--color-accent)}.progress-fill.over-budget{background:var(--color-danger)}.progress-fill.warning{background:var(--color-warning)}.empty-state{padding:var(--space-16) var(--space-8);text-align:center;color:var(--color-text-tertiary);flex-direction:column;justify-content:center;align-items:center;display:flex}.empty-state-icon{width:64px;height:64px;margin-bottom:var(--space-4);opacity:.4}.empty-state-title{color:var(--color-text-secondary);margin-bottom:var(--space-2);font-size:1.125rem;font-weight:600}.empty-state-text{margin-bottom:var(--space-6);max-width:360px;font-size:.875rem}.auth-page{min-height:100vh;padding:var(--space-4);background:var(--color-bg-primary);justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.auth-page:before{content:"";background:radial-gradient(ellipse at top left, var(--color-accent-light) 0%, transparent 50%), radial-gradient(ellipse at bottom right, #8b5cf614 0%, transparent 50%);pointer-events:none;width:200%;height:200%;position:absolute;top:-50%;left:-50%}.auth-card{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-10);width:100%;max-width:440px;box-shadow:var(--shadow-xl);animation:.6s fadeInUp;position:relative}.auth-header{text-align:center;margin-bottom:var(--space-8)}.auth-logo{background:linear-gradient(135deg, var(--color-accent), #8b5cf6);border-radius:var(--radius-lg);width:56px;height:56px;margin:0 auto var(--space-4);color:#fff;box-shadow:0 4px 20px var(--color-accent-glow);justify-content:center;align-items:center;display:flex}.auth-title{letter-spacing:-.02em;font-size:1.5rem;font-weight:800}.auth-subtitle{color:var(--color-text-secondary);margin-top:var(--space-2);font-size:.875rem}.auth-form{gap:var(--space-4);flex-direction:column;display:flex}.auth-switch{text-align:center;margin-top:var(--space-6);color:var(--color-text-secondary);font-size:.875rem}.auth-switch a,.auth-switch button{color:var(--color-accent);cursor:pointer;font-weight:500;font-size:inherit;background:0 0;border:none}.auth-switch a:hover,.auth-switch button:hover{text-decoration:underline}.auth-error{background:var(--color-danger-light);color:var(--color-danger);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);text-align:center;font-size:.813rem}.loader{border:2px solid var(--color-border);border-top-color:var(--color-accent);border-radius:50%;width:24px;height:24px;animation:.6s linear infinite spin}.loader-lg{border-width:3px;width:40px;height:40px}.page-loader{justify-content:center;align-items:center;min-height:400px;display:flex}.chart-container{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-6)}.chart-header{margin-bottom:var(--space-4);justify-content:space-between;align-items:center;display:flex}.chart-title{font-size:1rem;font-weight:600}.chart-period{gap:var(--space-1);display:flex}.chart-period-btn{border-radius:var(--radius-full);color:var(--color-text-tertiary);transition:all var(--transition-fast);padding:.25rem .75rem;font-size:.75rem;font-weight:500}.chart-period-btn:hover{background:var(--color-bg-hover);color:var(--color-text-primary)}.chart-period-btn.active{background:var(--color-accent-light);color:var(--color-accent)}.account-card{align-items:center;gap:var(--space-4);padding:var(--space-4);background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-lg);transition:all var(--transition-base);cursor:pointer;display:flex}.account-card:hover{box-shadow:var(--shadow-md);border-color:var(--color-accent);transform:translateY(-2px)}.account-card-icon{border-radius:var(--radius-md);flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.account-card-info{flex:1;min-width:0}.account-card-name{font-size:.875rem;font-weight:600}.account-card-type{color:var(--color-text-tertiary);font-size:.75rem}.account-card-balance{text-align:right;font-variant-numeric:tabular-nums;font-size:1.125rem;font-weight:700}.stock-row{align-items:center;gap:var(--space-4);padding:var(--space-4);border-bottom:1px solid var(--color-border-light);transition:all var(--transition-fast);display:flex}.stock-row:hover{background:var(--color-bg-hover)}.stock-row:last-child{border-bottom:none}.stock-symbol{width:70px;font-size:.875rem;font-weight:700}.stock-name{color:var(--color-text-secondary);white-space:nowrap;text-overflow:ellipsis;flex:1;min-width:0;font-size:.875rem;overflow:hidden}.stock-price{font-variant-numeric:tabular-nums;text-align:right;width:100px;font-weight:600}.stock-change{text-align:right;width:90px;font-size:.875rem;font-weight:500}.stock-value{text-align:right;font-variant-numeric:tabular-nums;width:120px;font-weight:700}.filter-bar{align-items:center;gap:var(--space-3);margin-bottom:var(--space-6);flex-wrap:wrap;display:flex}.filter-bar .form-input,.filter-bar .form-select{max-width:200px}@media (width<=768px){.filter-bar{flex-direction:column;align-items:stretch}.filter-bar .form-input,.filter-bar .form-select{max-width:100%}}.theme-toggle{border-radius:var(--radius-md);cursor:pointer;width:36px;height:36px;transition:all var(--transition-fast);color:var(--color-text-secondary);justify-content:center;align-items:center;display:flex}.theme-toggle:hover{background:var(--color-bg-hover);color:var(--color-accent)}.tabs{gap:var(--space-1);border-bottom:1px solid var(--color-border);margin-bottom:var(--space-6);display:flex}.tab{padding:var(--space-3) var(--space-4);color:var(--color-text-tertiary);transition:all var(--transition-fast);cursor:pointer;border-bottom:2px solid #0000;font-size:.875rem;font-weight:500}.tab:hover{color:var(--color-text-primary)}.tab.active{color:var(--color-accent);border-bottom-color:var(--color-accent)}.color-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px;display:inline-block}.recharts-tooltip-cursor{fill:var(--color-bg-hover)!important}.custom-tooltip{background:var(--color-bg-secondary)!important;border:1px solid var(--color-border)!important;border-radius:var(--radius-md)!important;padding:var(--space-3) var(--space-4)!important;box-shadow:var(--shadow-lg)!important}.custom-tooltip .label{color:var(--color-text-tertiary);margin-bottom:var(--space-1);font-size:.75rem}.custom-tooltip .value{font-size:.875rem;font-weight:600}
