body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.login-container{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.login-box{background:#fff;border-radius:16px;width:100%;max-width:420px;padding:48px;box-shadow:0 20px 60px #0000004d}.login-header{text-align:center;margin-bottom:32px}.login-header h1{color:#1a1a1a;margin-bottom:8px;font-size:32px;font-weight:700}.login-header p{color:#666;font-size:16px}.login-form{flex-direction:column;gap:20px;display:flex}.form-group{flex-direction:column;gap:8px;display:flex}.form-group label{color:#333;font-size:14px;font-weight:600}.form-group input{border:2px solid #e0e0e0;border-radius:8px;padding:14px 16px;font-size:16px;transition:all .2s}.form-group input:focus{border-color:#667eea;outline:none;box-shadow:0 0 0 3px #667eea1a}.error-message{color:#c33;text-align:center;background:#fee;border-radius:8px;padding:12px;font-size:14px}.login-button{color:#fff;cursor:pointer;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border:none;border-radius:8px;margin-top:8px;padding:16px;font-size:16px;font-weight:600;transition:all .2s}.login-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 20px #667eea66}.login-button:disabled{opacity:.6;cursor:not-allowed}.login-footer{text-align:center;margin-top:24px}.login-footer p{color:#888;font-size:13px}.upload-section h2{color:#333;margin-bottom:20px}.source-selector{gap:20px;margin-bottom:20px;display:flex}.source-selector label{cursor:pointer;align-items:center;gap:8px;display:flex}.dropzone{text-align:center;cursor:pointer;background:#fafafa;border:2px dashed #ccc;border-radius:12px;padding:60px 20px;transition:all .3s}.dropzone.active{background:#f0f4ff;border-color:#667eea}.dropzone.disabled{opacity:.6;cursor:not-allowed}.dropzone-content p{color:#666;margin-bottom:8px;font-size:18px}.dropzone-content .hint{color:#999;font-size:14px}.uploading,.analyzing{color:#667eea;font-size:18px;font-weight:600}.message{border-radius:8px;margin-top:20px;padding:15px;font-weight:500}.message.success{color:#155724;background:#d4edda;border:1px solid #c3e6cb}.message.error{color:#721c24;background:#f8d7da;border:1px solid #f5c6cb}.info-box{background:#f8f9fa;border-radius:8px;margin-top:30px;padding:20px}.info-box h3{color:#333;margin-bottom:10px}.info-box ul{color:#666;margin-left:20px}.info-box li{margin-bottom:5px}.dashboard h2{color:#333;margin-bottom:30px}.loading,.empty{text-align:center;color:#666;padding:60px 20px;font-size:18px}.summary-cards{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;margin-bottom:30px;display:grid}.card{color:#fff;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border-radius:12px;padding:20px;box-shadow:0 4px 10px #667eea4d}.card h3{opacity:.9;margin-bottom:10px;font-size:14px}.card .value{font-size:28px;font-weight:600}.charts-row{grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:30px;margin-bottom:30px;display:grid}.chart-container{background:#f8f9fa;border-radius:12px;flex-direction:column;height:400px;padding:20px;display:flex}.chart-container.full-width{grid-column:1/-1}.chart-container h3{color:#333;margin-bottom:20px;font-size:18px}.chart-container canvas{flex:1;width:100%!important}.recent-section{margin-top:30px}.recent-section h3{color:#333;margin-bottom:20px}table{border-collapse:collapse;width:100%}.transactions h2{color:#333;margin-bottom:20px}.filters{grid-template-columns:1fr 1fr;gap:15px;margin-bottom:20px;display:grid}.filters input{border:1px solid #ddd;border-radius:8px;padding:12px;font-size:14px}.filters input:focus{border-color:#667eea;outline:none}.loading,.empty{text-align:center;color:#666;padding:40px}table{border-collapse:collapse;width:100%;margin-bottom:20px}th,td{text-align:left;border-bottom:1px solid #eee;padding:12px}th{color:#666;background:#f8f9fa;font-weight:600}tr:hover{background:#f8f9fa}.category-badge{border-radius:20px;padding:4px 12px;font-size:12px;font-weight:500;display:inline-block}.cat-subscriptions{color:#fff;background:#ff6b6b}.cat-groceries{color:#fff;background:#4ecdc4}.cat-transportation{color:#333;background:#95e1d3}.cat-dining{color:#fff;background:#f38181}.cat-shopping{color:#fff;background:#aa96da}.cat-transfers{color:#333;background:#fcbad3}.cat-education{color:#333;background:#a8d8ea}.cat-services{color:#fff;background:#aa96da}.cat-cash_banking{color:#fff;background:#f8b500}.cat-entertainment{color:#fff;background:#ff6b9d}.cat-health{color:#fff;background:#44bd32}.cat-other{color:#fff;background:#999}.pagination{justify-content:center;align-items:center;gap:20px;display:flex}.pagination button{color:#fff;cursor:pointer;background:#667eea;border:none;border-radius:8px;padding:10px 20px;font-size:14px}.pagination button:hover:not(:disabled){background:#5568d3}.pagination button:disabled{cursor:not-allowed;background:#ccc}*{box-sizing:border-box;margin:0;padding:0}body{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif}.app{max-width:1200px;margin:0 auto;padding:20px}.header{background:#fff;border-radius:12px;margin-bottom:20px;padding:20px;box-shadow:0 2px 10px #0000001a}.header h1{color:#333;margin-bottom:15px}.tabs{gap:10px;display:flex}.tabs button{cursor:pointer;background:#f0f0f0;border:none;border-radius:8px;padding:10px 20px;font-size:14px;transition:all .2s}.tabs button:hover{background:#e0e0e0}.tabs button.active{color:#fff;background:#667eea}.main-content{background:#fff;border-radius:12px;min-height:500px;padding:30px;box-shadow:0 2px 10px #0000001a}.footer{text-align:center;color:#fff;opacity:.8;margin-top:20px}.logout-button{color:#ff6b6b;cursor:pointer;background:#fff;border:2px solid #ff6b6b;border-radius:8px;padding:10px 20px;font-size:14px;font-weight:600;transition:all .2s}.logout-button:hover{color:#fff;background:#ff6b6b}.loading-container{color:#fff;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);flex-direction:column;justify-content:center;align-items:center;min-height:100vh;display:flex}.loading-spinner{border:4px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:50px;height:50px;animation:1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.header{background:#fff;border-radius:12px;flex-direction:column;gap:15px;margin-bottom:20px;padding:20px;display:flex;box-shadow:0 2px 10px #0000001a}@media (width>=768px){.header{flex-direction:row;justify-content:space-between;align-items:center}}
