code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}body,html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:#333;color:var(--text-primary-color);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0;transition:background-color .3s,color .3s}.auth-page-container,.login-page-container{align-items:center;background-image:url(../../static/media/background.b1b0d6548ff3164e0ae5.jpg);background-position:50%;background-size:cover;box-sizing:border-box;display:flex;justify-content:center;min-height:100dvh;overflow-x:hidden;padding:20px;position:relative}.auth-form-container,.login-form-container{align-items:center;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);background:#ffffffe6;border:1px solid #ffffff2e;border-radius:20px;box-shadow:0 8px 32px 0 #1f26875e;display:flex;flex-direction:column;justify-content:center;margin:20px auto;max-width:420px;padding:40px;position:relative;text-align:center;width:100%;z-index:1}.form-flipper{min-height:420px}.form-wrapper{inset:0}.form-wrapper:not(.active){pointer-events:none}.auth-form,.login-form,.multi-step-form{display:flex;flex-direction:column;gap:15px;margin-top:20px;width:100%}.auth-form input,.login-form input,.multi-step-form input,.multi-step-form select{background:#fff;border:1px solid #ddd;border-radius:8px;box-sizing:border-box;font-size:16px;padding:12px 15px;width:100%}.auth-form .submit-button,.submit-button{background:linear-gradient(90deg,#2dd4bf,#34d399);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:16px;font-weight:700;padding:12px;transition:transform .2s}.auth-form .submit-button:hover,.submit-button:hover{transform:scale(1.03)}.auth-form .submit-button:disabled,.submit-button:disabled{cursor:not-allowed;opacity:.6;transform:none}.auth-links,.login-links{display:flex;justify-content:space-between;margin-top:20px;width:100%}.auth-links .link-button,.auth-links a,.login-links .link-button,.login-links a{background:none;border:0;color:#555;cursor:pointer;font-weight:500;font:inherit;padding:0;text-decoration:none}.auth-links .link-button:hover,.auth-links a:hover,.login-links .link-button:hover,.login-links a:hover{text-decoration:underline}.message-container{margin:15px 0;min-height:20px;width:100%}.info-banner{background:linear-gradient(135deg,#e3f2fd,#f0f8ff);border:1px solid #2196f3;border-radius:8px;margin:15px 0 10px;padding:12px 15px;text-align:center}.info-banner p{color:#1565c0;font-size:14px;font-weight:500;margin:0}[data-theme=dark] .info-banner{background:linear-gradient(135deg,#0d1b2a,#1a2332);border-color:#3b82f6}[data-theme=dark] .info-banner p{color:#60a5fa}.duplicate-email-options{background:linear-gradient(135deg,#fff3cd,#fef9e7);border:1px solid #f5c842;border-radius:10px;margin-top:15px;padding:15px;text-align:center}.duplicate-email-options p{color:#8a6d00;font-size:14px;font-weight:500;margin:0 0 12px}.duplicate-email-actions{display:flex;flex-wrap:wrap;gap:10px;justify-content:center}.link-button{align-items:center;background:#007bff;border:none;border-radius:6px;color:#fff;cursor:pointer;display:inline-flex;font-size:13px;font-weight:500;gap:5px;padding:8px 16px;text-decoration:none;transition:all .2s}.link-button:hover{background:#0056b3;transform:translateY(-1px)}[data-theme=dark] .duplicate-email-options{background:linear-gradient(135deg,#2d2a24,#3a3529);border-color:#d4a853}[data-theme=dark] .duplicate-email-options p{color:#f4d03f}.error-message{font-size:14px;margin:10px 0;padding:10px}.success-message{animation:successPulse .5s ease-out;border:2px solid #28a745;border-radius:12px;box-shadow:0 4px 12px #28a74533;font-size:15px;font-weight:500;line-height:1.4;margin:15px 0;padding:15px 20px;text-align:center}@keyframes successPulse{0%{opacity:0;transform:scale(.95)}50%{transform:scale(1.02)}to{opacity:1;transform:scale(1)}}[data-theme=dark] .success-message{background-color:#064e3b;border-color:#10b981;box-shadow:0 4px 12px #10b9814d;color:#4ade80}.form-step .password-input-container{width:100%}@media (max-width:768px){.auth-page-container,.login-page-container{align-items:center;justify-content:center;min-height:100dvh;padding:15px}.auth-form-container,.login-form-container{box-shadow:0 8px 32px 0 #1f26875e;margin:0;max-width:100%;padding:30px 25px;width:100%}.logo-img{margin-bottom:1.2rem;width:65px}.form-wrapper h2{font-size:1.3rem;line-height:1.4;margin-bottom:15px}.auth-form,.login-form,.multi-step-form{gap:18px;margin-top:20px}.auth-form input,.login-form input,.multi-step-form input,.multi-step-form select{font-size:16px;margin-bottom:5px;padding:16px 15px}.auth-form .submit-button,.submit-button{font-size:16px;margin-top:8px;padding:16px}.form-step .password-input-container,.password-input-container{width:100%}.auth-links,.login-links{align-items:center;flex-direction:column;gap:15px;margin-top:25px}}@media (max-width:480px){.auth-page-container,.login-page-container{align-items:center;justify-content:center;min-height:100dvh;padding:10px}.auth-form-container,.login-form-container{border-radius:18px;box-shadow:0 8px 32px 0 #1f268766;margin:0;max-width:100%;padding:25px 20px;width:100%}.logo-img{margin-bottom:1rem;width:55px}.form-wrapper h2{font-size:1.1rem;line-height:1.3;margin-bottom:12px}.auth-form,.login-form,.multi-step-form{gap:20px;margin-top:18px}.auth-form input,.login-form input,.multi-step-form input,.multi-step-form select{font-size:16px;margin-bottom:3px;padding:14px 12px}.auth-form .submit-button,.submit-button{font-size:16px;margin-top:5px;padding:15px}.form-step{margin-bottom:15px}.login-links{gap:8px;margin-top:15px}}.modal-backdrop{animation:fadeIn .3s ease-out;background-color:#0009}.modal-content{animation:scaleUp .3s ease-out;background-color:var(--card-bg-color);box-shadow:0 5px 25px #0003;color:var(--text-primary-color);max-width:450px;transition:background-color .3s,color .3s}.modal-content h2{margin-top:0;text-align:center}.form-step label{color:var(--text-secondary-color)}.form-step input,.form-step select{background-color:var(--input-bg-color);border:1px solid var(--border-color);border-radius:8px;box-sizing:border-box;color:var(--text-primary-color);font-size:16px;padding:12px 15px;text-align:center;width:100%}.progress-bar-container{background-color:var(--border-color);width:100%}.form-step .submit-button{margin-top:10px}.modal-nav-buttons{display:flex;gap:10px;justify-content:space-between;margin-top:20px;width:100%}.btn-secondary{background-color:initial;border:1px solid var(--border-color);border-radius:8px;color:var(--text-secondary-color);cursor:pointer;flex-grow:1;font-size:1rem;font-weight:700;padding:12px;transition:background-color .2s,color .2s}.btn-secondary:hover{background-color:var(--input-bg-color);color:var(--text-primary-color)}@keyframes scaleUp{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@media (max-width:768px){.modal-content{border-radius:15px;margin:20px;max-width:100%;padding:25px 20px;width:95%}.modal-content h2{font-size:18px;margin-bottom:20px}.form-step input,.form-step select{font-size:16px;padding:14px 15px}.form-step label{font-size:14px}.form-step .submit-button{font-size:16px;padding:14px}.modal-nav-buttons{flex-direction:column;gap:10px}.btn-secondary{padding:12px;width:100%}.progress-bar-container{margin:15px 0}}@media (max-width:480px){.modal-backdrop{align-items:flex-start;padding-top:50px}.modal-content{border-radius:12px;margin:10px;padding:20px 15px;width:95%}.modal-content h2{font-size:16px;margin-bottom:15px}.form-step input,.form-step select{font-size:16px;padding:12px}.form-step label{font-size:13px}.form-step .submit-button{font-size:14px;padding:12px}.btn-secondary{font-size:14px;padding:10px}.progress-bar-container{margin:12px 0}.progress-bar{height:6px}}.transaction-animation{align-items:center;bottom:0;display:flex;height:100vh;justify-content:center;left:0;opacity:0;overflow:hidden;pointer-events:none;position:fixed;right:0;top:0;transition:opacity .3s ease;width:100vw;z-index:9999}.transaction-animation.show{opacity:1;pointer-events:all}.transaction-animation.hide{opacity:0}.animation-overlay{backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);background:#000000bf;bottom:0;height:100%;left:0;position:absolute;right:0;top:0;width:100%}.animation-container{height:100vh;width:100vw}.animation-circle,.animation-container{align-items:center;display:flex;justify-content:center;position:relative}.animation-circle{animation:pulseGlow 2s ease-in-out infinite;backdrop-filter:blur(15px);-webkit-backdrop-filter:blur(15px);background:linear-gradient(135deg,#ffffff26,#ffffff0d);border:3px solid #ffffff4d;border-radius:50%;box-shadow:0 12px 40px #0006;flex-direction:column;height:min(200px,40vw);width:min(200px,40vw);z-index:10}.animation-circle.income{border-color:#22c55e99;box-shadow:0 12px 40px #22c55e66,0 0 60px #22c55e33}.animation-circle.expense{border-color:#ef444499;box-shadow:0 12px 40px #ef444466,0 0 60px #ef444433}.amount-display{color:#fff;font-size:clamp(1rem,3vw,1.5rem);font-weight:700;margin-bottom:8px;text-align:center;text-shadow:0 3px 6px #0009}.transaction-icon{animation:bounce 1.5s ease-in-out infinite;font-size:clamp(1.5rem,5vw,2.5rem)}.animated-arrow{animation:arrowFlow 2s ease-out forwards;height:4px;opacity:0;position:absolute;width:clamp(40px,8vw,80px);z-index:5}.animated-arrow .arrow-line{border-radius:2px;height:100%;overflow:hidden;position:relative;width:100%}.animated-arrow.income .arrow-line{background:linear-gradient(90deg,#0000,#22c55e,#16a34a,#0000);box-shadow:0 0 10px #22c55e99,0 0 20px #22c55e4d}.animated-arrow.income .arrow-line:after{border-bottom:6px solid #0000;border-left:8px solid #22c55e;border-top:6px solid #0000;content:"";filter:drop-shadow(0 0 4px rgba(34,197,94,.6));height:0;position:absolute;right:-8px;top:50%;transform:translateY(-50%);width:0}.animated-arrow.expense .arrow-line{background:linear-gradient(90deg,#0000,#ef4444,#dc2626,#0000);box-shadow:0 0 10px #ef444499,0 0 20px #ef44444d}.animated-arrow.expense .arrow-line:after{border-bottom:6px solid #0000;border-left:8px solid #ef4444;border-top:6px solid #0000;content:"";filter:drop-shadow(0 0 4px rgba(239,68,68,.6));height:0;position:absolute;right:-8px;top:50%;transform:translateY(-50%);width:0}.particles-container{bottom:0;height:100%;left:0;pointer-events:none;position:absolute;right:0;top:0;width:100%;z-index:3}.particle{animation:particleFloat 2s ease-out forwards;border-radius:50%;height:clamp(4px,1vw,8px);opacity:0;position:absolute;width:clamp(4px,1vw,8px)}.particle.income{background:radial-gradient(circle,#22c55e,#16a34a);box-shadow:0 0 15px #22c55eb3,0 0 30px #22c55e4d}.particle.expense{background:radial-gradient(circle,#ef4444,#dc2626);box-shadow:0 0 15px #ef4444b3,0 0 30px #ef44444d}.animation-text{animation:fadeInUp .6s ease-out .5s both;bottom:clamp(40px,10vh,80px);color:#fff;font-size:clamp(1rem,3vw,1.3rem);font-weight:600;left:50%;line-height:1.4;max-width:90vw;padding:0 20px;position:absolute;text-align:center;text-shadow:0 3px 6px #000c;transform:translateX(-50%);z-index:10}@keyframes pulseGlow{0%,to{opacity:1;transform:scale(1)}50%{opacity:.9;transform:scale(1.08)}}@keyframes bounce{0%,20%,50%,80%,to{transform:translateY(0)}40%{transform:translateY(-12px)}60%{transform:translateY(-6px)}}@keyframes arrowFlow{0%{opacity:0;transform:scale(.5) translateX(-30px)}20%{opacity:1;transform:scale(1) translateX(0)}80%{opacity:.8;transform:scale(1.1) translateX(40px)}to{opacity:0;transform:scale(.8) translateX(80px)}}@keyframes fadeInUp{0%{opacity:0;transform:translateX(-50%) translateY(30px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}@media (max-width:768px){.animation-overlay{backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}.animation-circle{border-width:2px;height:min(160px,35vw);width:min(160px,35vw)}.animated-arrow{height:3px;width:clamp(30px,6vw,60px)}.animated-arrow.expense .arrow-line:after,.animated-arrow.income .arrow-line:after{border-bottom-width:4px;border-left-width:6px;border-top-width:4px;right:-6px}.particle{height:clamp(3px,.8vw,6px);width:clamp(3px,.8vw,6px)}}@media (max-width:480px){.animation-circle{height:min(140px,32vw);width:min(140px,32vw)}.animated-arrow{height:2px;width:clamp(25px,5vw,50px)}.animation-text{bottom:clamp(50px,12vh,100px);font-size:clamp(.9rem,2.8vw,1.2rem);padding:0 15px}}@media (min-height:800px) and (max-width:480px){.animation-text{bottom:clamp(60px,8vh,120px)}}@media (min-height:900px) and (max-width:480px){.animation-text{bottom:clamp(80px,10vh,140px)}}@media (max-width:768px){.transaction-animation{padding:env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left)}.animation-text{bottom:calc(clamp(40px, 10vh, 80px) + env(safe-area-inset-bottom));margin-bottom:env(safe-area-inset-bottom)}}@media (max-width:768px) and (orientation:landscape){.animation-text{bottom:clamp(30px,8vh,50px);font-size:clamp(.9rem,2.5vw,1.1rem)}}.streak-animation{align-items:center;bottom:0;display:flex;height:100vh;justify-content:center;left:0;opacity:0;overflow:hidden;pointer-events:none;position:fixed;right:0;top:0;transition:opacity .3s ease;width:100vw;z-index:9999}.streak-animation.show{opacity:1;pointer-events:all}.streak-animation.hide{opacity:0}.streak-overlay{backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);background:#0006;bottom:0;height:100%;left:0;position:absolute;right:0;top:0;width:100%}.streak-animation-container{height:100vh;width:100vw}.streak-animation-container,.streak-circle{align-items:center;display:flex;justify-content:center;position:relative}.streak-circle{animation:streakCirclePulse 2s ease-in-out infinite;backdrop-filter:blur(15px);-webkit-backdrop-filter:blur(15px);background:linear-gradient(135deg,#ffffff26,#ffffff0d);border:4px solid;border-radius:50%;box-shadow:0 15px 50px #0006;flex-direction:column;height:min(250px,45vw);width:min(250px,45vw);z-index:10}.streak-circle.basic{box-shadow:0 15px 50px #22c55e4d}.streak-circle.solid{box-shadow:0 15px 50px #00bfff4d}.streak-circle.golden{box-shadow:0 15px 50px #ffa5004d}.streak-circle.legendary{background:linear-gradient(135deg,#ffd70033,#ffa5001a);box-shadow:0 15px 50px #ffd70066}.streak-symbol-large{animation:streakBounce 1.5s ease-in-out infinite;font-size:clamp(3rem,8vw,5rem);margin-bottom:10px}.streak-count-display{color:#fff;font-size:clamp(2rem,6vw,3rem);font-weight:700;margin-bottom:5px;text-shadow:0 3px 6px #0009}.streak-days-label{color:#ffffffe6;font-size:clamp(1rem,3vw,1.3rem);font-weight:500;text-shadow:0 2px 4px #00000080}.streak-particle{animation:streakParticleFloat 2s ease-out forwards;font-size:clamp(1.5rem,4vw,2.5rem);opacity:0;position:absolute;z-index:5}.streak-waves{left:50%;top:50%;z-index:3}.streak-wave,.streak-waves{position:absolute;transform:translate(-50%,-50%)}.streak-wave{border:3px solid;border-radius:50%;height:min(250px,45vw);opacity:0;width:min(250px,45vw)}.streak-wave:first-child{animation:streakWaveExpand 2s ease-out 0s infinite}.streak-wave:nth-child(2){animation:streakWaveExpand 2s ease-out .3s infinite}.streak-wave:nth-child(3){animation:streakWaveExpand 2s ease-out .6s infinite}.streak-message{animation:streakMessageFadeIn .6s ease-out .5s both;bottom:clamp(40px,10vh,80px);color:#fff;font-size:clamp(1.2rem,4vw,1.8rem);font-weight:600;left:50%;max-width:90vw;padding:0 20px;position:absolute;text-align:center;text-shadow:0 3px 6px #000c;transform:translateX(-50%);z-index:10}.streak-confetti{height:100%;left:0;pointer-events:none;position:absolute;top:0;width:100%;z-index:8}.confetti-piece{animation:confettiFall 3s linear forwards;border-radius:2px;height:8px;position:absolute;top:-10px;width:8px}@keyframes streakCirclePulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}@keyframes streakBounce{0%,20%,50%,80%,to{transform:translateY(0) rotate(0deg)}40%{transform:translateY(-15px) rotate(5deg)}60%{transform:translateY(-8px) rotate(-3deg)}}@keyframes streakParticleFloat{0%{opacity:0;transform:scale(.5) translateY(0) rotate(0deg)}20%{opacity:1;transform:scale(1) translateY(-30px) rotate(90deg)}80%{opacity:.8;transform:scale(1.2) translateY(-100px) rotate(270deg)}to{opacity:0;transform:scale(.3) translateY(-150px) rotate(1turn)}}@keyframes streakWaveExpand{0%{opacity:.7;transform:translate(-50%,-50%) scale(1)}to{opacity:0;transform:translate(-50%,-50%) scale(2.5)}}@keyframes streakMessageFadeIn{0%{opacity:0;transform:translateX(-50%) translateY(30px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}@keyframes confettiFall{0%{opacity:1;transform:translateY(0) rotate(0deg)}to{opacity:0;transform:translateY(100vh) rotate(2turn)}}@media (max-width:768px){.streak-overlay{backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}.streak-circle{border-width:3px;height:min(200px,40vw);width:min(200px,40vw)}.confetti-piece{height:6px;width:6px}}@media (max-width:480px){.streak-circle{border-width:2px;height:min(180px,38vw);width:min(180px,38vw)}.streak-message{bottom:clamp(30px,8vh,60px);padding:0 15px}}@media (max-width:768px){.streak-animation{padding:env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left)}}.streak-animation.light .streak-overlay{backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);background:#fff9}.streak-animation.light .streak-count-display{color:#1e293b;text-shadow:0 2px 4px #0000001a}.streak-animation.light .streak-days-label{color:#1e293bcc;text-shadow:0 1px 2px #0000001a}.streak-animation.light .streak-message{color:#1e293b;text-shadow:0 2px 4px #0000001a}.streak-animation.dark .streak-overlay{backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);background:#0006}.streak-animation.dark .streak-count-display{color:#fff;text-shadow:0 3px 6px #000c}.streak-animation.dark .streak-days-label{color:#ffffffe6;text-shadow:0 2px 4px #00000080}.streak-animation.dark .streak-message{color:#fff;text-shadow:0 3px 6px #000c}.streak-counter{cursor:pointer;transition:transform .2s ease}.streak-counter:hover{transform:scale(1.05)}.streak-display{align-items:center;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);background:#ffffff1a;border:2px solid #fff3;border-radius:20px;box-shadow:0 4px 20px #0000001a;display:flex;gap:8px;min-width:100px;padding:12px 16px;transition:all .3s ease}.streak-display:hover{background:#ffffff26;box-shadow:0 6px 25px #00000026}.streak-display.basic{border-color:#22c55e66;box-shadow:0 4px 20px #22c55e1a}.streak-display.solid{border-color:#00bfff66;box-shadow:0 4px 20px #00bfff1a}.streak-display.golden{border-color:#ffa50066;box-shadow:0 4px 20px #ffa5001a}.streak-display.legendary{background:linear-gradient(135deg,#ffd7001a,#ffa5000d);border-color:#ffd70066;box-shadow:0 4px 20px #ffd7001a}.streak-symbol{animation:streakPulse 2s ease-in-out infinite;font-size:1.5rem}.streak-info{align-items:center;display:flex;flex-direction:column;gap:2px}.streak-number{color:#fff;font-size:1.2rem;line-height:1;text-shadow:0 2px 4px #0000004d}.streak-label{color:#fffc;font-size:.7rem;font-weight:500;letter-spacing:.5px;text-transform:uppercase}@media (min-width:769px) and (max-width:1024px){.streak-display{gap:6px;min-width:90px;padding:10px 14px;position:relative;z-index:10}.streak-symbol{font-size:1.4rem}.streak-number{font-size:1.1rem}.streak-label{font-size:.65rem}}@media (max-width:768px){.streak-counter{display:flex;justify-content:center;width:100%}.streak-display{gap:6px;margin:0 auto;min-width:85px;padding:10px 12px}.streak-symbol{font-size:1.3rem}.streak-number{font-size:1.1rem}.streak-label{font-size:.65rem}}@media (max-width:480px){.streak-counter{display:flex;justify-content:center;width:100%}.streak-display{gap:4px;margin:0 auto;min-width:75px;padding:8px 10px}.streak-symbol{font-size:1.2rem}.streak-number{font-size:1rem}.streak-label{font-size:.6rem}}@media (prefers-color-scheme:dark){.streak-display{background:#0000004d;border-color:#ffffff1a}.streak-display:hover{background:#0006}}.streak-counter.light .streak-display{backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);background:#ffffffe6;border-color:#0000001a;box-shadow:0 4px 20px #00000014}.streak-counter.light .streak-display:hover{background:#fffffff2;box-shadow:0 6px 25px #0000001f}.streak-counter.light .streak-number{color:#1e293b;text-shadow:0 1px 2px #0000001a}.streak-counter.light .streak-label{color:#1e293bb3}.streak-counter.light .streak-display.basic{border-color:#22c55e4d;box-shadow:0 4px 20px #22c55e14}.streak-counter.light .streak-display.solid{border-color:#00bfff4d;box-shadow:0 4px 20px #00bfff14}.streak-counter.light .streak-display.golden{border-color:#ffa5004d;box-shadow:0 4px 20px #ffa50014}.streak-counter.light .streak-display.legendary{background:linear-gradient(135deg,#ffd7000d,#ffa50005);border-color:#ffd7004d;box-shadow:0 4px 20px #ffd70014}.streak-counter.dark .streak-display{background:#0000004d;border-color:#ffffff1a}.streak-counter.dark .streak-display:hover{background:#0006}.streak-counter.dark .streak-number{color:#fff;text-shadow:0 2px 4px #0000004d}.streak-counter.dark .streak-label{color:#fffc}.summary-card{background-color:var(--card-bg-color);border-radius:20px;box-shadow:0 4px 20px #00000014;color:var(--text-primary-color);height:100%;padding:25px;transition:background-color .3s,color .3s}.summary-card h3{margin-top:0;text-align:left}.summary-balance{margin:20px 0;text-align:left}.summary-balance span{color:var(--text-secondary-color);font-size:1rem}.summary-balance h2{color:var(--text-primary-color);font-size:2.2rem;margin:5px 0 0}.summary-details{display:flex;gap:20px;justify-content:space-between;margin-bottom:30px}.summary-item{align-items:center;gap:10px;text-align:left}.summary-item .dot{border-radius:50%;height:12px;width:12px}.summary-item.income .dot{background-color:#4bc0c0}.summary-item.expense .dot{background-color:#ff6384}.summary-item p{color:var(--text-secondary-color);font-size:.9rem;margin:0}.summary-item strong{font-size:1.1rem}.summary-chart{height:180px;position:relative}@media (max-width:768px){.summary-card{border-radius:15px;padding:20px}.summary-balance h2{font-size:1.8rem}.summary-details{flex-direction:column;gap:15px;margin-bottom:25px}.summary-item{gap:8px}.summary-item p{font-size:.85rem}.summary-item strong{font-size:1rem}.summary-chart{height:160px}}@media (max-width:480px){.summary-card{border-radius:12px;padding:15px}.summary-card h3{font-size:16px}.summary-balance span{font-size:.9rem}.summary-balance h2{font-size:1.6rem}.summary-details{gap:12px;margin-bottom:20px}.summary-item{gap:6px}.summary-item .dot{height:10px;width:10px}.summary-item p{font-size:.8rem}.summary-item strong{font-size:.9rem}.summary-chart{height:140px}}.history-table-container{background-color:var(--card-bg-color);border-radius:20px;box-shadow:0 4px 20px #00000014;margin-top:40px;padding:25px;transition:background-color .3s}.history-table-container h3{color:var(--text-primary-color);margin-top:0;text-align:left}.history-table-container table{border-collapse:collapse;margin-top:20px;width:100%}.history-table-container th{border-bottom:2px solid var(--border-color);color:var(--text-secondary-color);font-size:.9rem;padding:12px 8px;text-align:left}.history-table-container td{border-bottom:1px solid var(--border-color);color:var(--text-primary-color);padding:15px 8px}.history-table-container tr:last-child td{border-bottom:none}.amount-col{font-weight:500;text-align:right}.income-row .amount-col{color:#34d399}.expense-row .amount-col{color:#ef4444}.type-indicator{font-size:1.5rem;font-weight:700;line-height:1;vertical-align:middle}.type-indicator.income{color:#34d399}.type-indicator.expense{color:#ef4444}.description-text{display:block;font-weight:500}.category-text{color:var(--text-secondary-color);display:block;font-size:.85rem}.no-transactions-message{color:var(--text-secondary-color);padding:30px;text-align:center}.actions-col{text-align:center;width:100px}.action-btn{margin:0 5px;padding:5px}.action-icon{height:20px;transition:fill .2s ease-in-out;width:20px}.edit-btn .action-icon{fill:var(--text-secondary-color)}.edit-btn:hover .action-icon{fill:#34d399}.delete-btn .action-icon{fill:var(--text-secondary-color)}.delete-btn:hover .action-icon{fill:#ef4444}@media (max-width:768px){.history-table-container{border-radius:15px;margin-top:30px;padding:20px 15px}.history-table-container h3{font-size:18px}.history-table-container table{font-size:14px}.history-table-container th{font-size:.8rem;padding:10px 6px}.history-table-container td{padding:12px 6px}.category-col,.date-col{display:none}.actions-col{width:80px}.action-btn{height:32px;width:32px}.action-btn svg{height:14px;width:14px}}@media (max-width:480px){.history-table-container{margin-top:25px;padding:15px 10px}.history-table-container h3{font-size:16px}.history-table-container table{font-size:13px}.history-table-container th{padding:8px 4px}.history-table-container td{padding:10px 4px}.actions-col{width:60px}.action-btn{height:28px;margin:0 2px;width:28px}.action-btn svg{height:12px;width:12px}.history-table-container{overflow-x:auto}.history-table-container table{min-width:300px}}.welcome-modal-overlay{align-items:center;animation:welcomeOverlayFadeIn .6s ease-out;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#000c;display:flex;height:100%;justify-content:center;left:0;position:fixed;top:0;width:100%;z-index:2000}.welcome-modal-overlay.dark{background:#000000e6}@keyframes welcomeOverlayFadeIn{0%{-webkit-backdrop-filter:blur(0);backdrop-filter:blur(0);opacity:0}to{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);opacity:1}}.welcome-modal{animation:welcomeModalSlideIn .6s cubic-bezier(.34,1.56,.64,1);background:linear-gradient(135deg,#fff,#f8fafc);border-radius:24px;box-shadow:0 25px 50px #00000026;display:flex;flex-direction:column;max-height:90vh;max-width:600px;overflow:hidden;position:relative;width:90%}.welcome-modal-overlay.dark .welcome-modal{background:linear-gradient(135deg,#1a202c,#2d3748);box-shadow:0 25px 50px #0000004d}@keyframes welcomeModalSlideIn{0%{opacity:0;transform:translateY(50px) scale(.9)}to{opacity:1;transform:translateY(0) scale(1)}}.welcome-header{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffc;border-bottom:1px solid #0000001a;display:flex;justify-content:space-between;padding:20px 30px}.welcome-modal-overlay.dark .welcome-header{background:#1a202ccc;border-bottom:1px solid #ffffff1a}.close-button,.skip-button{background:none;border:none;border-radius:8px;color:#64748b;cursor:pointer;font-size:16px;padding:8px 12px;transition:all .3s ease}.close-button:hover,.skip-button:hover{background:#0000000d;color:#334155}.welcome-modal-overlay.dark .close-button,.welcome-modal-overlay.dark .skip-button{color:#a0aec0}.welcome-modal-overlay.dark .close-button:hover,.welcome-modal-overlay.dark .skip-button:hover{background:#ffffff0d;color:#e2e8f0}.close-button{font-size:24px;height:40px;justify-content:center;width:40px}.close-button,.slide-indicator{align-items:center;display:flex}.slide-indicator{gap:8px}.indicator-dot{background:#cbd5e1;border-radius:50%;height:10px;position:relative;transition:all .3s ease;width:10px}.indicator-dot.active{background:#10b981;transform:scale(1.2)}.indicator-dot.completed{background:#10b981}.indicator-dot.completed:after{color:#fff;content:"✓";font-size:8px;font-weight:700;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%)}.welcome-content{display:flex;flex:1 1;flex-direction:column;overflow-y:auto;padding:30px;text-align:center;transition:all .3s ease}.welcome-content.animating{opacity:.7;transform:translateX(20px)}.slide-header{margin-bottom:20px}.slide-title{-webkit-text-fill-color:#0000;animation:titleGlow 2s ease-in-out infinite alternate;background:linear-gradient(135deg,#10b981,#059669);background-clip:text;-webkit-background-clip:text;color:#1e293b;font-size:32px;font-weight:700;margin:0 0 10px}.welcome-modal-overlay.dark .slide-title{color:#f1f5f9}@keyframes titleGlow{0%{text-shadow:0 0 20px #10b9814d}to{text-shadow:0 0 30px #10b98180}}.slide-subtitle{color:#64748b;font-size:18px;margin:0}.welcome-modal-overlay.dark .slide-subtitle{color:#a0aec0}.slide-body{flex:1 1;justify-content:center}.slide-body,.welcome-slide{align-items:center;display:flex}.welcome-slide{flex-direction:column;gap:30px}.welcome-icon{align-items:center;display:flex;justify-content:center;position:relative}.money-icon{animation:welcomeBounce 2s ease-in-out infinite;font-size:80px}.sparkles{animation:sparkle 2s ease-in-out infinite;font-size:30px;position:absolute}@keyframes welcomeBounce{0%,to{transform:translateY(0) scale(1)}50%{transform:translateY(-10px) scale(1.1)}}@keyframes sparkle{0%,to{opacity:.7;transform:rotate(0deg) scale(1)}50%{opacity:1;transform:rotate(180deg) scale(1.2)}}.feature-slide{gap:20px}.feature-icon,.feature-slide{align-items:center;display:flex;flex-direction:column}.feature-icon{gap:15px}.feature-icon,.streak-demo{position:relative}.streak-counter-demo{animation:streakPulse 2s ease-in-out infinite;background:linear-gradient(135deg,#10b981,#059669);border-radius:20px;box-shadow:0 10px 25px #10b9814d;color:#fff;padding:20px 30px}.streak-number{display:block;font-size:36px;font-weight:700}.streak-text{font-size:14px;opacity:.9}.streak-particles{display:flex;gap:15px;left:50%;position:absolute;top:-20px;transform:translateX(-50%)}.streak-particles .particle{animation:particleFloat 3s ease-in-out infinite;font-size:20px}.streak-particles .particle:nth-child(2){animation-delay:.5s}.streak-particles .particle:nth-child(3){animation-delay:1s}@keyframes streakPulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}@keyframes particleFloat{0%,to{opacity:.7;transform:translateY(0) rotate(0deg)}50%{opacity:1;transform:translateY(-15px) rotate(180deg)}}.goal-progress-demo{animation:goalFloat 3s ease-in-out infinite;background:#fff;border-radius:16px;box-shadow:0 8px 20px #0000001a;padding:20px;width:280px}.welcome-modal-overlay.dark .goal-progress-demo{background:#2d3748;box-shadow:0 8px 20px #0000004d}.goal-title{color:#1e293b;font-weight:600;margin-bottom:10px}.welcome-modal-overlay.dark .goal-title{color:#f1f5f9}.progress-bar{background:#e2e8f0;margin-bottom:10px}.welcome-modal-overlay.dark .progress-bar{background:#4a5568}.progress-fill{animation:progressGrow 3s ease-in-out infinite;width:45%}.goal-amount{color:#64748b;font-size:14px;font-weight:500}.welcome-modal-overlay.dark .goal-amount{color:#a0aec0}.goal-icons{display:flex;gap:15px;margin-top:20px}.goal-icon{animation:goalIconBounce 2s ease-in-out infinite;background:#10b9811a;border-radius:12px;font-size:24px;padding:10px}.goal-icon:nth-child(2){animation-delay:.3s}.goal-icon:nth-child(3){animation-delay:.6s}@keyframes goalFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}@keyframes progressGrow{0%{width:0}50%{width:45%}to{width:45%}}@keyframes goalIconBounce{0%,to{transform:translateY(0) scale(1)}50%{transform:translateY(-3px) scale(1.1)}}.debts-demo{position:relative}.debt-cards-demo{animation:debtCardsFloat 3s ease-in-out infinite;display:flex;gap:12px;justify-content:center}.debt-card{background:#fff;border-radius:10px;box-shadow:0 4px 12px #0000001a;padding:12px 16px;text-align:left;width:140px}.welcome-modal-overlay.dark .debt-card{background:#2d3748;box-shadow:0 4px 12px #0000004d}.debt-card:before{width:3px}.debt-card.debt-owing:before{background:linear-gradient(180deg,#10b981,#059669)}.debt-card.debt-owed:before{background:linear-gradient(180deg,#f59e0b,#d97706)}.debt-type{font-size:10px;font-weight:600;letter-spacing:.5px;margin-bottom:4px;text-transform:uppercase}.debt-card.debt-owing .debt-type{color:#10b981}.debt-card.debt-owed .debt-type{color:#f59e0b}.welcome-modal-overlay.dark .debt-card.debt-owing .debt-type{color:#68d391}.welcome-modal-overlay.dark .debt-card.debt-owed .debt-type{color:#fbbf24}.debt-amount{color:#1e293b;font-size:18px;font-weight:700;margin-bottom:4px}.welcome-modal-overlay.dark .debt-amount{color:#f1f5f9}.debt-creditor{color:#64748b;font-size:12px;font-weight:500}.welcome-modal-overlay.dark .debt-creditor{color:#a0aec0}.debt-icons{display:flex;gap:12px;justify-content:center;margin-top:15px}.debt-icon{animation:debtIconPulse 2s ease-in-out infinite;background:#3b82f61a;border-radius:8px;font-size:20px;padding:8px}.debt-icon:nth-child(2){animation-delay:.4s;background:#10b9811a}.debt-icon:nth-child(3){animation-delay:.8s;background:#f59e0b1a}@keyframes debtCardsFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}@keyframes debtIconPulse{0%,to{opacity:.8;transform:scale(1)}50%{opacity:1;transform:scale(1.05)}}.feature-description{max-width:400px;text-align:left}.feature-description p{color:#475569;font-size:16px;line-height:1.6;margin-bottom:15px}.welcome-modal-overlay.dark .feature-description p{color:#cbd5e1}.feature-benefits{display:flex;flex-direction:column;gap:10px;margin-top:20px}.benefit{align-items:center;background:#10b9810d;border-left:3px solid #10b981;border-radius:8px;color:#64748b;display:flex;font-size:14px;gap:10px;padding:8px 12px}.welcome-modal-overlay.dark .benefit{background:#10b9811a;color:#a0aec0}.ready-slide{flex-direction:column;gap:20px}.ready-icon,.ready-slide{align-items:center;display:flex}.ready-icon{background:linear-gradient(135deg,#10b981,#059669);border-radius:50%;box-shadow:0 15px 30px #10b9814d;height:80px;justify-content:center;width:80px}.check-animation{animation:checkBounce 2s ease-in-out infinite;color:#fff;font-size:40px;font-weight:700}@keyframes checkBounce{0%,to{transform:scale(1)}50%{transform:scale(1.2)}}.ready-encouragement{color:#10b981;font-size:18px;font-weight:600}.quick-actions{display:flex;flex-direction:column;gap:15px;margin-top:20px}.quick-action{align-items:center;background:#10b9810d;border:1px solid #10b98133;border-radius:12px;display:flex;gap:15px;padding:15px 20px;transition:all .3s ease}.welcome-modal-overlay.dark .quick-action{background:#10b9811a;border:1px solid #10b9814d}.quick-action:hover{background:#10b9811a;transform:translateX(5px)}.action-icon{font-size:20px}.welcome-navigation{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffc;border-top:1px solid #0000001a;display:flex;flex-shrink:0;justify-content:space-between;padding:20px 30px}.welcome-modal-overlay.dark .welcome-navigation{background:#1a202ccc;border-top:1px solid #ffffff1a}.nav-button{border:none;font-size:16px;font-weight:600;min-width:100px;padding:12px 24px;transition:all .3s ease}.nav-button.prev{background:#f1f5f9;color:#64748b}.nav-button.prev:hover:not(:disabled){background:#e2e8f0;color:#475569}.nav-button.prev:disabled{cursor:not-allowed;opacity:.5}.nav-button.finish,.nav-button.next{background:linear-gradient(135deg,#10b981,#059669);box-shadow:0 4px 12px #10b9814d;color:#fff}.nav-button.finish:hover,.nav-button.next:hover{box-shadow:0 6px 20px #10b98166;transform:translateY(-2px)}.nav-button.finish{background:linear-gradient(135deg,#dc2626,#b91c1c);box-shadow:0 4px 12px #dc26264d}.nav-button.finish:hover{box-shadow:0 6px 20px #dc262666}@media (max-width:768px){.welcome-modal{margin:20px;max-height:calc(100vh - 40px);width:95%}.welcome-content,.welcome-header,.welcome-navigation{padding:15px 20px}.slide-title{font-size:24px}.slide-subtitle{font-size:16px}.welcome-content{min-height:300px}.feature-slide{gap:20px}.feature-description{max-width:none}.quick-actions{width:100%}.goal-progress-demo{max-width:250px;width:100%}.money-icon{font-size:60px}.streak-counter-demo{padding:15px 25px}.streak-number{font-size:28px}}.dashboard-grid-container{grid-gap:0;background-color:var(--background-color);box-sizing:border-box;display:grid;gap:0;grid-template-columns:1fr 400px;height:100vh;height:calc(100vh - var(--safe-area-inset-top, 0px) - var(--safe-area-inset-bottom, 0px));max-height:100vh;max-height:calc(100vh - var(--safe-area-inset-top, 0px) - var(--safe-area-inset-bottom, 0px));padding:30px;transition:background-color .3s}.dashboard-summary{border-left:1px solid var(--border-color);padding-left:30px;transition:border-color .3s}.dashboard-main-content,.dashboard-summary{max-height:calc(100vh - 60px);max-height:calc(100vh - 60px - var(--safe-area-inset-top, 0px) - var(--safe-area-inset-bottom, 0px));overflow-y:auto;padding-right:10px}.dashboard-main-content::-webkit-scrollbar,.dashboard-summary::-webkit-scrollbar{width:8px}.dashboard-main-content::-webkit-scrollbar-track,.dashboard-summary::-webkit-scrollbar-track{background:#0000}.dashboard-main-content::-webkit-scrollbar-thumb,.dashboard-summary::-webkit-scrollbar-thumb{background-color:var(--border-color);border-radius:4px}.dashboard-main-content::-webkit-scrollbar-thumb:hover,.dashboard-summary::-webkit-scrollbar-thumb:hover{background-color:var(--text-secondary-color)}.dashboard-main-content{display:flex;flex-direction:column}.dashboard-header{text-align:left}.header-content{align-items:flex-start;display:flex;flex-wrap:wrap;gap:20px;justify-content:space-between}.header-text{flex:1 1;min-width:250px}.header-actions{align-items:flex-start;display:flex;gap:15px;margin-top:5px}.dashboard-header h1{color:var(--text-primary-color);font-size:2.5rem;margin:0}.dashboard-header p{color:var(--text-secondary-color);font-size:1.2rem;margin-top:10px}.dark-mode-toggle-dashboard{display:flex;justify-content:flex-start;margin-top:20px}.dashboard-actions-grid{display:flex;flex-direction:row;gap:25px;margin-top:40px;width:100%}.action-card{background-color:var(--card-bg-color);border-radius:20px;box-shadow:0 4px 20px #00000014;cursor:pointer;flex:1 1;padding:30px;text-align:center;transition:transform .3s,box-shadow .3s,background-color .3s}.action-card:hover{box-shadow:0 8px 30px #0000001f;transform:translateY(-8px)}.action-card h2{color:var(--text-primary-color);font-size:1.5rem;margin:10px 0 0}.icon-placeholder{font-size:3rem;font-weight:700}.income .icon-placeholder{color:#34d399}.expense .icon-placeholder{color:#ef4444}@media (max-width:1024px){.dashboard-grid-container{gap:30px;grid-template-columns:1fr;height:auto;max-height:none}.dashboard-summary{border-left:none;padding-left:0}.dashboard-main-content,.dashboard-summary{max-height:none;overflow-y:visible;padding-right:0}.dashboard-summary{order:-1}}@media (max-width:600px){.dashboard-actions-grid{flex-direction:column}}@media (max-width:1024px){.dashboard-grid-container{gap:20px;grid-template-columns:1fr;padding:20px}.dashboard-summary{border-left:none;border-top:1px solid var(--border-color);order:2;padding-left:0;padding-top:20px}.dashboard-main-content{order:1}.header-actions{align-items:center;margin-top:15px}.header-content{align-items:flex-start;gap:15px}}@media (min-width:768px) and (max-width:1024px) and (orientation:landscape){.header-content{align-items:center;gap:20px}.header-actions{flex-shrink:0;margin-top:0}.dashboard-header{border-bottom:1px solid var(--border-color);margin-bottom:20px;padding-bottom:15px}}@media (min-width:768px) and (max-width:1024px) and (orientation:portrait){.header-actions{margin-top:10px}.header-content{align-items:flex-start;flex-direction:column;gap:10px}}@media (max-width:768px){.dashboard-grid-container{height:auto;min-height:calc(100vh - 60px);padding:15px}.dashboard-main-content,.dashboard-summary{max-height:none;overflow-y:visible;padding-right:0}.header-content{align-items:flex-start;flex-direction:column;gap:15px}.header-actions{align-self:center;justify-content:center;margin-top:0;width:100%}.dashboard-header h1{font-size:2rem}.dashboard-header p{font-size:1.1rem}.dashboard-title{font-size:20px;margin-bottom:15px}.dashboard-actions-grid{gap:10px;margin-bottom:20px}}@media (max-width:480px){.dashboard-grid-container{padding:10px}.header-content{gap:10px}.dashboard-header h1{font-size:1.8rem}.dashboard-header p{font-size:1rem;margin-top:5px}.dashboard-title{font-size:18px;margin-bottom:12px}.dashboard-actions-grid{gap:8px;margin-bottom:15px}.dashboard-summary{padding-top:15px}}.analytics-container{margin:0 auto;max-width:1200px;padding:80px 20px 20px;padding:calc(80px + var(--safe-area-inset-top, 0px)) 20px calc(20px + var(--safe-area-inset-bottom, 0px)) 20px;text-align:center}.analytics-container h1{color:var(--text-primary-color)}.analytics-cards-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));margin:24px 0 40px}.analytics-card{background-color:var(--card-bg-color);border-radius:16px;box-shadow:0 4px 20px #00000014;color:var(--text-primary-color);padding:16px}.analytics-card .big{font-size:1.6rem;font-weight:700;margin:8px 0 0}.analytics-card .small{color:var(--text-secondary-color);font-size:.85rem;margin:4px 0 0;opacity:.8}.chart-wrapper{background-color:var(--card-bg-color);border-radius:20px;box-shadow:0 4px 20px #00000014;margin-bottom:40px;margin-left:auto;margin-right:auto;max-width:700px;padding:20px;transition:background-color .3s}.chart-wrapper h2{color:var(--text-primary-color);margin-bottom:12px}@media (max-width:1024px){.analytics-container{padding:70px 15px 15px}.chart-wrapper{max-width:100%;padding:15px}}@media (max-width:768px){.analytics-container{padding:80px 10px 20px}.analytics-container h1{font-size:24px;margin-bottom:20px}.analytics-cards-grid{gap:12px;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));margin:20px 0 30px}.analytics-card{border-radius:12px;padding:12px}.analytics-card h3{font-size:14px;margin-bottom:8px}.analytics-card .big{font-size:1.3rem}.chart-wrapper{border-radius:15px;margin-bottom:30px;padding:15px}.chart-wrapper h2{font-size:18px;margin-bottom:10px}}@media (max-width:480px){.analytics-container{padding:70px 5px 15px}.analytics-container h1{font-size:20px;margin-bottom:15px}.analytics-cards-grid{gap:10px;grid-template-columns:1fr;margin:15px 0 25px}.analytics-card{padding:10px}.analytics-card h3{font-size:13px}.analytics-card .big{font-size:1.1rem}.chart-wrapper{margin-bottom:25px;padding:12px}.chart-wrapper h2{font-size:16px;margin-bottom:8px}}.profile-container{animation:fadeIn .5s ease-in-out;margin:0 auto;max-width:800px;padding:80px 20px 20px;padding:calc(80px + var(--safe-area-inset-top, 0px)) 20px calc(20px + var(--safe-area-inset-bottom, 0px)) 20px}.error-message{background-color:#fee;border-left:4px solid #c33;color:#c33}.error-message,.success-message{border-radius:8px;margin-bottom:20px;padding:10px 15px}.success-message{background-color:#efe;border-left:4px solid #363;color:#363}.profile-card,.settings-card{background-color:var(--card-bg-color);border-radius:20px;box-shadow:0 4px 20px #00000014;margin-bottom:30px;padding:25px;text-align:center;transition:background-color .3s,color .3s}.profile-avatar{align-items:center;background:linear-gradient(45deg,#2dd4bf,#34d399);border-radius:50%;color:#fff;display:flex;font-size:3rem;font-weight:700;height:100px;justify-content:center;margin:0 auto 15px;width:100px}.profile-card h2{color:var(--text-primary-color);margin:0}.profile-card p{color:#666;margin:5px 0 15px}.member-since{color:#888;font-size:.9rem}.settings-card h3{color:var(--text-primary-color);margin-bottom:25px;margin-top:0;text-align:left}.setting-item{display:flex;flex-direction:column;margin-bottom:20px;text-align:left}.setting-item label{color:var(--text-secondary-color);font-weight:500;margin-bottom:8px}.setting-item input{background-color:var(--input-bg-color);border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary-color);font-size:1rem;padding:12px}.save-button{background:linear-gradient(90deg,#2dd4bf,#34d399);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:700;padding:12px;transition:transform .2s;width:100%}.save-button:hover{transform:scale(1.02)}.dark-mode-toggle{align-items:center;flex-direction:row;justify-content:space-between}.switch{display:inline-block;height:28px;position:relative;width:50px}.switch input{height:0;opacity:0;width:0}.slider{background-color:#ccc;bottom:0;cursor:pointer;left:0;right:0;top:0}.slider,.slider:before{position:absolute;transition:.4s}.slider:before{background-color:#fff;bottom:4px;content:"";height:20px;left:4px;width:20px}input:checked+.slider{background-color:#2dd4bf}input:checked+.slider:before{transform:translateX(22px)}.slider.round{border-radius:34px}.slider.round:before{border-radius:50%}@media (max-width:768px){.profile-container{padding:70px 15px 15px}.profile-card,.settings-card{border-radius:15px;margin-bottom:25px;padding:20px}.profile-avatar{font-size:28px;height:80px;width:80px}.profile-info h2{font-size:20px;margin:15px 0 5px}.profile-info p{font-size:14px}.profile-form input,.profile-form select{font-size:16px;padding:12px 15px}.profile-form button{font-size:16px;padding:12px 20px}.theme-toggle{gap:15px}.theme-toggle h3{font-size:16px}.switch{height:28px;width:50px}.slider:before{bottom:3px;height:22px;left:3px;width:22px}input:checked+.slider:before{transform:translateX(22px)}}@media (max-width:480px){.profile-container{padding:60px 10px 10px}.profile-card,.settings-card{border-radius:12px;margin-bottom:20px;padding:15px}.profile-avatar{font-size:24px;height:70px;width:70px}.profile-info h2{font-size:18px;margin:12px 0 5px}.profile-info p{font-size:13px}.profile-form input,.profile-form select{font-size:16px;padding:10px 12px}.profile-form button{font-size:14px;padding:10px 15px}.theme-toggle{flex-direction:column;gap:10px;text-align:center}.theme-toggle h3{font-size:14px;margin:0}.switch{align-self:center;height:25px;width:45px}.slider:before{bottom:3px;height:19px;left:3px;width:19px}input:checked+.slider:before{transform:translateX(20px)}.error-message,.success-message{font-size:13px;padding:8px 12px}}.goal-modal-content{animation:modalSlideIn .3s ease-out;background:var(--card-bg-color);border-radius:20px;box-shadow:0 20px 40px #0003;max-height:90vh;max-width:600px;overflow-y:auto;padding:0;width:90%}.modal-header{align-items:center;border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border-color,#e2e8f0);display:flex;justify-content:space-between;padding:25px 30px}.modal-header h2{color:var(--text-primary-color);font-size:1.5rem;margin:0}.close-btn{align-items:center;background:none;border:none;border-radius:50%;color:var(--text-secondary-color);cursor:pointer;display:flex;font-size:1.5rem;height:30px;justify-content:center;transition:all .2s;width:30px}.close-btn:hover{background:var(--background-color);color:var(--text-primary-color)}.close-btn:disabled{cursor:not-allowed;opacity:.5}.goal-modal-content form{padding:30px}.form-group{margin-bottom:20px}.form-group label{color:var(--text-primary-color);display:block;margin-bottom:8px}.form-group input,.form-group textarea{background:var(--card-bg-color);border:2px solid #e2e8f0;border-radius:12px;box-sizing:border-box;color:var(--text-primary-color);font-size:1rem;padding:12px 16px;transition:all .2s;width:100%}.form-group input:focus,.form-group textarea:focus{border-color:#2dd4bf;box-shadow:0 0 0 3px #2dd4bf1a;outline:none}.form-group input.error,.form-group textarea.error{border-color:#ef4444}.form-group input:disabled,.form-group textarea:disabled{cursor:not-allowed;opacity:.7}.form-group textarea{min-height:80px}.form-group input[type=date]{background:var(--card-bg-color);border:2px solid #e2e8f0;border-radius:12px;box-sizing:border-box;color:var(--text-primary-color);cursor:pointer;font-size:1rem;padding:12px 16px;transition:all .2s;width:100%}.form-group input[type=date]:focus{border-color:#2dd4bf;box-shadow:0 0 0 3px #2dd4bf1a;outline:none}.form-group input[type=date]:disabled{cursor:not-allowed;opacity:.7}.form-row{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr 1fr}@media (max-width:600px){.form-row{grid-template-columns:1fr}}.error-message{color:#ef4444;display:block;font-size:.85rem;font-weight:500;margin-top:5px}.submit-error{background:#fef2f2;border:1px solid #fecaca;border-radius:8px;margin-bottom:20px;padding:12px;text-align:center}.monthly-info{margin:25px 0}.info-card{align-items:center;background:linear-gradient(135deg,#2dd4bf1a,#34d3991a);border:1px solid #2dd4bf33;border-radius:12px;display:flex;justify-content:space-between;padding:15px 20px}.info-label{color:var(--text-secondary-color);font-size:.95rem}.info-value{color:var(--text-primary-color);font-size:1.1rem;font-weight:700}.modal-actions{border-top:1px solid #e2e8f0;border-top:1px solid var(--border-color,#e2e8f0);display:flex;gap:15px;margin-top:30px;padding-top:20px}.modal-actions .btn{border:none;border-radius:12px;cursor:pointer;flex:1 1;font-size:1rem;font-weight:600;padding:12px 24px;transition:all .2s}.modal-actions .btn:disabled{cursor:not-allowed;opacity:.7}.modal-actions .btn-secondary{background:var(--background-color);border:2px solid #e2e8f0;color:var(--text-primary-color)}.modal-actions .btn-secondary:hover:not(:disabled){background:#f1f5f9;border-color:#cbd5e1}.modal-actions .btn-primary{background:linear-gradient(90deg,#2dd4bf,#34d399);color:#fff}.modal-actions .btn-primary:hover:not(:disabled){box-shadow:0 4px 12px #2dd4bf4d;transform:translateY(-1px)}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-50px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@media (max-width:768px){.goal-modal-content{margin:20px;width:95%}.goal-modal-content form,.modal-header{padding:20px}.modal-actions{flex-direction:column}}.goals-container{animation:fadeIn .5s ease-in-out;margin:0 auto;max-width:1200px;padding:80px 20px 20px}.goals-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:30px}.goals-header h1{color:var(--text-primary-color);font-size:2.5rem;margin:0}.create-goal-btn{background:linear-gradient(90deg,#2dd4bf,#34d399);border:none;border-radius:12px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:12px 24px;transition:transform .2s,box-shadow .2s}.create-goal-btn:hover{box-shadow:0 8px 20px #2dd4bf4d;transform:translateY(-2px)}.create-goal-btn.primary{font-size:1.1rem;padding:16px 32px}.empty-state{background:var(--card-bg-color)}.empty-icon{font-size:4rem;margin-bottom:20px}.empty-state h2{color:var(--text-primary-color);margin-bottom:10px}.empty-state p{color:var(--text-secondary-color)}.goals-grid{grid-gap:25px;display:grid;gap:25px;grid-template-columns:repeat(auto-fit,minmax(350px,1fr))}.goal-card{background:var(--card-bg-color);border-radius:20px;box-shadow:0 4px 20px #00000014;padding:25px;transition:transform .2s,box-shadow .2s}.goal-card:hover{box-shadow:0 8px 30px #0000001f;transform:translateY(-5px)}.goal-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:15px}.goal-header h3{color:var(--text-primary-color);flex:1 1;font-size:1.5rem;margin:0}.status-badge{border-radius:20px;font-size:.85rem;font-weight:600;padding:6px 12px;text-transform:uppercase}.status-badge.active{background:#dcfce7;color:#166534}.status-badge.completed{background:#dbeafe;color:#1d4ed8}.goal-description{color:var(--text-secondary-color);line-height:1.5;margin-bottom:20px}.goal-amounts{background:var(--background-color);border-radius:12px;display:flex;justify-content:space-between;margin-bottom:20px;padding:15px}.amount-info{align-items:center;display:flex;flex-direction:column}.amount-info .label{color:var(--text-secondary-color);font-size:.9rem;margin-bottom:5px}.amount-info .amount{font-size:1.1rem;font-weight:700}.amount.target{color:#ef4444}.amount.current{color:#22c55e}.progress-section{margin-bottom:20px}.progress-bar{background:#f1f5f9;border-radius:5px;height:10px;margin-bottom:8px}.progress-fill{background:linear-gradient(90deg,#2dd4bf,#34d399);border-radius:5px}.progress-text{font-size:.9rem;font-weight:600}.goal-timeline{background:#2dd4bf1a;border-radius:8px;display:flex;justify-content:space-between;margin-bottom:20px;padding:12px}.timeline-info{align-items:center;display:flex;flex-direction:column}.timeline-info .label{color:var(--text-secondary-color);font-size:.85rem;margin-bottom:3px}.timeline-info .date,.timeline-info .months{color:var(--text-primary-color);font-weight:600}.monthly-required{background:linear-gradient(90deg,#2dd4bf1a,#34d3991a);border-radius:12px;color:var(--text-primary-color);font-size:1rem;margin-bottom:20px;padding:15px;text-align:center}.goal-actions{display:flex;gap:10px}.goal-actions button{border:none;border-radius:8px;cursor:pointer;flex:1 1;font-weight:600;padding:12px;transition:all .2s}.btn-secondary{background:var(--background-color);border:2px solid #e2e8f0;color:var(--text-primary-color)}.btn-secondary:hover{background:#f1f5f9;border-color:#cbd5e1}.btn-primary{background:linear-gradient(90deg,#2dd4bf,#34d399);color:#fff}.btn-primary:hover{box-shadow:0 4px 12px #2dd4bf4d;transform:translateY(-1px)}.modal-backdrop{align-items:center;background:#00000080;display:flex;height:100%;justify-content:center;left:0;position:fixed;top:0;width:100%;z-index:1000}.modal-content{background:var(--card-bg-color);border-radius:20px;box-shadow:0 20px 40px #0003;max-width:500px;padding:30px;width:90%}.loading{color:var(--text-secondary-color);font-size:1.1rem;padding:40px;text-align:center}@media (max-width:768px){.goals-header{flex-direction:column;gap:20px;text-align:center}.goals-grid{grid-template-columns:1fr}.goal-amounts{flex-direction:column;gap:15px}.goal-timeline{gap:10px}.goal-actions,.goal-timeline{flex-direction:column}}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.debt-modal-overlay{align-items:center;animation:overlayFade .25s ease-out;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#000000bf;display:flex;inset:0;justify-content:center;padding:16px;position:fixed;z-index:2000}@keyframes overlayFade{0%{opacity:0}to{opacity:1}}.debt-modal{animation:modalIn .24s ease-out;background:#0f172a;background:var(--card-bg-color,#0f172a);border:1px solid #ffffff12;border-radius:16px;box-shadow:0 24px 60px #00000073;color:#e5e7eb;color:var(--text-primary-color,#e5e7eb);display:flex;flex-direction:column;max-height:90vh;max-width:560px;overflow:hidden;width:100%}@keyframes modalIn{0%{opacity:0;transform:translateY(10px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.debt-header{background:linear-gradient(135deg,#667eea,#764ba2 60%,#667eea);background-size:200% 200%;color:#fff;flex-shrink:0;padding:18px 20px;position:relative}.debt-header h2{font-size:1.25rem;font-weight:700;margin:0}.close-button{-webkit-appearance:none;appearance:none;background:#ffffff2e;border:0;border-radius:999px;color:#fff;cursor:pointer;display:grid;font-size:18px;height:36px;place-items:center;transition:transform .15s ease,background .15s ease;width:36px}.close-button:hover{background:#ffffff47;transform:scale(1.05)}.step-indicator{background:linear-gradient(180deg,#0000,#00000014);display:flex;gap:8px;padding:10px 16px 14px}.step-dot{background:#ffffff1f;border-radius:999px;color:#fff;cursor:pointer;display:grid;font-size:1.05rem;height:34px;line-height:1;place-items:center;transition:transform .15s ease,background .15s ease,opacity .15s ease;-webkit-user-select:none;user-select:none;width:34px}.step-dot:hover{background:#ffffff2e;transform:translateY(-1px)}.step-dot.active{outline:2px solid #ffffff59}.step-dot.completed{background:#10b98140}.debt-content{background:#0f172a;background:var(--card-bg-color,#0f172a);max-height:calc(90vh - 160px);overflow:auto;padding:16px 20px;scroll-behavior:smooth}.error-banner{align-items:center;background:#ef44441f;border:1px solid #ef444440;border-radius:10px;color:#fecaca;display:flex;gap:8px;margin-bottom:12px;padding:10px 12px}.error-icon{font-size:18px}.error-text{flex:1 1}.error-close{-webkit-appearance:none;appearance:none;background:#0000;border:0;color:inherit;cursor:pointer;font-size:16px}.step-container{transition:opacity .2s ease,transform .2s ease}.step-container.animating{opacity:.6;transform:translateY(4px)}.step-content{grid-gap:14px;display:grid;gap:14px}.step-header{align-items:center;display:flex;gap:10px}.step-icon{font-size:1.25rem}.step-fields{grid-gap:14px;display:grid;gap:14px}.form-group{grid-gap:8px;display:grid;gap:8px}.form-group label{align-items:center;color:#e5e7eb;color:var(--text-primary-color,#e5e7eb);display:flex;font-size:.95rem;font-weight:600;gap:6px}.form-group input,.form-group select,.form-group textarea{background:#0b1220;background:var(--input-bg-color,#0b1220);border:1.5px solid #1f2a44;border:1.5px solid var(--border-color,#1f2a44);border-radius:12px;box-sizing:border-box;color:#e5e7eb;color:var(--text-primary-color,#e5e7eb);font-size:1rem;padding:12px 14px;transition:border-color .15s ease,box-shadow .15s ease,background .15s ease;width:100%}.form-group textarea{min-height:84px;resize:vertical}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea2e;outline:none}.radio-group{grid-gap:10px;display:grid;gap:10px}.radio-option{grid-gap:10px;align-items:center;background:#0b1220;background:var(--input-bg-color,#0b1220);border:1.5px solid #1f2a44;border:1.5px solid var(--border-color,#1f2a44);border-radius:12px;display:grid;gap:10px;grid-template-columns:20px 1fr;padding:12px;transition:border-color .15s ease,transform .15s ease}.radio-option.selected{background:#667eea14;border-color:#667eea}.radio-option:hover{transform:translateY(-1px)}.radio-icon{font-size:1.1rem}.installment-section{grid-gap:12px;background:#667eea0f;border:1px solid #667eea2e;border-radius:12px;display:grid;gap:12px;padding:12px}.debt-summary{background:#0b1220;background:var(--input-bg-color,#0b1220);border:1px solid #1f2a44;border:1px solid var(--border-color,#1f2a44);border-radius:12px;margin-top:6px;padding:12px}.debt-summary h4{font-size:1rem;margin:0 0 8px}.summary-item{border-bottom:1px dashed #1f2a44;border-bottom:1px dashed var(--border-color,#1f2a44);display:flex;gap:12px;justify-content:space-between;padding:8px 0}.summary-item:last-child{border-bottom:0}.summary-item span,.summary-item strong{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.debt-navigation{align-items:center;background:#0b1220;background:var(--nav-bg,#0b1220);border-top:1px solid #1f2a44;border-top:1px solid var(--border-color,#1f2a44);display:flex;flex-shrink:0;gap:12px;justify-content:space-between;padding:14px 20px}.nav-info{color:#94a3b8;color:var(--text-secondary-color,#94a3b8);font-size:.9rem}.nav-button{align-items:center;-webkit-appearance:none;appearance:none;border:0;border-radius:12px;cursor:pointer;display:inline-flex;font-size:.95rem;font-weight:700;gap:8px;justify-content:center;letter-spacing:.2px;min-width:120px;padding:10px 16px;transition:transform .12s ease,box-shadow .12s ease,opacity .12s ease}.nav-button.secondary{background:#0f172a;background:var(--card-bg-color,#0f172a);border:1.5px solid #1f2a44;border:1.5px solid var(--border-color,#1f2a44);color:#e5e7eb;color:var(--text-primary-color,#e5e7eb)}.nav-button.primary{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 8px 22px #667eea47;color:#fff}.nav-button:hover:not(.disabled){transform:translateY(-1px)}.nav-button.disabled,.nav-button:disabled{cursor:not-allowed;opacity:.55;transform:none}.spinner{animation:spin 1s linear infinite;border:2px solid #ffffff59;border-radius:999px;border-top-color:#fff;height:16px;width:16px}@keyframes spin{to{transform:rotate(1turn)}}@media (max-width:640px){.debt-modal{max-height:92vh}.debt-content{max-height:calc(92vh - 170px)}.nav-button{min-width:0;width:100%}.debt-navigation{align-items:stretch;flex-direction:column;gap:10px}}.debts-page .modal-header{animation:none!important;background:#0000!important;border:0!important}.debts-page .modal-header:after,.debts-page .modal-header:before{content:none!important}.payment-modal{animation:modalAppear .3s ease-out;background-color:var(--card-bg-color);border-radius:15px;box-shadow:0 25px 50px #00000040;max-height:90vh;max-width:450px;overflow-y:auto;width:100%}.debt-summary-info{background:var(--input-bg-color);border-bottom:1px solid var(--border-color);margin-bottom:20px;padding:0 25px 20px}.debt-name{color:var(--text-primary-color);font-size:1.1rem;font-weight:600;margin-bottom:5px}.debt-desc{color:var(--text-secondary-color);font-size:.9rem;margin-bottom:10px}.pending-amount{color:var(--text-primary-color);font-size:.95rem}.pending-amount strong{color:#ef4444;font-size:1.1rem}.payment-form{padding:0 25px 25px}.amount-suggestions{display:flex;flex-wrap:wrap;gap:10px;margin-top:10px}.suggestion-btn{background:var(--input-bg-color);border:1px solid var(--border-color);border-radius:20px;color:var(--text-secondary-color);cursor:pointer;font-size:.8rem;padding:6px 12px;transition:all .3s ease}.suggestion-btn:hover{background:#667eea;border-color:#667eea;color:#fff}.form-footer{display:flex;gap:15px;margin-top:25px}.form-footer .btn-primary,.form-footer .btn-secondary{flex:1 1}@media (max-width:768px){.payment-modal{max-width:95vw}.debt-summary-info,.payment-form{padding-left:20px;padding-right:20px}.amount-suggestions{flex-direction:column}.suggestion-btn{text-align:center}.form-footer{flex-direction:column-reverse}}@media (max-width:480px){.debt-summary-info,.payment-form{padding-left:15px;padding-right:15px}}.debt-card{background:var(--card-bg-color);border:1px solid var(--border-color);border-radius:15px;box-shadow:0 4px 20px #0000001a;overflow:hidden;padding:20px;position:relative;transition:all .3s ease}.debt-card:hover{box-shadow:0 6px 25px #00000026;transform:translateY(-2px)}.debt-card:before{background:var(--accent-color);content:"";height:100%;left:0;position:absolute;top:0;width:4px}.debt-card.i_owe:before{background:linear-gradient(180deg,#ef4444,#dc2626)}.debt-card.owed_to_me:before{background:linear-gradient(180deg,#10b981,#059669)}.debt-card.paid{background:var(--input-bg-color);opacity:.7}.debt-card.overdue{background:linear-gradient(135deg,#ef44440d 0,var(--card-bg-color) 100%);border-color:#ef4444}.debt-card.due-soon{background:linear-gradient(135deg,#f59e0b0d 0,var(--card-bg-color) 100%);border-color:#f59e0b}.debt-card-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:15px}.debt-info{flex:1 1}.debt-type-badge{background:var(--input-bg-color);border-radius:20px;color:var(--text-secondary-color);display:inline-block;font-size:.75rem;font-weight:600;margin-bottom:8px;padding:4px 8px}.debt-card.i_owe .debt-type-badge{background:#ef44441a;color:#ef4444}.debt-card.owed_to_me .debt-type-badge{background:#10b9811a;color:#10b981}.creditor-name{color:var(--text-primary-color);font-size:1.2rem;font-weight:600;margin:0 0 5px}.debt-description{color:var(--text-secondary-color);font-size:.9rem;margin:0}.debt-actions{display:flex;gap:8px}.action-btn{align-items:center;background:none;border:none;border-radius:50%;cursor:pointer;display:flex;font-size:1rem;height:36px;justify-content:center;padding:8px;transition:all .3s ease;width:36px}.action-btn:hover{background:var(--input-bg-color);transform:scale(1.1)}.action-btn.delete:hover{background:#ef44441a}.debt-amounts{margin-bottom:15px}.amount-row{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px}.amount-row:last-child{margin-bottom:0}.amount-row.pending{border-top:1px solid var(--border-color);font-weight:600;padding-top:8px}.amount-row .label{color:var(--text-secondary-color);font-size:.9rem}.amount-row .amount{font-size:1rem;font-weight:600}.amount-row .amount,.amount-row .amount.total{color:var(--text-primary-color)}.amount-row .amount.paid{color:#10b981}.amount-row.pending .amount{color:var(--text-primary-color);font-size:1.1rem}.debt-card.i_owe .amount-row.pending .amount{color:#ef4444}.debt-card.owed_to_me .amount-row.pending .amount{color:#10b981}.progress-container{margin:15px 0}.progress-bar{background:var(--border-color);height:8px;margin-bottom:5px;overflow:hidden;width:100%}.progress-fill{background:linear-gradient(90deg,#10b981,#059669);border-radius:4px;height:100%;transition:width .3s ease}.debt-card.i_owe .progress-fill{background:linear-gradient(90deg,#ef4444,#dc2626)}.progress-text{color:var(--text-secondary-color);display:block;font-size:.8rem;text-align:right}.debt-status{margin-bottom:15px}.status-text{border-radius:20px;display:inline-block;font-size:.8rem;font-weight:500;padding:6px 12px}.status-text.paid{background:#10b9811a;color:#10b981}.status-text.overdue{background:#ef44441a;color:#ef4444}.status-text.due-soon{background:#f59e0b1a;color:#f59e0b}.status-text.no-due-date,.status-text.normal{background:var(--input-bg-color);color:var(--text-secondary-color)}.installment-info{background:var(--input-bg-color);border-left:3px solid #667eea;border-radius:8px;margin-bottom:15px;padding:10px}.installment-text{color:var(--text-secondary-color);font-size:.85rem}.debt-card-footer{display:flex;flex-direction:column;gap:10px}.detail-btn{background:none;border:1px solid var(--border-color);border-radius:6px;color:var(--text-secondary-color);cursor:pointer;font-size:.85rem;padding:8px 16px;transition:all .3s ease}.detail-btn:hover{border-color:#667eea;color:#667eea}.payment-actions{display:flex;gap:10px}.payment-btn{border:none;border-radius:8px;cursor:pointer;flex:1 1;font-size:.9rem;font-weight:500;padding:10px 16px;transition:all .3s ease}.payment-btn.partial{background:var(--input-bg-color);border:1px solid var(--border-color);color:var(--text-primary-color)}.payment-btn.partial:hover{background:#667eea;border-color:#667eea;color:#fff}.payment-btn.full{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.payment-btn.full:hover{box-shadow:0 4px 15px #10b9814d;transform:translateY(-1px)}.debt-details{animation:slideDown .3s ease-out;border-top:1px solid var(--border-color);margin-top:15px;padding-top:15px}@keyframes slideDown{0%{max-height:0;opacity:0}to{max-height:500px;opacity:1}}.detail-row{display:flex;flex-wrap:wrap;gap:5px;justify-content:space-between;margin-bottom:8px}.detail-row strong{color:var(--text-secondary-color);font-size:.85rem;font-weight:500}.detail-row span{color:var(--text-primary-color);font-size:.85rem;max-width:60%;text-align:right}.payments-history{margin-top:15px}.payments-history strong{color:var(--text-secondary-color);display:block;font-size:.85rem;margin-bottom:10px}.payments-list{background:var(--input-bg-color);border-radius:8px;max-height:150px;overflow-y:auto;padding:10px}.payment-item{align-items:center;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;padding:6px 0}.payment-item:last-child{border-bottom:none}.payment-date{color:var(--text-secondary-color);font-size:.8rem}.payment-amount{color:#10b981;font-size:.85rem;font-weight:600}@media (max-width:768px){.debt-card{padding:15px}.debt-card-header{flex-direction:column;gap:10px}.debt-actions{align-self:flex-end}.creditor-name{font-size:1.1rem}.detail-row,.payment-actions{flex-direction:column}.detail-row{gap:2px}.detail-row span{max-width:100%;text-align:left}}@media (max-width:480px){.debt-card{padding:12px}.amount-row .amount{font-size:.9rem}.amount-row.pending .amount{font-size:1rem}.action-btn{font-size:.9rem;height:32px;width:32px}}[data-theme=dark] .debt-card{box-shadow:0 4px 20px #0000004d}[data-theme=dark] .debt-card:hover{box-shadow:0 6px 25px #0006}[data-theme=dark] .payments-list{border:1px solid var(--border-color)}.debt-page{--bg:var(--background-color,#0b1120);--card:var(--card-bg-color,#0f172a);--text:var(--text-primary-color,#e5e7eb);--muted:var(--text-secondary-color,#94a3b8);--border:var(--border-color,#1f2a44);--accent-mint-a:#2dd4bf;--accent-mint-b:#34d399;--accent-green:#10b981;--accent-red:#ef4444;--primary-indigo:#667eea;background-color:var(--bg);color:var(--text);margin:0 auto;max-width:1200px;min-height:100vh;padding:20px}.debt-header{align-items:center;display:flex;flex-wrap:wrap;gap:15px;justify-content:space-between;margin-bottom:30px}.debt-header h1{color:var(--text);font-size:2.5rem;margin:0}.create-debt-btn{background:linear-gradient(90deg,var(--accent-mint-a),var(--accent-mint-b));border:none;border-radius:12px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:12px 24px;transition:transform .2s,box-shadow .2s}.create-debt-btn:hover{box-shadow:0 8px 20px #2dd4bf4d;transform:translateY(-2px)}.create-debt-btn.primary{font-size:1.1rem;padding:16px 32px}.debt-stats{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:30px}.stat-card{background:var(--card);border:1px solid var(--border);border-radius:15px;box-shadow:0 4px 20px #0000001a;padding:20px;text-align:center;transition:transform .3s ease}.stat-card:hover{transform:translateY(-5px)}.stat-card h3{color:var(--muted);font-size:.9rem;font-weight:500;letter-spacing:.5px;margin:0 0 10px;text-transform:uppercase}.stat-card .amount{color:var(--text);font-size:1.8rem;font-weight:700;margin:0}.stat-card.owed-to-me .amount{color:var(--accent-green)}.stat-card.i-owe .amount{color:var(--accent-red)}.stat-card.balance .amount.positive{color:var(--accent-green)}.stat-card.balance .amount.negative{color:var(--accent-red)}.debt-controls{background:var(--card);border:1px solid var(--border);border-radius:16px;box-shadow:0 2px 10px #0000000d;margin-bottom:25px;padding:20px}.filter-section{margin-bottom:20px}.filter-title{color:var(--text);font-size:1rem;font-weight:600;margin:0 0 12px}.filter-chips{display:flex;flex-wrap:wrap;gap:8px}.filter-chip{align-items:center;background:var(--bg);border:2px solid var(--border);border-radius:20px;color:var(--text);cursor:pointer;display:inline-flex;font-size:.9rem;font-weight:500;gap:6px;padding:10px 16px;transition:all .3s ease;white-space:nowrap}.filter-chip:hover{background:#2dd4bf0d;border-color:var(--accent-mint-a);transform:translateY(-1px)}.filter-chip.active{background:linear-gradient(90deg,var(--accent-mint-a),var(--accent-mint-b));border-color:var(--accent-mint-a);box-shadow:0 4px 12px #2dd4bf4d;color:#fff}.sort-section{align-items:center;display:flex;flex-wrap:wrap;gap:12px}.sort-label{color:var(--text);font-size:.95rem;font-weight:500;margin:0}.sort-select{background:var(--bg);border:2px solid var(--border);border-radius:12px;color:var(--text);cursor:pointer;font-size:.9rem;min-width:200px;padding:10px 16px;transition:all .3s ease}.sort-select:hover{border-color:var(--accent-mint-a)}.sort-select:focus{border-color:var(--primary-indigo);box-shadow:0 0 0 3px #667eea26;outline:none}.debts-list{grid-gap:20px;display:grid;gap:20px}.empty-state{background:var(--card);border:1px solid var(--border);border-radius:20px;box-shadow:0 4px 20px #00000014;padding:60px 20px;text-align:center}.empty-state .empty-icon{font-size:4rem;margin-bottom:20px}.empty-state h2{color:var(--text);font-size:1.8rem;font-weight:600;margin-bottom:15px}.empty-state p{color:var(--muted);font-size:1.1rem;margin-bottom:30px}@media (max-width:768px){.debt-page{padding:15px}.debt-header{align-items:stretch;flex-direction:column;gap:15px}.debt-header h1{font-size:2rem;text-align:center}.debt-stats{gap:15px;grid-template-columns:1fr}.debt-controls{padding:16px}.filter-section{margin-bottom:16px}.filter-chips{gap:6px}.filter-chip{flex:1 1;font-size:.85rem;justify-content:center;min-width:0;padding:8px 14px}.sort-section{align-items:stretch;flex-direction:column;gap:8px}.sort-label{font-size:.9rem}.sort-select{min-width:100%;width:100%}}@media (max-width:480px){.debt-page{padding:10px}.debt-header h1{font-size:1.8rem}.debt-controls{padding:12px}.filter-chips{grid-gap:8px;display:grid;gap:8px;grid-template-columns:1fr 1fr}.filter-chip{font-size:.8rem;padding:10px 8px}.create-debt-btn{margin-top:10px;width:100%}.stat-card{padding:15px}.stat-card .amount{font-size:1.5rem}}[data-theme=dark] .stat-card{box-shadow:0 4px 20px #0000004d}[data-theme=dark] .create-debt-btn{box-shadow:0 4px 15px #2dd4bf33}[data-theme=dark] .create-debt-btn:hover{box-shadow:0 8px 20px #2dd4bf4d}.debt-page .modal-header,.debt-page .modal-header:after,.debt-page .modal-header:before{animation:none!important;background:#0000!important;background-image:none!important;border:0!important;box-shadow:none!important;content:none!important}.debt-page .debt-header,.debt-page .debt-header:after,.debt-page .debt-header:before,.debt-page .modal-header,.debt-page .modal-header:after,.debt-page .modal-header:before,.debt-page .page-header,.debt-page .page-header:after,.debt-page .page-header:before,.debt-page header,.debt-page header:after,.debt-page header:before{animation:none!important;background:#0000!important;background-image:none!important;border:0!important;box-shadow:none!important;content:none!important;filter:none!important}.debt-page [class*=Header]:after,.debt-page [class*=Header]:before,.debt-page [class*=header]:after,.debt-page [class*=header]:before{background:#0000!important;background-image:none!important;content:none!important}.debt-page .bg-gradient-to-b,.debt-page .bg-gradient-to-l,.debt-page .bg-gradient-to-r,.debt-page .bg-gradient-to-t,.debt-page .from-indigo-500,.debt-page .from-purple-500,.debt-page .to-indigo-600,.debt-page .to-purple-600,.debt-page .via-purple-500{background-color:initial!important;background-image:none!important}.debt-page.debt-page .debt-header,.debt-page.debt-page .debt-header *{background:#0000!important;background-image:none!important}.hamburger-menu{background:none;border:none;cursor:pointer;display:flex;flex-direction:column;height:24px;justify-content:space-around;padding:0;position:fixed;right:25px;right:calc(25px + var(--safe-area-inset-right, 0px));top:25px;top:calc(25px + var(--safe-area-inset-top, 0px));width:30px;z-index:2001}.line{background-color:var(--text-primary-color);border-radius:2px;height:3px;transition:all .3s ease-in-out;width:100%}.line-1.open{transform:rotate(45deg) translate(5px,6px)}.line-2.open{opacity:0}.line-3.open{transform:rotate(-45deg) translate(5px,-6px)}.sidebar{background-color:var(--card-bg-color);box-shadow:-5px 0 20px #0000001a;height:100vh;height:calc(100vh - var(--safe-area-inset-bottom, 0px));padding-bottom:0;padding-bottom:var(--safe-area-inset-bottom,0);padding-top:80px;padding-top:calc(80px + var(--safe-area-inset-top, 0px));position:fixed;right:0;top:0;transform:translateX(100%);transition:transform .3s ease-in-out,background-color .3s;width:280px;z-index:2000}.sidebar.open{transform:translateX(0)}.sidebar nav ul{list-style:none;margin:0;padding:0}.sidebar nav li{padding:20px;text-align:center}.sidebar nav a{color:var(--text-primary-color);font-size:1.2rem;font-weight:700;text-decoration:none}.dashboard-grid-container{position:relative;z-index:1}.logout-button{background-color:initial;border:2px solid var(--text-secondary-color);border-radius:8px;color:var(--text-secondary-color);cursor:pointer;font-size:1rem;font-weight:700;margin-top:10px;padding:10px 20px;transition:all .2s ease-in-out;width:80%}.logout-button:hover{background-color:var(--text-secondary-color);color:var(--card-bg-color)}@media (max-width:768px){.hamburger-menu{height:20px;right:20px;right:calc(20px + var(--safe-area-inset-right, 0px));top:20px;top:calc(20px + var(--safe-area-inset-top, 0px));width:25px}.line{height:2px}.sidebar{max-width:320px;padding-top:70px;padding-top:calc(70px + var(--safe-area-inset-top, 0px));width:100%}.sidebar nav a{font-size:16px;padding:15px 20px}.logout-button{font-size:16px;padding:12px;width:90%}}@media (max-width:480px){.hamburger-menu{height:18px;right:15px;right:calc(15px + var(--safe-area-inset-right, 0px));top:15px;top:calc(15px + var(--safe-area-inset-top, 0px));width:22px}.sidebar{padding-top:60px;padding-top:calc(60px + var(--safe-area-inset-top, 0px));width:100vw}.sidebar nav a{font-size:15px;padding:12px 15px}.logout-button{font-size:14px;margin-top:15px;padding:10px;width:95%}}:root{--background-color:#f7f9fc;--card-bg-color:#fff;--text-primary-color:#333;--text-secondary-color:#666;--border-color:#ddd;--input-bg-color:#f7f9fc;--safe-area-inset-top:env(safe-area-inset-top);--safe-area-inset-right:env(safe-area-inset-right);--safe-area-inset-bottom:env(safe-area-inset-bottom);--safe-area-inset-left:env(safe-area-inset-left)}[data-theme=dark]{--background-color:#121212;--card-bg-color:#1e1e1e;--text-primary-color:#e0e0e0;--text-secondary-color:#b0b0b0;--border-color:#444;--input-bg-color:#2a2a2a}body,html{overflow-x:hidden}#root,body,html{background-color:#f7f9fc;background-color:var(--background-color)}#root{min-height:100vh;min-height:calc(100vh - env(safe-area-inset-top) - env(safe-area-inset-bottom));min-height:calc(100vh - var(--safe-area-inset-top) - var(--safe-area-inset-bottom));padding:env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left);padding:var(--safe-area-inset-top) var(--safe-area-inset-right) var(--safe-area-inset-bottom) var(--safe-area-inset-left);transition:background-color .3s}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f7f9fc;background-color:var(--background-color);color:#333;color:var(--text-primary-color);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0;transition:background-color .3s,color .3s}.login-page-container{background-attachment:fixed;background-image:url(../../static/media/background.b1b0d6548ff3164e0ae5.jpg);background-position:50%;background-size:cover;box-sizing:border-box;min-height:100vh;min-height:calc(100vh - env(safe-area-inset-top) - env(safe-area-inset-bottom));min-height:calc(100vh - var(--safe-area-inset-top, 0px) - var(--safe-area-inset-bottom, 0px));overflow-x:hidden;padding:20px}.login-form-container,.login-page-container{align-items:center;display:flex;justify-content:center;position:relative}.login-form-container{backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);background:#ffffffe6;border:1px solid #ffffff2e;border-radius:20px;box-shadow:0 8px 32px 0 #1f26875e;flex-direction:column;margin:20px auto;max-width:400px;min-height:auto;padding:40px;text-align:center;width:100%;z-index:1}.logo-img{margin-bottom:1rem;width:80px}.login-form{display:flex;flex-direction:column;gap:15px;margin-top:20px;width:100%}.login-form input{border:1px solid #ddd;border-radius:8px;font-size:16px;padding:12px 15px}.submit-button{background:linear-gradient(90deg,#2dd4bf,#34d399);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:16px;font-weight:700;padding:12px;transition:transform .2s}.submit-button:hover{transform:scale(1.03)}.login-links{display:flex;justify-content:space-between;margin-top:20px;width:100%}.login-links a{color:#555;font-size:14px;text-decoration:none}.login-links a:hover{text-decoration:underline}.loading-spinner-overlay{align-items:center;display:flex;justify-content:center}.loading-spinner-logo{animation:pulse 1.5s ease-in-out infinite;width:100px}@keyframes pulse{0%{transform:scale(.95)}50%{transform:scale(1.05)}to{transform:scale(.95)}}.form-flipper{height:100%;position:relative;width:100%}.form-wrapper{align-items:center;display:flex;flex-direction:column;height:100%;justify-content:center;left:0;opacity:0;position:absolute;top:0;transform:translateX(100%);transition:opacity .4s ease-in-out,transform .4s ease-in-out;width:100%}.form-wrapper.active{opacity:1;transform:translateX(0)}.form-wrapper:not(.active){transform:translateX(-100%)}.form-wrapper h2{color:#333;font-size:1.2rem;margin:10px 0}.progress-bar-container{background-color:#e0e0e0;border-radius:4px;height:8px;margin:15px 0;overflow:hidden;width:80%}.progress-bar{background:linear-gradient(90deg,#2dd4bf,#34d399);border-radius:4px;height:100%;transition:width .4s ease-in-out}.multi-step-form{margin-top:10px;min-height:180px;overflow:hidden;position:relative;width:100%}.form-step{align-items:center;display:flex;flex-direction:column;gap:10px;left:0;opacity:0;position:absolute;top:0;transform:translateY(20px);transition:opacity .4s ease-out,transform .4s ease-out,visibility .4s;visibility:hidden;width:100%}.form-step.active{opacity:1;transform:translateY(0);visibility:visible}.form-step label{color:#333;font-weight:700}.form-step input{border:1px solid #ddd;border-radius:8px;font-size:16px;padding:12px 15px;text-align:center;width:90%}.form-step .submit-button{width:100%}.error-message,.success-message{border-radius:8px;font-weight:500;margin-bottom:15px;padding:12px;text-align:center;width:100%}.error-message{background-color:#f8d7da;border:1px solid #f5c6cb;color:#721c24}.success-message{background-color:#d4edda;border:1px solid #c3e6cb;color:#155724}.password-input-container{align-items:center;display:flex;position:relative;width:100%}.password-input-container input{box-sizing:border-box;padding-right:45px!important;width:100%}.password-toggle-btn{align-items:center;background:none;border:none;cursor:pointer;display:flex;justify-content:center;padding:0;position:absolute;right:10px;top:50%;transform:translateY(-50%)}.password-toggle-btn svg{stroke:#666;stroke:var(--text-secondary-color);transition:stroke .2s}.password-toggle-btn:hover svg{stroke:#333;stroke:var(--text-primary-color)}.form-step .password-input-container{width:90%}@media (max-width:768px){.login-page-container{align-items:center;justify-content:center;min-height:100vh;padding:20px 15px}.login-form-container{box-shadow:0 8px 32px 0 #1f26875e;margin:0;max-width:100%;min-height:auto;padding:30px 25px;width:100%}.logo-img{margin-bottom:1.2rem;width:65px}.form-wrapper h2{font-size:1.3rem;line-height:1.4;margin-bottom:15px}.login-form,.multi-step-form{gap:18px;margin-top:20px}.login-form input,.multi-step-form input,.multi-step-form select{font-size:16px;margin-bottom:5px;padding:16px 15px}.submit-button{font-size:16px;margin-top:8px;padding:16px}.form-step h3{font-size:18px;margin-bottom:10px}.form-step .password-input-container,.password-input-container{width:100%}.login-links{align-items:center;flex-direction:column;gap:15px;margin-top:25px}.modal-nav-buttons{flex-direction:column;gap:12px;margin-top:15px}.btn-secondary{padding:14px;width:100%}}@media (max-width:480px){.login-page-container{align-items:center;justify-content:center;min-height:100vh;padding:15px 10px}.login-form-container{border-radius:18px;box-shadow:0 8px 32px 0 #1f268766;margin:0;max-width:100%;padding:25px 20px;width:100%}.logo-img{margin-bottom:1rem;width:55px}.form-wrapper h2{font-size:1.1rem;line-height:1.3;margin-bottom:12px}.login-form,.multi-step-form{gap:20px;margin-top:18px}.login-form input,.multi-step-form input,.multi-step-form select{font-size:16px;margin-bottom:3px;padding:14px 12px}.submit-button{font-size:16px;margin-top:5px;padding:15px}.form-step h3{font-size:16px;margin-bottom:10px}.form-step{margin-bottom:15px}.login-links,.modal-nav-buttons{gap:8px;margin-top:15px}.input-hint{font-size:12px;margin-top:5px}.password-toggle-btn{padding:8px}}
/*# sourceMappingURL=main.fd96ec5f.css.map*/