@import"https://fonts.googleapis.com/css2?family=Montserrat:wght@300;400;500;600;700&display=swap";*{margin:0;padding:0;box-sizing:border-box}:root{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--color-bg-base: #ffffff;--color-bg-gradient-start: #ffffff;--color-bg-gradient-end: #ffffff;--color-bg-card: #ffffff;--color-bg-card-blur: rgba(255, 255, 255, .6);--color-text-main: #111827;--color-text-muted: #6b7280;--color-text-inverse: #ffffff;--color-border-soft: rgba(15, 23, 42, .06);--shadow-soft: 0 10px 30px rgba(15, 23, 42, .08);--color-primary: #BFC6C4;--color-primary-soft: #EFEFEF;--color-primary-strong: #6B7573;--color-accent-green: #22c55e;--color-accent-yellow: #facc15;--color-expense: #ef4444;--color-expense-soft: #fee2e2;--color-expense-text: #b91c1c;--color-saving: #10b981;--color-saving-soft: #d1fae5;--color-saving-text: #059669}[data-theme=dark]{--color-bg-base: #161a1d;--color-bg-gradient-start: #161a1d;--color-bg-gradient-end: #0b090a;--color-bg-card: #1f2428;--color-bg-card-blur: rgba(22, 26, 29, .8);--color-text-main: #ffffff;--color-text-muted: #9BA4B5;--color-border-soft: rgba(255, 255, 255, .05);--shadow-soft: 0 10px 30px #0b090a;--color-primary-soft: rgba(255, 255, 255, .1);--color-expense: #f87171;--color-expense-soft: rgba(248, 113, 113, .15);--color-expense-text: #fecaca;--color-saving: #34d399;--color-saving-soft: rgba(52, 211, 153, .15);--color-saving-text: #6ee7b7}html{height:100dvh;width:100vw;overflow:hidden;position:fixed}body{margin:0;padding:0;min-width:320px;width:100vw;height:100dvh;overflow:hidden;position:fixed;background:radial-gradient(circle at top left,var(--color-bg-gradient-start) 0%,var(--color-bg-gradient-end) 50%,var(--color-bg-gradient-start) 100%);background-attachment:fixed;color:var(--color-text-main);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overscroll-behavior:none;touch-action:manipulation;-webkit-tap-highlight-color:transparent;transition:background .3s ease,color .3s ease}#root{height:100%;width:100%;overflow:hidden;margin:0;padding:0;display:flex;flex-direction:column}[data-theme=dark] .app-name,[data-theme=dark] .card-title,[data-theme=dark] .review-title,[data-theme=dark] .review-value,[data-theme=dark] .ganaat-input,[data-theme=dark] .review-input{color:#fff}[data-theme=dark] .app-tagline,[data-theme=dark] .review-label,[data-theme=dark] .footer-text{color:#9ba4b5}[data-theme=dark] .input-card,[data-theme=dark] .review-card{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);box-shadow:10px 10px 20px #0b090a,-5px -5px 15px #ffffff08}[data-theme=dark] .ganaat-input,[data-theme=dark] .review-input{background:#0000004d;border:1px solid rgba(255,255,255,.1);color:#fff}[data-theme=dark] .input-icon,[data-theme=dark] .password-toggle,[data-theme=dark] .review-input-icon{color:#fff9}.app-name{font-size:2rem;font-weight:600;color:#1a1a1a;margin:0 0 .5rem;letter-spacing:-.01em}.ganaat-content{flex:.8;padding:1.5rem 1.5rem 2rem;display:flex;flex-direction:column;justify-content:flex-start;align-items:center;position:relative;overflow:visible}.cards-container{position:relative;width:100%;max-width:100%;min-height:200px;display:flex;justify-content:center;align-items:flex-start;padding-top:2rem}.input-card{position:absolute;width:calc(100% - 1rem);max-width:calc(100% - 1rem);background:#ffffff40;backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px);border-radius:24px;padding:1rem 1.5rem;border:1px solid rgba(255,255,255,.3);box-shadow:0 2px 8px #0000000d;transition:all .4s cubic-bezier(.4,0,.2,1);transform-origin:top left;top:0;left:.5rem}.input-card.active{transform:translateY(0) translate(0) scale(1);opacity:1;z-index:10;background:#ffffff4d;box-shadow:0 2px 8px #0000000d}.input-card.stacked{opacity:.8;pointer-events:none;background:#fff3;box-shadow:0 2px 8px #0000000d;display:flex;flex-direction:column}.input-card.active{display:flex;flex-direction:column}.card-header{margin-bottom:.5rem;margin-top:0;padding-top:0;padding-left:0;text-align:left}.input-card.stacked .card-header{margin-bottom:0;margin-top:.75rem;order:2}.input-card.stacked .input-field-wrapper{order:1}.input-field-wrapper{display:flex;align-items:center;gap:.75rem;width:100%}.card-title{font-size:.95rem;font-weight:600;color:#1a1a1a;margin:0;text-shadow:0 1px 2px rgba(255,255,255,.5);letter-spacing:-.01em}.input-card.stacked .card-title{font-size:.75rem;font-weight:500}.previous-icon-button{width:40px;height:40px;min-width:40px;display:flex;align-items:center;justify-content:center;background:#bfc6c426;backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px);border:1.5px solid rgba(191,198,196,.4);border-radius:50%;cursor:pointer;transition:all .2s ease;-webkit-tap-highlight-color:transparent;touch-action:manipulation;box-shadow:none;color:#bfc6c4;padding:0}.previous-icon-button:hover{background:#bfc6c440;border-color:#bfc6c499}.previous-icon-button svg{width:22px;height:22px}.previous-icon-button:active{transform:scale(.95);background:linear-gradient(135deg,#bfc6c4e6,#bfc6c4e6)}.previous-icon-button:disabled{opacity:.6;cursor:not-allowed}.next-icon-button{width:40px;height:40px;min-width:40px;display:flex;align-items:center;justify-content:center;background:#bfc6c426;backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px);border:1.5px solid rgba(191,198,196,.4);border-radius:50%;cursor:pointer;transition:all .2s ease;-webkit-tap-highlight-color:transparent;touch-action:manipulation;box-shadow:none;color:#bfc6c4;padding:0}.next-icon-button:hover{background:#bfc6c440;border-color:#bfc6c499}.next-icon-button svg{width:22px;height:22px}.next-icon-button:active{transform:scale(.95);background:linear-gradient(135deg,#bfc6c4e6,#bfc6c4e6)}.next-icon-button:disabled{opacity:.6;cursor:not-allowed}.review-section{width:100%;max-width:100%;animation:fadeIn .4s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.review-card-container{width:100%;display:flex;justify-content:center;align-items:flex-start}.review-card{width:100%;background:#ffffff40;backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px);border-radius:24px;padding:1.5rem;border:1px solid rgba(255,255,255,.3);box-shadow:0 2px 8px #0000000d;animation:slideUp .4s ease-out}.review-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid rgba(255,255,255,.2)}.review-title{font-size:1.5rem;font-weight:600;color:#1a1a1a;margin:0;flex:1}.edit-button{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:#bfc6c426;backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px);border:1.5px solid rgba(191,198,196,.4);border-radius:50%;cursor:pointer;transition:all .2s ease;-webkit-tap-highlight-color:transparent;touch-action:manipulation;color:#bfc6c4;padding:0}.edit-button:hover{background:#bfc6c440;border-color:#bfc6c499}.edit-button:active{transform:scale(.95)}.edit-button svg{width:18px;height:18px}.review-content{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1.5rem}.review-item{display:flex;align-items:center;gap:.75rem;padding:.5rem 0}.review-label{font-size:.875rem;font-weight:600;color:#666;min-width:80px}.review-value{font-size:.9375rem;font-weight:500;color:#1a1a1a;flex:1}.review-form{margin-top:1.5rem}.review-card.edit-mode{padding-bottom:1.5rem}.review-edit-content{display:flex;flex-direction:column;gap:1rem}.review-edit-item{display:flex;flex-direction:column;gap:.5rem}.review-edit-label{font-size:.875rem;font-weight:600;color:#666;margin-bottom:.25rem}.review-input-wrapper{position:relative;display:flex;align-items:center}.review-input-icon{position:absolute;left:.875rem;width:18px;height:18px;color:#1a1a1ab3;z-index:1;pointer-events:none}.review-input-icon svg{width:100%;height:100%}.review-input{width:100%;padding:.625rem .875rem .625rem 3rem;font-size:14px;border:1px solid rgba(255,255,255,.4);border-radius:12px;background:#fff6;backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px);color:#1a1a1a;transition:all .3s ease;outline:none;font-family:inherit;-webkit-appearance:none;appearance:none;min-height:44px;box-sizing:border-box;box-shadow:none}.review-input:focus{border:1px solid rgba(255,255,255,.6);background:#ffffff80;box-shadow:0 0 0 2px #fff3}.review-input.input-error{border:1px solid rgba(255,59,48,.5);background:#fff5f566}.review-input.input-error:focus{border:1px solid rgba(255,59,48,.6);background:#fff5f580;box-shadow:0 0 0 2px #ff3b3033}.review-password-toggle{position:absolute;right:.875rem;width:20px;height:20px;display:flex;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;color:#1a1a1a99;padding:0;z-index:1;transition:color .2s ease}.review-password-toggle:hover{color:#1a1a1acc}.review-password-toggle svg{width:100%;height:100%}.review-error-text{font-size:.75rem;color:#ff3b30;margin-top:.25rem;padding-left:.5rem}.review-edit-actions{display:flex;gap:.75rem;margin-top:1rem}.review-cancel-button,.review-save-button{flex:1;padding:.875rem 1.5rem;font-size:.9375rem;font-weight:600;border-radius:12px;cursor:pointer;transition:all .2s ease;border:none;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.review-cancel-button{background:#fff3;color:#666;border:1px solid rgba(255,255,255,.3)}.review-cancel-button:active{background:#ffffff4d;transform:scale(.98)}.review-save-button{background:linear-gradient(135deg,#bfc6c4e6,#bfc6c4e6);color:#fff;border:1px solid rgba(255,255,255,.3);box-shadow:0 2px 6px #bfc6c433}.review-save-button:active{transform:scale(.98);background:linear-gradient(135deg,#bfc6c4e6,#bfc6c4e6)}.ganaat-form{display:flex;flex-direction:column;gap:1.25rem;max-width:100%}.input-field{position:relative;display:flex;align-items:center;flex:1}.input-icon{position:absolute;left:.875rem;width:18px;height:18px;color:#1a1a1ab3;z-index:1;pointer-events:none}.ganaat-input{width:100%;padding:.625rem .875rem .625rem 3rem;font-size:14px;border:1px solid rgba(255,255,255,.4);border-radius:12px;background:#fff6;backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px);color:#1a1a1a;transition:all .3s ease;outline:none;font-family:inherit;-webkit-appearance:none;appearance:none;min-height:44px;box-sizing:border-box;box-shadow:none}.ganaat-input:focus{border:1px solid rgba(255,255,255,.6);background:#ffffff80;box-shadow:0 0 0 4px #ffffff4d,0 2px 8px #0000000d inset}.ganaat-input.input-error:focus{border:1px solid rgba(255,59,48,.6);background:#fff5f580;box-shadow:0 0 0 4px #ff3b3033,0 2px 8px #0000000d inset}.ganaat-input:disabled{opacity:.5;cursor:not-allowed;background:#fff3;border:1px solid rgba(255,255,255,.2)}.password-toggle:disabled{opacity:.3;pointer-events:none}.password-toggle{position:absolute;right:.75rem;background:#ffffff4d;backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px);border:1px solid rgba(255,255,255,.3);border-radius:6px;padding:.375rem;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#1a1a1ab3;-webkit-tap-highlight-color:transparent;touch-action:manipulation;z-index:1;transition:all .2s ease}.password-toggle:active{background:#fff6;transform:scale(.95)}.password-toggle svg{width:14px;height:14px}.password-toggle:active{opacity:.6}.error-text{color:#ff3b30;font-size:.8125rem;font-weight:500;margin-top:.5rem;margin-left:.5rem;line-height:1.4;display:block}@media(min-width:640px){.ganaat-container{background:radial-gradient(circle at top left,#fff7f0,#ffe9dc 45%,#fff7f0);align-items:center;justify-content:center;padding:2rem}.ganaat-header{max-width:480px;width:100%;padding:2.5rem 1.5rem 2rem}.ganaat-content{max-width:480px;width:100%;padding:2rem 1.5rem}.ganaat-footer{max-width:480px;width:100%;padding:1.5rem}.logo-icon{width:100px;height:100px;border-radius:24px}.logo-icon svg{width:60px;height:60px}.app-name{font-size:2.5rem}.app-tagline{font-size:1rem}.ganaat-form{gap:1.5rem}}@media(min-width:1024px){.ganaat-header,.ganaat-content,.ganaat-footer{max-width:520px}}@media screen and (max-width:768px){html{-webkit-text-size-adjust:100%}}@supports (padding: max(0px)){.ganaat-container{padding-top:max(0px,env(safe-area-inset-top,0px));padding-bottom:max(0px,env(safe-area-inset-bottom,0px))}}.ganaat-content{scroll-behavior:smooth;-webkit-overflow-scrolling:touch}.ganaat-container{min-height:100vh;min-height:100dvh;display:flex;flex-direction:column;background:radial-gradient(circle at top left,#fff7f0,#ffe9dc 45%,#fff7f0);padding-top:env(safe-area-inset-top,0px);padding-bottom:env(safe-area-inset-bottom,0px);overflow-x:hidden;overflow-y:auto;position:relative}[data-theme=dark] .app-name,[data-theme=dark] .login-title,[data-theme=dark] .ganaat-input,[data-theme=dark] .review-value{color:#fff}[data-theme=dark] .app-tagline,[data-theme=dark] .footer-text{color:#9ba4b5}[data-theme=dark] .login-card{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);box-shadow:10px 10px 20px #0b090a,-5px -5px 15px #ffffff08}[data-theme=dark] .ganaat-input{background:#0000004d;border:1px solid rgba(255,255,255,.1);color:#fff}[data-theme=dark] .input-icon,[data-theme=dark] .password-toggle{color:#fff9}.logo-icon{width:80px;height:80px;background:#bfc6c4;border-radius:15px;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 4px #bfc6c433;margin:0 auto}.app-name{font-size:2rem;font-weight:600;color:var(--neu-text);margin:0 0 .5rem;letter-spacing:-.01em}.app-tagline{font-size:.95rem;color:#666;margin:0;font-weight:400}.login-card{width:100%;max-width:100%;background:#ffffff40;backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px);border-radius:24px;padding:2rem 1.5rem;border:1px solid rgba(255,255,255,.3);box-shadow:0 2px 8px #0000000d;animation:slideUp .4s ease-out}.login-title{font-size:1.75rem;font-weight:600;color:var(--neu-text);margin:0 0 2rem;text-align:center}.login-form{display:flex;flex-direction:column;gap:1.25rem}.login-field{position:relative;display:flex;flex-direction:column;gap:.5rem}.input-icon{position:absolute;left:.875rem;top:50%;transform:translateY(-50%);width:18px;height:18px;color:#1a1a1ab3;z-index:1;pointer-events:none}.input-icon svg{width:100%;height:100%}.ganaat-input{width:100%;padding:.625rem .875rem .625rem 3rem;font-size:14px;border:1px solid rgba(255,255,255,.4);border-radius:12px;background:#fff6;backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px);color:var(--neu-text);transition:all .3s ease;outline:none;font-family:inherit;-webkit-appearance:none;appearance:none;min-height:44px;box-sizing:border-box;box-shadow:none}.ganaat-input:focus{border:1px solid rgba(255,255,255,.6);background:#ffffff80;box-shadow:0 0 0 2px #fff3}.ganaat-input::placeholder{color:#999;opacity:1}.ganaat-input.input-error{border:1px solid rgba(255,59,48,.5);background:#fff5f566}.ganaat-input.input-error:focus{border:1px solid rgba(255,59,48,.6);background:#fff5f580;box-shadow:0 0 0 2px #ff3b3033}.password-toggle{position:absolute;right:.875rem;top:50%;transform:translateY(-50%);width:20px;height:20px;display:flex;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;color:#1a1a1a99;padding:0;z-index:1;transition:color .2s ease;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.password-toggle:hover{color:#1a1a1acc}.password-toggle:active{opacity:.7}.password-toggle svg{width:100%;height:100%}.error-text{font-size:.75rem;color:#ff3b30;margin-top:.25rem;padding-left:.5rem}.submit-error-message{background:#ff3b301a;border:1px solid rgba(255,59,48,.3);border-radius:12px;padding:.875rem 1rem;color:#ff3b30;font-size:.875rem;margin-bottom:1rem;text-align:center}.forgot-password{text-align:right;margin-top:-.5rem;margin-bottom:.5rem}.forgot-password-link{font-size:.875rem;color:#bfc6c4;text-decoration:none;font-weight:600;transition:opacity .2s ease;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.forgot-password-link:active{opacity:.7}.ganaat-button{width:100%;padding:1.125rem 1.5rem;font-size:1rem;font-weight:600;color:#fff;background:linear-gradient(135deg,#bfc6c4e6,#bfc6c4e6);backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px);border:1px solid rgba(255,255,255,.3);border-radius:16px;cursor:pointer;transition:all .3s ease;margin-top:.75rem;min-height:56px;-webkit-tap-highlight-color:transparent;touch-action:manipulation;box-shadow:0 2px 6px #bfc6c433;display:flex;align-items:center;justify-content:center;gap:.5rem}.ganaat-button span{flex:1;text-align:center}.ganaat-button svg{width:20px;height:20px;flex-shrink:0}.ganaat-button:active{transform:scale(.98);background:linear-gradient(135deg,#bfc6c4e6,#bfc6c4e6);box-shadow:0 1px 4px #bfc6c44d}.ganaat-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.ganaat-footer{padding:1.5rem;padding-bottom:max(1.5rem,env(safe-area-inset-bottom,0px) + 1rem);text-align:center}.footer-text{font-size:.875rem;color:#666;margin:0;line-height:1.5}.footer-link{color:#bfc6c4;text-decoration:none;font-weight:600;transition:opacity .2s ease;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.footer-link:active{opacity:.7}@media(min-width:640px){.ganaat-container{align-items:center;justify-content:center;padding:2rem}.ganaat-header{max-width:480px;width:100%;padding:2.5rem 1.5rem 2rem}.ganaat-content{max-width:480px;width:100%;padding:2rem 1.5rem}.login-card{max-width:480px}.ganaat-footer{max-width:480px;width:100%}}.ganaat-container{min-height:100vh;min-height:100dvh;display:flex;flex-direction:column;background:#f8f6f8;padding-top:env(safe-area-inset-top,0px);padding-bottom:env(safe-area-inset-bottom,0px);overflow-x:hidden;overflow-y:auto;position:relative}[data-theme=dark] .ganaat-container{background:#161a1d}[data-theme=dark] .app-name,[data-theme=dark] .success-title{color:#fff}[data-theme=dark] .app-tagline,[data-theme=dark] .success-message,[data-theme=dark] .success-auto-redirect{color:#9ba4b5}[data-theme=dark] .success-card{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);box-shadow:10px 10px 20px #0b090a,-5px -5px 15px #ffffff08}.ganaat-header{display:flex;flex-direction:column;align-items:center;padding:2rem 1.5rem 1.5rem;text-align:center}.logo-container{margin-bottom:1rem}.logo-icon{width:80px;height:80px;background:#219ebc;border-radius:15px;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 4px #219ebc33;margin:0 auto}.logo-icon svg{width:50px;height:50px;color:#fff}.app-name{font-size:2rem;font-weight:600;color:var(--neu-text);margin:0 0 .5rem;letter-spacing:-.02em}.app-tagline{font-size:.95rem;color:var(--neu-text-secondary);margin:0;font-weight:400}.ganaat-content{flex:1;padding:1.5rem 1.5rem 2rem;display:flex;flex-direction:column;justify-content:flex-start;align-items:center;position:relative;overflow:visible}.success-card{width:100%;max-width:100%;background:#ffffff40;backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px);border-radius:24px;padding:3rem 2rem;border:1px solid rgba(255,255,255,.3);box-shadow:0 2px 8px #0000000d;animation:slideUp .4s ease-out;text-align:center;display:flex;flex-direction:column;align-items:center}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.success-icon{width:80px;height:80px;background:linear-gradient(135deg,#219ebce6,#219ebce6);border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:1.5rem;color:#fff;animation:scaleIn .5s ease-out}@keyframes scaleIn{0%{transform:scale(0);opacity:0}to{transform:scale(1);opacity:1}}.success-icon svg{width:50px;height:50px}.success-title{font-size:1.75rem;font-weight:600;color:var(--neu-text);margin:0 0 1rem}.success-message{font-size:1rem;color:var(--neu-text-secondary);margin:0 0 1rem;line-height:1.6}.success-user-name{font-size:1.125rem;font-weight:600;color:#219ebc;margin:0 0 2rem}.success-button{width:100%;padding:1.125rem 1.5rem;font-size:1rem;font-weight:600;color:#fff;background:linear-gradient(135deg,#219ebce6,#219ebce6);backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px);border:1px solid rgba(255,255,255,.3);border-radius:16px;cursor:pointer;transition:all .3s ease;margin-top:1rem;min-height:56px;-webkit-tap-highlight-color:transparent;touch-action:manipulation;box-shadow:0 2px 6px #219ebc33}.success-button:active{transform:scale(.98);background:linear-gradient(135deg,#219ebce6,#219ebce6);box-shadow:0 1px 4px #219ebc4d}.success-auto-redirect{font-size:.875rem;color:#999;margin:1.5rem 0 0}@media(min-width:640px){.success-card{max-width:480px}}.habits-container{min-height:100vh;min-height:100dvh;background:radial-gradient(circle at top left,var(--color-bg-gradient-start) 0%,var(--color-bg-gradient-end) 50%,var(--color-bg-gradient-start) 100%);padding:env(safe-area-inset-top,0px) 0 env(safe-area-inset-bottom,0px) 0;overflow-x:hidden;overflow-y:auto;position:relative}.habits-header{display:flex;align-items:center;justify-content:space-between;padding:1rem .5rem;background:var(--color-bg-card-blur);border-bottom:1px solid var(--color-border-soft);position:sticky;top:0;z-index:10;box-shadow:0 1px 3px #0000000a}.back-button{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:10px;cursor:pointer;color:var(--color-text-main);transition:all .2s ease;-webkit-tap-highlight-color:transparent}.back-button:hover{background:var(--color-border-soft)}.back-button:active{transform:scale(.95);background:#00000014}.back-button svg{width:22px;height:22px}.habits-title{font-size:1.25rem;font-weight:600;color:var(--color-text-main);margin:0;flex:1;text-align:center;letter-spacing:-.02em}.add-habit-button{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-strong) 100%);border:none;border-radius:12px;cursor:pointer;color:#fff;transition:all .25s cubic-bezier(.4,0,.2,1);-webkit-tap-highlight-color:transparent;box-shadow:0 2px 4px #bfc6c44d}.add-habit-button:hover{background:linear-gradient(135deg,var(--color-primary-strong) 0%,#ff6b1f 100%);transform:translateY(-1px);box-shadow:0 4px 10px #f8943c59}.add-habit-button:active{transform:translateY(0) scale(.95);box-shadow:0 2px 4px #f8943c40}.add-habit-button svg{width:18px;height:18px}.habits-content{padding:1rem .5rem 2rem;max-width:2592px;margin:0 auto}.habits-loading{text-align:center;padding:3rem 1rem;color:var(--color-text-muted);font-size:.875rem}.habits-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 1rem;text-align:center}.habits-empty svg{width:56px;height:56px;color:var(--color-text-muted);margin-bottom:.875rem;opacity:.5}.habits-empty p{font-size:.9375rem;color:var(--color-text-muted);margin:0 0 1.25rem}.habits-empty-button{padding:.6875rem 1.25rem;background:var(--color-primary);color:#fff;border:none;border-radius:10px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease}.habits-empty-button:hover{background:var(--color-primary-strong)}.habits-empty-button:active{background:#17819a;transform:scale(.98)}.habits-error{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 1rem;text-align:center}.habits-error svg{width:56px;height:56px;color:#ff6b35;margin-bottom:.875rem}.habits-error-message{font-size:.9375rem;color:var(--color-text-muted);margin:0 0 1.25rem;max-width:400px}.habits-retry-button{padding:.6875rem 1.25rem;background:var(--color-primary);color:#fff;border:none;border-radius:10px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease;-webkit-tap-highlight-color:transparent}.habits-retry-button:hover{background:var(--color-primary-strong)}.habits-retry-button:active{transform:scale(.98)}.habits-list{display:flex;flex-direction:column;gap:.25rem;padding-bottom:1rem}.habits-create-button-wrapper{display:flex;justify-content:center;align-items:center;padding:1.5rem 0;margin-top:.5rem}.habits-create-button{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:linear-gradient(135deg,#bfc6c4b3,#bfc6c4bf);color:#fff;border:none;border-radius:12px;cursor:pointer;transition:all .25s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 4px #bfc6c44d;-webkit-tap-highlight-color:transparent;touch-action:manipulation;padding:0}.habits-create-button:hover{background:linear-gradient(135deg,#bfc6c4cc,#a8b0aed9);transform:translateY(-1px);box-shadow:0 4px 10px #f8943c59}.habits-create-button:active{transform:translateY(0) scale(.95);box-shadow:0 2px 4px #f8943c40}.habits-create-button svg{width:18px;height:18px}.habits-create-button span{font-size:.875rem;font-weight:500;white-space:nowrap}.habit-item{background:var(--color-bg-card);border-radius:14px;padding:1.125rem 1.5rem;border:1px solid var(--color-border-soft);box-shadow:var(--shadow-soft);display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;transition:all .25s cubic-bezier(.4,0,.2,1);cursor:pointer;-webkit-user-select:none;user-select:none;width:100%;min-height:60px;max-width:100%;box-sizing:border-box}.habit-item:hover{box-shadow:0 6px 18px #0f172a1f;border-color:var(--color-primary-soft);transform:translateY(-1px)}.habit-item-expanded{border-color:var(--color-primary-soft);box-shadow:0 8px 24px #0f172a24;background:var(--color-bg-card)}.habit-info{flex:1;min-width:0}.habit-header-info{display:flex;align-items:center;gap:.5rem;margin-bottom:.375rem;flex-wrap:wrap;width:100%}.habit-item-expanded .habit-header-info{margin-bottom:.375rem}.habit-summary{display:flex;flex-wrap:wrap;gap:.75rem;padding-top:.625rem;margin-top:.375rem;border-top:1px solid var(--color-border-soft)}.habit-summary-item{font-size:.75rem;color:var(--color-text-muted);line-height:1.5;display:flex;align-items:center;gap:.25rem;opacity:.7}.habit-summary-item strong{color:var(--color-text-main);font-weight:600;font-size:.75rem}.habit-category{font-size:1rem;font-weight:600;color:var(--color-text-main);margin:0;line-height:1.5;letter-spacing:-.01em}.habit-subcategory{font-size:.75rem;color:var(--color-primary-strong);background:var(--color-primary-soft);padding:.25rem .625rem;border-radius:999px;font-weight:500;border:1px solid var(--color-primary-soft)}.habit-expand-icon{width:20px;height:20px;color:var(--color-text-muted);margin-left:auto;transition:transform .3s cubic-bezier(.4,0,.2,1);flex-shrink:0;opacity:.7}.habit-item:hover .habit-expand-icon{opacity:1;color:#bfc6c4}.habit-expand-icon.expanded{transform:rotate(180deg);color:#bfc6c4;opacity:1}.habit-create-item{background:var(--color-bg-card-blur);border:2px dashed var(--color-border-soft);box-shadow:none}.habit-create-item:hover{background:var(--color-bg-card);border-color:var(--color-primary);box-shadow:none}.habit-details{display:flex;flex-direction:column;gap:.5rem;animation:slideDown .3s cubic-bezier(.4,0,.2,1);overflow:hidden;padding:1rem .875rem;margin-top:.75rem;border-top:1px solid var(--color-border-soft);width:100%;background:var(--color-bg-base);border-radius:10px}@keyframes slideDown{0%{opacity:0;max-height:0;transform:translateY(-10px)}to{opacity:1;max-height:300px;transform:translateY(0)}}.habit-detail-item{font-size:.75rem;color:var(--color-text-muted);line-height:1.5;display:flex;align-items:center;gap:.375rem;padding:.375rem 0;opacity:.7}.habit-detail-item strong{color:var(--color-text-main);font-weight:600;min-width:110px;flex-shrink:0;font-size:.75rem}.habit-status-active{color:#10b981;font-weight:600;background:#10b9811a;padding:.125rem .5rem;border-radius:6px;font-size:.75rem}.habit-status-inactive{color:#ef4444;font-weight:600;background:#ef44441a;padding:.125rem .5rem;border-radius:6px;font-size:.75rem}.habit-actions{display:flex;align-items:center;gap:.375rem;flex-shrink:0}.habit-action-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:10px;cursor:pointer;transition:all .25s cubic-bezier(.4,0,.2,1);-webkit-tap-highlight-color:transparent}.habit-action-btn.edit-btn{color:#bfc6c4}.habit-action-btn.edit-btn:hover{background:#bfc6c41f;transform:translateY(-1px);box-shadow:0 2px 4px #bfc6c433}.habit-action-btn.edit-btn:active{background:#bfc6c42e;transform:translateY(0) scale(.95)}.habit-action-btn.delete-btn{color:#ff6b35}.habit-action-btn.delete-btn:hover{background:#ff6b351f;transform:translateY(-1px);box-shadow:0 2px 4px #ff6b3533}.habit-action-btn.delete-btn:active{background:#ff6b352e;transform:translateY(0) scale(.95)}.habit-action-btn svg{width:18px;height:18px}.modal-overlay{position:fixed;inset:0;background:#00000080;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:10000;padding:1rem}.modal-content-habit{background:var(--color-bg-card);border-radius:16px;width:100%;max-width:480px;max-height:90vh;overflow-y:auto;box-shadow:0 4px 20px #00000026}.habits-compact-section{margin:.75rem 0;width:100%}.habits-compact-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.habits-compact-title{font-size:.9375rem;font-weight:600;color:var(--color-text-main);margin:0;padding:0}.habits-see-all-button{display:flex;align-items:center;gap:.375rem;padding:.5rem .875rem;background:transparent;border:none;border-radius:10px;color:var(--color-primary);font-size:.8125rem;font-weight:600;cursor:pointer;transition:all .2s ease;-webkit-tap-highlight-color:transparent}.habits-see-all-button:hover{background:var(--color-primary-soft);color:var(--color-primary-strong)}.habits-see-all-button:active{transform:scale(.98);background:var(--color-primary-soft)}.habits-see-all-button svg{width:14px;height:14px;flex-shrink:0}.habits-add-button-compact{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-strong) 100%);border:none;border-radius:8px;cursor:pointer;color:#fff;transition:all .2s ease;box-shadow:0 2px 4px #bfc6c44d;-webkit-tap-highlight-color:transparent;flex-shrink:0}.habits-add-button-compact:hover{background:linear-gradient(135deg,var(--color-primary-strong) 0%,#ff6b1f 100%);transform:translateY(-1px);box-shadow:0 4px 10px #f8943c59}.habits-add-button-compact:active{transform:translateY(0) scale(.95);box-shadow:0 2px 4px #f8943c40}.habits-add-button-compact svg{width:18px;height:18px}.habits-scroll-container{display:flex;gap:.5rem;overflow-x:auto;overflow-y:hidden;padding-bottom:.5rem;-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none;touch-action:pan-x;overscroll-behavior-x:contain;pointer-events:auto}.habits-scroll-container::-webkit-scrollbar{display:none}.habit-square-card{min-width:180px;width:180px;height:160px;background:var(--color-bg-card);border-radius:16px;padding:.8rem 1rem;border:1.5px solid var(--color-border-soft);box-shadow:0 4px 12px #0f172a14,0 2px 4px #0f172a0a;display:flex;flex-direction:column;justify-content:space-between;flex-shrink:0;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.habit-square-card:hover{transform:translateY(-2px);box-shadow:0 8px 20px #0f172a1f,0 4px 8px #0f172a0f;border-color:var(--color-primary-soft)}.habit-square-content{display:flex;flex-direction:column;gap:.5rem;height:100%;min-height:0;overflow:hidden}.habit-square-icon-wrapper{width:48px;height:48px;background:var(--color-primary-soft);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--color-primary);margin-bottom:auto}.habit-square-icon-wrapper svg{width:24px;height:24px}.habit-square-info{display:flex;flex-direction:column;gap:.25rem;width:100%}.habit-square-header{display:flex;flex-direction:column;gap:.375rem;flex-shrink:0;display:none}.habit-square-subcategory-text{font-weight:400;color:var(--color-text-muted);opacity:.8}.habit-square-category{font-size:.9rem;font-weight:700;color:var(--color-text-main);margin:0;line-height:1.2;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;letter-spacing:-.01em}.habit-square-costs{display:flex;flex-direction:column;align-items:flex-start;justify-content:flex-start;gap:.25rem;padding:0;border:none;flex-shrink:0;margin-top:.25rem}.habit-square-cost-item{display:flex;flex-direction:row;align-items:center;justify-content:flex-start;gap:.25rem}.habit-square-cost-label{font-size:.75rem;font-weight:500;color:var(--color-text-muted);text-transform:capitalize;letter-spacing:.01em;opacity:.9;white-space:nowrap;flex-shrink:0}.habit-square-cost-value{font-size:.9rem;font-weight:700;color:var(--color-expense);line-height:1.2;text-align:left;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.habit-square-cost-alt .habit-square-cost-value{color:var(--color-saving-text)}.habit-square-cost-alt .habit-square-cost-value{color:var(--color-accent-green)}.habit-square-notes{display:flex;flex-direction:column;gap:.1rem;margin-top:0;padding-top:.1rem;width:100%;flex-shrink:1;min-height:0;overflow:hidden}.habit-square-note-item{display:flex;flex-direction:row;align-items:baseline;gap:.15rem;padding:0;background:transparent;border:none;width:100%;box-sizing:border-box;flex-shrink:0}.habit-square-note-alt{background:transparent;border:none}.habit-square-note-label{display:block;font-size:.4rem;font-weight:700;color:var(--color-text-muted);text-transform:none;letter-spacing:.02em;opacity:.7;white-space:nowrap;flex-shrink:0}.habit-square-note-text{font-size:.5rem;color:var(--color-text-muted);line-height:1.1;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;opacity:.8;text-align:left;white-space:normal;font-style:normal;font-weight:400}.habits-empty-placeholder{min-width:120px;width:120px;height:140px;display:flex;align-items:center;justify-content:center;font-size:.6875rem;color:var(--color-text-muted);background:#fffc;border-radius:16px;flex-shrink:0;padding:.5rem;text-align:center;line-height:1.3}.habit-create-card{cursor:pointer;background:linear-gradient(135deg,#bfc6c40d,#bfc6c414);border:2px dashed rgba(191,198,196,.3);display:flex;align-items:center;justify-content:center;box-shadow:none}.habit-create-card:hover{background:linear-gradient(135deg,#bfc6c414,#bfc6c41f);border-color:#bfc6c480;transform:translateY(-2px)}.habit-create-card:active{transform:translateY(0) scale(.98)}.habit-create-content{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;width:100%;height:100%}.habit-create-content svg{width:48px;height:48px;color:#bfc6c499}.habit-create-content span{font-size:.75rem;font-weight:600;color:#bfc6c4b3}.modal-header-habit{display:flex;align-items:center;justify-content:space-between;padding:1.5rem;border-bottom:1px solid rgba(0,0,0,.05)}.modal-title-habit{font-size:1.125rem;font-weight:600;color:#1a1a1a;margin:0}.modal-close-btn-habit{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:8px;cursor:pointer;color:#666;transition:all .2s ease;-webkit-tap-highlight-color:transparent}.modal-close-btn-habit:active{background:#0000000d}.modal-close-btn-habit svg{width:20px;height:20px}.habit-form{padding:1.5rem}.habit-form-group{margin-bottom:1.25rem}.habit-form-group:last-of-type{margin-bottom:1.5rem}.habit-form-label{display:block;font-size:.875rem;font-weight:500;color:#1a1a1a;margin-bottom:.5rem}.habit-form-input{width:100%;padding:.75rem;background:#fffc;border:1px solid rgba(0,0,0,.1);border-radius:12px;font-size:.875rem;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;color:#1a1a1a;transition:all .2s ease;box-sizing:border-box;-webkit-appearance:none;appearance:none}.habit-form-input:focus{outline:none;border-color:#bfc6c4;background:#fff}.habit-form-input::placeholder{color:#999}.habit-form-input[type=select],.habit-form-input select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%231a1a1a' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;background-size:12px;padding-right:2.25rem;cursor:pointer}.habit-form-cost-group{display:flex;gap:.5rem}.habit-form-cost-input{flex:1}.habit-form-currency-select{width:100px;flex-shrink:0;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%231a1a1a' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;background-size:12px;padding-right:2.25rem;-webkit-appearance:none;appearance:none}.habit-form-radio-group{display:flex;gap:1rem;margin-top:.5rem}.habit-form-radio-label{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.875rem;color:var(--color-text-main);-webkit-user-select:none;user-select:none}.habit-form-radio{width:18px;height:18px;cursor:pointer;accent-color:var(--color-primary)}.habit-form-textarea{resize:vertical;min-height:80px;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.habit-form-actions{display:flex;gap:.75rem;margin-top:1.5rem}.habit-form-cancel-btn,.habit-form-submit-btn{flex:1;padding:.75rem;border:none;border-radius:12px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease;-webkit-tap-highlight-color:transparent}.habit-form-cancel-btn{background:#0000000d;color:#666}.habit-form-cancel-btn:active{background:#0000001a;transform:scale(.98)}.habit-form-submit-btn{background:#bfc6c4;color:#fff}.habit-form-submit-btn:active{background:#1a8ba8;transform:scale(.98)}.delete-confirm-modal{background:#fff;border-radius:16px;width:100%;max-width:360px;padding:1.5rem;box-shadow:0 4px 20px #00000026;text-align:center}.delete-confirm-icon{width:56px;height:56px;margin:0 auto 1rem;display:flex;align-items:center;justify-content:center;background:#ff6b351a;border-radius:50%;color:#ff6b35}.delete-confirm-icon svg{width:28px;height:28px}.delete-confirm-title{font-size:1.125rem;font-weight:600;color:#1a1a1a;margin:0 0 .5rem}.delete-confirm-message{font-size:.875rem;color:#666;line-height:1.5;margin:0 0 1.5rem}.delete-confirm-actions{display:flex;gap:.75rem}.delete-confirm-cancel,.delete-confirm-delete{flex:1;padding:.75rem}.habit-confirm-modal{background:#fff;border-radius:16px;width:100%;max-width:420px;max-height:85vh;padding:1.5rem;box-shadow:0 4px 20px #00000026;overflow-y:auto}.habit-confirm-title{font-size:1.25rem;font-weight:600;color:#1a1a1a;margin:0 0 1.25rem;text-align:center}.habit-confirm-content{display:flex;flex-direction:column;gap:1.25rem;margin-bottom:1.5rem}.habit-confirm-section{background:#f8f9fa;border-radius:12px;padding:1rem;border:1px solid rgba(0,0,0,.05)}.habit-confirm-section-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.875rem;padding-bottom:.75rem;border-bottom:1px solid rgba(0,0,0,.08)}.habit-confirm-section-title{font-size:1rem;font-weight:600;color:#1a1a1a}.habit-confirm-details{display:flex;flex-direction:column;gap:.625rem}.habit-confirm-detail-row{display:flex;justify-content:space-between;align-items:flex-start;gap:.75rem}.habit-confirm-label{font-size:.875rem;color:#666;font-weight:500;flex-shrink:0}.habit-confirm-value{font-size:.875rem;color:#1a1a1a;text-align:right;word-break:break-word}.habit-confirm-amount{font-weight:600;font-size:.9375rem;color:#bfc6c4}.habit-confirm-actions{display:flex;gap:.75rem;margin-top:1rem}.habit-confirm-cancel,.habit-confirm-submit{flex:1;padding:.875rem;border:none;border-radius:10px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease;-webkit-tap-highlight-color:transparent}.habit-confirm-cancel{background:#0000000d;color:#666}.habit-confirm-cancel:hover{background:#00000014}.habit-confirm-cancel:active{background:#0000001f;transform:scale(.98)}.habit-confirm-cancel:disabled{opacity:.5;cursor:not-allowed}.habit-confirm-submit{background:#bfc6c4;color:#fff}.habit-confirm-submit:hover{background:#e67a2c}.habit-confirm-submit:active{background:#cc6a1f;transform:scale(.98)}.habit-confirm-submit:disabled{opacity:.6;cursor:not-allowed;background:#bfc6c4}.delete-confirm-cancel{background:#0000000d;color:#666}.delete-confirm-cancel:hover{background:#00000014}.delete-confirm-cancel:active{background:#0000001f;transform:scale(.98)}.delete-confirm-delete{background:#ff6b35;color:#fff}.delete-confirm-delete:hover{background:#e55a2b}.delete-confirm-delete:active{background:#cc4f24;transform:scale(.98)}:root{--home-bg: #f8f9fa;--home-top-gradient: linear-gradient(180deg, rgba(233, 237, 201, .7) 0%, rgba(233, 237, 201, .1) 100%);--home-bottom-gradient: linear-gradient(to top, rgba(169, 214, 229, .7) 0%, rgba(169, 214, 229, .1) 100%);--home-button-color: #247ba0;--home-border: 2px solid #ffffff;--home-shadow: 0 -4px 20px rgba(255, 255, 255, 1);--home-separator: #ffffff}[data-theme=dark] .home-container,[data-theme=dark]{--home-bg: #0f172a;--home-top-gradient: linear-gradient(180deg, rgba(20, 184, 166, .15) 0%, rgba(20, 184, 166, .02) 100%);--home-bottom-gradient: linear-gradient(to top, rgba(56, 189, 248, .15) 0%, rgba(56, 189, 248, .02) 100%);--home-button-color: #38bdf8;--home-border: 2px solid var(--color-border-soft);--home-shadow: 0 0 10px rgba(0, 0, 0, .3);--home-separator: var(--color-border-soft)}.home-container{min-height:100vh;min-height:100dvh;background:var(--home-bg);padding:0;position:relative;display:flex;flex-direction:column}.home-top-section{background:var(--color-bg-base);padding:env(safe-area-inset-top,0px) 1rem 2rem 1rem;padding-top:calc(env(safe-area-inset-top,0px) + 1rem);border-bottom-left-radius:32px;border-bottom-right-radius:32px}.home-bottom-section{padding:1.5rem 1rem calc(env(safe-area-inset-bottom,0px) + 100px) 1rem;background:var(--color-bg-base);border-top-left-radius:32px;border-top-right-radius:32px;margin-top:.25rem;position:relative;z-index:10;border-top:var(--home-border);box-shadow:var(--home-shadow);flex:1;overflow-y:auto;overflow-x:hidden}.pull-to-refresh-indicator{position:fixed;top:0;left:0;right:0;display:flex;align-items:center;justify-content:center;padding:.75rem;background:var(--color-bg-card-blur);backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px);z-index:1000;font-size:.875rem;color:var(--color-text-muted);font-weight:500;transition:transform .2s ease}.home-header{padding:.75rem 0 .5rem}.header-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.app-title{font-size:1.75rem;font-weight:600;color:var(--color-text-main);margin:0}.settings-button{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:#0f766e59;border:none;border-radius:12px;cursor:pointer;color:#ecfdf5;transition:all .2s ease}.settings-button:active{transform:scale(.95);background:#0f766e80}.settings-button svg{width:24px;height:24px}.greeting-section{margin-top:.125rem}.greeting{font-size:1.125rem;font-weight:600;color:var(--color-text-main);margin:0 0 .125rem}.quote{font-size:.7875rem;color:var(--color-text-muted);margin:0;font-style:italic}.habits-scroll-section{margin:.75rem 0;width:100%}.current-balance-card{background:var(--color-bg-card-blur);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-radius:15px;padding:1rem;flex:1;border:1px solid var(--color-border-soft);box-shadow:var(--shadow-soft);display:flex;flex-direction:column;justify-content:space-between}.balance-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.375rem}.balance-label{font-size:.875rem;font-weight:600;color:#666}.balance-actions{display:flex;gap:.5rem}.action-icon{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:#ffffff80;border:none;border-radius:8px;cursor:pointer;color:#1a1a1a;transition:all .2s ease;padding:0}.action-icon:active{transform:scale(.95);background:#ffffffb3}.action-icon svg{width:16px;height:16px}.balance-amount{font-size:1.75rem;font-weight:600;color:#1a1a1a;display:flex;align-items:baseline;gap:.25rem;transition:filter .3s ease;margin-top:auto}.balance-amount.blurred{filter:blur(4px);-webkit-filter:blur(4px)}.currency-symbol{font-size:1.25rem;font-weight:600;margin-left:.25rem}.hidden-balance{font-size:1.75rem;letter-spacing:.5rem}.summary-section{display:flex;gap:.5rem;margin-bottom:.75rem;align-items:stretch;justify-content:space-between}.summary-cards{display:grid;grid-template-columns:1fr 1fr;gap:.625rem;flex:1;align-items:stretch}.summary-card{background:var(--color-bg-card);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border-radius:16px;padding:.5rem .75rem;border:1px solid var(--color-border-soft);box-shadow:var(--shadow-soft);display:flex;flex-direction:column;align-items:flex-start;gap:.125rem;min-height:0;overflow:hidden;height:auto}.summary-content{display:flex;flex-direction:column;gap:.125rem;flex:1;width:100%;justify-content:flex-end;min-height:100%}.summary-label{font-size:.75rem;font-weight:600;color:var(--color-text-muted);margin:0;letter-spacing:.5px}.summary-amount{font-size:1.25rem;font-weight:600;color:var(--color-text-main);margin:0;display:flex;align-items:baseline;gap:.25rem}.summary-amount .currency-symbol{font-size:1.125rem}.savings-progress-wrapper{margin-bottom:.75rem}.progress-header{display:flex;align-items:center;gap:.625rem;margin-bottom:.5rem}.savings-progress-card{background:var(--color-bg-card);border-radius:12px;padding:.35rem .875rem;border:1px solid var(--color-border-soft);box-shadow:var(--shadow-soft)}.progress-icon{width:32px;height:32px;background:var(--color-primary-soft);color:var(--color-primary-strong);border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.progress-icon svg{width:18px;height:18px}.progress-title{font-size:.8125rem;font-weight:600;color:var(--color-text-main);margin:0}.progress-stats{display:flex;align-items:stretch;gap:0}.progress-stat{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.125rem;flex:1;padding:.15rem .5rem;min-height:24px}.progress-stat:first-child{border-right:1px solid rgba(15,118,110,.45);padding-right:.625rem}.progress-stat:last-child{padding-left:.625rem}.stat-label{font-size:.59375rem;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}.stat-value{font-size:.8125rem;font-weight:700;color:var(--color-text-main);display:flex;align-items:baseline;gap:.125rem}.stat-value .currency-symbol{font-size:.75rem;font-weight:600;opacity:.7}.recent-activity-section{margin-bottom:1rem}.section-header-with-button{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem;gap:.75rem}.section-title{font-size:1rem;font-weight:600;color:var(--color-text-main);margin:0}.statistics-button-small,.personal-finance-button{background:transparent;border:none;cursor:pointer;display:flex;align-items:center;gap:.375rem;font-size:.8125rem;font-weight:600;color:var(--home-button-color);padding:.25rem .5rem;border-radius:8px;transition:all .2s ease}.statistics-button-small:active,.personal-finance-button:active{opacity:.7;background-color:#247ba01a}.statistics-button-small svg,.personal-finance-button svg{width:18px;height:18px}.loading-text,.no-activities{text-align:center;padding:1rem;color:var(--color-text-muted);font-size:.875rem}.view-more-container{display:flex;justify-content:center;padding:.75rem;margin-top:.5rem}.view-more-link{color:#6ee7b7;font-size:.875rem;font-weight:500;cursor:pointer;text-decoration:underline;transition:all .2s ease;-webkit-tap-highlight-color:transparent}.view-more-link:active{opacity:.7}.activity-wrapper{border-bottom:none;padding:0 .25rem}.activity-item{background:var(--color-bg-card);padding:.75rem;display:flex;align-items:center;gap:.75rem;cursor:pointer;transition:all .2s ease;border-radius:16px;margin-bottom:.75rem;border:var(--home-border);box-shadow:var(--home-shadow)}.activity-item:hover:not(.expanded){background-color:var(--color-border-soft);box-shadow:none}.activity-item.expanded{background-color:var(--color-bg-card);box-shadow:none}.activity-icon{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;border:2px solid}.activity-icon.saving{background:var(--color-saving-soft);border-color:var(--color-saving);color:var(--color-saving-text)}.activity-icon.expense{background:var(--color-expense-soft);border-color:var(--color-expense);color:var(--color-expense-text)}.activity-icon svg{width:16px;height:16px}.activity-title{font-size:.8125rem;font-weight:500;color:var(--color-text-main);margin:0;line-height:1.3}.activity-note{font-size:.75rem;color:var(--color-text-muted);margin:0;font-weight:400;opacity:.7;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0}.activity-time{font-size:.6875rem;color:var(--color-text-muted);margin:0}.activity-amount.saving{color:var(--color-saving-text)}.activity-amount.expense{color:var(--color-expense-text)}.activity-dropdown-header{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem .5rem;border-bottom:1px solid var(--color-border-soft)}.activity-edit-btn{color:#6ee7b7}.activity-edit-btn:active{transform:scale(.95);background:#10b98129}.activity-delete-btn{color:#fecaca}.activity-delete-btn:active{transform:scale(.95);background:#f8717129}.activity-detail-row:has(select.activity-edit-input:focus){z-index:100}.activity-detail-value.expense{color:#fecaca;font-weight:600}.activity-detail-value.saving{color:#bbf7d0;font-weight:600}.activity-edit-input{flex:1;padding:.5rem .75rem;background:var(--color-bg-base);border:1px solid var(--color-border-soft);border-radius:8px;font-size:.75rem;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;color:var(--color-text-main);transition:all .2s ease;-webkit-appearance:none;appearance:none;box-sizing:border-box;text-align:right}.activity-edit-input:focus{outline:none;border-color:#2dd4bfe6;background:#0f172afa}.activity-edit-input select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%231a1a1a' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;background-size:10px;padding-right:2rem;cursor:pointer}select.activity-edit-input{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%231a1a1a' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;background-size:10px;padding-right:2rem;cursor:pointer;position:relative;z-index:10;min-width:120px;text-align:left}select.activity-edit-input:focus{z-index:100;position:relative;outline:none;border-color:#2dd4bfe6;background-color:#0f172afa;box-shadow:0 0 0 2px #2dd4bf59}select.activity-edit-input:focus{z-index:100;position:relative}select.activity-edit-input option{padding:.5rem;background:var(--color-bg-card);color:var(--color-text-main)}.activity-detail-row{position:relative}.activity-detail-row select.activity-edit-input{appearance:none;-webkit-appearance:none;-moz-appearance:none;background-color:#ffffffe6;border:1px solid rgba(0,0,0,.1);border-radius:8px;padding:.5rem 2rem .5rem .75rem;font-size:.75rem;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;color:#1a1a1a;cursor:pointer;min-width:120px}.activity-detail-row select.activity-edit-input:focus{outline:none;border-color:#219ebc;background-color:#fff;box-shadow:0 0 0 2px #219ebc1a}.activity-edit-actions{display:flex;gap:.5rem;margin-top:.5rem;padding-top:.75rem;border-top:1px solid var(--color-border-soft)}.activity-save-btn,.activity-cancel-btn{flex:1;padding:.625rem 1rem;border:none;border-radius:8px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease;-webkit-tap-highlight-color:transparent}.activity-save-btn{background:#219ebc;color:#fff}.activity-cancel-btn{background:#e0e0e0;color:#333}.activity-cancel-btn:active{transform:scale(.98);background:#ccc}.activity-type-select-wrapper{flex:1;position:relative;display:flex;justify-content:flex-end}.activity-type-select-btn{display:flex;align-items:center;justify-content:space-between;gap:.5rem;padding:.5rem .75rem;background:#ffffffe6;border:1px solid rgba(0,0,0,.1);border-radius:8px;font-size:.75rem;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;color:#1a1a1a;cursor:pointer;transition:all .2s ease;min-width:120px;text-align:left;-webkit-tap-highlight-color:transparent}.activity-type-select-btn:focus{outline:none;border-color:#219ebc;background:#fff;box-shadow:0 0 0 2px #219ebc1a}.activity-type-select-btn svg{width:12px;height:12px;flex-shrink:0;transition:transform .2s ease}.activity-type-select-wrapper:has(.activity-type-dropdown) .activity-type-select-btn svg{transform:rotate(180deg)}.activity-type-dropdown{position:absolute;bottom:100%;right:0;margin-bottom:.25rem;background:var(--color-bg-card);border:1px solid var(--color-border-soft);border-radius:8px;box-shadow:0 4px 12px #00000026;z-index:1000;min-width:120px;overflow:hidden;animation:slideUp .2s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.activity-type-option{display:block;width:100%;padding:.625rem .75rem;background:var(--color-bg-card);border:none;text-align:left;font-size:.75rem;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;color:var(--color-text-main);cursor:pointer;transition:all .2s ease;-webkit-tap-highlight-color:transparent}.activity-type-option:hover{background:#219ebc1a}.activity-type-option.selected{background:#219ebc26;color:#219ebc;font-weight:500}.activity-type-option:active{background:#219ebc33}.bottom-nav{position:fixed;bottom:0;left:0;right:0;background:#fff;backdrop-filter:none;-webkit-backdrop-filter:none;border-top:1px solid rgba(0,0,0,.1);padding:.25rem 0;padding-bottom:0!important;min-height:50px;height:auto;display:flex;justify-content:space-around;align-items:center;box-shadow:0 -1px 4px #0000000d;z-index:100;transform:translateZ(0);-webkit-transform:translateZ(0);will-change:transform;-webkit-backface-visibility:hidden;backface-visibility:hidden}.nav-item{display:flex;flex-direction:column;align-items:center;gap:.125rem;background:none;border:none;cursor:pointer;padding:.375rem .75rem;color:#999;transition:all .2s ease;-webkit-tap-highlight-color:transparent;border-radius:12px;flex:1;min-width:0}.nav-item:not(.active){color:#999}.nav-item:not(.active) svg,.nav-item:not(.active) svg path,.nav-item:not(.active) svg circle{color:#999;stroke:#999;fill:#999}.nav-item.nav-item-add{flex:0 0 auto;padding:.375rem .75rem;border-radius:12px}.nav-item.active{color:#bfc6c4}.nav-item.active svg,.nav-item.active svg path,.nav-item.active svg circle{color:#bfc6c4;stroke:#bfc6c4;fill:#bfc6c4}.nav-item-add{background:transparent!important;color:#666!important;padding:.375rem .75rem;box-shadow:none!important;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0;flex-direction:column;gap:.125rem}.nav-item-add:hover{color:#bfc6c4;background:transparent!important;box-shadow:none!important}.nav-item-add:active{color:#bfc6c4;transform:scale(.95);box-shadow:none!important;background:transparent!important}.nav-item-add svg{width:20px;height:20px;color:#666!important}.nav-item-add svg path{stroke:#666!important;fill:none}.nav-item-add:hover svg,.nav-item-add:hover svg path{stroke:#bfc6c4!important;color:#bfc6c4!important}.nav-item-add:active svg,.nav-item-add:active svg path{stroke:#bfc6c4!important;color:#bfc6c4!important}.nav-item-add span{font-size:.6875rem;font-weight:500;color:inherit}.nav-item svg{width:20px;height:20px}.nav-item span{font-size:.6875rem;font-weight:500;line-height:1}.delete-modal-overlay{position:fixed;inset:0;background:#00000080;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:10000;padding:1rem;animation:fadeIn .2s ease-out}.delete-modal{background:var(--color-bg-card);border-radius:15px;padding:1.5rem;max-width:400px;width:100%;box-shadow:0 8px 32px #0003;animation:slideUp .3s ease-out;position:relative}.delete-modal-icon{width:64px;height:64px;margin:0 auto 1rem;background:#f443361a;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#f44336}.delete-modal-icon svg{width:32px;height:32px}.delete-modal-title{font-size:1.25rem;font-weight:600;color:var(--color-text-main);text-align:center;margin:0 0 .75rem}.delete-modal-message{font-size:.9375rem;color:var(--color-text-muted);text-align:center;margin:0 0 1.5rem;line-height:1.5}.delete-modal-actions{display:flex;gap:.75rem}.delete-modal-cancel-btn,.delete-modal-confirm-btn{flex:1;padding:.75rem 1.5rem;border:none;border-radius:12px;font-size:.9375rem;font-weight:500;cursor:pointer;transition:all .2s ease;-webkit-tap-highlight-color:transparent}.delete-modal-cancel-btn{background:#e0e0e0;color:var(--color-text-main)}.delete-modal-cancel-btn:active{transform:scale(.98);background:#ccc}.delete-modal-confirm-btn{background:#f44336;color:#fff}.delete-modal-confirm-btn:active{transform:scale(.98);background:#d32f2f}.chart-button{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.25rem;padding:.5rem .375rem;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-strong) 100%);border:none;border-radius:16px;color:#fff;font-size:.75rem;font-weight:600;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 12px #f8943c59;-webkit-tap-highlight-color:transparent;touch-action:manipulation;width:72px;flex-shrink:0;align-self:stretch;height:auto}.chart-button:active{transform:scale(.98);box-shadow:0 2px 6px #f8943c4d}.chart-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.chart-button svg{width:28px;height:28px;fill:currentColor}.chart-button span{text-align:center;line-height:1.2;font-size:.56875rem}.chart-modal-overlay{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;z-index:2000;padding:1rem;overflow-y:auto;-webkit-tap-highlight-color:transparent;cursor:pointer}.chart-modal-overlay:before{content:"";position:fixed;inset:0;background:#0006;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);z-index:-1;will-change:backdrop-filter;transform:translateZ(0);-webkit-transform:translateZ(0)}.personal-finance-button{display:flex;align-items:center;gap:.25rem;padding:.25rem .5rem;font-size:.55rem;font-weight:600;color:#1a1a1a;background:#fec89a;border:none;border-radius:6px;cursor:pointer;transition:all .2s ease;white-space:nowrap;-webkit-tap-highlight-color:transparent;touch-action:manipulation;box-shadow:0 2px 6px #fec89a4d;height:24px}[data-theme=dark] .personal-finance-button{background:#01497c;color:#fff;box-shadow:0 2px 6px #01497c4d}@media(prefers-color-scheme:dark){:root:not([data-theme=light]) .personal-finance-button{background:#01497c;color:#fff;box-shadow:0 2px 6px #01497c4d}}.personal-finance-icon{width:12px;height:12px;flex-shrink:0}.personal-finance-button:hover{transform:translateY(-1px);background:linear-gradient(135deg,#3cb9d7,#2396b4,#196e87);box-shadow:0 4px 12px #219ebc66}.personal-finance-button:active{transform:scale(.98);box-shadow:0 1px 4px #219ebc4d}.personal-finance-modal-overlay{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;z-index:2000;padding:1rem;overflow-y:auto;-webkit-tap-highlight-color:transparent;cursor:pointer}.personal-finance-modal-overlay:before{content:"";position:fixed;inset:0;background:#0006;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);z-index:-1;will-change:backdrop-filter;transform:translateZ(0);-webkit-transform:translateZ(0)}.personal-finance-modal{background:var(--color-bg-card);border-radius:16px;width:100%;max-width:800px;max-height:95vh;overflow-y:auto;box-shadow:0 8px 32px #0000004d;position:relative;z-index:1;cursor:default}.personal-finance-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid rgba(0,0,0,.1);position:sticky;top:0;background:var(--color-bg-card-blur);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);z-index:10}.personal-finance-modal-header h2{font-size:1.25rem;font-weight:600;color:var(--color-text-main);margin:0}.personal-finance-modal-close{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:none;border:none;font-size:28px;color:var(--color-text-muted);cursor:pointer;border-radius:8px;-webkit-tap-highlight-color:transparent;touch-action:manipulation;user-select:none;-webkit-user-select:none;padding:0;margin:0;line-height:1;flex-shrink:0}.personal-finance-modal-close:hover{background:#0000000d}.personal-finance-modal-close:active{background:#00000026}.personal-finance-modal-content{padding:1.5rem;width:100%;box-sizing:border-box}.personal-finance-month-selector{width:100%;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:rgba(33,158,188,.3) transparent;margin-bottom:1rem}.personal-finance-month-selector::-webkit-scrollbar-thumb{background:#219ebc4d;border-radius:3px}.personal-finance-month-selector::-webkit-scrollbar-thumb:hover{background:#219ebc80}.month-pill:hover{background:#e8e8e8;border-color:#219ebc4d}.payments-card{background:var(--color-bg-card);border-radius:16px;padding:1.25rem;margin-bottom:1.5rem;box-shadow:0 2px 8px #0000000d}.payments-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem}.payments-title{font-size:1.5rem;font-weight:700;color:var(--color-text-main);margin:0}.payments-header-icons{display:flex;gap:.5rem}.header-icon-button{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;border-radius:8px;color:#666;transition:all .2s ease;-webkit-tap-highlight-color:transparent}.header-icon-button svg{width:20px;height:20px}.header-icon-button:hover{background:#f5f5f5}.header-icon-button:active{transform:scale(.95)}.summary-pill{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;border-radius:15px;font-size:.875rem;font-weight:500;white-space:nowrap;flex-shrink:0;border:2px solid transparent;cursor:pointer;transition:all .2s ease;-webkit-tap-highlight-color:transparent;touch-action:manipulation;background:var(--color-primary-soft);color:var(--color-text-main)}.summary-pill.active{border-color:var(--color-primary-strong);box-shadow:var(--shadow-soft)}.expense-pill{background:var(--color-primary)}.savings-pill{background:linear-gradient(135deg,#4ade80,#22c55e)}.summary-amount{font-weight:600}.category-pill.blue{background:#dbeafe;color:#1d4ed8}.category-pill.orange{background:#fed7aa;color:#9a3412}.categories-section .category-pill.active{background:#a47148!important;color:#fff!important;border-color:#a47148!important}.personal-finance-section-title{font-size:.75rem;font-weight:600;color:#1a1a1a;opacity:.4;margin:0 0 .5rem}.personal-finance-options{display:flex;gap:.5rem;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:rgba(33,158,188,.3) transparent;padding-bottom:.5rem;width:100%}.personal-finance-options::-webkit-scrollbar-thumb{background:#219ebc4d;border-radius:3px}.personal-finance-options::-webkit-scrollbar-thumb:hover{background:#219ebc80}.personal-finance-option{padding:.625rem 1.25rem;font-size:.875rem;font-weight:500;color:var(--color-text-muted);background:var(--color-primary-soft);border:2px solid transparent;border-radius:8px;cursor:pointer;transition:all .2s ease;-webkit-tap-highlight-color:transparent;touch-action:manipulation;white-space:nowrap;flex-shrink:0}.personal-finance-option:hover{background:#e8e8e8;border-color:#219ebc4d}.personal-finance-option.active{color:#fff;background:var(--color-bg-base);border-color:#219ebc;box-shadow:0 2px 6px #219ebc4d}.personal-finance-option:active{transform:scale(.98)}.chart-modal{background:var(--color-bg-card);border-radius:16px;width:100%;max-width:500px;max-height:90vh;overflow-y:auto;box-shadow:0 8px 32px #0000004d;position:relative;z-index:1;cursor:default}.chart-modal-header{display:flex;align-items:center;justify-content:space-between;padding:.625rem 1rem;border-bottom:1px solid rgba(0,0,0,.1);position:sticky;top:0;background:var(--color-bg-card-blur);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);z-index:10}.chart-modal-header h2{font-size:1rem;font-weight:600;color:var(--color-text-main);margin:0}.chart-modal-close{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:none;border:none;font-size:28px;color:var(--color-text-muted);cursor:pointer;border-radius:8px;-webkit-tap-highlight-color:transparent;touch-action:manipulation;user-select:none;-webkit-user-select:none;padding:0;margin:0;line-height:1;flex-shrink:0}.chart-modal-close:hover{background:#0000000d}.chart-modal-close:active{background:#00000026}.chart-modal-content{padding:.5rem 1rem .75rem}.chart-section{margin-bottom:.375rem}.chart-title{font-size:.875rem;font-weight:600;color:var(--color-text-main);margin:0 0 .25rem}.chart-info{display:flex;gap:.5rem;margin-bottom:.5rem;flex-wrap:wrap}.chart-info-item{font-size:.75rem;color:#666;padding:.375rem .625rem;background:#219ebc1a;border-radius:6px}.chart-summary{margin-top:.25rem;padding-top:.375rem;border-top:1px solid rgba(0,0,0,.1)}.chart-summary-item{display:flex;justify-content:space-between;align-items:center;padding:.25rem 0}.chart-summary-label{font-size:.8125rem;color:#666}.chart-summary-value{font-size:.9375rem;font-weight:600}.chart-summary-value.expense{color:#f44336}.chart-summary-value.saving{color:#4caf50}.chart-empty{text-align:center;padding:3rem 1rem;color:#999}.transaction-modal-overlay{position:fixed;inset:0;background:#ffffff80;backdrop-filter:blur(35px);-webkit-backdrop-filter:blur(35px);display:flex;align-items:flex-end;justify-content:center;z-index:1000;animation:fadeIn .2s ease-out;padding-bottom:env(safe-area-inset-bottom,20px)}.transaction-modal-content{display:flex;gap:1rem;align-items:center;justify-content:center;flex-direction:column;animation:slideUp .3s cubic-bezier(.16,1,.3,1);background:transparent;width:100%;max-width:100%;padding:1.5rem 1rem;padding-bottom:calc(1.5rem + env(safe-area-inset-bottom,0px))}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.transaction-option{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;padding:2rem 2.5rem;background:#ffffffa6!important;backdrop-filter:blur(20px)!important;-webkit-backdrop-filter:blur(20px)!important;border:1px solid rgba(255,255,255,.3)!important;border-radius:15px;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 16px #0000001a;flex:1;width:100%;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.expense-option,.saving-option{background:#ffffffa6!important;backdrop-filter:blur(20px)!important;-webkit-backdrop-filter:blur(20px)!important}.transaction-option:active{transform:scale(.95);background:#ffffff4d;box-shadow:0 2px 8px #00000026}.transaction-modal-content .habit-square-card{background:#ffffffa6!important;backdrop-filter:blur(20px)!important;-webkit-backdrop-filter:blur(20px)!important;border:1px solid rgba(255,255,255,.3)!important;box-shadow:0 4px 12px #0000000d!important}.transaction-modal-content .habit-square-subcategory-text,.transaction-modal-content .habit-square-cost-label{color:#fff!important;opacity:.9!important;font-weight:500!important}.transaction-modal-content .habit-square-icon-wrapper{color:#fff!important;background:#fff3!important}.transaction-modal-content .habit-square-cost-alt .habit-square-cost-value{color:#15803d!important}.transaction-modal-content .habit-square-cost-value{color:#b91c1c!important}.transaction-option span{font-size:1.5rem;font-weight:600;color:#1a1a1a}.saving-option svg{color:#2e7d32}.habits-option svg{color:#8b5cf6}[data-theme=dark] .transaction-option{background:#0f172aa6!important;border:1px solid rgba(255,255,255,.15)!important}[data-theme=dark] .expense-option,[data-theme=dark] .saving-option{background:#0f172aa6!important}[data-theme=dark] .transaction-modal-content .habit-square-card{background:#0f172aa6!important;border:1px solid rgba(255,255,255,.15)!important}[data-theme=dark] .transaction-modal-overlay{background:#0f172a80!important}[data-theme=dark] .transaction-modal-content .habit-square-subcategory-text,[data-theme=dark] .transaction-modal-content .habit-square-cost-label{color:var(--color-text-muted)!important}[data-theme=dark] .transaction-modal-content .habit-square-icon-wrapper{color:var(--color-primary)!important;background:var(--color-primary-soft)!important}[data-theme=dark] .transaction-modal-content .habit-square-category{color:var(--color-text-main)!important}@media(min-width:640px){.home-container{max-width:480px;margin:0 auto}}.home-action-buttons{display:flex;gap:.625rem;margin-top:.25rem}.home-action-buttons .chart-button{flex:1}.section-header-actions{display:flex;gap:.5rem;align-items:center}.statistics-button-small{display:flex;align-items:center;gap:.25rem;padding:.25rem .5rem;font-size:.55rem;font-weight:600;color:#1a1a1a;background:#fec89a;border:none;border-radius:6px;cursor:pointer;transition:all .2s ease;white-space:nowrap;-webkit-tap-highlight-color:transparent;touch-action:manipulation;box-shadow:0 2px 6px #fec89a4d;height:24px}[data-theme=dark] .statistics-button-small{background:#01497c;color:#fff;box-shadow:0 2px 6px #01497c4d}@media(prefers-color-scheme:dark){:root:not([data-theme=light]) .statistics-button-small{background:#01497c;color:#fff;box-shadow:0 2px 6px #01497c4d}}.statistics-button-small svg{width:12px;height:12px;flex-shrink:0}.statistics-button-small:active{transform:scale(.98);box-shadow:0 1px 4px #bc8a5f4d}[data-theme=dark] .statistics-button-small:active{box-shadow:0 1px 4px #01497c4d}@media(prefers-color-scheme:dark){:root:not([data-theme=light]) .statistics-button-small:active{box-shadow:0 1px 4px #01497c4d}}.statistics-btn,.more-menu-container{position:relative}.more-button{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:#0f766e59;border:none;border-radius:12px;cursor:pointer;color:#ecfdf5;transition:all .2s ease}.more-button:active{transform:scale(.95);background:#0f766e80}.more-button svg{width:24px;height:24px}.more-menu-dropdown{position:absolute;top:100%;right:0;margin-top:.5rem;background:var(--color-bg-card);border:1px solid var(--color-border-soft);border-radius:12px;box-shadow:0 4px 20px #00000026;width:180px;padding:.5rem;z-index:100;transform-origin:top right;animation:menuFadeIn .2s ease}@keyframes menuFadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.more-menu-item{display:flex;align-items:center;gap:.75rem;width:100%;padding:.75rem 1rem;border:none;background:none;color:var(--color-text-main);font-size:.9375rem;font-weight:500;cursor:pointer;border-radius:8px;transition:all .2s ease;text-align:left}.more-menu-item:hover{background:var(--color-bg-base)}.more-menu-item:active{background:var(--color-border-soft)}.more-menu-item svg{width:18px;height:18px;color:var(--color-text-muted)}.bottom-navigation-container{position:fixed;bottom:0;left:0;right:0;z-index:1000;pointer-events:none;background:transparent;display:flex;justify-content:center;padding-bottom:calc(env(safe-area-inset-bottom,20px) - 15px)}.bottom-nav-content{pointer-events:auto;position:relative;width:100%;max-width:400px;height:64px;margin:0 20px;background:var(--color-bg-card);border-radius:15px;box-shadow:0 8px 24px #0000001f;display:flex;justify-content:space-between;align-items:center;padding-left:1.5rem;padding-right:1.5rem;box-sizing:border-box;border:1px solid var(--color-border-soft)}.nav-tab{display:flex;flex-direction:column;align-items:center;justify-content:center;background:transparent;border:none;cursor:pointer;color:var(--color-text-muted);transition:all .2s ease;width:60px;padding:4px 0}.nav-tab.active{color:var(--color-primary)}.nav-tab .nav-icon-wrapper svg{width:24px;height:24px;margin-bottom:4px;transition:transform .2s ease}.nav-tab:active .nav-icon-wrapper svg{transform:scale(.9)}.nav-label{font-size:11px;font-weight:500;letter-spacing:.3px}.nav-add-button{position:absolute;top:-24px;left:50%;transform:translate(-50%);background:transparent;border:none;cursor:pointer;display:flex;flex-direction:column;align-items:center;z-index:1001;width:72px}.add-button-inner{width:56px;height:56px;border-radius:50%;background:#6096ba;box-shadow:0 4px 12px #bfc6c466;display:flex;align-items:center;justify-content:center;color:#fff;transition:transform .2s cubic-bezier(.4,0,.2,1),box-shadow .2s ease;margin-bottom:4px}.nav-add-button:active .add-button-inner{transform:scale(.92);box-shadow:0 2px 6px #bfc6c44d}.add-button-inner svg{width:32px;height:32px}.add-label{color:var(--color-text-muted);opacity:0;transform:translateY(-5px);transition:all .2s ease;font-weight:600}.nav-tab:first-child{margin-right:auto}.nav-tab:last-child{margin-left:auto}.neu-spinner-container{display:flex;justify-content:center;padding:30px;width:100%;box-sizing:border-box}.neu-spinner{width:36px;height:36px;border-radius:50%;background:var(--neu-bg);box-shadow:var(--neu-shadow-inset);position:relative;animation:neu-spin .8s linear infinite}.neu-spinner:after{content:"";position:absolute;inset:-4px;border-radius:50%;border:4px solid transparent;border-top-color:var(--neu-accent-blue);opacity:.8}@keyframes neu-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}:root{--neu-bg: #ebeef2;--neu-text: #1f2937;--neu-text-secondary: #6b7280;--neu-shadow-light: 0 0 15px rgba(0, 0, 0, .25);--neu-shadow-dark: 0 0 15px rgba(0, 0, 0, .25);--neu-shadow-inset: inset 2px 2px 5px rgba(255, 255, 255, .7), inset -2px -2px 5px rgba(0, 0, 0, .1);--neu-shadow-equal-sm: 0 0 8px rgba(0, 0, 0, .15);--neu-overlay-bg: rgba(224, 229, 236, .8);--neu-accent: #ff4b5c;--neu-accent-blue: #00d2ff;--neu-accent-green: #00ff9d}[data-theme=dark]{--neu-bg: #161a1d;--neu-text: #ffffff;--neu-text-secondary: #E5E7EB;--neu-shadow-light: 0 0 10px rgba(0, 0, 0, .3);--neu-shadow-dark: 0 0 10px rgba(0, 0, 0, .3);--neu-shadow-inset: inset 2px 2px 5px #0b090a, inset -2px -2px 5px rgba(255, 255, 255, .03);--neu-shadow-equal-sm: 0 0 5px rgba(0, 0, 0, .3);--neu-overlay-bg: rgba(0, 0, 0, .6);--neu-accent: #ff4b5c;--neu-accent-blue: #00d2ff;--neu-accent-green: #00ff9d}.neu-container{background-color:var(--neu-bg);color:var(--neu-text);padding:20px;padding-top:calc(20px + env(safe-area-inset-top));height:100dvh;width:100vw;display:flex;flex-direction:column;overflow:hidden;position:relative;box-sizing:border-box;padding-bottom:0;max-width:100vw;-webkit-overflow-scrolling:touch}.neu-scroll-content{flex:1;overflow-y:auto;overflow-x:hidden;padding-bottom:150px;margin-top:20px;padding-right:0;-webkit-overflow-scrolling:touch;overscroll-behavior-y:contain;width:100%;box-sizing:border-box;touch-action:pan-y}.neu-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px}.neu-app-logo{display:flex;align-items:center;margin-bottom:5px;height:20px;justify-content:center;margin-top:5vh}.neu-icon-btn{width:50px;height:50px;border-radius:50%;border:none;background:var(--neu-bg);box-shadow:var(--neu-shadow-light),var(--neu-shadow-dark);display:flex;align-items:center;justify-content:center;color:var(--neu-text);cursor:pointer;transition:all .2s ease;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.neu-icon-btn:active{box-shadow:var(--neu-shadow-inset);transform:scale(.95)}.neu-main-card{border-radius:15px;background:var(--neu-bg);box-shadow:var(--neu-shadow-light),var(--neu-shadow-dark);padding:20px;margin-bottom:30px;position:relative;overflow:hidden}.neu-card-label{font-size:.85rem;font-weight:500;color:var(--neu-text)}.neu-savings-row{display:flex;justify-content:space-between;gap:12px;margin-bottom:30px}.neu-saving-card{flex:1;min-width:0;border-radius:15px;background:var(--neu-bg);box-shadow:var(--neu-shadow-light),var(--neu-shadow-dark);padding:12px;display:flex;flex-direction:column;align-items:center;text-align:center}.neu-section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}html,body{overflow:hidden!important;height:100dvh!important;width:100vw!important;position:fixed!important;overscroll-behavior:none}.neu-transaction-list{display:flex;flex-direction:column;gap:7px;padding-bottom:120px}.neu-sticky-header{position:sticky;top:-20px;z-index:90;background:var(--neu-bg);margin:0 -20px;padding:15px 20px;display:flex;justify-content:space-between;align-items:center;transition:box-shadow .3s ease;box-sizing:border-box;width:calc(100% + 40px)}.neu-group-header{font-size:.85rem;color:var(--neu-text-secondary);margin:15px 0 5px 5px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.neu-transaction-item{padding:12px 5px;display:flex;align-items:flex-start;gap:15px;border-bottom:1px solid rgba(0,0,0,.05)}.neu-trans-icon-circle{width:44px;height:44px;border-radius:50%;border:2px solid;display:flex;align-items:center;justify-content:center;flex-shrink:0;background:#fff}.neu-trans-details{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px}.neu-trans-row-primary{display:flex;justify-content:space-between;align-items:flex-start}.neu-trans-title{font-size:.95rem;font-weight:700;color:var(--neu-text)}.neu-trans-amount{font-size:.95rem;font-weight:700;white-space:nowrap}.neu-trans-amount.saving{color:#00d2ff}.neu-trans-row-secondary{font-size:.75rem;font-weight:500;color:#9ca3af}.neu-trans-row-tertiary{font-size:.7rem;color:#9ca3af;font-weight:400}.neu-fab-container{position:fixed;bottom:20px;left:50%;transform:translate(-50%);display:flex;align-items:center;justify-content:space-around;gap:10px;z-index:100;background:var(--neu-bg);padding:8px 15px;border-radius:15px;box-shadow:var(--neu-shadow-light),var(--neu-shadow-dark);width:90%;max-width:400px;height:60px}.neu-add-btn{width:60px;height:60px;border-radius:50%;background:#00d2ff;border:none;color:#fff;font-size:2rem;display:flex;align-items:center;justify-content:center;box-shadow:0 5px 15px #fffc;transform:translateY(-20px)}.neu-modal-overlay{position:fixed;inset:0;background:var(--neu-overlay-bg);-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);z-index:2000;display:flex;align-items:center;justify-content:center;animation:fadeIn .2s}.neu-modal-content{background:var(--neu-bg);padding:30px;border-radius:15px;box-shadow:var(--neu-shadow-light),var(--neu-shadow-dark);display:flex;gap:20px;flex-direction:column;align-items:center;width:92%;max-width:400px;box-sizing:border-box;animation:scaleIn .2s}.neu-option-btn{flex:1;height:100px;border-radius:15px;background:var(--neu-bg);box-shadow:var(--neu-shadow-light),var(--neu-shadow-dark);display:flex;flex-direction:column;align-items:center;justify-content:center;border:none;color:var(--neu-text);cursor:pointer;font-size:1rem;font-weight:600;gap:10px}.neu-form-container{padding:10px}.neu-input-group{margin-bottom:25px}.neu-label{display:block;margin-bottom:10px;font-size:.9rem;color:var(--neu-text-secondary);font-weight:500;margin-left:5px}.neu-input,.neu-textarea{width:100%;padding:15px 20px;border-radius:15px;background:var(--neu-bg);border:none;box-shadow:var(--neu-shadow-inset);font-size:1.1rem;color:var(--neu-text);outline:none;box-sizing:border-box;font-family:inherit;transition:all .3s ease}.neu-input[type=date]{padding:12px 15px;font-size:1rem;font-family:Outfit,Montserrat,sans-serif;color:var(--neu-text-secondary);min-height:52px;height:52px;display:block;-webkit-appearance:none;background-color:var(--neu-bg);opacity:1}.neu-input[type=date]::-webkit-date-and-time-value{text-align:left}.neu-input[type=date]::-webkit-calendar-picker-indicator{filter:invert(.6);cursor:pointer}[data-theme=dark] .neu-input[type=date]::-webkit-calendar-picker-indicator{filter:invert(.9)}.neu-input:focus,.neu-textarea:focus{box-shadow:var(--neu-shadow-inset)}.neu-textarea{resize:none;min-height:120px}.neu-full-btn{width:100%;padding:18px;border-radius:25px;background:var(--neu-bg);box-shadow:var(--neu-shadow-light),var(--neu-shadow-dark);color:var(--neu-accent);font-weight:700;font-size:1.1rem;border:none;cursor:pointer;text-align:center;transition:all .2s ease;margin-top:20px;display:flex;align-items:center;justify-content:center;gap:10px}.neu-full-btn:active{box-shadow:var(--neu-shadow-inset);transform:scale(.98)}.neu-full-btn:disabled{opacity:.6;cursor:not-allowed;box-shadow:none}.neu-active-dot{width:6px;height:6px;border-radius:50%;background:var(--neu-accent);box-shadow:0 0 8px #fff}.neu-scan-btn{width:100%;padding:15px;border-radius:15px;background:var(--neu-bg);border:2px dashed rgba(163,177,198,.5);color:var(--neu-text-secondary);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;cursor:pointer;transition:all .2s ease;margin-bottom:25px}.neu-scan-btn:hover{border-color:var(--neu-accent);color:var(--neu-accent)}.neu-error-msg{color:var(--neu-accent);font-size:.8rem;margin-top:5px;margin-left:10px}.neu-scan-modal{background:var(--neu-bg);border-radius:15px;box-shadow:var(--neu-shadow-light);padding:25px;max-width:90%;width:400px}.neu-search-container{position:relative;margin-bottom:20px}.neu-search-bar{width:100%;padding:12px 45px 12px 20px;border-radius:15px;background:var(--neu-bg);border:none;box-shadow:var(--neu-shadow-inset);font-size:1rem;color:var(--neu-text);outline:none;box-sizing:border-box}.neu-search-icon{position:absolute;right:15px;top:50%;transform:translateY(-50%);color:var(--neu-text-secondary);pointer-events:none}.neu-activity-card{border-radius:15px;background:var(--neu-bg);box-shadow:var(--neu-shadow-equal-sm);padding:20px;margin:0 10px 10px;cursor:pointer;transition:all .2s ease;border:none;width:calc(100% - 20px);box-sizing:border-box}.neu-activity-card:active{box-shadow:var(--neu-shadow-inset);transform:scale(.98)}.neu-activity-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.neu-activity-title{font-weight:700;font-size:1.1rem;color:var(--neu-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.neu-activity-budget{font-weight:600;color:#1a7399}.neu-activity-dates{font-size:.8rem;color:var(--neu-text-secondary);display:flex;align-items:center;gap:5px;margin-bottom:10px}.neu-activity-footer{display:flex;justify-content:space-between;align-items:center}.neu-badge{padding:5px 12px;border-radius:12px;font-size:.75rem;font-weight:600;background:var(--neu-bg);box-shadow:var(--neu-shadow-light),var(--neu-shadow-dark)}.neu-horizontal-scroll{display:flex;overflow-x:auto;gap:12px;padding:8px 5px;-webkit-overflow-scrolling:touch;scrollbar-width:none;margin-bottom:15px}.neu-horizontal-scroll::-webkit-scrollbar{display:none}.neu-month-pill{flex-shrink:0;padding:8px 12px;border-radius:15px;background:#e2e8f0;border:none;color:var(--neu-text-secondary);display:flex;align-items:center;gap:8px;width:max-content;cursor:pointer;transition:all .2s ease}.neu-month-pill.active{background:#60a5fa;color:#fff;box-shadow:0 4px 10px #ffffff80}.neu-month-pill.active .neu-month-amount{color:#ffffffe6}.neu-month-name{font-size:.9rem;font-weight:500}.neu-month-amount{font-size:.75rem;font-weight:600;color:var(--neu-text);white-space:nowrap}.neu-summary-row{display:flex;gap:15px;margin-bottom:20px}.neu-summary-card{flex:1;padding:12px 20px;border-radius:15px;background:var(--neu-bg);border:2px solid transparent;cursor:pointer;display:flex;align-items:center;justify-content:space-between;transition:all .2s ease;box-shadow:var(--neu-shadow-light)}.neu-summary-card.active{box-shadow:var(--neu-shadow-inset);transform:translateY(1px)}.neu-summary-card.expense.active{background:#fee2e2;border-color:#fca5a5;color:#991b1b}.neu-summary-card.savings.active{background:#e0f2fe;border-color:#7dd3fc;color:#075985}.neu-summary-card:not(.active){opacity:.7}.neu-summary-card.active{opacity:1;box-shadow:0 4px 15px #0b090a,var(--neu-shadow-inset)}.neu-summary-label{font-size:.85rem;font-weight:500;opacity:.8}.neu-summary-amount{font-size:1.1rem;font-weight:700;white-space:nowrap}.neu-cat-grid{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:20px}.neu-category-pill{display:inline-flex;align-items:center;gap:10px;padding:8px 12px;border-radius:18px;background:var(--neu-bg);box-shadow:var(--neu-shadow-light),var(--neu-shadow-dark);border:none;color:var(--neu-text);cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);width:max-content}.neu-category-pill.active{background:#60a5fa;color:#fff;box-shadow:0 4px 15px #60a5fa66;transform:translateY(1px)}.neu-cat-icon-container{width:28px;height:28px;border-radius:8px;background:var(--neu-bg);box-shadow:var(--neu-shadow-light),var(--neu-shadow-dark);display:flex;align-items:center;justify-content:center;color:var(--neu-accent);flex-shrink:0}.neu-category-pill.active .neu-cat-icon-container{background:#fff3;box-shadow:none;color:#fff}.neu-cat-pill-details{display:flex;align-items:center;gap:10px;flex:1}.neu-cat-pill-name{font-size:.8rem;font-weight:600;color:var(--neu-text);white-space:nowrap}.neu-cat-pill-amount{font-size:.75rem;font-weight:500;color:var(--neu-text-secondary);margin-left:auto;white-space:nowrap}.neu-section-header{font-size:.9rem;font-weight:600;margin-bottom:12px;color:var(--neu-text-secondary);text-transform:uppercase;letter-spacing:1px;margin-top:5px}.neu-transaction-item.expanded{box-shadow:var(--neu-shadow-inset)!important;border-radius:15px 20px 0 0!important}:root{--neu-bg: #ebeef2;--neu-text: #1f2937;--neu-text-secondary: #6b7280;--neu-shadow-light: 0 0 15px #ffffff;--neu-shadow-dark: 0 0 0 transparent;--neu-shadow-inset: inset 0 2px 4px 0 rgba(0, 0, 0, .06);--neu-accent: #ff4b5c;--neu-accent-blue: #00d2ff;--neu-accent-green: #00ff9d}[data-theme=dark]{--neu-bg: #161a1d;--neu-text: #ffffff;--neu-text-secondary: #E5E7EB;--neu-shadow-light: 0 0 10px rgba(0, 0, 0, .3);--neu-shadow-dark: 0 0 10px rgba(0, 0, 0, .3);--neu-shadow-inset: inset 2px 2px 5px #0b090a, inset -2px -2px 5px rgba(255, 255, 255, .03);--neu-accent: #ff4b5c;--neu-accent-blue: #00d2ff;--neu-accent-green: #00ff9d}.neu-container{background-color:var(--neu-bg);color:var(--neu-text);padding:20px 0;padding-top:calc(12px + env(safe-area-inset-top));height:100dvh;display:flex;flex-direction:column;overflow:hidden;overflow-x:hidden;box-sizing:border-box;padding-bottom:0;max-width:100vw}.neu-scroll-content{flex:1;overflow-y:auto;padding-bottom:150px;margin-top:10px;padding-right:2px;-webkit-overflow-scrolling:touch;-ms-overflow-style:none;scrollbar-width:none}.neu-scroll-content::-webkit-scrollbar{width:0;height:0;background:transparent}.neu-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding:0 20px}.neu-avatar-box{width:50px;height:50px;border-radius:12px;background:var(--neu-bg);box-shadow:var(--neu-shadow-light),var(--neu-shadow-dark);display:flex;align-items:center;justify-content:center;color:var(--neu-accent)}.neu-welcome-text{flex:1;display:flex;flex-direction:column;align-items:center}.neu-app-logo{display:flex;align-items:center;margin-bottom:5px;height:20px;justify-content:center;margin-top:24px}.neu-app-logo svg{height:100%;width:auto;color:var(--neu-text)}.neu-welcome-subtitle{font-size:.72rem;font-weight:500;color:var(--neu-text-secondary)}.neu-icon-btn{width:50px;height:50px;border-radius:50%;border:none;background:var(--neu-bg);box-shadow:var(--neu-shadow-light),var(--neu-shadow-dark);display:flex;align-items:center;justify-content:center;color:var(--neu-text);cursor:pointer;transition:all .2s ease}.neu-icon-btn:active{box-shadow:var(--neu-shadow-inset)}.neu-main-card{border-radius:15px;background:var(--neu-bg);box-shadow:var(--neu-shadow-light),var(--neu-shadow-dark);padding:20px;margin:0 20px 16px;position:relative;overflow:hidden}.neu-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.neu-card-label{font-size:.85rem;font-weight:500;color:var(--neu-text-secondary)}.neu-header-actions{display:flex;gap:12px}.neu-icon-btn-small{width:36px;height:36px;border-radius:10px;background:var(--neu-bg);box-shadow:var(--neu-shadow-light),var(--neu-shadow-dark);display:flex;align-items:center;justify-content:center;border:none;outline:none;color:var(--neu-text-secondary);cursor:pointer;transition:all .2s ease}.neu-icon-btn-small:active{box-shadow:var(--neu-shadow-inset);transform:scale(.95)}.neu-chart-icon{display:none;width:40px;height:40px;border-radius:10px;background:var(--neu-bg);box-shadow:var(--neu-shadow-light),var(--neu-shadow-dark);display:flex;align-items:center;justify-content:center;color:var(--neu-accent)}.neu-amount-large{font-size:2.5rem;font-weight:800;color:var(--neu-text);margin:5px 0 15px}.neu-amount-decimal{font-size:1.5rem;color:var(--neu-text-secondary)}.neu-progress-container{height:8px;background:#e0e5ec;border-radius:4px;box-shadow:var(--neu-shadow-inset);position:relative;overflow:hidden}.neu-progress-bar{height:100%;background:#ff4b5c;border-radius:4px;width:60%;box-shadow:2px 0 5px #ff4b5c66}.neu-savings-row{display:flex;justify-content:space-between;gap:12px;margin:0 20px 16px}.neu-saving-card{flex:1;min-width:0;border-radius:20px;background:var(--neu-bg);box-shadow:var(--neu-shadow-light),var(--neu-shadow-dark);padding:12px;display:flex;flex-direction:column;align-items:center;text-align:center}.neu-saving-time{font-size:.7rem;font-weight:600;color:var(--neu-text-secondary);text-transform:uppercase;margin-bottom:10px}.neu-saving-amount{font-size:1.2rem;font-weight:700;color:var(--neu-text);margin-bottom:5px}.neu-trend{font-size:.7rem;font-weight:600;display:flex;align-items:center;gap:5px}.neu-trend.up{color:#00b894}.neu-trend.down{color:#ff4b5c}.neu-trend.track{color:#00d2ff}.neu-section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding:0 20px}.neu-section-title{font-size:.95rem;font-weight:600;color:var(--neu-text);text-transform:none}.neu-view-all{font-size:.8rem;font-weight:600;color:#00d2ff;cursor:pointer}html,body{overflow-y:auto!important;overflow-x:hidden!important;height:auto!important;overscroll-behavior-y:none;width:100%;position:relative}.neu-collapsible-top{transform-origin:top center;transition:transform .1s linear,opacity .1s linear;will-change:transform,opacity}.neu-transaction-list{display:flex;flex-direction:column;gap:7px;padding:0 20px 120px;-ms-overflow-style:none;scrollbar-width:none}.neu-transaction-list::-webkit-scrollbar{width:0;height:0;background:transparent}.neu-trans-group{display:flex;flex-direction:column;gap:7px}.neu-sticky-header{position:sticky;top:-20px;z-index:90;background:var(--neu-bg);margin:0;padding:10px 20px;display:flex;justify-content:space-between;align-items:center;transition:box-shadow .3s ease;box-sizing:border-box;width:100%}.neu-sticky-header.stuck{box-shadow:0 5px 15px #0b090a}.neu-collapsible-top{transform-origin:top center;transition:transform .1s linear,opacity .1s linear}.neu-group-header{font-size:.85rem;color:var(--neu-text-secondary);margin:15px 0 5px 20px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.neu-transaction-item{border-radius:12px;background:var(--neu-bg);box-shadow:var(--neu-shadow-light),var(--neu-shadow-dark);padding:10px 10px 10px 5px;display:flex;align-items:center;justify-content:space-between;overflow:hidden;width:100%;box-sizing:border-box}.neu-trans-icon-box{width:45px;height:45px;border-radius:50%;background:transparent;box-shadow:none;display:flex;align-items:center;justify-content:center;color:var(--neu-text);font-size:1.2rem;flex-shrink:0}.neu-img-icon{width:24px;height:24px;object-fit:contain}.neu-trans-details{flex:1;margin-left:5px;min-width:0}.neu-trans-title{font-size:.8rem;font-weight:600;color:var(--neu-text);margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.neu-trans-cat{font-size:.65rem;color:var(--neu-text-secondary);text-transform:none}.neu-trans-amount-box{text-align:right}.neu-trans-amount{font-size:1rem;font-weight:700;color:var(--neu-text)}.neu-trans-amount.expense{color:#ff4b5c}.neu-trans-amount.saving,.neu-trans-amount.income{color:#1a7399}.neu-trans-amount.income{color:#00b894}.neu-trans-time{font-size:.75rem;color:var(--neu-text-secondary)}.neu-fab-container{position:fixed;bottom:20px;left:50%;transform:translate(-50%);display:flex;align-items:center;justify-content:space-around;gap:10px;z-index:100;background:var(--neu-bg);padding:8px 15px;border-radius:20px;box-shadow:var(--neu-shadow-light),var(--neu-shadow-dark);width:90%;max-width:400px;height:60px}.neu-nav-btn{width:40px;height:40px;border-radius:12px;border:none;background:var(--neu-bg);box-shadow:var(--neu-shadow-light),var(--neu-shadow-dark);display:flex;align-items:center;justify-content:center;color:var(--neu-text-secondary);cursor:pointer}.neu-nav-btn.active{color:#00d2ff;box-shadow:var(--neu-shadow-inset)}.neu-add-btn{width:60px;height:60px;border-radius:50%;background:#00d2ff;border:none;color:#fff;font-size:2rem;display:flex;align-items:center;justify-content:center;box-shadow:5px 5px 10px #00d2ff66;transform:translateY(-20px);-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.neu-more-menu-dropdown{position:absolute;top:60px;right:20px;background:var(--neu-bg);border-radius:15px;padding:10px;width:180px;z-index:1000;box-shadow:var(--neu-shadow-light),var(--neu-shadow-dark);display:flex;flex-direction:column;gap:8px;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.neu-menu-item{display:flex;align-items:center;gap:12px;padding:12px;border-radius:10px;border:none;background:transparent;color:var(--neu-text);font-family:Outfit,sans-serif;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s;text-align:left}.neu-menu-item:hover{box-shadow:var(--neu-shadow-inset);color:var(--neu-accent-blue)}.neu-menu-item svg{width:18px;height:18px}.neu-modal-overlay{position:fixed;inset:0;z-index:2000;display:flex;align-items:center;justify-content:center;animation:fadeIn .2s}.neu-modal-overlay.blur-overlay{-webkit-backdrop-filter:blur(20px)}.neu-modal-content.open-layout{background:#e0e5ec1a;box-shadow:none;border-radius:0;width:100%;height:100%;max-width:none;padding:40px 20px;justify-content:center;animation:fadeIn .3s ease}.modal-header-actions h3{text-shadow:0 2px 4px rgba(0,0,0,.05)}.habits-integrated-section{animation:slideUp .4s ease-out}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.neu-options-row{display:flex;gap:20px;width:100%;justify-content:center}.neu-option-btn{flex:1;height:100px;border-radius:20px;background:var(--neu-bg);box-shadow:var(--neu-shadow-light),var(--neu-shadow-dark);display:flex;flex-direction:column;align-items:center;justify-content:center;border:none;color:var(--neu-text);cursor:pointer;font-size:1rem;font-weight:600;gap:10px}.neu-option-btn:active{box-shadow:var(--neu-shadow-inset)}.neu-option-btn.expense{color:#ff4b5c}.neu-option-btn.saving{color:#00b894}.neu-search-bar{width:100%;padding:12px 45px 12px 20px;border-radius:30px;background:var(--neu-bg);border:none;box-shadow:var(--neu-shadow-inset);font-size:.9rem;color:var(--neu-text);outline:none;box-sizing:border-box;-webkit-appearance:none;appearance:none}.neu-close-btn{margin-top:10px;padding:10px 30px;border-radius:15px;background:var(--neu-bg);box-shadow:var(--neu-shadow-light),var(--neu-shadow-dark);border:none;color:var(--neu-text-secondary);font-weight:600;cursor:pointer}.neu-close-btn:active{box-shadow:var(--neu-shadow-inset)}.neu-transaction-wrapper{transition:all .3s cubic-bezier(.4,0,.2,1)}.neu-transaction-wrapper.expanded{margin:10px 0}.neu-transaction-item.expanded{box-shadow:var(--neu-shadow-inset);border-radius:20px 20px 0 0}.neu-transaction-dropdown{background:var(--neu-bg);border-radius:0 0 20px 20px;box-shadow:var(--neu-shadow-light),var(--neu-shadow-dark);padding:15px;margin-top:-1px;animation:slideDown .3s ease-out;border-top:1px solid rgba(0,0,0,.05)}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.neu-dropdown-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.neu-dropdown-label{font-size:.75rem;font-weight:600;color:var(--neu-text-secondary);text-transform:uppercase;letter-spacing:.5px}.neu-dropdown-actions{display:flex;gap:10px}.neu-action-btn{width:32px;height:32px;border-radius:8px;border:none;background:var(--neu-bg);box-shadow:var(--neu-shadow-light),var(--neu-shadow-dark);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.neu-action-btn.edit{color:var(--neu-accent-blue)}.neu-action-btn.delete{color:var(--neu-accent)}.neu-action-btn:active{box-shadow:var(--neu-shadow-inset);transform:scale(.95)}.neu-detail-row{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid rgba(0,0,0,.03)}.neu-detail-row:last-child{border-bottom:none}.neu-detail-row .label{font-size:.85rem;color:var(--neu-text-secondary)}.neu-detail-row .value{font-size:.85rem;font-weight:600;color:var(--neu-text)}.neu-detail-row .value.expense{color:var(--neu-accent)}.neu-detail-row .value.saving{color:#1a7399}.neu-edit-form{display:flex;flex-direction:column;gap:12px}.neu-input-group{display:flex;flex-direction:column;gap:6px}.neu-input-group label{font-size:.75rem;font-weight:600;color:var(--neu-text-secondary);margin-left:5px}.neu-edit-input{width:100%;height:40px;border-radius:12px;border:none;background:var(--neu-bg);box-shadow:var(--neu-shadow-inset);padding:0 15px;font-family:inherit;font-size:.9rem;color:var(--neu-text);box-sizing:border-box;outline:none}.neu-edit-input.type-select{display:flex;justify-content:space-between;align-items:center;cursor:pointer;text-align:left}.activity-type-select-wrapper{position:relative;width:100%}.neu-type-dropdown{position:absolute;top:45px;left:0;right:0;background:var(--neu-bg);border-radius:12px;box-shadow:var(--neu-shadow-light),var(--neu-shadow-dark);z-index:100;overflow:hidden}.neu-type-option{padding:12px 15px;font-size:.9rem;color:var(--neu-text);cursor:pointer;transition:background .2s}.neu-type-option:hover{background:#0000000d}.neu-type-option.active{background:var(--neu-accent-blue);color:#fff}.neu-edit-actions{display:flex;gap:12px;margin-top:5px}.neu-save-btn{flex:2;height:40px;border-radius:12px;border:none;background:var(--neu-accent-blue);color:#fff;font-weight:600;cursor:pointer;box-shadow:0 4px 10px #00d2ff4d}.neu-cancel-btn{flex:1;height:40px;border-radius:12px;border:none;background:var(--neu-bg);box-shadow:var(--neu-shadow-light),var(--neu-shadow-dark);color:var(--neu-text-secondary);font-weight:600;cursor:pointer}.neu-save-btn:active,.neu-cancel-btn:active{transform:scale(.98)}.neu-modal-content.delete{max-width:300px;padding:25px}.neu-delete-icon{width:60px;height:60px;border-radius:50%;background:var(--neu-bg);box-shadow:var(--neu-shadow-light),var(--neu-shadow-dark);display:flex;align-items:center;justify-content:center;color:var(--neu-accent)}.neu-delete-modal-actions{display:flex;flex-direction:column;gap:12px;width:100%}.neu-confirm-delete-btn{height:45px;border-radius:15px;border:none;background:var(--neu-accent);color:#fff;font-weight:700;cursor:pointer;box-shadow:0 4px 12px #ff4b5c4d}.neu-cancel-delete-btn{height:45px;border-radius:15px;border:none;background:var(--neu-bg);box-shadow:var(--neu-shadow-light),var(--neu-shadow-dark);color:var(--neu-text-secondary);font-weight:600;cursor:pointer}.neu-confirm-delete-btn:active,.neu-cancel-delete-btn:active{transform:scale(.98)}.scan-section{margin-bottom:1.5rem}.form-divider{display:flex;align-items:center;text-align:center;margin:1.5rem 0;color:var(--color-text-muted);font-size:.875rem}.form-divider:before,.form-divider:after{content:"";flex:1;border-bottom:1px solid rgba(0,0,0,.1)}.form-divider span{padding:0 1rem}.scan-button{width:100%;padding:1rem;background:linear-gradient(135deg,#9c27b0e6,#9c27b0e6);border:none;border-radius:12px;color:var(--color-text-inverse);font-size:1rem;font-weight:600;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:.5rem;box-shadow:0 2px 6px #9c27b033;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.scan-button:active{transform:scale(.98);box-shadow:0 1px 4px #9c27b04d}.scan-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.scan-button svg{width:24px;height:24px}.scanned-items-section{background:var(--color-bg-card);backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px);border:1px solid var(--color-border-soft);border-radius:12px;padding:1.5rem;margin-bottom:1.5rem}.scanned-items-title{font-size:1.125rem;font-weight:600;color:var(--color-text-main);margin:0 0 1rem}.scanned-items-list{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1rem;max-height:300px;overflow-y:auto}.scan-total-section{margin-bottom:1rem;padding-top:1rem;border-top:1px solid var(--color-border-soft)}.scan-total{display:flex;justify-content:space-between;align-items:center;padding:.875rem;background:#bfc6c40d;border:1px solid rgba(191,198,196,.2);border-radius:8px;margin-bottom:1rem}.scan-total-label{font-size:1rem;font-weight:600;color:var(--color-text-main)}.scan-total-amount{font-size:1.125rem;font-weight:700;color:#bfc6c4}.scanned-item-checkbox{display:flex;align-items:center;gap:.75rem;padding:.875rem;background:var(--color-bg-card);border:1px solid var(--color-border-soft);border-radius:8px;cursor:pointer;transition:all .2s ease}.scanned-item-checkbox:hover{background:#bfc6c40d;border-color:#bfc6c44d}.scanned-item-checkbox input[type=checkbox]{width:20px;height:20px;cursor:pointer;accent-color:#BFC6C4}.scanned-item-content{flex:1;display:flex;justify-content:space-between;align-items:center;gap:1rem}.scanned-item-name{font-size:.9375rem;color:var(--color-text-main);flex:1}.scanned-item-amount{font-size:.9375rem;font-weight:600;color:#bfc6c4}.add-selected-button{width:100%;padding:.875rem;background:linear-gradient(135deg,#bfc6c4,#a8b0ae);border:none;border-radius:8px;color:var(--color-text-inverse);font-size:.9375rem;font-weight:600;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;cursor:pointer;transition:all .2s ease;margin-bottom:.5rem;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.add-selected-button:active{transform:scale(.98)}.add-selected-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.clear-scan-button{width:100%;padding:.75rem;background:transparent;border:1px solid rgba(0,0,0,.2);border-radius:8px;color:var(--color-text-muted);font-size:.875rem;font-weight:500;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;cursor:pointer;transition:all .2s ease;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.clear-scan-button:active{transform:scale(.98);background:#0000000d}.scan-modal-overlay{position:fixed;inset:0;background:#00000080;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.scan-modal{background:var(--color-bg-card);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-radius:16px;width:100%;max-width:400px;max-height:90vh;overflow-y:auto;box-shadow:0 8px 32px #0003}.scan-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem;border-bottom:1px solid rgba(0,0,0,.1)}.scan-modal-header h2{font-size:1.25rem;font-weight:600;color:#1a1a1a;margin:0}.scan-modal-close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:none;border:none;font-size:24px;color:var(--color-text-muted);cursor:pointer;border-radius:8px;transition:all .2s ease;-webkit-tap-highlight-color:transparent}.scan-modal-close:hover{background:#0000000d}.scan-modal-close:active{transform:scale(.95)}.scan-modal-close:disabled{opacity:.5;cursor:not-allowed}.scan-modal-content{padding:1.5rem}.scan-modal-description{font-size:.9375rem;color:var(--color-text-muted);margin:0 0 1.5rem;line-height:1.5}.scan-error-message{background:#ff3b301a;border:1px solid rgba(255,59,48,.3);border-radius:8px;padding:.875rem;color:#ff3b30;font-size:.875rem;margin-bottom:1rem}.scanning-indicator{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:2rem;margin-bottom:1rem}.scanning-spinner{width:48px;height:48px;border:4px solid rgba(191,198,196,.2);border-top-color:#bfc6c4;border-radius:50%;animation:spin 1s linear infinite}.scanning-indicator p{font-size:.9375rem;color:var(--color-text-muted);margin:0 0 .75rem}.scan-progress-bar{width:100%;height:4px;background:#bfc6c433;border-radius:2px;overflow:hidden;margin-top:.5rem}.scan-progress-fill{height:100%;background:linear-gradient(90deg,#bfc6c4,#22c55e);border-radius:2px;transition:width .3s ease}.scan-options{display:flex;flex-direction:column;gap:.75rem}.scan-option-button{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:1rem;background:var(--color-bg-card);border:1px solid var(--color-border-soft);border-radius:12px;cursor:pointer;transition:all .2s ease;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.scan-option-button:hover{background:#bfc6c40d;border-color:#bfc6c44d}.scan-option-button:active{transform:scale(.98)}.scan-option-button svg{width:24px;height:24px;color:#bfc6c4}.scan-option-button span{font-size:1rem;font-weight:500;color:var(--color-text-main)}.transaction-container{min-height:100vh;min-height:100dvh;background:radial-gradient(circle at top left,var(--color-bg-gradient-start) 0%,var(--color-bg-gradient-end) 50%,var(--color-bg-gradient-start) 100%);padding:env(safe-area-inset-top,0px) 0 env(safe-area-inset-bottom,80px) 0;padding-bottom:calc(env(safe-area-inset-bottom,0px) + 100px);overflow-x:hidden;overflow-y:auto;position:relative}.transaction-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;background:var(--color-bg-card-blur);backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px);border-bottom:1px solid var(--color-border-soft);position:sticky;top:0;z-index:50}.back-button{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;color:#1a1a1a;padding:0;-webkit-tap-highlight-color:transparent;touch-action:manipulation;transition:all .2s ease}.back-button:active{transform:scale(.95);opacity:.7}.transaction-title{font-size:1.5rem;font-weight:600;color:var(--color-text-main);margin:0;flex:1;text-align:center}.transaction-content{padding:1.5rem 1rem;max-width:100%}.transaction-form{display:flex;flex-direction:column;gap:1.5rem}.input-label{font-size:.9375rem;font-weight:500;color:#1a1a1a;margin:0}.input-wrapper{position:relative;width:100%}.transaction-input{width:100%;padding:.875rem 1rem;background:var(--color-bg-card);backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px);border:1px solid var(--color-border-soft);border-radius:12px;font-size:1rem;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;color:var(--color-text-main);transition:all .2s ease;-webkit-appearance:none;appearance:none;box-sizing:border-box}.transaction-input select{cursor:pointer}.transaction-input:focus{outline:none;border-color:#bfc6c4;background:var(--color-bg-card);box-shadow:0 0 0 2px #bfc6c41a}.transaction-textarea{resize:vertical;min-height:100px;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.transaction-input.input-error{border-color:#ff3b3080;background:#fff5f566}.transaction-input.input-error:focus{border-color:#ff3b3099;box-shadow:0 0 0 2px #ff3b301a}.error-message{font-size:.875rem;color:#ff3b30;margin:0}.submit-error-message{background:#ff3b301a;border:1px solid rgba(255,59,48,.3);border-radius:12px;padding:.875rem 1rem;color:#ff3b30;font-size:.875rem;text-align:center}.transaction-button{width:100%;padding:1rem;background:linear-gradient(135deg,#bfc6c4,#a8b0ae);border:none;border-radius:12px;color:var(--color-text-inverse);font-size:1rem;font-weight:600;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:.5rem;box-shadow:0 2px 6px #bfc6c433;-webkit-tap-highlight-color:transparent;touch-action:manipulation;margin-top:.5rem}.transaction-button:active{transform:scale(.98);box-shadow:0 1px 4px #bfc6c44d}.transaction-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.transaction-button .spinner{width:20px;height:20px;animation:spin 1s linear infinite}.bottom-nav{position:fixed;bottom:0;left:0;right:0;background:var(--color-bg-card);backdrop-filter:none;-webkit-backdrop-filter:none;border-top:1px solid var(--color-border-soft);padding:.5rem 0;padding-bottom:0!important;min-height:64px;display:flex;justify-content:space-around;align-items:center;box-shadow:0 -1px 4px #0000000d;z-index:100}.nav-item{display:flex;flex-direction:column;align-items:center;gap:.25rem;background:none;border:none;cursor:pointer;padding:.5rem 1rem;color:var(--color-text-muted);transition:all .2s ease;-webkit-tap-highlight-color:transparent}.nav-item:active{transform:scale(.95)}.nav-item.active{color:var(--color-primary)}.nav-item-add{background:linear-gradient(135deg,#bfc6c4b3,#bfc6c4bf);color:var(--color-text-inverse);padding:.5rem;box-shadow:0 2px 8px #bfc6c433;border-radius:16px;width:64px;height:64px;display:flex;align-items:center;justify-content:center}.nav-item-add:active{transform:scale(.95);box-shadow:0 1px 4px #bfc6c433}.nav-item-add svg{width:48px;height:48px}.nav-item svg{width:24px;height:24px}.nav-item span{font-size:.75rem;font-weight:600}.transaction-modal-overlay{position:fixed;inset:0;background:#0006;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:2000;padding:1rem;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.transaction-modal-content{display:flex;gap:1rem;align-items:center;justify-content:center;animation:slideUp .3s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.transaction-option{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;padding:2rem 2.5rem;background:var(--color-bg-card);border:none;border-radius:15px;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 16px #00000026;min-width:140px;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.transaction-option:active{transform:scale(.95);box-shadow:0 2px 8px #0003}.transaction-option svg{width:48px;height:48px}.transaction-option span{font-size:1.5rem;font-weight:600;color:var(--color-text-main)}.expense-option svg{color:#f44336}.saving-option svg{color:#4caf50}@media(min-width:640px){.transaction-container{max-width:480px;margin:0 auto}}.activities-container{min-height:100vh;min-height:100dvh;background:radial-gradient(circle at top left,var(--color-bg-gradient-start) 0%,var(--color-bg-gradient-end) 50%,var(--color-bg-gradient-start) 100%);padding:env(safe-area-inset-top,0px) 0 env(safe-area-inset-bottom,80px) 0;padding-bottom:calc(env(safe-area-inset-bottom,0px) + 100px);overflow-x:hidden;overflow-y:auto;position:relative}.activities-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;background:var(--color-bg-card-blur);backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px);border-bottom:1px solid var(--color-border-soft);position:sticky;top:0;z-index:50}.back-button,.activities-stats-button{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;color:var(--color-text-main);padding:0;-webkit-tap-highlight-color:transparent;touch-action:manipulation;transition:all .2s ease}.back-button:active,.activities-stats-button:active{transform:scale(.95);opacity:.7}.activities-title{font-size:1.25rem;font-weight:600;color:var(--color-text-main);margin:0}.activities-search-wrapper{padding:.75rem 1rem;background:var(--color-bg-card-blur);backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px);border-bottom:1px solid var(--color-border-soft);position:sticky;top:60px;z-index:40}.activities-search{position:relative;display:flex;align-items:center}.search-icon{position:absolute;left:.75rem;width:18px;height:18px;color:var(--color-text-muted);pointer-events:none}.activities-search-input{width:100%;padding:.625rem 2.5rem .625rem 2.75rem;background:#ffffffe6;border:1px solid rgba(0,0,0,.1);border-radius:10px;font-size:.875rem;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;color:var(--color-text-main);transition:all .2s ease;-webkit-appearance:none;appearance:none;box-sizing:border-box}[data-theme=dark] .activities-search-input{background:#1e293be6;border-color:#ffffff1a}.activities-search-input:focus{outline:none;border-color:#bfc6c4;background:var(--color-bg-card);box-shadow:0 0 0 3px #bfc6c41a}.activities-search-input::placeholder{color:var(--color-text-muted)}.search-clear-button{position:absolute;right:.5rem;width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:var(--color-border-soft);border:none;border-radius:6px;cursor:pointer;color:var(--color-text-muted);padding:0;-webkit-tap-highlight-color:transparent;transition:all .2s ease}.search-clear-button:active{transform:scale(.95);background:#0000001a}.search-clear-button svg{width:16px;height:16px}.no-results{text-align:center;padding:3rem 1rem;color:var(--color-text-muted)}.no-results p{font-size:.9375rem;margin:0 0 .5rem;color:var(--color-text-main);font-weight:500}.no-results-subtitle{font-size:.8125rem;color:var(--color-text-muted);margin:0}.activities-content{padding:1rem;min-height:calc(100vh - 200px);display:flex;flex-direction:column}.activities-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;min-height:400px;gap:.75rem}.add-activity-button{width:72px;height:72px;border-radius:50%;background:#bfc6c4;color:#fff;border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 12px #bfc6c44d;-webkit-tap-highlight-color:transparent}.add-activity-button:active{transform:scale(.95);box-shadow:0 2px 8px #bfc6c466}.add-activity-button svg{width:36px;height:36px}.empty-message{font-size:1rem;font-weight:600;color:var(--color-text-main);margin:0}.empty-submessage{font-size:.8125rem;color:var(--color-text-muted);margin:0;text-align:center;padding:0 1rem}.floating-add-button{position:fixed;bottom:180px;right:1rem;width:64px;height:64px;border-radius:50%;background:linear-gradient(135deg,#bfc6c4b3,#bfc6c4bf);color:#fff;border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;box-shadow:0 3px 10px #bfc6c44d;z-index:90;-webkit-tap-highlight-color:transparent}.floating-add-button:active{transform:scale(.95);box-shadow:0 2px 6px #bfc6c466}.floating-add-button svg{width:36px;height:36px}.activities-list-wrapper{position:relative}.activities-list{display:flex;flex-direction:column;gap:.375rem}.activities-list .activity-card{background:var(--color-bg-card);backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px);border-radius:12px;padding:.75rem;border:1px solid var(--color-border-soft);box-shadow:0 2px 8px #00000014;transition:all .2s ease;cursor:pointer;margin-bottom:.75rem}.activities-list .activity-card:active{transform:scale(.98);background:var(--color-bg-card);box-shadow:0 1px 4px #0000001f}.activities-list .activity-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.25rem;gap:.75rem}.activities-list .activity-card-name{font-size:1rem;font-weight:600;color:var(--color-text-main);margin:0;line-height:1.4}.activities-list .activity-card-budget{font-size:.75rem;font-weight:700;color:var(--color-primary-strong);white-space:nowrap;background:var(--color-primary-soft);padding:.3rem .6rem;border-radius:8px;flex-shrink:0;text-transform:uppercase;letter-spacing:.5px}.currency-symbol{font-size:.6875rem;margin-left:.125rem}.activity-card-dates{margin-bottom:.25rem}.activity-card-description-row{display:flex;justify-content:space-between;align-items:center;gap:.75rem}.activity-card-description{font-size:.75rem;color:var(--color-text-muted);margin:0;line-height:1.4;flex:1;display:-webkit-box;-webkit-line-clamp:1;line-clamp:1;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis}.activity-card-mode{font-size:.6875rem;font-weight:600;padding:.375rem .625rem;border-radius:8px;white-space:nowrap;flex-shrink:0;letter-spacing:.3px}.activity-date{display:flex;align-items:center;gap:.375rem;font-size:.75rem;color:var(--color-text-muted)}.date-icon{width:14px;height:14px;color:var(--color-text-muted);flex-shrink:0}.activities-form-wrapper{width:100%}.activities-form{display:flex;flex-direction:column;gap:1rem}.form-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.form-header h2{font-size:1.125rem;font-weight:600;color:var(--color-text-main);margin:0}.close-form-button{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:var(--color-border-soft);border:none;border-radius:6px;cursor:pointer;color:var(--color-text-main);padding:0;-webkit-tap-highlight-color:transparent;transition:all .2s ease}.close-form-button:active{transform:scale(.95);background:#0000001a}.close-form-button svg{width:20px;height:20px}.submit-error-message{background:#f443361a;border:1px solid rgba(244,67,54,.3);border-radius:10px;padding:.75rem 1rem;color:#f44336;font-size:.875rem;text-align:center;margin-bottom:.5rem}.input-group{display:flex;flex-direction:column;gap:.5rem}.input-label{font-size:.875rem;font-weight:500;color:#666;margin:0}.input-wrapper{position:relative}.transaction-input{width:100%;padding:.875rem 1rem;background:var(--color-bg-card);border:1px solid var(--color-border-soft);border-radius:10px;font-size:1rem;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;color:var(--color-text-main);transition:all .2s ease;-webkit-appearance:none;appearance:none;box-sizing:border-box}.transaction-input:focus{outline:none;border-color:#bfc6c4;background:var(--color-bg-card);box-shadow:0 0 0 3px #bfc6c41a}.transaction-input::placeholder{color:var(--color-text-muted)}.transaction-input:disabled{opacity:.6;cursor:not-allowed}.transaction-input.input-error{border-color:#f44336;background:#f443360d}.transaction-input.input-error:focus{border-color:#f44336;box-shadow:0 0 0 3px #f443361a}.transaction-textarea{resize:vertical;min-height:100px;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.5}.error-message{font-size:.75rem;color:#f44336;margin-top:-.25rem}.transaction-button{width:100%;padding:1rem;background:var(--color-primary);color:var(--color-text-inverse);border:none;border-radius:10px;font-size:1rem;font-weight:600;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:.5rem;margin-top:.5rem;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.transaction-button:hover:not(:disabled){background:var(--color-primary-strong)}.transaction-button:active:not(:disabled){transform:scale(.98)}.transaction-button:disabled{opacity:.6;cursor:not-allowed}.spinner{width:20px;height:20px;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-text{text-align:center;color:var(--color-text-muted);font-size:.875rem;padding:2rem}.activity-detail-container{min-height:100vh;min-height:100dvh;background:radial-gradient(circle at top left,var(--color-bg-gradient-start) 0%,var(--color-bg-gradient-end) 50%,var(--color-bg-gradient-start) 100%);padding:env(safe-area-inset-top,0px) 0 env(safe-area-inset-bottom,90px) 0;padding-bottom:calc(env(safe-area-inset-bottom,0px) + 90px);overflow-x:hidden;overflow-y:auto;position:relative}.activity-detail-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 10px;background:var(--color-bg-card-blur);backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px);border-bottom:1px solid var(--color-border-soft);position:sticky;top:0;z-index:50}.back-button,.menu-button{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;color:var(--color-text-main);padding:0;-webkit-tap-highlight-color:transparent;touch-action:manipulation;transition:all .2s ease}.back-button:active,.menu-button:active{transform:scale(.95);opacity:.7}.back-button svg,.menu-button svg{width:24px;height:24px}.activity-detail-title{font-size:1.125rem;font-weight:600;color:var(--color-text-main);margin:0;flex:1;text-align:center}.activity-detail-card{background:var(--color-bg-card);border-radius:15px;margin:0 10px 16px;overflow:hidden;box-shadow:var(--shadow-soft)}.budget-overview{padding:1.25rem 1rem;border-bottom:1px solid var(--color-border-soft)}.budget-label{font-size:.6875rem;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:.5rem}.budget-header{display:flex;justify-content:space-between;align-items:center;gap:1rem}.budget-amount{font-size:1.75rem;font-weight:600;color:var(--color-text-main);display:flex;align-items:baseline;gap:.25rem}.currency-symbol{font-size:1.25rem;font-weight:600}.budget-status-badge{font-size:.6875rem;font-weight:600;padding:.375rem .625rem;border-radius:8px;white-space:nowrap;letter-spacing:.3px}.budget-dates{display:flex;flex-direction:column;gap:.375rem;margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--color-border-soft)}.budget-date-item{display:flex;align-items:center;gap:.375rem;font-size:.75rem}.budget-date-item .date-icon{width:14px;height:14px;color:var(--color-text-muted);flex-shrink:0}.budget-date-item .date-value{color:var(--color-text-muted);font-weight:400}.budget-date-item .date-separator{color:var(--color-text-muted);margin:0 .25rem;font-size:.75rem}.expenses-section{padding:1.25rem 1rem}.expenses-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.75rem;gap:1rem}.expenses-title{font-size:1rem;font-weight:600;color:var(--color-text-main);margin:0}.expenses-stats{display:flex;flex-direction:column;align-items:flex-end;gap:.25rem}.expenses-percentage{font-size:.75rem;color:var(--color-text-muted)}.expenses-amount{font-size:.875rem;font-weight:600;color:var(--color-text-main)}.expenses-progress-bar{width:100%;height:8px;background:#00000014;border-radius:4px;overflow:hidden}.expenses-progress-fill{height:100%;background:#bfc6c4;border-radius:4px;transition:width .3s ease,background-color .3s ease}.budget-warning{display:flex;align-items:center;gap:.75rem;padding:.875rem 1rem;margin-top:1rem;border-radius:12px;border:1px solid;font-size:.875rem;font-weight:500;animation:slideIn .3s ease}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.budget-warning .warning-icon{width:20px;height:20px;flex-shrink:0}.budget-warning .warning-message{flex:1}.view-chart-button{display:flex;align-items:center;justify-content:center;gap:.75rem;width:100%;padding:.875rem 1rem;margin-top:1rem;background:var(--color-primary);color:var(--color-text-inverse);border:none;border-radius:12px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s ease;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.view-chart-button:hover{background:var(--color-primary-strong)}.view-chart-button:active{transform:scale(.98);opacity:.9}.view-chart-button svg{width:20px;height:20px}.view-chart-button span{flex:1;text-align:center}.detail-action-buttons{display:flex;gap:.625rem;margin-top:1rem}.detail-action-buttons .view-chart-button{margin-top:0;flex:1}.detail-action-buttons .statistics-action-button{background-color:#efece3;border-color:#efece3;color:#000}.recent-activities-section{margin:0 10px 16px}.recent-activities-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.recent-activities-title{font-size:1rem;font-weight:600;color:var(--color-text-main);margin:0}.view-all-button{background:none;border:none;color:var(--color-primary);font-size:.875rem;font-weight:500;cursor:pointer;padding:0;-webkit-tap-highlight-color:transparent}.view-all-button:active{opacity:.7}.activity-list{display:flex;flex-direction:column;gap:0}.activity-wrapper{border-bottom:1px solid var(--color-border-soft)}.activity-wrapper:last-child{border-bottom:none}.activity-item{background:transparent;padding:.625rem 0;display:flex;align-items:center;gap:.625rem;cursor:pointer;transition:background-color .2s ease}.activity-item:hover{background-color:var(--color-border-soft)}.activity-item:hover .activity-icon{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;border:2px solid}.activity-item:hover .activity-icon.expense{background:#f4433626;border-color:#f44336;color:#f44336}.activity-item:hover .activity-icon.saving{background:#0096c726;border-color:#0096c7;color:#0096c7}.activity-item:hover .activity-icon svg{width:16px;height:16px}.activity-details{flex:1;display:flex;flex-direction:column;gap:.125rem;min-width:0;overflow:hidden}.activity-title{font-size:.8125rem;font-weight:400;color:var(--color-text-main);margin:0;line-height:1.3}.activity-meta{display:flex;align-items:center;gap:.375rem;flex-wrap:nowrap;min-width:0}.activity-note{font-size:.75rem;color:#999;margin:0;font-weight:400;opacity:.7;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0}.activity-time{font-size:.6875rem;color:#999;margin:0;flex-shrink:0}.activity-separator{font-size:.6875rem;color:var(--color-text-muted);opacity:.5;margin:0;flex-shrink:0}.activity-amount{font-size:.875rem;font-weight:600;display:flex;align-items:baseline;gap:.125rem;flex-shrink:0}.activity-amount.saving{color:#0096c7}.activity-amount.expense{color:#f44336}.activity-amount .currency-symbol{font-size:.75rem}.activity-item.expanded{background-color:var(--color-bg-card-blur)}.activity-wrapper .activity-item:not(.expanded){background-color:transparent}.activity-dropdown{overflow:visible;animation:slideDown .3s ease-out;background:var(--color-bg-card);border-top:1px solid var(--color-border-soft);position:relative;z-index:1}@keyframes slideDown{0%{max-height:0;opacity:0}to{max-height:500px;opacity:1}}.activity-dropdown-header{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem .5rem;border-bottom:1px solid rgba(0,0,0,.08)}.activity-dropdown-title{font-size:.875rem;font-weight:600;color:var(--color-text-main);margin:0}.activity-header-actions{display:flex;gap:.5rem;align-items:center}.activity-edit-btn,.activity-delete-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:8px;cursor:pointer;transition:all .2s ease;padding:0;-webkit-tap-highlight-color:transparent}.activity-edit-btn{color:var(--color-primary)}.activity-edit-btn:active{transform:scale(.95);background:#bfc6c41a}.activity-delete-btn{color:#f44336}.activity-delete-btn:active{transform:scale(.95);background:#f443361a}.activity-edit-btn svg,.activity-delete-btn svg{width:18px;height:18px}.activity-dropdown-content{padding:1rem;display:flex;flex-direction:column;gap:.75rem}.activity-detail-row{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;position:relative;z-index:1}.activity-detail-label{font-size:.75rem;color:var(--color-text-muted);font-weight:500;flex-shrink:0}.activity-detail-value{font-size:.75rem;color:var(--color-text-main);text-align:right;flex:1;word-break:break-word}.activity-detail-value.expense{color:#f44336;font-weight:600}.activity-detail-value.saving{color:#0096c7;font-weight:600}.activity-edit-input{flex:1;padding:.5rem .75rem;background:#ffffffe6;border:1px solid rgba(0,0,0,.1);border-radius:8px;font-size:.75rem;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;color:var(--color-text-main);transition:all .2s ease;-webkit-appearance:none;appearance:none;box-sizing:border-box;text-align:right}.activity-edit-input:focus{outline:none;border-color:#bfc6c4;background:var(--color-bg-card)}.activity-edit-input[type=number]{text-align:right}.activity-edit-actions{display:flex;gap:.5rem;justify-content:flex-end;margin-top:.5rem}.activity-save-btn,.activity-cancel-btn{padding:.5rem 1rem;border:none;border-radius:8px;font-size:.75rem;font-weight:600;cursor:pointer;transition:all .2s ease;-webkit-tap-highlight-color:transparent}.activity-save-btn{background:var(--color-primary);color:var(--color-text-inverse)}.activity-save-btn:active{transform:scale(.98);background:#1a8ba8}.activity-cancel-btn{background:var(--color-border-soft);color:var(--color-text-main)}.activity-cancel-btn:active{transform:scale(.98);background:#0000001a}.activity-type-row{position:relative}.activity-type-select-wrapper{position:relative;flex:1}.activity-type-button{width:100%;display:flex;justify-content:space-between;align-items:center;padding:.5rem .75rem;background:#ffffffe6;border:1px solid rgba(0,0,0,.1);border-radius:8px;font-size:.75rem;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;color:var(--color-text-main);cursor:pointer;transition:all .2s ease;text-align:left;-webkit-appearance:none;appearance:none}.activity-type-button:focus,.activity-type-button.active{outline:none;border-color:#bfc6c4;background:var(--color-bg-card);box-shadow:0 0 0 2px #bfc6c41a}.dropdown-arrow{width:16px;height:16px;transition:transform .2s ease;flex-shrink:0}.dropdown-arrow.rotated{transform:rotate(180deg)}.activity-type-dropdown-options{position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--color-bg-card);border:1px solid var(--color-border-soft);border-radius:8px;box-shadow:var(--shadow-soft);z-index:1000;overflow:hidden}.activity-type-option{width:100%;padding:.75rem 1rem;background:transparent;border:none;text-align:left;font-size:.75rem;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;color:var(--color-text-main);cursor:pointer;transition:background-color .2s ease;-webkit-tap-highlight-color:transparent}.activity-type-option:hover{background:var(--color-border-soft)}.activity-type-option.selected{background:var(--color-primary-soft);color:var(--color-primary);font-weight:600}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal-card{background:var(--color-bg-card);border-radius:16px;padding:1.5rem;max-width:400px;width:100%;box-shadow:0 8px 24px #0003;animation:scaleIn .2s ease-out}@keyframes scaleIn{0%{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}.modal-icon-wrapper{width:64px;height:64px;margin:0 auto 1rem;background:#f443361a;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#f44336}.modal-icon-wrapper svg{width:32px;height:32px}.modal-title{font-size:1.25rem;font-weight:600;color:var(--color-text-main);text-align:center;margin:0 0 .5rem}.modal-message{font-size:.875rem;color:var(--color-text-muted);text-align:center;margin:0 0 1.5rem;line-height:1.5}.modal-actions{display:flex;gap:.75rem}.modal-cancel-btn,.modal-delete-btn{flex:1;padding:.75rem 1rem;border:none;border-radius:10px;font-size:.9375rem;font-weight:600;cursor:pointer;transition:all .2s ease;-webkit-tap-highlight-color:transparent}.modal-cancel-btn{background:#0000000d;color:var(--color-text-main)}.modal-cancel-btn:active{transform:scale(.98);background:#0000001a}.modal-delete-btn{background:#f44336;color:#fff}.modal-delete-btn:active{transform:scale(.98);background:#d32f2f}.activity-date-group{margin-bottom:1.5rem}.activity-date-group:last-child{margin-bottom:0}.activity-date-header{font-size:.875rem;font-weight:600;color:var(--color-text-muted);margin:0 0 .75rem;text-transform:capitalize}.no-activities{text-align:center;padding:1rem;color:var(--color-text-muted);font-size:.875rem}.bottom-navigation{position:fixed;bottom:0;left:0;right:0;display:flex;background:#fff;backdrop-filter:none;-webkit-backdrop-filter:none;border-top:1px solid rgba(0,0,0,.06);padding:.5rem 1rem;padding-bottom:0!important;min-height:50px;gap:.5rem;z-index:100;box-shadow:0 -2px 12px #00000008}.nav-button{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.3125rem;padding:.5rem .375rem;border:none;background:transparent;border-radius:14px;cursor:pointer;transition:all .25s cubic-bezier(.4,0,.2,1);-webkit-tap-highlight-color:transparent;position:relative;overflow:hidden}.nav-button:after{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:#0000000d;transform:translate(-50%,-50%);transition:width .4s ease,height .4s ease}.nav-button:active:after{width:200px;height:200px}.nav-button svg{width:20px;height:20px;transition:all .25s cubic-bezier(.4,0,.2,1);position:relative;z-index:1}.nav-button span{font-size:.625rem;font-weight:600;letter-spacing:.3px;transition:all .25s cubic-bezier(.4,0,.2,1);position:relative;z-index:1;text-transform:uppercase}.nav-button:active{transform:scale(.94)}.nav-button-home{color:#bfc6c4}.nav-button-home svg{color:#bfc6c4;fill:#bfc6c4}.nav-button-home span{color:#bfc6c4}.nav-button-home:active svg{transform:scale(1.1)}.nav-button-expense{color:#ff6b35}.nav-button-expense svg{color:#ff6b35;fill:#ff6b35}.nav-button-expense span{color:#ff6b35}.nav-button-expense:active svg{transform:scale(1.1)}.loading-text,.error-text{text-align:center;padding:3rem 1rem;color:var(--color-text-muted);font-size:.9375rem}.menu-button-wrapper{position:relative}.activity-menu-dropdown{position:absolute;top:100%;right:0;margin-top:.5rem;background:var(--color-bg-card);border:1px solid var(--color-border-soft);border-radius:12px;box-shadow:0 4px 12px #00000026;z-index:100;min-width:160px;overflow:hidden;animation:fadeIn .2s ease-out}.activity-menu-item{width:100%;display:flex;align-items:center;gap:.75rem;padding:.875rem 1rem;background:none;border:none;text-align:left;font-size:.9375rem;color:var(--color-text-main);cursor:pointer;transition:background-color .2s ease;-webkit-tap-highlight-color:transparent}.activity-menu-item:hover{background-color:var(--color-border-soft)}.activity-menu-item:active{background-color:#0000000d}.activity-menu-item-delete{color:#f44336}.activity-menu-item-delete:hover{background-color:#f443361a}.activity-menu-item svg{width:18px;height:18px;flex-shrink:0}.activity-menu-item span{flex:1}.modal-card-large{max-width:500px;width:90%;max-height:90vh;overflow-y:auto}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--color-border-soft)}.modal-close-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;color:var(--color-text-muted);padding:0;border-radius:6px;transition:all .2s ease;-webkit-tap-highlight-color:transparent}.modal-close-btn:hover{background-color:var(--color-border-soft)}.modal-close-btn:active{transform:scale(.95)}.modal-close-btn svg{width:20px;height:20px}.modal-content{display:flex;flex-direction:column;gap:1rem;margin-bottom:1.5rem}.modal-save-btn{flex:1;padding:.875rem;border-radius:10px;font-size:.9375rem;font-weight:600;cursor:pointer;transition:all .2s ease;-webkit-tap-highlight-color:transparent;background:var(--color-primary);color:var(--color-text-inverse);border:none}.modal-save-btn:hover{background:var(--color-primary-strong)}.modal-save-btn:active{transform:scale(.98)}.chart-header{margin-bottom:1rem}.chart-activity-name{font-size:1.125rem;font-weight:600;color:var(--neu-text);margin:0 0 .375rem}.chart-dates{font-size:.75rem;color:var(--neu-text-secondary);display:flex;align-items:center;gap:.25rem}.chart-container{width:100%;height:256px;margin-top:.5rem;margin-bottom:1rem;padding-bottom:0}.burn-up-chart-title{font-size:.875rem;font-weight:600;color:var(--neu-text);margin:0 0 .75rem}.chart-legend{display:flex;justify-content:center;gap:1.5rem;margin-top:.5rem;margin-bottom:.75rem;padding:0;border:none}.legend-item{display:flex;align-items:center;gap:.5rem;font-size:.75rem;color:var(--neu-text-secondary)}.legend-line{width:30px;height:2px;border-radius:1px}.legend-line.plan-line{background:repeating-linear-gradient(to right,#BFC6C4 0,#BFC6C4 4px,transparent 4px,transparent 8px);height:2px}.legend-line.actual-line{background:#4caf50}.legend-line.daily-plan-line{background:repeating-linear-gradient(to right,#ff9800 0,#ff9800 4px,transparent 4px,transparent 8px);height:2px}.legend-line.adjusted-daily-plan-line{background:repeating-linear-gradient(to right,#9c27b0 0,#9c27b0 3px,transparent 3px,transparent 6px);height:2px}.legend-line.daily-actual-line{background:#bfc6c4}.chart-empty{text-align:center;padding:3rem 1rem;color:var(--neu-text-secondary)}.chart-empty p{margin:0;font-size:.875rem}.chart-loading{text-align:center;padding:2rem 1rem;color:var(--neu-text-secondary)}.chart-loading p{margin:0;font-size:.875rem}.loading-text{display:flex;align-items:center;justify-content:center;min-height:50vh;color:var(--neu-text-secondary);font-size:.875rem}.daily-chart-container{margin-top:3rem;padding-top:1.5rem;border-top:1px solid rgba(128,128,128,.2)}.daily-chart-title{font-size:.875rem;font-weight:600;color:var(--neu-text);margin:0 0 .75rem}.statistics-page{min-height:100vh;min-height:100dvh;background:radial-gradient(circle at top left,var(--color-bg-gradient-start) 0%,var(--color-bg-gradient-end) 50%,var(--color-bg-gradient-start) 100%);padding:env(safe-area-inset-top,0px) 0 env(safe-area-inset-bottom,0px) 0;overflow-x:hidden;display:flex;flex-direction:column}.statistics-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;background:var(--color-bg-card-blur);backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px);border-bottom:1px solid var(--color-border-soft);position:sticky;top:0;z-index:10}.statistics-content{padding:1rem;padding-bottom:env(safe-area-inset-bottom,20px);max-width:600px;margin:0 auto;width:100%;box-sizing:border-box}.stats-summary-container{display:flex;justify-content:center;margin-bottom:2rem;height:250px;position:relative}.expense-pie-chart-container{width:100%;height:100%;position:relative;display:flex;align-items:center;justify-content:center}.donut-centered-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;pointer-events:none;z-index:0}.donut-centered-text h3{font-size:.65rem;color:var(--color-text-muted);margin:0 0 .2rem;text-transform:uppercase;letter-spacing:.5px;font-weight:500}.total-amount-center{font-size:1.1rem;font-weight:700;color:var(--color-text-main);margin:0;line-height:1.1;white-space:nowrap}.details-header{margin:0 0 1rem;padding-bottom:.5rem;border-bottom:1px solid var(--color-border-soft)}.details-header h3{font-size:1rem;font-weight:600;color:var(--color-text-main);margin:0}.currency-symbol{font-size:.7em!important;opacity:.8;margin-left:2px}.categories-list{display:flex;flex-direction:column;gap:.75rem}.statistics-title{font-size:1.25rem;font-weight:600;color:var(--color-text-main);margin:0;flex:1;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.category-item{background:var(--color-bg-card);border:1px solid var(--color-border-soft);border-radius:12px;padding:.4rem .6rem;position:relative;overflow:hidden;transition:all .2s ease}.category-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.2rem;position:relative;z-index:2}.subcategories-list{margin-top:.2rem;padding-top:.2rem;border-top:1px dashed var(--color-border-soft);display:flex;flex-direction:column;gap:0}.subcategory-item{display:flex;justify-content:space-between;align-items:center;font-size:.7rem;padding:.05rem .5rem;border-radius:4px;margin-left:1.5rem;opacity:.9}.subcategory-name{color:var(--color-text-muted)}.subcategory-amount{font-weight:600;color:var(--color-text-main)}.category-icon-container{width:28px;height:28px;border-radius:8px;display:flex;align-items:center;justify-content:center;background:var(--color-bg-subtle);flex-shrink:0}.category-icon-wrapper{width:16px;height:16px;display:flex;align-items:center;justify-content:center}.category-icon-wrapper svg{width:100%;height:100%}.category-icon-wrapper.food{color:#ff9800}.category-icon-wrapper.cart,.category-icon-wrapper.shopping{color:#4caf50}.category-icon-wrapper.car,.category-icon-wrapper.transportation{color:#2196f3}.category-icon-wrapper.utilities{color:#ffc107}.category-icon-wrapper.health{color:#e91e63}.category-icon-wrapper.entertainment{color:#9c27b0}.category-icon-wrapper.travel{color:#00bcd4}.category-icon-wrapper.education{color:#3f51b5}.category-icon-wrapper.financial{color:#607d8b}.category-icon-wrapper.home{color:#795548}.category-icon-wrapper.personal{color:#673ab7}.category-icon-wrapper.pets{color:#ff5722}.category-icon-wrapper.gifts{color:#ff4081}.category-icon-wrapper.government{color:#009688}.category-icon-wrapper.communication{color:#03a9f4}.category-icon-wrapper.sports{color:#ffeb3b}.category-icon-wrapper.others{color:#999}.category-item:hover .category-icon-wrapper.food~.category-icon-container,.category-icon-wrapper.food{--icon-color: #FF9800}.category-icon-container{background:#0000000d}[data-theme=dark] .category-icon-container{background:#ffffff1a}.category-info{flex:1;min-width:0}.category-name{font-size:.8rem;font-weight:600;color:var(--color-text-main);margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.category-count{font-size:.65rem;color:var(--color-text-muted);margin:0}.category-amount{font-size:.85rem;font-weight:700;color:var(--color-text-main);text-align:right;white-space:nowrap}.category-progress-bg{position:absolute;bottom:0;left:0;height:4px;width:100%;background:var(--color-bg-subtle)}.category-progress-fill{height:100%;background:#088395;border-radius:0 4px 4px 0}.settings-container{min-height:100vh;min-height:100dvh;background:radial-gradient(circle at top left,var(--color-bg-gradient-start) 0%,var(--color-bg-gradient-end) 50%,var(--color-bg-gradient-start) 100%);padding:env(safe-area-inset-top,0px) 0 env(safe-area-inset-bottom,0px) 0;overflow-x:hidden;overflow-y:auto;position:relative}.settings-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;background:var(--color-bg-card-blur);backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px);border-bottom:1px solid var(--color-border-soft);position:sticky;top:0;z-index:10}.settings-title{font-size:1.25rem;font-weight:600;color:var(--color-text-main);margin:0}.settings-content{padding:1rem 1.5rem 2rem;display:flex;flex-direction:column;gap:2rem}.settings-category{margin-bottom:0;padding:2rem 1.75rem;background:var(--color-bg-card);border-radius:15px;border:2px solid rgba(191,198,196,.2);box-shadow:var(--shadow-soft);position:relative;overflow:hidden}.settings-category:before{content:"";position:absolute;top:0;left:0;right:0;height:5px;background:linear-gradient(90deg,#bfc6c4,#bfc6c480);border-radius:15px 20px 0 0}.category-title{font-size:1.5rem;font-weight:700;color:var(--color-text-main);margin:0 0 2rem;letter-spacing:-.02em;padding-bottom:1rem;border-bottom:3px solid rgba(191,198,196,.3);position:relative}.settings-section{margin-bottom:1.25rem}.settings-section:last-of-type{margin-bottom:1rem}.section-title{font-size:.875rem;font-weight:600;color:var(--color-text-main);margin:0 0 .75rem}.settings-group{background:var(--color-bg-card-blur);backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px);border-radius:16px;padding:.75rem;border:1px solid var(--color-border-soft);box-shadow:var(--shadow-soft)}.setting-item{margin-bottom:.75rem}.setting-item:last-child{margin-bottom:0}.setting-row{display:flex;align-items:center;justify-content:space-between;gap:.75rem}.setting-info{flex:1;min-width:0}.setting-label{display:block;font-size:.75rem;font-weight:500;color:var(--color-text-muted);margin-bottom:.375rem}.setting-input,.setting-select{width:100%;padding:.5rem .75rem;background:#fffc;border:1px solid rgba(0,0,0,.1);border-radius:12px;font-size:.875rem;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;color:#1a1a1a;transition:all .2s ease;-webkit-appearance:none;appearance:none;box-sizing:border-box}.setting-input:focus,.setting-select:focus{outline:none;border-color:#bfc6c4;background:var(--color-bg-card)}.setting-select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%231a1a1a' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;background-size:12px;padding-right:2.25rem}.setting-select-dropdown{width:100%;padding:.5rem 2.25rem .5rem .75rem;background:#fffc;border:1px solid rgba(0,0,0,.1);border-radius:12px;font-size:.875rem;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;color:#1a1a1a;transition:all .2s ease;-webkit-appearance:none;appearance:none;box-sizing:border-box;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%231a1a1a' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;background-size:12px;cursor:pointer}.setting-select-dropdown:focus{outline:none;border-color:#bfc6c4;background-color:#fff}.setting-select-dropdown:hover{background-color:#fffffff2;border-color:#00000026}.setting-input-dropdown{width:100%;padding:.5rem .75rem;background:#fffc;border:1px solid rgba(0,0,0,.1);border-radius:12px;font-size:.875rem;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;color:#1a1a1a;transition:all .2s ease;box-sizing:border-box}.setting-input-dropdown:focus{outline:none;border-color:#bfc6c4;background-color:#fff}.setting-input-dropdown:hover{background-color:#fffffff2;border-color:#00000026}.setting-input-dropdown::placeholder{color:#999}.settings-navigation-btn{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:8px;cursor:pointer;color:#bfc6c4;transition:all .2s ease;-webkit-tap-highlight-color:transparent;flex-shrink:0}.settings-navigation-btn:active{transform:scale(.95);background:#bfc6c41a}.settings-navigation-btn svg{width:20px;height:20px}.setting-value{font-size:.875rem;color:#1a1a1a;padding:.5rem .75rem;background:#00000005;border-radius:12px}.edit-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:8px;cursor:pointer;color:#666;transition:all .2s ease;-webkit-tap-highlight-color:transparent;flex-shrink:0}.edit-btn:active{transform:scale(.95);background:#0000000d}.edit-btn svg{width:18px;height:18px}.setting-actions{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.setting-action-button{padding:.5rem 1rem;background:#bfc6c4;color:#fff;border:none;border-radius:8px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease;-webkit-tap-highlight-color:transparent}.setting-action-button:hover{background:#a8b0ae}.setting-action-button:active{transform:scale(.95);background:#ff6b1f}.logout-button{background:#ff6b35}.logout-button:hover{background:#ff5a25}.logout-button:active{background:#ff4a15}.action-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:8px;cursor:pointer;transition:all .2s ease;-webkit-tap-highlight-color:transparent}.action-btn svg{width:18px;height:18px}.save-btn{color:#bfc6c4}.save-btn:active{transform:scale(.95);background:#bfc6c41a}.cancel-btn{color:#666}.cancel-btn:active{transform:scale(.95);background:#0000000d}.personal-finance-page{min-height:100vh;min-height:100dvh;background:var(--color-bg-base);padding:env(safe-area-inset-top,0px) 1rem env(safe-area-inset-bottom,80px) 1rem;padding-bottom:calc(env(safe-area-inset-bottom,0px) + 100px);overflow-x:hidden;overflow-y:auto;position:relative;touch-action:pan-y}.personal-finance-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 0;margin-bottom:1rem;position:sticky;top:0;background:var(--color-bg-base);z-index:100;padding-top:calc(env(safe-area-inset-top,0px) + 1rem)}.back-button{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;border-radius:8px;color:var(--color-text-main);transition:all .2s ease;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.back-button:hover{background:#0000000d}.back-button:active{transform:scale(.95)}.personal-finance-title{font-size:1.5rem;font-weight:600;color:var(--color-text-main);margin:0}.personal-finance-content{width:100%;max-width:800px;margin:0 auto}.personal-finance-section{margin-bottom:1rem;width:100%}.personal-finance-section:last-child{margin-bottom:0}.personal-finance-section-title{font-size:.75rem;font-weight:600;color:var(--color-text-main);opacity:.4;margin:0 0 .5rem}.personal-finance-month-selector{width:100%;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:rgba(191,198,196,.3) transparent;margin-bottom:1rem}.personal-finance-month-selector:first-child{margin-top:0}.personal-finance-month-selector::-webkit-scrollbar{height:6px}.personal-finance-month-selector::-webkit-scrollbar-track{background:transparent}.personal-finance-month-selector::-webkit-scrollbar-thumb{background:#bfc6c44d;border-radius:3px}.personal-finance-month-selector::-webkit-scrollbar-thumb:hover{background:#bfc6c480}.month-select{display:flex;gap:.5rem;padding-bottom:.5rem;min-width:max-content;width:max-content}.month-pill{display:flex;align-items:center;justify-content:center;padding:.5rem .875rem;font-size:.875rem;font-weight:500;color:var(--color-text-muted);background:var(--color-primary-soft);border:2px solid transparent;border-radius:15px;cursor:pointer;transition:all .2s ease;white-space:nowrap;-webkit-tap-highlight-color:transparent;touch-action:manipulation;flex-shrink:0}.month-pill:hover{background:#e8e8e8;border-color:#bfc6c44d}.month-pill.active{color:#fff;background:#6096ba;border-color:#6096ba;box-shadow:0 2px 6px #6096ba4d}.month-pill:active{transform:scale(.98)}.month-amount{font-weight:600;font-size:.75rem;opacity:.8;margin-left:.5rem;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.payments-summary{display:flex;gap:.5rem;margin-bottom:1rem}.summary-pill{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;border-radius:15px;font-size:.875rem;font-weight:500;white-space:nowrap;flex-shrink:0;border:2px solid transparent;cursor:pointer;transition:all .2s ease;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.summary-pill:hover{transform:translateY(-1px);box-shadow:0 2px 8px #0000001a}.summary-pill:active{transform:scale(.98)}.summary-pill.active{border-color:#0003;box-shadow:0 2px 8px #00000026}.expense-pill{background:#f9b5ac;color:var(--neu-text)}.savings-pill{background:#84d2f6;color:var(--neu-text)}.summary-label{font-weight:500}.payments-summary .summary-amount{font-weight:600;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.personal-finance-options{display:flex;gap:.5rem;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:rgba(191,198,196,.3) transparent;padding-bottom:.5rem;width:100%}.personal-finance-options::-webkit-scrollbar{height:6px}.personal-finance-options::-webkit-scrollbar-track{background:transparent}.personal-finance-options::-webkit-scrollbar-thumb{background:#bfc6c44d;border-radius:3px}.personal-finance-options::-webkit-scrollbar-thumb:hover{background:#bfc6c480}.category-pill{display:flex;align-items:center;gap:.5rem;padding:.5rem .875rem;border-radius:15px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap;flex-shrink:0;-webkit-tap-highlight-color:transparent;touch-action:manipulation;border:none}.category-icon{width:18px;height:18px;flex-shrink:0}.category-pill.red{background:var(--color-expense-soft);color:var(--color-expense-text)}.category-pill.green{background:var(--color-saving-soft);color:var(--color-saving-text)}.category-pill.blue{background:#4dabf7;color:#fff}.category-pill.orange{background:#ff922b;color:#fff}.category-pill.purple{background:#9775fa;color:#fff}.category-pill.teal{background:#20c997;color:#fff}.category-pill.gray{background:var(--color-primary-soft);color:var(--color-text-muted)}.category-pill.active{box-shadow:0 2px 8px #00000026;transform:scale(1.02)}.categories-section .category-pill.active{background:#ddbea9!important;color:#fff!important;border-color:#ddbea9!important}.subcategories-section .category-pill.active{background:#d4a276!important;color:#fff!important;border-color:#d4a276!important}.category-pill:active{transform:scale(.98)}.category-name{font-weight:500}.category-amount{font-weight:600;margin-left:auto;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.transactions-section{margin-top:2rem}.transactions-loading,.transactions-empty{text-align:center;padding:2rem;color:var(--color-text-muted);font-size:.875rem}.transactions-list{display:flex;flex-direction:column;gap:0;width:100%}.transaction-item{background:transparent;border-radius:0;padding:.625rem 0;box-shadow:none;transition:all .2s ease;display:flex;align-items:center;gap:.625rem;border-bottom:1px solid var(--color-border-soft)}.transaction-item:last-child{border-bottom:none}.transaction-item:hover{background-color:var(--color-border-soft);box-shadow:none}.transaction-icon-wrapper{flex-shrink:0}.transaction-icon{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--color-text-muted);background:var(--color-primary-soft);transition:all .2s ease;flex-shrink:0;border:2px solid}.transaction-icon svg{width:16px;height:16px;stroke-width:2}.transaction-icon.expense{background:var(--color-expense-soft);border-color:var(--color-expense);color:var(--color-expense-text)}.transaction-icon.saving{background:var(--color-saving-soft);border-color:var(--color-saving);color:var(--color-saving-text)}.transaction-details{flex:1;display:flex;flex-direction:column;gap:.25rem;min-width:0}.transaction-main{display:flex;align-items:flex-start;justify-content:space-between;gap:.5rem;width:100%}.transaction-info{flex:1;display:flex;flex-direction:column;gap:.0625rem;min-width:0}.transaction-note{font-size:.8125rem;font-weight:500;color:var(--color-text-main);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;line-height:1.3;margin:0}.transaction-category{font-size:.75rem;font-weight:400;color:var(--color-text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;opacity:.7;margin:0}.transaction-amount-wrapper{flex-shrink:0;display:flex;align-items:center}.transaction-amount{font-size:.875rem;font-weight:700;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;white-space:nowrap}.transaction-amount.expense{color:var(--color-expense-text)}.transaction-amount.saving{color:var(--color-saving-text)}.transaction-meta{display:flex;align-items:center;gap:.375rem;font-size:.6875rem;color:var(--color-text-muted)}.transaction-date{font-weight:500;margin:0}.transaction-time{font-weight:400;margin:0}.transaction-time:before{content:"•";margin-right:.375rem;opacity:.5}.settings-menu-container{min-height:100vh;min-height:100dvh;background:radial-gradient(circle at top left,var(--color-bg-gradient-start) 0%,var(--color-bg-gradient-end) 50%,var(--color-bg-gradient-start) 100%);padding:env(safe-area-inset-top,0px) 0 env(safe-area-inset-bottom,0px) 0;overflow-x:hidden;overflow-y:auto;position:relative}[data-theme=dark] .settings-menu-container{background:#161a1d}[data-theme=dark] .settings-menu-header{background:#161a1dcc}[data-theme=dark] .settings-menu-list{background:#1f2428;border:1px solid rgba(255,255,255,.05);box-shadow:10px 10px 20px #0b090a}[data-theme=dark] .settings-menu-item{border-bottom:1px solid rgba(255,255,255,.05)}.settings-menu-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;background:var(--color-bg-card-blur);backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px);border-bottom:1px solid var(--color-border-soft);position:sticky;top:0;z-index:10}.back-button{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:12px;cursor:pointer;color:var(--color-text-main);transition:all .2s ease;-webkit-tap-highlight-color:transparent}.back-button:active{transform:scale(.95);background:#0000000d}.back-button svg{width:24px;height:24px}.settings-menu-title{font-size:1.25rem;font-weight:600;color:var(--color-text-main);margin:0}.settings-menu-content{padding:1rem .75rem 2rem;display:flex;flex-direction:column;gap:2rem;max-width:1200px;margin:0 auto}.settings-category-menu{margin-bottom:0}.settings-category-menu:last-of-type{margin-bottom:0}.category-title-menu{font-size:1.125rem;font-weight:700;color:var(--color-text-main);margin:0 0 1rem .75rem;letter-spacing:-.02em;padding-bottom:.75rem;border-bottom:3px solid rgba(33,158,188,.3);opacity:.65}.settings-menu-list{display:flex;flex-direction:column;background:var(--color-bg-card);backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px);border-radius:15px;overflow:hidden;border:2px solid rgba(33,158,188,.2);box-shadow:var(--shadow-soft);position:relative;min-height:200px;padding:.5rem 0}.settings-menu-list:before{content:"";position:absolute;top:0;left:0;right:0;height:5px;background:linear-gradient(90deg,#bfc6c4,#bfc6c480);border-radius:15px 20px 0 0}.settings-menu-item{display:flex;align-items:center;gap:.75rem;padding:1.25rem 1.75rem;background:transparent;border:none;border-bottom:1px solid var(--color-border-soft);cursor:pointer;transition:all .2s ease;text-align:left;width:100%;-webkit-tap-highlight-color:transparent;min-height:80px}.settings-menu-item:last-child{border-bottom:none}.settings-menu-item:hover{background:#00000005}.settings-menu-item:active{background:#0000000a;opacity:.8}.settings-menu-item-icon{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:transparent;border-radius:0;color:#219ebc;flex-shrink:0}.settings-menu-item-icon svg{width:20px;height:20px}.settings-menu-item-info{flex:1;min-width:0}.settings-menu-item-title{font-size:.9375rem;font-weight:600;color:var(--color-text-main);margin:0 0 .125rem;line-height:1.3}.settings-menu-item-description{font-size:.75rem;color:var(--color-text-muted);margin:0;line-height:1.3}.settings-menu-item-arrow{width:24px;height:24px;display:flex;align-items:center;justify-content:center;color:#999;flex-shrink:0}.settings-menu-item-arrow svg{width:20px;height:20px}.settings-menu-item-danger:hover{background:#ef44440d}.settings-menu-item-icon.text-red-500,.settings-menu-item-danger .settings-menu-item-title,.settings-menu-item-danger .settings-menu-item-arrow,.settings-menu-item-danger .settings-menu-item-description{color:#ef4444}.emvco-home{min-height:100vh;min-height:100dvh;background:linear-gradient(180deg,#1e1b4b,#312e81,#4338ca);display:flex;flex-direction:column;padding:2rem 1.5rem;padding-bottom:calc(2rem + env(safe-area-inset-bottom,0px))}.emvco-hero{text-align:center;margin-bottom:2rem}.emvco-logo{width:80px;height:80px;background:#ffffff26;border-radius:15px;display:flex;align-items:center;justify-content:center;margin:0 auto 1.25rem;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.emvco-logo svg{width:44px;height:44px;color:#fff}.emvco-hero h1{font-size:1.75rem;font-weight:700;color:#fff;margin:0 0 .5rem}.emvco-hero p{font-size:.95rem;color:#ffffffb3;margin:0;line-height:1.5}.emvco-actions{margin-bottom:2rem}.emvco-scan-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:.75rem;padding:1.25rem;background:#fff;border:none;border-radius:16px;font-size:1.1rem;font-weight:700;color:#4338ca;cursor:pointer;transition:transform .2s,box-shadow .2s;box-shadow:0 4px 20px #0003}.emvco-scan-btn:active{transform:scale(.98)}.emvco-scan-btn svg{width:28px;height:28px}.emvco-features{display:flex;flex-direction:column;gap:.75rem;margin-bottom:2rem}.emvco-feature{display:flex;align-items:center;gap:1rem;padding:1rem;background:#ffffff1a;border-radius:14px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.feature-icon{width:44px;height:44px;background:#ffffff26;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.feature-icon svg{width:24px;height:24px;color:#a5b4fc}.feature-icon.azqr{background:linear-gradient(135deg,#10b981,#059669)}.feature-icon.azqr span{font-size:1.25rem}.feature-text h3{font-size:.95rem;font-weight:600;color:#fff;margin:0 0 .2rem}.feature-text p{font-size:.8rem;color:#fff9;margin:0}.emvco-networks{margin-bottom:2rem}.emvco-networks h2{font-size:.85rem;font-weight:600;color:#ffffff80;text-transform:uppercase;letter-spacing:.5px;margin:0 0 .75rem;text-align:center}.network-tags{display:flex;flex-wrap:wrap;justify-content:center;gap:.5rem}.network-tags span{padding:.4rem .75rem;background:#ffffff1a;border-radius:15px;font-size:.75rem;font-weight:500;color:#fffc}.emvco-footer{margin-top:auto;text-align:center}.emvco-footer p{font-size:.7rem;color:#fff6;margin:0}.scanner{min-height:100vh;min-height:100dvh;background:#f8fafc;display:flex;flex-direction:column}.scanner-header{display:flex;align-items:center;gap:.5rem;padding:.75rem;padding-top:calc(.75rem + env(safe-area-inset-top,0px));background:transparent}.scanner-back{width:28px;height:28px;border:none;background:#0000000d;border-radius:6px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s}.scanner-back:active{background:#0000001a}.scanner-back svg{width:18px;height:18px;color:#475569}.scanner-header span{font-size:.75rem;font-weight:500;margin:0;color:#64748b}.scanner-content{flex:1;padding:.75rem;padding-bottom:calc(.75rem + env(safe-area-inset-bottom,0px));display:flex;flex-direction:column;gap:.5rem}.scanner-title{font-size:1rem;font-weight:700;color:#1e293b;text-align:center;margin:.4rem 0 .5rem}.scanner-actions{display:flex;flex-direction:column;gap:.5rem}.scan-btn{display:flex;align-items:center;justify-content:center;gap:.4rem;padding:.6rem;border:none;border-radius:10px;font-size:.75rem;font-weight:600;cursor:pointer;transition:all .2s}.scan-btn input{display:none}.scan-btn svg{width:16px;height:16px}.scan-btn.primary{background:linear-gradient(135deg,#4338ca,#6366f1);color:#fff;box-shadow:0 4px 12px #4338ca4d}.scan-btn.secondary{background:#fff;color:#4338ca;border:2px solid #c7d2fe}.scan-btn.full{width:100%;margin-top:.25rem}.scan-btn.disabled{opacity:.6;pointer-events:none}.scan-btn:active{transform:scale(.98)}.scanner-error{display:flex;align-items:center;justify-content:space-between;padding:.4rem .5rem;background:#fef2f2;border:1px solid #fecaca;border-radius:6px;color:#dc2626;font-size:.65rem}.scanner-error button{background:none;border:none;color:#dc2626;font-size:.9rem;cursor:pointer;padding:0 .25rem}.scanner-result{background:#fff;border-radius:12px;padding:.75rem;box-shadow:0 1px 3px #00000014}.result-status{display:flex;align-items:center;gap:.3rem;padding:.35rem .5rem;border-radius:8px;font-weight:600;font-size:.65rem;margin-bottom:.4rem}.result-status.valid{background:#dcfce7;color:#15803d}.result-status.warning{background:#fef9c3;color:#a16207}.azqr-badge{margin-left:auto;background:#059669;color:#fff;padding:.1rem .3rem;border-radius:4px;font-size:.55rem}.merchant-panel{background:linear-gradient(135deg,#1e293b,#334155);border-radius:8px;padding:.5rem;margin-bottom:.4rem;color:#fff}.merchant-panel h3{font-size:.5rem;font-weight:500;color:#94a3b8;margin:0 0 .3rem;text-transform:uppercase;letter-spacing:.5px}.merchant-content{display:flex;flex-direction:column;gap:.2rem}.merchant-name{font-size:.75rem;font-weight:700;color:#fff}.merchant-details{display:flex;align-items:center;flex-wrap:wrap;gap:.3rem;font-size:.55rem;color:#cbd5e1}.merchant-details .separator{color:#64748b}.mcc-badge{background:#ffffff26;padding:.1rem .25rem;border-radius:3px;font-size:.5rem}.merchant-amount{font-size:1.1rem;font-weight:800;color:#4ade80;margin-top:.3rem;padding-top:.3rem;border-top:1px solid rgba(255,255,255,.15)}.result-summary{display:flex;flex-direction:column;gap:0;margin-bottom:.5rem;border:1px solid #e2e8f0;border-radius:6px;overflow:hidden}.result-row{display:flex;justify-content:space-between;align-items:center;padding:.35rem .5rem;background:#fff;border-bottom:1px solid #e2e8f0}.result-row:last-child{border-bottom:none}.result-row:nth-child(odd){background:#f8fafc}.result-row.highlight{background:linear-gradient(135deg,#eef2ff,#e0e7ff)}.row-label{font-size:.6rem;color:#64748b}.row-value{font-size:.65rem;font-weight:600;color:#1e293b;text-align:right;max-width:60%;word-break:break-all}.result-row.highlight .row-value{color:#4338ca;font-size:.7rem}.result-fields-section{margin-bottom:.5rem}.result-fields-section h3,.result-raw-section h3{font-size:.6rem;font-weight:600;color:#475569;margin:0 0 .3rem;display:flex;align-items:center;gap:.3rem}.field-count{background:#e0e7ff;color:#4338ca;padding:.05rem .3rem;border-radius:6px;font-size:.55rem;font-weight:700}.fields-grid{display:flex;flex-direction:column;gap:0;border:1px solid #e2e8f0;border-radius:6px;overflow:hidden}.field-card{display:flex;align-items:center;justify-content:space-between;padding:.35rem .5rem;background:#fff;border-bottom:1px solid #e2e8f0}.field-card:last-child{border-bottom:none}.field-card:nth-child(odd){background:#f8fafc}.field-header{display:flex;align-items:center;gap:.25rem;flex-shrink:0}.field-tag{background:#4338ca;color:#fff;padding:.1rem .25rem;border-radius:3px;font-weight:700;font-size:.5rem;min-width:18px;text-align:center}.field-name{color:#64748b;font-size:.55rem;font-weight:500;white-space:nowrap}.field-val{color:#1e293b;font-size:.6rem;font-weight:600;text-align:right;word-break:break-all;margin-left:.5rem;flex:1}.field-card.has-nested{flex-direction:column;align-items:stretch}.field-card.has-nested .field-header{margin-bottom:.25rem;padding-bottom:.2rem;border-bottom:1px dashed #e2e8f0}.field-subfields{display:flex;flex-direction:column;gap:.15rem}.subfield-row{display:flex;justify-content:space-between;align-items:flex-start;padding:.1rem 0}.subfield-name{font-size:.5rem;color:#64748b;flex-shrink:0}.subfield-val{font-size:.55rem;font-weight:600;color:#1e293b;text-align:right;word-break:break-all;margin-left:.3rem}.result-raw-section{margin-bottom:.5rem}.result-raw-section code{display:block;padding:.35rem;background:#1e293b;border-radius:6px;color:#4ade80;font-size:.5rem;word-break:break-all;white-space:pre-wrap;font-family:SF Mono,monospace;line-height:1.2}.scanner-hint{text-align:center;padding:.75rem .5rem;color:#64748b;font-size:.65rem}#root{max-width:100%;margin:0;padding:0;text-align:left;width:100%;height:100%}.logo{height:6em;padding:1.5em;will-change:filter;transition:filter .3s}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.react:hover{filter:drop-shadow(0 0 2em #61dafbaa)}@keyframes logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(prefers-reduced-motion:no-preference){a:nth-of-type(2) .logo{animation:logo-spin infinite 20s linear}}.card{padding:2em}.read-the-docs{color:#888}
