@import "https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700&display=swap";@import "https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.4.0/css/all.min.css";:root{--bg-color:#080b12;--panel-bg:#0f141fa6;--panel-border:#ffffff0f;--card-bg:#141b29cc;--text-main:#f8f9fa;--text-muted:#94a3b8;--primary:#0ea5e9;--primary-hover:#0284c7;--success:#10b981;--success-hover:#059669;--success-bg:#10b9811a;--danger:#ef4444;--danger-hover:#dc2626;--danger-bg:#ef44441a;--warning:#f59e0b;--warning-hover:#d97706;--font-family:"Outfit", sans-serif;--shadow-sm:0 4px 6px -1px #0000001a, 0 2px 4px -1px #0000000f;--shadow-md:0 10px 15px -3px #0000004d, 0 4px 6px -2px #00000026;--radius-md:12px;--radius-lg:16px;--radius-xl:24px;--transition:all .3s cubic-bezier(.4, 0, .2, 1)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-family);background-color:var(--bg-color);color:var(--text-main);-webkit-font-smoothing:antialiased;background-image:radial-gradient(circle at 100% 0,#0ea5e926,#0000 40%),radial-gradient(circle at 0 100%,#8b5cf61f,#0000 40%),url("data:image/svg+xml,%3Csvg width='40' height='40' viewBox='0 0 40 40' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M20 20.5V18H0v-2h20v-2H0v-2h20v-2H0V8h20V6H0V4h20V2H0V0h22v20h2V0h2v20h2V0h2v20h2V0h2v20h2V0h2v20h2v2H20v-1.5zM0 20h2v20H0V20zm4 0h2v20H4V20zm4 0h2v20H8V20zm4 0h2v20h-2V20zm4 0h2v20h-2V20zm4 4h20v2H20v-2zm0 4h20v2H20v-2zm0 4h20v2H20v-2zm0 4h20v2H20v-2z' fill='%23ffffff' fill-opacity='0.02' fill-rule='evenodd'/%3E%3C/svg%3E");background-attachment:fixed;min-height:100vh;line-height:1.5}h1,h2,h3{font-weight:600}.text-success{color:var(--success)!important}.text-danger{color:var(--danger)!important}.text-primary{color:var(--primary)!important}.text-warning{color:var(--warning)!important}.app-container{max-width:1200px;margin:0 auto;padding:2rem 1.5rem}.app-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:2.5rem;display:flex}.header-brand{align-items:center;gap:1rem;display:flex}.icon-box{background:linear-gradient(135deg, var(--primary), #8b5cf6);border-radius:var(--radius-md);color:#fff;justify-content:center;align-items:center;width:48px;height:48px;font-size:1.5rem;display:flex;box-shadow:0 0 20px #3b82f666}.header-brand h1{letter-spacing:-.5px;font-size:1.75rem}.header-actions{gap:1rem;display:flex}.btn{border-radius:var(--radius-md);font-family:var(--font-family);cursor:pointer;transition:var(--transition);border:none;justify-content:center;align-items:center;gap:.5rem;padding:.75rem 1.25rem;font-size:.95rem;font-weight:500;display:inline-flex}.btn:active{transform:scale(.98)}.btn-primary{background-color:var(--primary);color:#fff}.btn-primary:hover{background-color:var(--primary-hover);box-shadow:0 0 15px #3b82f666}.btn-success{background-color:var(--success);color:#fff}.btn-success:hover{background-color:var(--success-hover);box-shadow:0 0 15px #10b98166}.btn-danger{background-color:var(--danger);color:#fff}.btn-danger:hover{background-color:var(--danger-hover);box-shadow:0 0 15px #ef444466}.btn-export{color:#fff;background-color:#8b5cf6}.btn-export:hover{background-color:#7c3aed;box-shadow:0 0 15px #8b5cf666}.btn-secondary{color:#fff;background-color:#64748b}.btn-secondary:hover{background-color:#475569}.btn-text{color:var(--text-muted);background:0 0}.btn-text:hover{color:var(--text-main);background:#ffffff0d}.btn-small{padding:.5rem .75rem;font-size:.85rem}.btn-large{padding:1rem;font-size:1.1rem}.btn-block{width:100%}.glass-panel{background:var(--panel-bg);-webkit-backdrop-filter:blur(12px);border:1px solid var(--panel-border);border-radius:var(--radius-xl);margin-bottom:2rem;padding:1.5rem;transition:box-shadow .3s,border-color .3s;box-shadow:0 4px 30px #0000001a}.glass-panel:hover{border-color:#0ea5e94d;box-shadow:0 8px 32px #0ea5e91a}.card{background:var(--card-bg);border:1px solid var(--panel-border);border-radius:var(--radius-lg);transition:var(--transition);padding:1.5rem}.card:hover{border-color:#0ea5e966;transform:translateY(-4px);box-shadow:0 10px 25px -5px #0ea5e926}.dashboard{flex-direction:column;gap:1rem;display:flex}.goal-header{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.goal-title-area{align-items:center;gap:.75rem;display:flex}.goal-title-area h2{align-items:center;gap:.75rem;font-size:1.25rem;display:flex}.icon-circle{width:32px;height:32px;color:var(--primary);background:#3b82f626;border-radius:50%;justify-content:center;align-items:center;display:flex}.badge-month{background:#ffffff1a;border-radius:20px;padding:.2rem .6rem;font-size:.8rem;font-weight:500}.goal-info{justify-content:space-between;margin-bottom:1rem;display:flex}.goal-stat{flex-direction:column;display:flex}.goal-stat.right{align-items:flex-end}.goal-stat .label{color:var(--text-muted);margin-bottom:.25rem;font-size:.85rem}.goal-value{font-size:1.5rem;font-weight:700}.goal-diff{font-size:1.25rem;font-weight:600}.goal-progress-container{background:#ffffff0d;border-radius:10px;height:12px;margin-bottom:.75rem;overflow:hidden}.goal-progress-bar{background:linear-gradient(90deg, var(--primary), #8b5cf6);border-radius:10px;height:100%;transition:width 1s cubic-bezier(.4,0,.2,1);box-shadow:0 0 10px #3b82f680}.goal-status{color:var(--text-muted);font-size:.9rem}.summary-cards{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;margin-bottom:2rem;display:grid}.summary-card{align-items:center;gap:1.25rem;display:flex}.summary-card .card-icon{border-radius:var(--radius-md);justify-content:center;align-items:center;width:56px;height:56px;font-size:1.5rem;display:flex}.summary-card.income .card-icon{background:var(--success-bg);color:var(--success)}.summary-card.expense .card-icon{background:var(--danger-bg);color:var(--danger)}.summary-card.balance .card-icon{color:var(--primary);background:#3b82f61a}.summary-card h3{color:var(--text-muted);margin-bottom:.25rem;font-size:.9rem;font-weight:500}.summary-card .amount{font-size:1.75rem;font-weight:700}.cycles-section{grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem;margin-bottom:2rem;display:grid}.cycle-header{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.cycle-header h2{font-size:1.25rem}.badge{color:var(--primary);background:#3b82f626;border-radius:20px;padding:.25rem .75rem;font-size:.75rem;font-weight:600}.badge-secondary{color:#8b5cf6;background:#8b5cf626}.cycle-stats{flex-direction:column;gap:1rem;display:flex}.stat{justify-content:space-between;align-items:center;display:flex}.stat-label{color:var(--text-muted);align-items:center;gap:.5rem;font-size:.95rem;display:flex}.stat-value{font-size:1.1rem;font-weight:600}.stat-divider{background:var(--panel-border);height:1px;margin:.25rem 0}.stat.total .stat-label{color:var(--text-main);font-weight:500}.stat.total .stat-value{font-size:1.5rem;font-weight:700}.section-header{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.section-header h2{font-size:1.25rem}.filter-group{border-radius:var(--radius-md);border:1px solid var(--panel-border);background:#0003;align-items:center;gap:.5rem;padding:.25rem .5rem;display:flex}.select-small{color:var(--text-main);font-family:var(--font-family);cursor:pointer;background:0 0;border:none;outline:none}.select-small option{background:var(--card-bg)}.transactions-list{flex-direction:column;gap:.75rem;max-height:400px;padding-right:.5rem;display:flex;overflow-y:auto}.transactions-list::-webkit-scrollbar{width:6px}.transactions-list::-webkit-scrollbar-track{background:0 0}.transactions-list::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:10px}.transaction-item{border-radius:var(--radius-md);transition:var(--transition);background:#ffffff05;border:1px solid #ffffff0d;justify-content:space-between;align-items:center;padding:1rem;display:flex}.transaction-item:hover{background:#ffffff0d}.tx-info{align-items:center;gap:1rem;display:flex}.tx-icon{border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;font-size:1rem;display:flex}.tx-icon.income{background:var(--success-bg);color:var(--success)}.tx-icon.expense{background:var(--danger-bg);color:var(--danger)}.tx-details h4{margin-bottom:.1rem;font-size:1rem}.tx-details p{color:var(--text-muted);font-size:.8rem}.tx-meta{flex-direction:column;align-items:flex-end;display:flex}.tx-amount{font-size:1.1rem;font-weight:600}.tx-amount.positive{color:var(--success)}.tx-amount.negative{color:var(--danger)}.tx-cycle{color:var(--text-muted);background:#ffffff1a;border-radius:4px;margin-top:.25rem;padding:.1rem .4rem;font-size:.75rem}.empty-state{text-align:center;color:var(--text-muted);padding:3rem 1rem}.empty-icon{opacity:.5;margin-bottom:1rem;font-size:3rem}.empty-state span{opacity:.7;margin-top:.5rem;font-size:.85rem;display:block}.modal-overlay{-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);z-index:1000;background:#000000b3;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:var(--card-bg);border-radius:var(--radius-xl);border:1px solid var(--panel-border);width:100%;max-width:450px;animation:.3s ease-out slideUp;box-shadow:0 25px 50px -12px #00000080}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{border-bottom:1px solid var(--panel-border);justify-content:space-between;align-items:center;padding:1.5rem;display:flex}.modal-header h2{align-items:center;gap:.5rem;font-size:1.25rem;display:flex}.btn-close{color:var(--text-muted);cursor:pointer;transition:var(--transition);background:0 0;border:none;font-size:1.25rem}.btn-close:hover{color:var(--text-main)}.modal-body{padding:1.5rem}.form-group{margin-bottom:1.5rem}.form-group label{color:var(--text-main);margin-bottom:.5rem;font-size:.95rem;font-weight:500;display:block}.form-control{border:1px solid var(--panel-border);width:100%;color:var(--text-main);border-radius:var(--radius-md);font-family:var(--font-family);transition:var(--transition);background:#0003;padding:.75rem 1rem;font-size:1rem}.form-control:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 2px #3b82f633}.input-with-icon{position:relative}.currency-symbol{color:var(--text-muted);font-weight:500;position:absolute;top:50%;left:1rem;transform:translateY(-50%)}.pl-40{padding-left:2.5rem}.help-box{border-radius:var(--radius-md);color:var(--text-muted);background:#ffffff0d;align-items:flex-start;gap:.5rem;margin-top:.5rem;padding:.75rem;font-size:.85rem;display:flex}.help-box.info{color:#93c5fd;background:#3b82f61a}.radio-group{gap:1rem;display:flex}.radio-card{cursor:pointer;flex:1;position:relative}.radio-card input{opacity:0;cursor:pointer;position:absolute}.radio-content{text-align:center;border:1px solid var(--panel-border);border-radius:var(--radius-md);transition:var(--transition);background:#0003;padding:.75rem;display:block}.radio-title{font-size:.95rem;font-weight:500}.radio-card input:checked~.radio-content{border-color:var(--primary);color:var(--primary);background:#3b82f61a}@media (width<=768px){.app-header{flex-direction:column;align-items:flex-start}.header-actions{justify-content:stretch;width:100%}.header-actions .btn{flex:1}.summary-cards,.cycles-section{grid-template-columns:1fr}.login-layout{flex-direction:column}.login-left{display:none}.login-right{padding:1.5rem}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes pulseGlow{0%{box-shadow:0 0 #0ea5e966}70%{box-shadow:0 0 0 15px #0ea5e900}to{box-shadow:0 0 #0ea5e900}}@keyframes float{0%{transform:translateY(0)}50%{transform:translateY(-10px)}to{transform:translateY(0)}}@keyframes orbFloat{0%{transform:translate(0)scale(1)}33%{transform:translate(30px,-50px)scale(1.1)}66%{transform:translate(-20px,20px)scale(.9)}to{transform:translate(0)scale(1)}}.stagger-1{opacity:0;animation:.5s ease-out forwards fadeInUp}.stagger-2{opacity:0;animation:.5s ease-out .1s forwards fadeInUp}.stagger-3{opacity:0;animation:.5s ease-out .2s forwards fadeInUp}.stagger-4{opacity:0;animation:.5s ease-out .3s forwards fadeInUp}.login-layout{width:100%;min-height:100vh;display:flex}.login-left{flex-direction:column;flex:1;justify-content:center;padding:4rem;display:flex;position:relative;overflow:hidden}.login-left-content{z-index:2;animation:.8s ease-out fadeInUp;position:relative}.login-title{background:linear-gradient(135deg, #fff, var(--primary));-webkit-text-fill-color:transparent;-webkit-background-clip:text;margin-bottom:1.5rem;font-size:3.5rem;font-weight:700;line-height:1.1}.login-subtitle{color:var(--text-muted);max-width:400px;font-size:1.25rem;line-height:1.6}.orb-1,.orb-2{filter:blur(80px);z-index:1;border-radius:50%;animation:15s ease-in-out infinite orbFloat;position:absolute}.orb-1{background:#0ea5e926;width:400px;height:400px;top:-100px;left:-100px}.orb-2{background:#8b5cf626;width:300px;height:300px;animation-delay:-5s;bottom:-50px;right:10%}.login-right{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-left:1px solid var(--panel-border);background:#0f141f4d;flex:1;justify-content:center;align-items:center;padding:2rem;display:flex}.login-panel{width:100%;max-width:420px;animation:.6s ease-out fadeInUp}
