.dashboard h1{color:#1a1a1a;margin-bottom:2rem;font-size:2.5rem}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-bottom:2rem}.stat-card{background:#fff;padding:1.5rem;border-radius:12px;box-shadow:0 4px 6px #0000001a}.stat-header{display:flex;align-items:center;gap:.5rem;margin-bottom:1rem;color:#667eea}.stat-header h3{font-size:.9rem;font-weight:600;color:#667eea;margin:0}.stat-value{font-size:2rem;font-weight:700;color:#333}.charts-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:1.5rem;margin-bottom:2rem}.recent-expenses{display:flex;flex-direction:column;gap:1rem}.expense-item{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:#f8f9fa;border-radius:8px}.category-name{font-weight:600;color:#333}.category-amount{font-weight:700;font-size:1.1rem;transition:color .3s ease}.expenses h1{color:#1a1a1a;margin-bottom:2rem}.expenses-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.header-actions{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.sort-filter{display:flex;align-items:center;gap:.5rem}.sort-filter label{font-weight:500;color:#333;font-size:.9rem}.sort-select{padding:.5rem 1rem;border:2px solid #e0e0e0;border-radius:8px;font-size:.9rem;background:#fff;color:#333;cursor:pointer;transition:border-color .3s ease}.sort-select:focus{outline:none;border-color:#667eea}.category-badge{background:#667eea;color:#fff;padding:.25rem .75rem;border-radius:12px;font-size:.85rem;font-weight:600}.amount{font-weight:700;color:#333}.action-buttons{display:flex;gap:.5rem}.btn-icon{background:none;border:none;cursor:pointer;padding:.5rem;border-radius:4px;color:#666;transition:all .3s ease}.btn-icon:hover{background:#f0f0f0;color:#333}.btn-icon.btn-danger{color:#ef4444}.btn-icon.btn-danger:hover{background:#fee;color:#dc2626}.modal-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:1.5rem}.budgets h1{color:#1a1a1a;margin-bottom:2rem}.budgets-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.budgets-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.budget-card{background:#fff;padding:1.5rem;border-radius:12px;box-shadow:0 4px 6px #0000001a}.budget-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.budget-header h3{margin:0;color:#333;font-size:1.25rem}.budget-actions{display:flex;gap:.5rem}.budget-amount{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.budget-label{color:#666;font-weight:500}.budget-value{font-size:1.5rem;font-weight:700;color:#1a1a1a}.budget-progress{margin-bottom:1rem}.progress-bar{width:100%;height:10px;background:#e0e0e0;border-radius:5px;overflow:hidden;margin-bottom:.5rem}.progress-fill{height:100%;background:#1a1a1a;transition:width .3s ease}.progress-fill.over-budget{background:#ef4444}.progress-info{display:flex;justify-content:space-between;font-size:.9rem;color:#666}.over-budget-text{color:#ef4444;font-weight:600}.budget-warning{display:flex;align-items:center;gap:.5rem;padding:.75rem;background:#fee;border-radius:8px;color:#ef4444;font-size:.9rem}.loading{text-align:center;padding:3rem;color:#666;font-size:1.5rem}.ai-chatbot{display:flex;flex-direction:column;height:calc(100vh - 120px)}.chat-header{margin-bottom:2rem}.chat-header h1{color:#1a1a1a;margin-bottom:.5rem}.chat-header p{color:#666;font-size:1.1rem}.quick-questions{background:#fff;padding:1.5rem;border-radius:12px;margin-bottom:1.5rem;box-shadow:0 4px 6px #0000001a}.quick-questions h3{margin-bottom:1rem;color:#333;font-size:1rem}.quick-buttons{display:flex;flex-wrap:wrap;gap:.75rem}.quick-btn{padding:.5rem 1rem;background:#f0f0f0;border:none;border-radius:20px;cursor:pointer;font-size:.9rem;color:#333;transition:all .3s ease}.quick-btn:hover{background:#1a1a1a;color:#fff;transform:translateY(-2px)}.chat-container{flex:1;display:flex;flex-direction:column;background:#fff;border-radius:12px;box-shadow:0 4px 6px #0000001a;overflow:hidden}.messages{flex:1;overflow-y:auto;padding:1.5rem;display:flex;flex-direction:column;gap:1rem}.message{display:flex;gap:.75rem;max-width:80%}.message.user{align-self:flex-end;flex-direction:row-reverse}.message.assistant{align-self:flex-start}.message-icon{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}.message.user .message-icon{background:#1a1a1a;color:#fff}.message.assistant .message-icon{background:#e8e8e8;color:#1a1a1a}.message-content{padding:.75rem 1rem;border-radius:12px;background:#f8f9fa;color:#333;line-height:1.5}.message.user .message-content{background:#1a1a1a;color:#fff}.chat-input-form{display:flex;padding:1rem;border-top:1px solid #e0e0e0;gap:.5rem}.chat-input{flex:1;padding:.75rem 1rem;border:2px solid #e0e0e0;border-radius:24px;font-size:1rem;outline:none;transition:border-color .3s ease}.chat-input:focus{border-color:#1a1a1a}.send-btn{width:48px;height:48px;border-radius:50%;border:none;background:#1a1a1a;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease}.send-btn:hover:not(:disabled){background:#333;transform:scale(1.05)}.send-btn:disabled{opacity:.5;cursor:not-allowed}.typing-indicator{display:flex;gap:4px;padding:.5rem}.typing-indicator span{width:8px;height:8px;border-radius:50%;background:#1a1a1a;animation:typing 1.4s infinite}.typing-indicator span:nth-child(2){animation-delay:.2s}.typing-indicator span:nth-child(3){animation-delay:.4s}@keyframes typing{0%,60%,to{transform:translateY(0);opacity:.7}30%{transform:translateY(-10px);opacity:1}}.auth-container{min-height:calc(100vh - 80px);display:flex;align-items:center;justify-content:center;padding:2rem;background:linear-gradient(135deg,#667eea,#764ba2)}.auth-card{background:#fff;border-radius:16px;padding:2.5rem;width:100%;max-width:420px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.auth-header{text-align:center;margin-bottom:2rem}.auth-icon{width:48px;height:48px;color:#667eea;margin:0 auto 1rem}.auth-header h1{font-size:1.875rem;font-weight:700;color:#1f2937;margin-bottom:.5rem}.auth-header p{color:#6b7280;font-size:.875rem}.error-message{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:#fee2e2;border:1px solid #fecaca;border-radius:8px;color:#dc2626;font-size:.875rem;margin-bottom:1.5rem}.auth-form{display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{display:flex;align-items:center;gap:.5rem;font-weight:500;color:#374151;font-size:.875rem}.form-group input{padding:.75rem 1rem;border:1px solid #d1d5db;border-radius:8px;font-size:1rem;transition:all .2s}.form-group input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-group input:disabled{background:#f3f4f6;cursor:not-allowed}.auth-button{padding:.875rem 1.5rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s;margin-top:.5rem}.auth-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 10px 15px -3px #667eea4d}.auth-button:disabled{opacity:.6;cursor:not-allowed}.auth-footer{margin-top:1.5rem;text-align:center;padding-top:1.5rem;border-top:1px solid #e5e7eb}.auth-footer p{color:#6b7280;font-size:.875rem}.auth-footer a{color:#667eea;font-weight:600;text-decoration:none}.auth-footer a:hover{text-decoration:underline}.app{min-height:100vh;display:flex;flex-direction:column}.navbar{background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 10px #0000001a;position:sticky;top:0;z-index:100}.nav-brand{display:flex;align-items:center;gap:.5rem}.nav-brand h1{font-size:1.5rem;color:#1a1a1a;font-weight:700}.nav-icon{color:#1a1a1a}.nav-links{display:flex;gap:1.5rem;align-items:center}.nav-link{display:flex;align-items:center;gap:.5rem;text-decoration:none;color:#333;font-weight:500;padding:.5rem 1rem;border-radius:8px;transition:all .3s ease}.nav-link:hover{background:#e8e8e8;color:#1a1a1a}.nav-link.active{background:#1a1a1a;color:#fff}.nav-user{display:flex;align-items:center;gap:1rem}.user-info{display:flex;align-items:center;gap:.5rem;color:#666;font-size:.875rem}.logout-btn{background:none;border:none;cursor:pointer}.main-content{flex:1;padding:2rem;max-width:1400px;width:100%;margin:0 auto}.card{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 4px 6px #0000001a;margin-bottom:1.5rem}.card h2{margin-bottom:1rem;color:#333;font-size:1.5rem}.btn{padding:.75rem 1.5rem;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:all .3s ease;font-size:1rem}.btn-primary{background:#1a1a1a;color:#fff}.btn-primary:hover{background:#333;transform:translateY(-2px);box-shadow:0 4px 8px #0003}.btn-secondary{background:#e0e0e0;color:#333}.btn-secondary:hover{background:#d0d0d0}.btn-danger{background:#ef4444;color:#fff}.btn-danger:hover{background:#dc2626}.form-group{margin-bottom:1rem}.form-group label{display:block;margin-bottom:.5rem;color:#333;font-weight:500}.form-group input,.form-group select,.form-group textarea{width:100%;padding:.75rem;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;transition:border-color .3s ease}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#1a1a1a}.grid{display:grid;gap:1.5rem}.grid-2{grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.grid-3{grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.grid-4{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.stat-card{background:#fff;color:#1a1a1a;padding:1.5rem;border-radius:12px;box-shadow:0 4px 6px #0000001a;border:1px solid #e0e0e0}.stat-card h3{font-size:.9rem;opacity:.9;margin-bottom:.5rem}.stat-card .stat-value{font-size:2rem;font-weight:700}.table{width:100%;border-collapse:collapse;margin-top:1rem}.table th,.table td{padding:1rem;text-align:left;border-bottom:1px solid #e0e0e0}.table th{background:#f8f9fa;font-weight:600;color:#333}.table tr:hover{background:#f8f9fa}.modal{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#fff;padding:2rem;border-radius:12px;max-width:500px;width:90%;max-height:90vh;overflow-y:auto}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.modal-header h2{margin:0}.close-btn{background:none;border:none;font-size:1.5rem;cursor:pointer;color:#666}.close-btn:hover{color:#333}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f5f5f5;min-height:100vh}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}#root{min-height:100vh}
