@import "https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700&display=swap";:root{--bg-app:#090d16;--bg-surface:#111827;--bg-surface-hover:#1f2937;--border-color:#ffffff14;--border-focus:#8b5cf6;--text-primary:#f3f4f6;--text-secondary:#9ca3af;--text-muted:#6b7280;--accent:#8b5cf6;--accent-light:#a78bfa;--accent-dark:#6d28d9;--accent-glow:#8b5cf640;--success:#10b981;--success-glow:#10b98126;--danger:#ef4444;--danger-glow:#ef444426;--warning:#f59e0b;--font-family:"Outfit", system-ui, -apple-system, sans-serif;--border-radius-sm:8px;--border-radius-md:12px;--border-radius-lg:20px;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -1px #0000000f;--shadow-lg:0 10px 15px -3px #0000004d, 0 4px 6px -2px #00000026;--shadow-glow:0 0 20px 0 var(--accent-glow);--transition-fast:.15s ease;--transition-normal:.25s cubic-bezier(.4, 0, .2, 1)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-family);background-color:var(--bg-app);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-image:radial-gradient(at 0 0,#8b5cf614 0,#0000 50%),radial-gradient(at 100% 100%,#3b82f60d 0,#0000 50%);background-attachment:fixed;min-height:100vh;line-height:1.5}#root{flex-direction:column;min-height:100vh;display:flex}.app-container{flex-direction:column;flex-grow:1;gap:24px;width:100%;max-width:1200px;margin:0 auto;padding:24px 16px;display:flex}.loading-screen{height:100vh;color:var(--text-secondary);flex-direction:column;justify-content:center;align-items:center;gap:16px;display:flex}.spinner{border:3px solid var(--border-color);border-top-color:var(--accent);border-radius:50%;width:40px;height:40px;animation:1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.auth-container{justify-content:center;align-items:center;min-height:calc(100vh - 48px);padding:20px;display:flex}.card-login{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--border-radius-lg);width:100%;max-width:420px;box-shadow:var(--shadow-lg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);flex-direction:column;gap:28px;padding:40px 32px;animation:.4s ease-out fadeIn;display:flex;position:relative;overflow:hidden}.card-login:before{content:"";background:linear-gradient(90deg, var(--accent), #3b82f6);width:100%;height:4px;position:absolute;top:0;left:0}@keyframes fadeIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.logo-header{text-align:center;flex-direction:column;align-items:center;gap:8px;display:flex}.logo-header h1{letter-spacing:-.5px;color:var(--text-primary);align-items:center;gap:8px;font-size:28px;font-weight:700;display:flex}.logo-header h1 span{background:linear-gradient(135deg, var(--accent-light), #60a5fa);-webkit-text-fill-color:transparent;-webkit-background-clip:text}.logo-header p{color:var(--text-secondary);font-size:14px}.form-group{flex-direction:column;gap:8px;display:flex}.form-group label{color:var(--text-secondary);font-size:14px;font-weight:500}.input-field{border:1px solid var(--border-color);color:var(--text-primary);border-radius:var(--border-radius-md);font-family:var(--font-family);transition:var(--transition-fast);background-color:#ffffff08;outline:none;padding:12px 16px;font-size:15px}.input-field:focus{border-color:var(--border-focus);background-color:#ffffff0d;box-shadow:0 0 0 3px #8b5cf626}.btn-primary{background:linear-gradient(135deg, var(--accent), var(--accent-dark));color:#fff;border-radius:var(--border-radius-md);font-family:var(--font-family);cursor:pointer;transition:var(--transition-normal);border:none;justify-content:center;align-items:center;gap:8px;padding:14px;font-size:16px;font-weight:600;display:flex;box-shadow:0 4px 12px #8b5cf633}.btn-primary:hover:not(:disabled){opacity:.95;transform:translateY(-2px);box-shadow:0 6px 20px #8b5cf659}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.alert-message{border-radius:var(--border-radius-md);align-items:center;gap:8px;padding:12px 16px;font-size:14px;font-weight:500;display:flex}.alert-error{background-color:var(--danger-glow);color:#fca5a5;border:1px solid #ef444433}.header-app{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding-bottom:16px;display:flex}.header-user{align-items:center;gap:16px;display:flex}.user-email{color:var(--text-secondary);border:1px solid var(--border-color);background-color:#ffffff0d;border-radius:20px;padding:4px 12px;font-size:14px}.btn-logout{color:var(--text-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius-md);font-family:var(--font-family);cursor:pointer;transition:var(--transition-fast);background:0 0;padding:8px 16px;font-size:14px;font-weight:500}.btn-logout:hover{color:#f87171;background-color:#ef44441a;border-color:#ef444433}.summary-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px;display:grid}.summary-card{background-color:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-md);flex-direction:column;gap:8px;padding:24px;display:flex;position:relative;overflow:hidden}.summary-card:after{content:"";pointer-events:none;background:radial-gradient(circle,#ffffff08 0%,#0000 70%);width:80px;height:80px;position:absolute;top:0;right:0}.summary-card-title{color:var(--text-secondary);align-items:center;gap:6px;font-size:14px;font-weight:500;display:flex}.summary-card-value{letter-spacing:-.5px;font-size:32px;font-weight:700}.value-income{color:var(--success)}.value-expense{color:var(--text-primary)}.value-balance{color:var(--accent-light)}.control-panel{background-color:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--border-radius-md);box-shadow:var(--shadow-sm);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;padding:16px 24px;display:flex}.btn-secondary{color:var(--text-primary);border:1px solid var(--border-color);border-radius:var(--border-radius-md);font-family:var(--font-family);cursor:pointer;transition:var(--transition-fast);background-color:#ffffff0d;align-items:center;gap:8px;padding:10px 20px;font-size:14px;font-weight:500;display:flex}.btn-secondary:hover:not(:disabled){border-color:var(--text-secondary);background-color:#ffffff14}.btn-secondary:disabled{opacity:.5;cursor:not-allowed}.transactions-section{flex-direction:column;gap:16px;display:flex}.section-title{color:var(--text-primary);align-items:center;gap:8px;font-size:20px;font-weight:600;display:flex}.table-container{background-color:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-md);overflow:hidden}.table-responsive{width:100%;overflow-x:auto}.transaction-table{border-collapse:collapse;text-align:left;width:100%;font-size:14px}.transaction-table th{color:var(--text-secondary);border-bottom:1px solid var(--border-color);background-color:#ffffff05;padding:16px 20px;font-weight:600}.transaction-table td{border-bottom:1px solid var(--border-color);vertical-align:middle;color:var(--text-primary);padding:16px 20px}.transaction-table tr:last-child td{border-bottom:none}.transaction-table tr:hover td{background-color:#ffffff03}.badge-category{border:1px solid #0000;border-radius:20px;align-items:center;gap:6px;padding:6px 12px;font-size:12px;font-weight:500;display:inline-flex}.badge-source{border:1px solid var(--border-color);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;background-color:#ffffff0d;border-radius:6px;padding:3px 8px;font-size:11px;font-weight:500;display:inline-flex}.text-amount-income{color:var(--success);font-weight:600}.text-amount-expense{color:var(--text-primary);font-weight:500}.empty-state{text-align:center;color:var(--text-secondary);flex-direction:column;align-items:center;gap:12px;padding:48px 24px;display:flex}.empty-icon{margin-bottom:8px;font-size:32px}.month-selector{scrollbar-width:none;gap:8px;padding-bottom:4px;display:flex;overflow-x:auto}.month-selector::-webkit-scrollbar{display:none}.month-btn{background:var(--bg-surface);border:1px solid var(--border-color);color:var(--text-secondary);font-family:var(--font-family);cursor:pointer;white-space:nowrap;transition:var(--transition-fast);border-radius:20px;padding:8px 18px;font-size:13px;font-weight:500}.month-btn:hover{border-color:var(--accent);color:var(--text-primary)}.month-btn-active{background:linear-gradient(135deg, var(--accent), var(--accent-dark));color:#fff;border-color:#0000;box-shadow:0 2px 12px #8b5cf659}.breakdown-section{flex-direction:column;gap:16px;display:flex}.breakdown-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px;display:grid}.breakdown-card{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--border-radius-md);flex-direction:column;gap:10px;padding:16px 20px;display:flex}.breakdown-header{justify-content:space-between;align-items:center;display:flex}.breakdown-label{color:var(--text-primary);font-size:14px;font-weight:500}.breakdown-pct{color:var(--text-secondary);font-size:13px;font-weight:600}.breakdown-bar-bg{background:#ffffff0f;border-radius:3px;width:100%;height:6px;overflow:hidden}.breakdown-bar-fill{border-radius:3px;height:100%;transition:width .4s}.breakdown-amount{color:#ef4444;font-size:18px;font-weight:700}.tx-count{color:var(--text-muted);background:#ffffff0d;border-radius:12px;margin-left:8px;padding:2px 10px;font-size:13px;font-weight:400}@media (width<=768px){.header-app{flex-direction:column;align-items:flex-start;gap:16px}.header-user{justify-content:space-between;width:100%}.control-panel{flex-direction:column;align-items:stretch}.btn-secondary{justify-content:center}}
