@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";:root{--bg-color:#0b0f19;--bg-color-secondary:#161e31;--text-primary:#fff;--text-secondary:#a0aec0;--accent-color:#6366f1;--accent-color-hover:#4f46e5;--success-color:#10b981;--danger-color:#ef4444;--glass-bg:#161e31b3;--glass-border:#ffffff1a;--glass-shadow:0 4px 30px #00000080;--border-radius:16px;--transition:all .3s cubic-bezier(.25, .8, .25, 1)}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--bg-color);color:var(--text-primary);-webkit-font-smoothing:antialiased;background-image:radial-gradient(circle at 15%,#6366f126,#0000 25%),radial-gradient(circle at 85% 30%,#10b98126,#0000 25%);background-attachment:fixed;min-height:100vh;font-family:Inter,sans-serif}#root{flex-direction:column;min-height:100vh;display:flex}a{color:var(--accent-color);transition:var(--transition);text-decoration:none}a:hover{color:var(--accent-color-hover)}.glass-panel{background:var(--glass-bg);-webkit-backdrop-filter:blur(12px);border:1px solid var(--glass-border);border-radius:var(--border-radius);box-shadow:var(--glass-shadow);padding:24px}.btn{background-color:var(--accent-color);color:#fff;cursor:pointer;transition:var(--transition);border:none;border-radius:12px;justify-content:center;align-items:center;gap:8px;padding:12px 24px;font-size:1rem;font-weight:500;display:inline-flex;box-shadow:0 4px 14px #6366f163}.btn:hover{background-color:var(--accent-color-hover);transform:translateY(-2px);box-shadow:0 6px 20px #6366f13b}.btn-secondary{border:1px solid var(--glass-border);box-shadow:none;background-color:#0000}.btn-secondary:hover{box-shadow:none;background-color:#ffffff0d}.btn-danger{color:var(--danger-color);box-shadow:none;background-color:#ef44441a;border:1px solid #ef44444d}.btn-danger:hover{background-color:#ef444433;transform:translateY(-2px)}input,textarea{border:1px solid var(--glass-border);width:100%;color:var(--text-primary);transition:var(--transition);background-color:#0003;border-radius:12px;outline:none;padding:12px 16px;font-family:Inter,sans-serif;font-size:1rem}input:focus,textarea:focus{border-color:var(--accent-color);box-shadow:0 0 0 2px #6366f133}.text-gradient{background:linear-gradient(90deg,#a855f7,#6366f1,#3b82f6);color:#0000;-webkit-background-clip:text;background-clip:text}.container{width:100%;max-width:1200px;margin:0 auto;padding:24px}.card-title{color:var(--text-primary);margin-bottom:16px;font-size:1.25rem;font-weight:600}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.animate-slide-up{animation:.5s cubic-bezier(.16,1,.3,1) forwards slideUp}.animate-fade-in{animation:.4s ease-out forwards fadeIn}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#fff3}.login-container{justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.login-panel{text-align:center;width:100%;max-width:420px;padding:40px}.login-header{margin-bottom:32px}.logo-icon{background:#6366f126;border-radius:50%;justify-content:center;align-items:center;width:64px;height:64px;margin:0 auto 16px;display:flex;box-shadow:0 0 20px #6366f133}.login-header h2{margin-bottom:8px;font-size:1.8rem;font-weight:700}.login-header p{color:var(--text-secondary);font-size:.95rem;line-height:1.5}.login-form{flex-direction:column;gap:16px;display:flex}.input-group{align-items:center;display:flex;position:relative}.input-icon{color:var(--text-secondary);position:absolute;left:16px}.input-group input{padding-left:48px}.login-btn{width:100%;margin-top:8px}.divider{text-align:center;align-items:center;margin:24px 0;display:flex}.divider:before,.divider:after{content:"";border-bottom:1px solid var(--glass-border);flex:1}.divider span{color:var(--text-secondary);padding:0 16px;font-size:.85rem}.social-login{flex-direction:column;gap:12px;display:flex}.social-btn{justify-content:center;align-items:center;gap:12px;width:100%;display:flex}.chat-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background:#0006;justify-content:flex-end;width:100%;height:100%;padding:24px;display:flex;position:fixed;top:0;left:0}.chat-container{background:var(--bg-color-secondary);border:1px solid var(--glass-border);flex-direction:column;width:100%;max-width:400px;height:100%;max-height:800px;padding:0;display:flex;overflow:hidden;box-shadow:0 10px 40px #00000080}.chat-header{border-bottom:1px solid var(--glass-border);background:#6366f11a;justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.chat-title{align-items:center;gap:12px;display:flex}.bot-avatar{background:linear-gradient(135deg,#a855f7,#6366f1);border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;display:flex;box-shadow:0 4px 10px #6366f14d}.chat-title h3{margin:0;font-size:1rem;font-weight:600}.online-status{color:var(--success-color);align-items:center;margin:0;font-size:.75rem;display:flex}.close-btn{color:var(--text-secondary);cursor:pointer;transition:var(--transition);background:0 0;border:none}.close-btn:hover{color:var(--text-primary);transform:rotate(90deg)}.chat-messages{flex-direction:column;flex:1;gap:16px;padding:20px;display:flex;overflow-y:auto}.message-bubble{gap:8px;max-width:85%;display:flex}.user-bubble{flex-direction:row-reverse;align-self:flex-end}.ai-bubble{align-self:flex-start}.bubble-avatar{width:28px;height:28px;color:var(--accent-color);background:#6366f133;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;margin-top:auto;display:flex}.message-content{background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:16px;padding:12px 16px;font-size:.95rem;line-height:1.5}.user-bubble .message-content{background:var(--accent-color);color:#fff;border-color:var(--accent-color);border-bottom-right-radius:4px}.ai-bubble .message-content{border-bottom-left-radius:4px}.chat-image{border-radius:8px;max-width:100%;margin-bottom:8px}.typing-indicator{opacity:.7}.spin{vertical-align:middle;margin-right:6px;animation:1s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.image-preview{background:#0003;align-items:center;padding:10px 20px;display:flex;position:relative}.image-preview img{border-radius:8px;height:60px}.remove-image{background:var(--danger-color);color:#fff;cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;width:20px;height:20px;display:flex;position:absolute;top:4px;left:70px}.chat-input-area{border-top:1px solid var(--glass-border);background:#0000004d;align-items:center;gap:12px;padding:16px;display:flex}.input-actions{display:flex}.action-btn{color:var(--text-secondary);cursor:pointer;transition:var(--transition);padding:8px}.action-btn:hover{color:var(--accent-color)}.chat-input-area input{border:1px solid var(--glass-border);background:#ffffff0d;border-radius:20px;flex:1;margin:0;padding:10px 16px}.send-btn{background:var(--accent-color);color:#fff;cursor:pointer;width:40px;height:40px;transition:var(--transition);border:none;border-radius:50%;justify-content:center;align-items:center;display:flex;box-shadow:0 4px 10px #6366f14d}.send-btn:hover:not(:disabled){background:var(--accent-color-hover);transform:scale(1.05)}.send-btn:disabled{color:var(--text-secondary);cursor:not-allowed;box-shadow:none;background:#ffffff1a}@media (width<=600px){.chat-overlay{padding:0}.chat-container{border:none;border-radius:0;max-width:100%}}.dashboard-layout{height:100vh;display:flex;overflow:hidden}.sidebar{flex-direction:column;width:250px;height:calc(100vh - 32px);margin:16px;display:flex}.logo-container{border-bottom:1px solid var(--glass-border);align-items:center;gap:12px;margin-bottom:24px;padding-bottom:24px;display:flex}.logo-container h2{background:linear-gradient(90deg,#a855f7,#6366f1);color:#0000;-webkit-background-clip:text;background-clip:text;font-size:1.25rem;font-weight:700}.nav-items{flex-direction:column;flex:1;gap:8px;display:flex}.nav-btn{color:var(--text-secondary);cursor:pointer;transition:var(--transition);text-align:left;background:0 0;border:none;border-radius:12px;align-items:center;gap:12px;padding:12px 16px;font-family:inherit;font-size:1rem;display:flex}.nav-btn:hover{color:var(--text-primary);background:#ffffff0d}.nav-btn.active{color:var(--accent-color);background:#6366f126;font-weight:500}.logout-btn:hover{color:var(--danger-color);background:#ef44441a}.main-content{flex-direction:column;flex:1;gap:24px;padding:16px 32px 16px 16px;display:flex;overflow-y:auto}.header{justify-content:space-between;align-items:flex-end;margin-top:16px;display:flex}.header h1{margin-bottom:4px;font-size:2rem}.text-secondary{color:var(--text-secondary)}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px;display:grid}.stat-card{align-items:center;gap:16px;padding:20px;display:flex}.stat-icon{border-radius:12px;justify-content:center;align-items:center;width:48px;height:48px;display:flex}.income-icon{color:#10b981;background:#10b98126}.expense-icon{color:#ef4444;background:#ef444426}.savings-icon{color:#6366f1;background:#6366f126}.stat-label{color:var(--text-secondary);margin-bottom:4px;font-size:.9rem}.stat-value{font-size:1.5rem;font-weight:700}.charts-grid{flex:1;grid-template-columns:2fr 1fr;gap:20px;min-height:400px;display:grid}.chart-container{flex-direction:column;display:flex}.chart-wrapper{flex:1;min-height:250px;margin-top:16px}.legend{flex-wrap:wrap;justify-content:center;gap:12px;margin-top:20px;display:flex}.legend-item{color:var(--text-secondary);align-items:center;gap:6px;font-size:.85rem;display:flex}.legend-color{border-radius:50%;width:10px;height:10px}@media (width<=900px){.charts-grid{grid-template-columns:1fr}}@media (width<=768px){.dashboard-layout{flex-direction:column}.sidebar{flex-direction:row;width:auto;height:auto;margin:16px;padding:12px 20px}.logo-container{border:none;margin:0;padding:0}.hidden-mobile{display:none}.nav-items{flex-direction:row;justify-content:center;gap:16px}.nav-btn{padding:8px}.main-content{padding:0 16px 16px}}
