@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";:root{--wv-primary:#a855f7;--wv-primary-hover:#c084fc;--wv-primary-muted:#a855f724;--wv-primary-border:#a855f759;--wv-primary-glow:#a855f773;--wv-gradient:linear-gradient(135deg, #a855f7 0%, #6366f1 100%);--wv-gradient-hover:linear-gradient(135deg, #c084fc 0%, #818cf8 100%);--wv-on-primary:#fff;--wv-income:#4ade80;--wv-expense:#fb7185;--wv-warning:#fbbf24;--wv-danger:#f43f5e;--wv-danger-bg:#f43f5e1a;--wv-bg:#09080f;--wv-bg-soft:#110e1a;--wv-surface:#ffffff0a;--wv-surface-hover:#ffffff12;--wv-surface-elevated:#ffffff0f;--wv-border:#a855f724;--wv-border-strong:#a855f752;--wv-modal-bg:#110e1af5;--wv-overlay:#09080fc7;--wv-text:#f5f3ff;--wv-text-secondary:#a5a3b8;--wv-text-muted:#6b6880;--wv-radius-sm:12px;--wv-radius:18px;--wv-radius-lg:24px;--wv-shadow:0 8px 32px #00000073;--wv-shadow-glow:0 0 60px #a855f71f;--wv-blur:blur(20px);--wv-font:"Inter", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;--wv-font-mono:ui-monospace, "Cascadia Code", Consolas, monospace;--wv-transition:.22s cubic-bezier(.4, 0, .2, 1)}*,:before,:after{box-sizing:border-box}html{scroll-behavior:smooth}body{min-height:100vh;font-family:var(--wv-font);color:var(--wv-text);background:radial-gradient(ellipse 100% 80% at 50% -30%, #a855f714, transparent), var(--wv-bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizelegibility;margin:0;font-size:16px;line-height:1.5}#root{width:100%;min-height:100vh;text-align:initial;border:none;margin:0;display:block}h1,h2,h3,h4{font-family:var(--wv-font);color:var(--wv-text);font-weight:700;line-height:1.2}h1{letter-spacing:-.02em;font-size:2rem}h2{letter-spacing:-.01em;font-size:1.5rem}h3{font-size:1.125rem}p{margin:0}a{color:var(--wv-primary);text-decoration:none}a:hover{color:var(--wv-primary-hover)}button,input,select,textarea,button{font-family:inherit}::selection{background:var(--wv-primary-muted);color:var(--wv-text)}:focus-visible{outline:2px solid var(--wv-primary);outline-offset:2px}@media (width<=768px){body{font-size:15px}}.login-wrapper{min-height:100vh;font-family:var(--wv-font);background:radial-gradient(90% 60% at 50% -10%,#a855f738,#0000),radial-gradient(50% 40% at 85% 90%,#6366f11a,#0000),linear-gradient(160deg,#06050c 0%,#110e1a 45%,#06050c 100%);justify-content:center;align-items:center;padding:24px;display:flex}.login-card{border:1px solid var(--wv-border-strong);border-radius:var(--wv-radius-lg);width:100%;max-width:420px;-webkit-backdrop-filter:var(--wv-blur);backdrop-filter:var(--wv-blur);box-shadow:var(--wv-shadow), var(--wv-shadow-glow);background:#ffffff08;padding:48px 40px;animation:.45s cubic-bezier(.4,0,.2,1) login-enter}@keyframes login-enter{0%{opacity:0;transform:translateY(24px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}.login-logo{align-items:center;gap:12px;margin-bottom:36px;display:flex}.logo-icon{filter:drop-shadow(0 0 16px var(--wv-primary-glow));font-size:28px}.logo-text{background:var(--wv-gradient);-webkit-text-fill-color:transparent;letter-spacing:-.02em;-webkit-background-clip:text;background-clip:text;font-size:22px;font-weight:700}.login-title{color:var(--wv-text);letter-spacing:-.02em;margin:0 0 8px;font-size:26px;font-weight:700}.login-subtitle{color:var(--wv-text-muted);margin:0 0 32px;font-size:14px;line-height:1.5}.login-error{background:var(--wv-danger-bg);color:#fda4af;border-radius:var(--wv-radius-sm);border:1px solid #f43f5e4d;margin-bottom:20px;padding:12px 16px;font-size:14px}.login-field{flex-direction:column;gap:8px;margin-bottom:20px;display:flex}.login-field label{color:var(--wv-text-muted);letter-spacing:.06em;text-transform:uppercase;font-size:12px;font-weight:600}.login-field input{background:var(--wv-surface);border:1px solid var(--wv-border);border-radius:var(--wv-radius-sm);color:var(--wv-text);transition:border-color var(--wv-transition), box-shadow var(--wv-transition), background var(--wv-transition);outline:none;padding:14px 16px;font-size:15px}.login-field input::placeholder{color:#524d66}.login-field input:hover{background:var(--wv-surface-hover);border-color:var(--wv-primary-border)}.login-field input:focus{border-color:var(--wv-primary);box-shadow:0 0 0 3px var(--wv-primary-muted);background:var(--wv-surface-hover)}.login-btn{background:var(--wv-gradient);border-radius:var(--wv-radius-sm);width:100%;color:var(--wv-on-primary);cursor:pointer;transition:background var(--wv-transition), transform var(--wv-transition), box-shadow var(--wv-transition);border:none;margin-top:8px;padding:15px;font-size:16px;font-weight:700;box-shadow:0 4px 20px #a855f759}.login-btn:hover:not(:disabled){background:var(--wv-gradient-hover);transform:translateY(-2px);box-shadow:0 8px 28px #a855f773}.login-btn:active:not(:disabled){transform:translateY(0)}.login-btn:disabled{opacity:.45;cursor:not-allowed;box-shadow:none;transform:none}@media (width<=480px){.login-card{padding:36px 24px}.login-title{font-size:22px}}.modal-overlay{background:var(--wv-overlay);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1000;justify-content:center;align-items:center;padding:20px;animation:.2s ease-out wv-modal-fade;display:flex;position:fixed;inset:0}.modal-overlay>.modal-content{background:var(--wv-modal-bg);border:1px solid var(--wv-border-strong);border-radius:var(--wv-radius);width:100%;max-width:420px;box-shadow:var(--wv-shadow), var(--wv-shadow-glow);text-align:left;padding:28px;animation:.28s cubic-bezier(.4,0,.2,1) wv-modal-slide}.modal-overlay>.modal-content>button:first-child{background:var(--wv-surface);border:1px solid var(--wv-border);color:var(--wv-text-muted);cursor:pointer;float:right;border-radius:var(--wv-radius-sm);width:34px;height:34px;transition:background var(--wv-transition), color var(--wv-transition), border-color var(--wv-transition);justify-content:center;align-items:center;font-size:14px;display:flex}.modal-overlay>.modal-content>button:first-child:hover{background:var(--wv-surface-hover);color:var(--wv-text);border-color:var(--wv-border-strong)}.modal-close{background:var(--wv-surface);border:1px solid var(--wv-border);color:var(--wv-text-muted);cursor:pointer;float:right;border-radius:var(--wv-radius-sm);width:34px;height:34px;transition:background var(--wv-transition), color var(--wv-transition);justify-content:center;align-items:center;font-size:16px;display:flex}.modal-close:hover{background:var(--wv-surface-hover);color:var(--wv-text);border-color:var(--wv-border-strong)}.modal-tabs{clear:both;background:var(--wv-surface);border-radius:var(--wv-radius-sm);border:1px solid var(--wv-border);gap:6px;margin-bottom:22px;padding:4px;display:flex}.modal-tabs button{color:var(--wv-text-muted);cursor:pointer;transition:all var(--wv-transition);background:0 0;border:none;border-radius:8px;flex:1;padding:11px;font-size:14px;font-weight:600}.modal-tabs button:hover:not(.active){color:var(--wv-text-secondary);background:var(--wv-surface-hover)}.modal-tabs button.active{background:var(--wv-gradient);color:var(--wv-on-primary);box-shadow:0 2px 12px #a855f759}.modal-form{flex-direction:column;gap:14px;display:flex}.modal-form input,.modal-form select{border:1px solid var(--wv-border);border-radius:var(--wv-radius-sm);background:var(--wv-surface);color:var(--wv-text);transition:border-color var(--wv-transition), box-shadow var(--wv-transition);outline:none;padding:13px 16px;font-size:15px}.modal-form input::placeholder{color:var(--wv-text-muted)}.modal-form select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23a855f7' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-position:right 14px center;background-repeat:no-repeat;padding-right:36px}.modal-form select option{background:var(--wv-bg-soft);color:var(--wv-text)}.modal-form input:focus,.modal-form select:focus{border-color:var(--wv-primary);box-shadow:0 0 0 3px var(--wv-primary-muted)}.modal-form input[type=date]::-webkit-calendar-picker-indicator{filter:invert(.6)sepia()saturate(3)hue-rotate(230deg);cursor:pointer}.modal-form button,.modal-submit{border-radius:var(--wv-radius-sm);background:var(--wv-gradient);color:var(--wv-on-primary);cursor:pointer;transition:background var(--wv-transition), opacity var(--wv-transition), box-shadow var(--wv-transition);border:none;margin-top:6px;padding:14px;font-size:15px;font-weight:700;box-shadow:0 4px 20px #a855f74d}.modal-form button:hover:not(:disabled),.modal-submit:hover:not(:disabled){background:var(--wv-gradient-hover);box-shadow:0 6px 24px #a855f766}.modal-form button:disabled,.modal-submit:disabled{opacity:.45;cursor:not-allowed;box-shadow:none}@keyframes wv-modal-fade{0%{opacity:0}to{opacity:1}}@keyframes wv-modal-slide{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media (width<=480px){.modal-overlay>.modal-content{padding:22px 18px}}.dashboard{background:radial-gradient(ellipse 80% 50% at 50% -20%, #a855f729, transparent), radial-gradient(ellipse 60% 40% at 100% 100%, #6366f114, transparent), var(--wv-bg);max-width:960px;min-height:100vh;margin:0 auto;padding:40px 24px 56px}.dashboard-loading{min-height:100vh;color:var(--wv-text-secondary);justify-content:center;align-items:center;font-size:15px;animation:1.4s ease-in-out infinite wv-pulse;display:flex}@keyframes wv-pulse{0%,to{opacity:.5}50%{opacity:1}}.dashboard-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;margin-bottom:28px;display:flex}.dashboard-title{letter-spacing:-.02em;background:var(--wv-gradient);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin:0;font-size:28px;font-weight:700}.dashboard-actions{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.dashboard-actions button{background:var(--wv-gradient);color:var(--wv-on-primary);border-radius:var(--wv-radius-sm);cursor:pointer;transition:background var(--wv-transition), transform var(--wv-transition), box-shadow var(--wv-transition);border:none;padding:12px 20px;font-size:14px;font-weight:700;box-shadow:0 4px 20px #a855f759}.dashboard-actions button:hover{background:var(--wv-gradient-hover);transform:translateY(-2px);box-shadow:0 8px 28px #a855f773}.dashboard-actions button.active{box-shadow:0 0 0 3px var(--wv-primary-muted), 0 8px 28px #a855f759}.dashboard .categories-btn{color:var(--wv-primary-hover);border:1px solid var(--wv-primary-border);border-radius:var(--wv-radius-sm);transition:background var(--wv-transition), border-color var(--wv-transition), color var(--wv-transition);background:0 0;justify-content:center;align-items:center;padding:12px 20px;font-size:14px;font-weight:600;text-decoration:none;display:inline-flex}.dashboard .categories-btn:hover{background:var(--wv-primary-muted);border-color:var(--wv-border-strong);color:var(--wv-text)}.summary-cards{grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:36px;display:grid}.dashboard .card{background:var(--wv-surface);border:1px solid var(--wv-border);border-radius:var(--wv-radius);text-align:left;-webkit-backdrop-filter:var(--wv-blur);backdrop-filter:var(--wv-blur);box-shadow:var(--wv-shadow);transition:border-color var(--wv-transition), transform var(--wv-transition), box-shadow var(--wv-transition);padding:24px;position:relative;overflow:hidden}.dashboard .card:after{content:"";pointer-events:none;background:radial-gradient(circle at 100% 0,#a855f70f,#0000 60%);position:absolute;inset:0}.dashboard .card:before{content:"";opacity:.85;height:3px;position:absolute;top:0;left:0;right:0}.dashboard .card-income:before,.dashboard .card-balance:before{background:var(--wv-income)}.dashboard .card-expense:before{background:var(--wv-expense)}.dashboard .card:hover{border-color:var(--wv-border-strong);box-shadow:var(--wv-shadow), var(--wv-shadow-glow);transform:translateY(-3px)}.dashboard .card h3{letter-spacing:.08em;text-transform:uppercase;color:var(--wv-text-muted);margin:0 0 12px;font-size:12px;font-weight:600}.dashboard .card p{font-size:28px;font-weight:700;font-family:var(--wv-font-mono);letter-spacing:-.02em;margin:0}.dashboard .card-income p,.dashboard .card-balance p{color:var(--wv-income)}.dashboard .card-expense p{color:var(--wv-expense)}.transactions{background:var(--wv-surface);border:1px solid var(--wv-border);border-radius:var(--wv-radius);-webkit-backdrop-filter:var(--wv-blur);backdrop-filter:var(--wv-blur);padding:24px}.transactions-title{color:var(--wv-text);margin:0 0 20px;font-size:18px;font-weight:700}.transactions-empty{color:var(--wv-text-muted);padding:16px 0;font-size:14px}.transactions-list{flex-direction:column;gap:10px;margin:0;padding:0;list-style:none;display:flex}.transaction-item{border:1px solid var(--wv-border);border-radius:var(--wv-radius-sm);transition:border-color var(--wv-transition), background var(--wv-transition);background:#ffffff05;justify-content:space-between;align-items:center;gap:16px;padding:14px 16px;display:flex}.transaction-item:hover{background:var(--wv-surface-hover);border-color:var(--wv-border-strong)}.transaction-info{flex-direction:column;gap:4px;min-width:0;display:flex}.transaction-description{color:var(--wv-text);white-space:nowrap;text-overflow:ellipsis;font-size:15px;font-weight:500;overflow:hidden}.transaction-date{color:var(--wv-text-muted);font-size:12px}.transaction-amount{font-size:15px;font-weight:700;font-family:var(--wv-font-mono);flex-shrink:0}.transaction-income .transaction-amount{color:var(--wv-income)}.transaction-expense .transaction-amount{color:var(--wv-expense)}@media (width<=768px){.dashboard{padding:28px 16px 40px}.summary-cards{grid-template-columns:1fr;gap:14px}.dashboard .card p,.dashboard-title{font-size:24px}}.list-categories{background:radial-gradient(ellipse 70% 45% at 50% -15%, #a855f724, transparent), radial-gradient(ellipse 40% 30% at 100% 80%, #6366f112, transparent), var(--wv-bg);max-width:640px;min-height:100vh;margin:0 auto;padding:40px 24px 100px}.back-btn{color:var(--wv-text-secondary);border-radius:var(--wv-radius-sm);transition:color var(--wv-transition), background var(--wv-transition), border-color var(--wv-transition);border:1px solid #0000;align-items:center;gap:6px;margin-bottom:20px;padding:8px 14px;font-size:14px;font-weight:500;text-decoration:none;display:inline-flex}.back-btn:hover{color:var(--wv-primary-hover);background:var(--wv-primary-muted);border-color:var(--wv-border)}.list-categories h2{color:var(--wv-text);letter-spacing:-.02em;margin:0 0 8px;font-size:28px;font-weight:700}.list-categories>p{color:var(--wv-text-secondary);padding:32px 0;font-size:15px}.list-categories ul{flex-direction:column;gap:10px;margin:28px 0 0;padding:0;list-style:none;display:flex}.list-categories li{background:var(--wv-surface);border:1px solid var(--wv-border);border-radius:var(--wv-radius-sm);color:var(--wv-text);-webkit-backdrop-filter:var(--wv-blur);backdrop-filter:var(--wv-blur);transition:border-color var(--wv-transition), background var(--wv-transition), transform var(--wv-transition), box-shadow var(--wv-transition);align-items:center;gap:14px;padding:16px 20px;font-size:15px;font-weight:500;display:flex}.list-categories li:before{content:"";background:var(--wv-gradient);width:8px;height:8px;box-shadow:0 0 10px var(--wv-primary-glow);border-radius:50%;flex-shrink:0}.list-categories li:hover{background:var(--wv-surface-hover);border-color:var(--wv-border-strong);transform:translate(4px);box-shadow:0 4px 20px #a855f71a}.new-category-btn{background:var(--wv-gradient);color:var(--wv-on-primary);cursor:pointer;transition:background var(--wv-transition), transform var(--wv-transition), box-shadow var(--wv-transition);z-index:10;border:none;border-radius:999px;padding:16px 32px;font-size:15px;font-weight:700;position:fixed;bottom:28px;left:50%;transform:translate(-50%);box-shadow:0 8px 32px #a855f766}.new-category-btn:hover{background:var(--wv-gradient-hover);transform:translate(-50%)translateY(-3px);box-shadow:0 14px 40px #a855f780}@media (width<=768px){.list-categories{padding:28px 16px 96px}.list-categories h2{font-size:24px}}.modal{background:var(--wv-overlay);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1000;justify-content:center;align-items:center;padding:20px;animation:.2s ease-out wv-fade-in;display:flex;position:fixed;inset:0}.modal>.modal-content{background:var(--wv-modal-bg);border:1px solid var(--wv-border-strong);border-radius:var(--wv-radius);width:100%;max-width:420px;box-shadow:var(--wv-shadow), var(--wv-shadow-glow);text-align:left;padding:28px;animation:.28s cubic-bezier(.4,0,.2,1) wv-slide-up}.modal>.modal-content h2{color:var(--wv-text);margin:0 0 24px;font-size:20px;font-weight:700}.modal>.modal-content form{flex-direction:column;gap:18px;display:flex}.modal>.modal-content label{letter-spacing:.06em;text-transform:uppercase;color:var(--wv-text-muted);flex-direction:column;gap:8px;font-size:12px;font-weight:600;display:flex}.modal>.modal-content input{background:var(--wv-surface);border:1px solid var(--wv-border);border-radius:var(--wv-radius-sm);color:var(--wv-text);transition:border-color var(--wv-transition), box-shadow var(--wv-transition);outline:none;padding:13px 16px;font-size:15px}.modal>.modal-content input::placeholder{color:var(--wv-text-muted)}.modal>.modal-content input:focus{border-color:var(--wv-primary);box-shadow:0 0 0 3px var(--wv-primary-muted)}.modal>.modal-content button[type=submit]{background:var(--wv-gradient);color:var(--wv-on-primary);border-radius:var(--wv-radius-sm);cursor:pointer;transition:background var(--wv-transition), opacity var(--wv-transition), box-shadow var(--wv-transition);border:none;margin-top:4px;padding:14px;font-size:15px;font-weight:700;box-shadow:0 4px 20px #a855f74d}.modal>.modal-content button[type=submit]:hover:not(:disabled){background:var(--wv-gradient-hover);box-shadow:0 6px 24px #a855f766}.modal>.modal-content button[type=submit]:disabled{opacity:.45;cursor:not-allowed;box-shadow:none}@keyframes wv-fade-in{0%{opacity:0}to{opacity:1}}@keyframes wv-slide-up{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
