@import "https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700&family=Prompt:wght@200;300;400;500;600;700&display=swap";@layer reset{*,:before,:after{box-sizing:border-box;margin:0;padding:0}}@layer base{:root{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark}body{font-family:var(--font-sans);background-color:var(--bg-main);color:var(--text-primary);min-height:100dvh;line-height:1.5;position:relative;overflow-x:hidden}button:focus-visible,a:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:2px solid hsl(var(--color-accent));outline-offset:4px}button:focus:not(:focus-visible),input:focus:not(:focus-visible),select:focus:not(:focus-visible){outline:none}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:#ffffff05}::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:4px;transition:background .3s}::-webkit-scrollbar-thumb:hover{background:#ffffff4d}*{scrollbar-color:#ffffff26 #ffffff05;scrollbar-width:thin}}@layer theme{:root{--font-sans:"Prompt", "Outfit", system-ui, -apple-system, sans-serif;--bg-main:#0b0f19;--text-primary:#f3f4f6;--text-secondary:#9ca3af;--text-muted:#6b7280;--color-income:142 76% 45%;--color-expense:350 89% 60%;--color-accent:262 83% 58%;--color-accent-rgb:139, 92, 246;--glass-bg:#1118278c;--glass-border:#ffffff14;--glass-shadow:#00000059;--radius-lg:24px;--radius-md:16px;--radius-sm:8px}}@layer components{.bg-mesh{z-index:-10;pointer-events:none;width:100vw;height:100vh;position:fixed;top:0;left:0;overflow:hidden}.glow-circle{filter:blur(120px);opacity:.45;mix-blend-mode:screen;will-change:transform;border-radius:50%;position:absolute}.glow-1{aspect-ratio:1;background:radial-gradient(circle, hsl(var(--color-accent) / .7) 0%, transparent 70%);width:min(500px,90vw);animation:25s ease-in-out infinite alternate float1;top:-10%;left:-10%}.glow-2{aspect-ratio:1;background:radial-gradient(circle, hsla(var(--color-income) / .5) 0%, transparent 70%);width:min(600px,100vw);animation:30s ease-in-out infinite alternate float2;bottom:-15%;right:-10%}.glow-3{aspect-ratio:1;background:radial-gradient(circle, hsla(var(--color-expense) / .55) 0%, transparent 70%);width:min(400px,80vw);animation:22s ease-in-out infinite alternate float3;top:40%;left:55%}@keyframes float1{0%{transform:translate(0)scale(1)}50%{transform:translate(100px,80px)scale(1.15)}to{transform:translate(-50px,120px)scale(.9)}}@keyframes float2{0%{transform:translate(0)scale(1.1)}50%{transform:translate(-120px,-60px)scale(.85)}to{transform:translate(80px,80px)scale(1.05)}}@keyframes float3{0%{transform:translate(0)scale(.9)}50%{transform:translate(60px,-90px)scale(1.1)}to{transform:translate(-100px,50px)scale(.95)}}.app-container{z-index:1;max-width:1280px;margin:0 auto;padding:2rem 1.5rem;position:relative}.app-header{background:var(--glass-bg);-webkit-backdrop-filter:blur(24px)saturate(180%);border:1px solid var(--glass-border);border-radius:var(--radius-md);box-shadow:0 8px 32px 0 var(--glass-shadow);justify-content:space-between;align-items:center;margin-bottom:2rem;padding:1.25rem 2rem;display:flex}.logo-area{align-items:center;gap:.75rem;display:flex}.logo-icon{background:linear-gradient(135deg, hsl(var(--color-income)), hsl(var(--color-accent)));-webkit-text-fill-color:transparent;filter:drop-shadow(0 2px 8px rgba(var(--color-accent-rgb), .3));-webkit-background-clip:text;font-size:2.25rem;font-weight:800}.logo-text{letter-spacing:-.5px;background:linear-gradient(90deg,#fff,#d1d5db);-webkit-text-fill-color:transparent;-webkit-background-clip:text;font-size:1.5rem;font-weight:700}.logo-sub{color:var(--text-secondary);margin-top:-2px;font-size:.75rem;font-weight:300;display:block}.balance-card{background:radial-gradient(circle at top right, #ffffff0d, transparent), var(--glass-bg);-webkit-backdrop-filter:blur(20px)saturate(180%);border:1px solid var(--glass-border);border-radius:var(--radius-lg);box-shadow:0 10px 40px 0 var(--glass-shadow);grid-template-columns:1fr;gap:1.5rem;margin-bottom:2rem;padding:2.25rem;display:grid}@media (width>=768px){.balance-card{grid-template-columns:1.2fr 1fr 1fr;align-items:center;gap:2.5rem}}.balance-primary{border-bottom:1px solid #ffffff0f;padding-bottom:1rem}@media (width>=768px){.balance-primary{border-bottom:none;padding-bottom:0;border-inline-end:1px solid #ffffff14;padding-inline-end:2.5rem}}.balance-title{color:var(--text-secondary);text-transform:uppercase;letter-spacing:1px;margin-bottom:.25rem;font-size:.875rem;font-weight:500}.balance-value{font-feature-settings:"tnum";letter-spacing:-1px;color:#fff;text-shadow:0 0 30px #ffffff1a;font-size:clamp(2rem,3.5vw,2.75rem);font-weight:700}.balance-stat{align-items:center;gap:1rem;padding:.5rem 0;display:flex}.stat-icon{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;font-size:1.25rem;display:flex}.stat-icon.income{color:hsl(var(--color-income));background:#10b9811f;border:1px solid #10b98140}.stat-icon.expense{color:hsl(var(--color-expense));background:#f43f5e1f;border:1px solid #f43f5e40}.stat-info{flex-direction:column;display:flex}.stat-label{color:var(--text-secondary);font-size:.825rem}.stat-number{font-feature-settings:"tnum";color:#fff;font-size:1.35rem;font-weight:600}.grid-layout{grid-template-columns:1fr;align-items:start;gap:2rem;display:grid}@media (width>=1024px){.grid-layout{grid-template-columns:1.1fr 1.9fr}}.glass-card{background:var(--glass-bg);-webkit-backdrop-filter:blur(20px)saturate(180%);border:1px solid var(--glass-border);border-radius:var(--radius-md);box-shadow:0 8px 32px 0 var(--glass-shadow);padding:1.75rem;transition:transform .3s cubic-bezier(.16,1,.3,1),border-color .3s,box-shadow .3s;overflow:hidden}.glass-card:hover{border-color:#ffffff1f;box-shadow:0 16px 48px #00000073}.card-title{color:#fff;border-bottom:1px solid #ffffff0f;align-items:center;gap:.5rem;margin-bottom:1.5rem;padding-bottom:.75rem;font-size:1.2rem;font-weight:600;display:flex}.card-title:before{content:"";background:linear-gradient(to bottom, hsl(var(--color-accent)), hsl(var(--color-income)));border-radius:3px;width:6px;height:1.25rem;display:inline-block}.form-group{flex-direction:column;gap:.5rem;margin-bottom:1.25rem;display:flex}.form-label{color:var(--text-primary);font-size:.875rem;font-weight:500}.input-control{border-radius:var(--radius-sm);color:#fff;background:#ffffff0a;border:1px solid #ffffff14;width:100%;padding:.75rem 1rem;font-family:inherit;font-size:.95rem;transition:all .2s ease-in-out}.input-control:hover{background:#ffffff0f;border-color:#ffffff26}.input-control:focus{border-color:hsl(var(--color-accent) / .6);box-shadow:0 0 0 3px hsl(var(--color-accent) / .15);background:#ffffff14;outline:none}.input-control:user-invalid{border-color:hsl(var(--color-expense) / .7);box-shadow:0 0 0 3px hsl(var(--color-expense) / .15)}.input-control:user-valid:not(:placeholder-shown){border-color:hsl(var(--color-income) / .6)}.type-selector{border-radius:var(--radius-sm);background:#ffffff08;border:1px solid #ffffff0d;grid-template-columns:1fr 1fr;gap:.75rem;margin-bottom:1.5rem;padding:4px;display:grid}.type-option{cursor:pointer;text-align:center;position:relative}.type-option input{opacity:0;cursor:pointer;width:0;height:0;position:absolute}.type-label{border-radius:calc(var(--radius-sm) - 2px);color:var(--text-secondary);-webkit-user-select:none;user-select:none;padding:.6rem 1rem;font-size:.95rem;font-weight:600;transition:all .25s cubic-bezier(.16,1,.3,1);display:block}.type-option:has(input[value=income]:checked) .type-label{color:#34d399;text-shadow:0 0 10px #34d3994d;background:#10b98126;border:1px solid #10b9814d}.type-option:has(input[value=expense]:checked) .type-label{color:#fb7185;text-shadow:0 0 10px #fb71854d;background:#f43f5e26;border:1px solid #f43f5e4d}.type-option:hover .type-label{color:#fff;background:#ffffff0d}.btn{border-radius:var(--radius-sm);cursor:pointer;-webkit-user-select:none;user-select:none;text-shadow:0 1px 2px #0003;border:none;justify-content:center;align-items:center;width:100%;padding:.8rem 1.5rem;font-family:inherit;font-size:1rem;font-weight:600;transition:all .3s cubic-bezier(.16,1,.3,1);display:inline-flex}.btn-primary{background:linear-gradient(135deg, hsl(var(--color-accent)), hsl(var(--color-accent) / .85));color:#fff;border:1px solid #ffffff1a;box-shadow:0 4px 15px #8b5cf64d}.btn-primary:hover:not(:disabled){filter:brightness(1.1);transform:translateY(-2px);box-shadow:0 6px 20px #8b5cf673}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-primary:disabled{opacity:.5;cursor:not-allowed;box-shadow:none}.btn-secondary{color:#fff;background:#ffffff0d;border:1px solid #ffffff14}.btn-secondary:hover{background:#ffffff1a;border-color:#ffffff26}.period-selector{border-radius:var(--radius-sm);background:#ffffff08;border:1px solid #ffffff0d;gap:.5rem;margin-bottom:1.5rem;padding:4px;display:flex}.period-btn{color:var(--text-secondary);border-radius:calc(var(--radius-sm) - 2px);cursor:pointer;background:0 0;border:none;flex:1;padding:.45rem .75rem;font-family:inherit;font-size:.875rem;font-weight:500;transition:all .2s}.period-btn:hover{color:#fff;background:#ffffff0a}.period-btn.active{color:#fff;background:#ffffff14;border:1px solid #ffffff14;font-weight:600}.chart-wrapper{width:100%;min-height:280px;max-height:340px;margin-bottom:1rem;position:relative}.list-filters{flex-wrap:wrap;gap:.75rem;margin-bottom:1.25rem;display:flex}.search-box{flex:1;min-width:180px}.filter-select{min-width:130px}.transaction-list{flex-direction:column;gap:.75rem;max-height:480px;padding-inline-end:4px;display:flex;overflow-y:auto}.transaction-item{border-radius:var(--radius-sm);background:#ffffff05;border:1px solid #ffffff0a;grid-template-columns:auto 1fr auto;align-items:center;gap:1rem;padding:.9rem 1.25rem;transition:all .25s cubic-bezier(.16,1,.3,1);display:grid}.transaction-item:hover{background:#ffffff0d;border-color:#ffffff14;transform:translate(4px)}.transaction-icon{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:42px;height:42px;font-size:1.2rem;display:flex}.transaction-item.income .transaction-icon{color:hsl(var(--color-income));background:#10b98114;border:1px solid #10b98126}.transaction-item.expense .transaction-icon{color:hsl(var(--color-expense));background:#f43f5e14;border:1px solid #f43f5e26}.transaction-details{flex-direction:column;min-width:0;display:flex}.transaction-title{color:#fff;white-space:nowrap;text-overflow:ellipsis;font-size:.95rem;font-weight:500;overflow:hidden}.transaction-meta{color:var(--text-secondary);align-items:center;gap:.5rem;margin-top:2px;font-size:.75rem;display:flex}.category-tag{background:#ffffff0f;border:1px solid #ffffff0a;border-radius:4px;padding:1px 6px;font-size:.7rem}.transaction-value{font-feature-settings:"tnum";text-align:right;flex-direction:column;align-items:flex-end;font-size:1.05rem;font-weight:600;display:flex}.transaction-item.income .transaction-value{color:hsl(var(--color-income))}.transaction-item.expense .transaction-value{color:hsl(var(--color-expense))}.delete-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;margin-top:4px;font-size:.75rem;transition:color .2s}.delete-btn:hover{color:hsl(var(--color-expense))}.empty-state{color:var(--text-secondary);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:.75rem;padding:3rem 1.5rem;display:flex}.empty-icon{opacity:.5;font-size:2.5rem}.category-section{grid-template-columns:1fr;gap:1.5rem;margin-top:2rem;display:grid}@media (width>=768px){.category-section{grid-template-columns:1.2fr 1.8fr}}.cat-item{border-radius:var(--radius-sm);background:#ffffff05;border:1px solid #ffffff0a;justify-content:space-between;align-items:center;padding:.65rem 1rem;display:flex}.cat-info{align-items:center;gap:.5rem;display:flex}.cat-dot{border-radius:50%;width:10px;height:10px}.cat-delete{color:var(--text-muted);cursor:pointer;background:0 0;border:none;transition:color .2s}.cat-delete:hover{color:hsl(var(--color-expense))}.cat-grid{flex-direction:column;gap:.5rem;max-height:250px;padding-inline-end:4px;display:flex;overflow-y:auto}}@layer utilities{.flex-row-between{justify-content:space-between;align-items:center;display:flex}.text-income{color:hsl(var(--color-income))}.text-expense{color:hsl(var(--color-expense))}.text-accent{color:hsl(var(--color-accent))}.text-muted{color:var(--text-muted)}.margin-top-md{margin-top:1.5rem}.scroll-y{overflow-y:auto}}
