*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg-primary: #0f1117;--bg-secondary: #1a1d27;--bg-tertiary: #242837;--bg-glass: rgba(255, 255, 255, .05);--text-primary: #f0f0f5;--text-secondary: #9ca3af;--text-muted: #6b7280;--accent-essential: #10b981;--accent-essential-bg: rgba(16, 185, 129, .1);--accent-saving: #3b82f6;--accent-saving-bg: rgba(59, 130, 246, .1);--accent-nonessential: #f59e0b;--accent-nonessential-bg: rgba(245, 158, 11, .1);--accent-danger: #ef4444;--accent-success: #10b981;--accent-warning: #f59e0b;--border-subtle: rgba(255, 255, 255, .08);--border-accent: rgba(255, 255, 255, .15);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .4);--shadow-md: 0 4px 16px rgba(0, 0, 0, .3);--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 24px;--transition-fast: .15s ease;--transition-normal: .25s ease;--transition-smooth: .35s cubic-bezier(.4, 0, .2, 1)}html{font-size:16px;-webkit-text-size-adjust:100%}body{font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;background-color:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.5;min-height:100vh;overscroll-behavior:none;touch-action:manipulation;padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom);padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right)}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:var(--bg-tertiary);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--border-accent)}*{scrollbar-width:thin;scrollbar-color:var(--bg-tertiary) var(--bg-primary)}::selection{background:#3b82f659;color:var(--text-primary)}::-moz-selection{background:#3b82f659;color:var(--text-primary)}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes slideDown{0%{transform:translateY(-10px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes scaleIn{0%{transform:scale(.95);opacity:0}to{transform:scale(1);opacity:1}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}[data-theme=light]{--bg-primary: #f8fafc;--bg-secondary: #ffffff;--bg-tertiary: #f1f5f9;--bg-glass: rgba(255, 255, 255, .7);--text-primary: #0f172a;--text-secondary: #334155;--text-muted: #64748b;--accent-essential: #059669;--accent-essential-bg: rgba(16, 185, 129, .15);--accent-saving: #2563eb;--accent-saving-bg: rgba(59, 130, 246, .15);--accent-nonessential: #d97706;--accent-nonessential-bg: rgba(245, 158, 11, .15);--accent-danger: #dc2626;--accent-success: #059669;--accent-warning: #d97706;--border-subtle: rgba(0, 0, 0, .08);--border-accent: rgba(0, 0, 0, .15);--shadow-lg: 0 10px 25px -5px rgba(0, 0, 0, .1), 0 8px 10px -6px rgba(0, 0, 0, .1);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -2px rgba(0, 0, 0, .1)}.app{display:flex;flex-direction:column;min-height:100vh;max-width:480px;margin:0 auto;padding:16px;padding-top:calc(16px + env(safe-area-inset-top));padding-bottom:calc(16px + env(safe-area-inset-bottom));gap:16px}.salary-input{background:var(--bg-glass);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:24px 20px;box-shadow:var(--shadow-md);animation:scaleIn var(--transition-smooth) both}.salary-input__label{font-size:.85rem;font-weight:500;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);margin-bottom:12px}.salary-input__wrapper{position:relative;display:flex;align-items:center}.salary-input__wrapper:before{content:"£";font-size:2rem;font-weight:700;color:var(--text-muted);margin-right:4px;pointer-events:none;transition:color var(--transition-fast)}.salary-input__wrapper:focus-within:before{color:var(--text-primary)}.salary-input__field{width:100%;background:transparent;border:none;border-bottom:2px solid var(--border-subtle);font-size:2rem;font-weight:700;color:var(--text-primary);font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;font-variant-numeric:tabular-nums;padding:4px 0;outline:none;transition:border-color var(--transition-normal);-webkit-appearance:none;appearance:none}.salary-input__field::placeholder{color:var(--text-muted)}.salary-input__field:focus{border-bottom-color:var(--accent-saving);box-shadow:0 2px 8px #3b82f633}.budget-summary{background:var(--bg-glass);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:20px;box-shadow:var(--shadow-md);animation:scaleIn var(--transition-smooth) both;animation-delay:50ms}.budget-summary__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.budget-summary__title{font-size:.85rem;font-weight:500;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary)}.budget-summary__view-toggle{background:var(--bg-tertiary);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:4px;display:flex;gap:4px}.budget-summary__view-btn{background:transparent;border:none;color:var(--text-muted);padding:4px 12px;border-radius:var(--radius-sm);font-size:.75rem;font-weight:600;cursor:pointer;transition:all var(--transition-fast)}.budget-summary__view-btn--active{background:var(--bg-secondary);color:var(--text-primary);box-shadow:var(--shadow-md)}.budget-summary__pie-container{display:flex;justify-content:center;align-items:center;padding:16px 0 24px}.budget-summary__pie{width:140px;height:140px;border-radius:50%;box-shadow:inset 0 0 0 1px var(--border-subtle),var(--shadow-md);position:relative;animation:scaleIn var(--transition-smooth) both;display:flex;align-items:center;justify-content:center}.budget-summary__pie-inner{width:90px;height:90px;background:var(--bg-secondary);border-radius:50%;border:1px solid var(--border-subtle);box-shadow:inset var(--shadow-md);display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:2}.budget-summary__pie-label{font-size:.7rem;text-transform:uppercase;color:var(--text-muted);font-weight:600;letter-spacing:.05em}.budget-summary__pie-value{font-size:1.1rem;font-weight:700;color:var(--text-primary)}.budget-summary__progress{width:100%;height:10px;border-radius:5px;background:var(--bg-tertiary);border:1px solid var(--border-subtle);display:flex;overflow:hidden;margin-bottom:20px}.budget-summary__progress-segment{height:100%;transition:width var(--transition-smooth)}.budget-summary__progress-segment--essential{background:var(--accent-essential)}.budget-summary__progress-segment--saving{background:var(--accent-saving)}.budget-summary__progress-segment--nonessential{background:var(--accent-nonessential)}.budget-summary__stats{display:flex;justify-content:space-between;gap:12px}.budget-summary__stat{flex:1;text-align:center}.budget-summary__stat-value{font-size:1.25rem;font-weight:700;font-variant-numeric:tabular-nums;color:var(--text-primary)}.budget-summary__stat-label{font-size:.75rem;font-weight:500;color:var(--text-muted);margin-top:2px}.budget-summary__stat-value--healthy{color:var(--accent-success)}.budget-summary__stat-value--warning{color:var(--accent-warning)}.budget-summary__stat-value--danger{color:var(--accent-danger)}.category-card{background:var(--bg-glass);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--border-subtle);border-left:4px solid var(--border-accent);border-radius:var(--radius-lg);padding:16px 20px;box-shadow:var(--shadow-md);animation:scaleIn var(--transition-smooth) both}.category-card--essential{border-left-color:var(--accent-essential)}.category-card--saving{border-left-color:var(--accent-saving)}.category-card--nonessential{border-left-color:var(--accent-nonessential)}.category-card__header{display:flex;align-items:center;justify-content:space-between;cursor:pointer;user-select:none;-webkit-user-select:none}.category-card__header-left{display:flex;align-items:center;gap:10px}.category-card__icon{font-size:1.25rem}.category-card__name{font-size:1.1rem;font-weight:600;color:var(--text-primary)}.category-card__total{font-size:1.25rem;font-weight:700;font-variant-numeric:tabular-nums;color:var(--text-primary)}.category-card__percent{font-size:.8rem;font-weight:500;color:var(--text-muted);margin-left:6px;font-variant-numeric:tabular-nums}.category-card__chevron{font-size:.85rem;color:var(--text-muted);transition:transform var(--transition-normal);margin-left:8px}.category-card__chevron--expanded{transform:rotate(180deg)}.category-card__content{max-height:0;overflow:hidden;transition:max-height var(--transition-smooth),opacity var(--transition-normal),margin-top var(--transition-normal);opacity:0;margin-top:0}.category-card__content--expanded{max-height:1000px;opacity:1;margin-top:16px}.payment-item{display:flex;align-items:center;justify-content:space-between;padding:10px 0;border-bottom:1px solid var(--border-subtle);animation:slideDown var(--transition-normal) both}.payment-item:last-of-type{border-bottom:none}.payment-item__left{display:flex;align-items:center;gap:10px;flex:1;min-width:0}.payment-item__badge{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em;padding:3px 8px;border-radius:20px;white-space:nowrap;flex-shrink:0}.payment-item__badge--essential{background:var(--accent-essential-bg);color:var(--accent-essential)}.payment-item__badge--saving{background:var(--accent-saving-bg);color:var(--accent-saving)}.payment-item__badge--nonessential{background:var(--accent-nonessential-bg);color:var(--accent-nonessential)}.payment-item__name{font-size:.9rem;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.payment-item__right{display:flex;align-items:center;gap:8px;flex-shrink:0}.payment-item__amount{font-size:1rem;font-weight:700;font-variant-numeric:tabular-nums;color:var(--text-primary)}.payment-item__percent{font-size:.75rem;font-weight:500;color:var(--text-muted);white-space:nowrap;font-variant-numeric:tabular-nums}.payment-item__edit{background:none;border:none;color:var(--text-muted);font-size:.95rem;cursor:pointer;padding:4px;border-radius:var(--radius-sm);opacity:.6;transition:opacity var(--transition-fast),color var(--transition-fast),background-color var(--transition-fast)}.payment-item__edit:hover{color:var(--accent-saving);background:#3b82f61a}.payment-item__delete{background:none;border:none;color:var(--text-muted);font-size:1rem;cursor:pointer;padding:4px;border-radius:var(--radius-sm);opacity:.6;transition:opacity var(--transition-fast),color var(--transition-fast),background-color var(--transition-fast)}.payment-item__delete:hover{color:var(--accent-danger);background:#ef44441a}.payment-item:hover .payment-item__edit,.payment-item:hover .payment-item__delete{opacity:1}.payment-item:nth-child(1){animation-delay:0ms}.payment-item:nth-child(2){animation-delay:50ms}.payment-item:nth-child(3){animation-delay:.1s}.payment-item:nth-child(4){animation-delay:.15s}.payment-item:nth-child(5){animation-delay:.2s}.payment-item:nth-child(6){animation-delay:.25s}.payment-item:nth-child(7){animation-delay:.3s}.payment-item:nth-child(8){animation-delay:.35s}.add-payment-btn{width:100%;background:transparent;border:2px dashed var(--border-accent);border-radius:var(--radius-md);padding:12px;color:var(--text-muted);font-size:.9rem;font-weight:500;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px;transition:opacity var(--transition-fast),border-color var(--transition-fast),color var(--transition-fast);margin-top:12px}.add-payment-btn:hover{opacity:1;border-color:var(--text-secondary);color:var(--text-secondary)}.add-payment-btn:active{transform:scale(.98)}.add-payment-btn__icon{font-size:1.1rem;font-weight:300}.modal-overlay{position:fixed;inset:0;background:#0009;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:100;animation:fadeIn var(--transition-fast) both;display:flex;align-items:center;justify-content:center;padding:16px}.add-payment-modal{background:var(--bg-secondary);border-radius:var(--radius-xl);padding:20px 20px 24px;box-shadow:var(--shadow-lg);animation:scaleIn var(--transition-smooth) both;width:100%;max-width:400px;max-height:calc(100dvh - 32px);overflow-y:auto}.add-payment-modal__handle{display:none}.add-payment-modal__title{font-size:1.1rem;font-weight:600;color:var(--text-primary);margin-bottom:20px}.add-payment-modal__form{display:flex;flex-direction:column;gap:14px}.add-payment-modal__field{display:flex;flex-direction:column;gap:6px}.add-payment-modal__label{font-size:.8rem;font-weight:500;text-transform:uppercase;letter-spacing:.04em;color:var(--text-secondary)}.add-payment-modal__input,.add-payment-modal__select{width:100%;background:var(--bg-tertiary);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:12px 14px;font-size:1rem;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;color:var(--text-primary);outline:none;transition:border-color var(--transition-normal),box-shadow var(--transition-normal);-webkit-appearance:none;appearance:none}.add-payment-modal__input::placeholder{color:var(--text-muted)}.add-payment-modal__input:focus,.add-payment-modal__select:focus{border-color:var(--accent-saving);box-shadow:0 0 0 3px #3b82f626}.add-payment-modal__actions{display:flex;gap:10px;margin-top:6px}.add-payment-modal__submit{flex:1;padding:14px;border:none;border-radius:var(--radius-md);font-size:1rem;font-weight:600;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;color:#fff;cursor:pointer;transition:box-shadow var(--transition-normal),transform var(--transition-fast)}.add-payment-modal__submit--essential{background:linear-gradient(135deg,#10b981,#059669)}.add-payment-modal__submit--saving{background:linear-gradient(135deg,#3b82f6,#2563eb)}.add-payment-modal__submit--nonessential{background:linear-gradient(135deg,#f59e0b,#d97706)}.add-payment-modal__submit:hover{box-shadow:0 4px 16px #0000004d}.add-payment-modal__submit:active{transform:scale(.98)}.add-payment-modal__cancel{padding:14px 20px;background:transparent;border:none;font-size:1rem;font-weight:500;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;color:var(--text-muted);cursor:pointer;border-radius:var(--radius-md);transition:color var(--transition-fast)}.add-payment-modal__cancel:hover{color:var(--text-secondary)}.sub-category-select{width:100%;background:var(--bg-tertiary);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:12px 36px 12px 14px;font-size:1rem;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;color:var(--text-primary);outline:none;cursor:pointer;transition:border-color var(--transition-normal),box-shadow var(--transition-normal);-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%239ca3af' d='M6 8.5L1 3.5h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center}.sub-category-select:focus{border-color:var(--accent-saving);box-shadow:0 0 0 3px #3b82f626}input[type=text],input[type=number],input[type=tel]{-webkit-appearance:none;appearance:none}input[type=number]::-webkit-inner-spin-button,input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}input[type=number]{-moz-appearance:textfield}@supports (-webkit-touch-callout: none){input,select,textarea{font-size:16px}*{-webkit-tap-highlight-color:transparent}}.app-header{display:flex;align-items:baseline;justify-content:space-between;padding-bottom:4px}.app-header h1{font-size:2rem;font-weight:800;letter-spacing:-.02em;background:linear-gradient(135deg,var(--text-primary),var(--text-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.app-header__right{display:flex;align-items:baseline;gap:12px}.app-month{font-size:.9rem;font-weight:500;color:var(--text-muted)}.app-header__auth-btn{background:none;border:none;color:var(--text-muted);font-size:.8rem;font-weight:500;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;cursor:pointer;padding:4px 8px;border-radius:var(--radius-sm);transition:color var(--transition-fast),background-color var(--transition-fast)}.app-header__auth-btn:hover{color:var(--text-secondary);background:var(--bg-tertiary)}.app--loading{display:flex;align-items:center;justify-content:center;min-height:100vh}.loading-spinner{width:40px;height:40px;border:3px solid var(--border-subtle);border-top-color:var(--accent-saving);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.login-screen{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:16px}.login-card{background:var(--bg-glass);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);padding:32px 24px;width:100%;max-width:400px;box-shadow:var(--shadow-lg);animation:scaleIn var(--transition-smooth) both}.login-card__header{text-align:center;margin-bottom:28px}.login-card__title{font-size:2.4rem;font-weight:800;letter-spacing:-.02em;background:linear-gradient(135deg,var(--text-primary),var(--text-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:8px}.login-card__subtitle{font-size:.9rem;color:var(--text-muted);font-weight:400}.login-card__actions{display:flex;flex-direction:column;gap:16px}.login-card__google-btn{display:flex;align-items:center;justify-content:center;gap:12px;width:100%;padding:14px 20px;background:#fff;border:none;border-radius:var(--radius-md);font-size:1rem;font-weight:600;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;color:#3c4043;cursor:pointer;box-shadow:0 1px 3px #00000014,0 1px 2px #0000001f;transition:box-shadow var(--transition-normal),transform var(--transition-fast),opacity var(--transition-fast)}.login-card__google-btn:hover{box-shadow:0 4px 12px #00000026,0 2px 4px #0000001f}.login-card__google-btn:active{transform:scale(.98)}.login-card__google-btn:disabled{opacity:.6;cursor:not-allowed}.login-card__google-icon{flex-shrink:0}.login-card__error{font-size:.85rem;color:var(--accent-danger);text-align:center;animation:fadeIn var(--transition-fast) both}.login-card__footer{display:flex;flex-direction:column;align-items:center;gap:12px;margin-top:24px}.login-card__skip{background:none;border:none;font-size:.8rem;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;color:var(--text-muted);cursor:pointer;padding:4px;transition:color var(--transition-fast)}.login-card__skip:hover{color:var(--text-secondary)}.app-footer{margin-top:8px;padding-top:16px;border-top:1px solid var(--border-subtle)}.reset-btn{width:100%;padding:14px;background:transparent;border:1px solid var(--accent-danger);border-radius:var(--radius-md);color:var(--accent-danger);font-size:.9rem;font-weight:600;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;cursor:pointer;transition:background-color var(--transition-fast),color var(--transition-fast),transform var(--transition-fast)}.reset-btn:hover{background:#ef44441a}.reset-btn:active{transform:scale(.98)}.payment-item__name-input,.payment-item__amount-input{background:var(--bg-tertiary);border:1px solid var(--accent-saving);border-radius:var(--radius-sm);padding:4px 8px;font-size:.9rem;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;color:var(--text-primary);outline:none;width:100%;box-shadow:0 0 0 3px #3b82f626}.payment-item__amount-input{width:80px;text-align:right;font-weight:700;font-variant-numeric:tabular-nums}.budget-view{display:flex;flex-direction:column;gap:16px}.person-switcher{background:var(--bg-glass);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:12px 14px;box-shadow:var(--shadow-md);display:flex;align-items:center;justify-content:space-between;gap:10px;animation:scaleIn var(--transition-smooth) both}.person-switcher__people{display:flex;align-items:center;gap:8px;overflow-x:auto;flex:1;min-width:0;scrollbar-width:none;-ms-overflow-style:none}.person-switcher__people::-webkit-scrollbar{display:none}.person-chip{display:flex;align-items:center;gap:4px;background:var(--bg-tertiary);border:1px solid var(--border-subtle);border-radius:20px;padding:4px 4px 4px 12px;flex-shrink:0;transition:all var(--transition-normal)}.person-chip--active{background:#3b82f626;border-color:var(--accent-saving);box-shadow:0 0 12px #3b82f633}.person-chip__name{background:none;border:none;color:var(--text-secondary);font-size:.85rem;font-weight:600;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;cursor:pointer;padding:4px;white-space:nowrap;transition:color var(--transition-fast)}.person-chip--active .person-chip__name{color:var(--accent-saving)}.person-chip__name:hover{color:var(--text-primary)}.person-chip__edit-input{background:var(--bg-secondary);border:1px solid var(--accent-saving);border-radius:8px;color:var(--text-primary);font-size:.85rem;font-weight:600;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;padding:4px 8px;width:80px;outline:none;box-shadow:0 0 0 3px #3b82f626}.person-chip__edit{background:none;border:none;color:var(--text-muted);font-size:.75rem;cursor:pointer;padding:4px;border-radius:50%;opacity:.5;transition:all var(--transition-fast);line-height:1}.person-chip__edit:hover{opacity:1;color:var(--accent-saving);background:#3b82f61a}.person-chip__remove{background:none;border:none;color:var(--text-muted);font-size:.7rem;cursor:pointer;padding:4px 6px;border-radius:50%;opacity:.5;transition:all var(--transition-fast);line-height:1}.person-chip__remove:hover{opacity:1;color:var(--accent-danger);background:#ef44441a}.person-switcher__add{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:var(--bg-tertiary);border:1px dashed var(--border-accent);border-radius:50%;color:var(--text-muted);font-size:1.1rem;font-weight:300;cursor:pointer;flex-shrink:0;transition:all var(--transition-fast)}.person-switcher__add:hover{color:var(--text-secondary);border-color:var(--text-secondary);background:#ffffff0d}.person-switcher__add:active{transform:scale(.92)}.person-switcher__compare{display:flex;align-items:center;gap:5px;background:var(--bg-tertiary);border:1px solid var(--border-subtle);border-radius:20px;padding:6px 14px;color:var(--text-muted);font-size:.8rem;font-weight:600;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;cursor:pointer;flex-shrink:0;transition:all var(--transition-normal);white-space:nowrap}.person-switcher__compare:disabled{opacity:.35;cursor:not-allowed}.person-switcher__compare:not(:disabled):hover{color:var(--text-secondary);border-color:var(--text-secondary)}.person-switcher__compare--active{background:#3b82f626;border-color:var(--accent-saving);color:var(--accent-saving);box-shadow:0 0 12px #3b82f633}.person-switcher__compare-icon{font-size:1rem}.compare-wrapper{display:flex;flex-direction:column;gap:12px}.compare-view{display:grid;grid-template-columns:1fr 1fr;gap:16px;animation:fadeIn var(--transition-smooth) both}.compare-column{display:flex;flex-direction:column;gap:12px;min-width:0}.compare-column__header{display:flex;align-items:center}.compare-column__select{width:100%;background:var(--bg-tertiary);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:10px 36px 10px 14px;font-size:.9rem;font-weight:600;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;color:var(--text-primary);outline:none;cursor:pointer;transition:border-color var(--transition-normal);-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%239ca3af' d='M6 8.5L1 3.5h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center}.compare-column__select:focus{border-color:var(--accent-saving);box-shadow:0 0 0 3px #3b82f626}.compare-dots{display:none}.app--compare{max-width:960px}.app--compound{max-width:1200px}@media(max-width:600px){.person-switcher__compare,.compare-wrapper,.compare-view{display:none}}.search-bar{display:flex;align-items:center;background:var(--bg-glass);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:0 12px;height:44px;box-shadow:var(--shadow-md);transition:border-color var(--transition-normal),box-shadow var(--transition-normal)}.search-bar:focus-within{border-color:var(--accent-saving);box-shadow:0 0 0 3px #3b82f626}.search-bar__icon{display:flex;align-items:center;justify-content:center;color:var(--text-muted);margin-right:8px}.search-bar__input{flex:1;background:transparent;border:none;font-size:.95rem;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;color:var(--text-primary);outline:none;padding:0;-webkit-appearance:none;appearance:none}.search-bar__input::placeholder{color:var(--text-muted)}.search-bar__clear{display:flex;align-items:center;justify-content:center;background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px;border-radius:50%;margin-left:8px;transition:color var(--transition-fast),background-color var(--transition-fast)}.search-bar__clear:hover{color:var(--text-primary);background:#ffffff1a}.category-card__empty-search{padding:16px;text-align:center;color:var(--text-muted);font-size:.9rem;font-style:italic}.theme-toggle{background:none;border:none;font-size:1.1rem;cursor:pointer;padding:4px;border-radius:50%;margin-right:8px;display:flex;align-items:center;justify-content:center;transition:transform var(--transition-normal),background-color var(--transition-fast)}.theme-toggle:hover{background:var(--bg-tertiary);transform:rotate(15deg)}.theme-toggle:active{transform:scale(.9)}[data-theme=light] .login-card__title,[data-theme=light] .app-header h1{background:linear-gradient(135deg,#0f172a,#334155);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}[data-theme=light] .login-card__google-btn{background:#f8fafc;border:1px solid var(--border-subtle);box-shadow:0 1px 2px #0000000d}[data-theme=light] .login-card__google-btn:hover{background:#fff;box-shadow:0 4px 6px -1px #0000001a}.undo-toast{position:fixed;bottom:calc(16px + env(safe-area-inset-bottom));left:50%;transform:translate(-50%) translateY(0);background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);display:flex;align-items:center;padding:12px 16px;gap:12px;z-index:1000;min-width:300px;max-width:90vw;transition:transform var(--transition-normal),opacity var(--transition-normal)}.undo-toast--enter{animation:toastSlideUp var(--transition-smooth) both}.undo-toast--exit{animation:toastSlideDown var(--transition-fast) both}.undo-toast__message{flex:1;font-size:.9rem;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.undo-toast__btn{background:#3b82f626;border:1px solid rgba(59,130,246,.3);color:var(--accent-saving);font-size:.85rem;font-weight:600;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;padding:6px 12px;border-radius:var(--radius-md);cursor:pointer;transition:background-color var(--transition-fast),color var(--transition-fast)}.undo-toast__btn:hover{background:#3b82f640;color:#60a5fa}.undo-toast__btn:active{transform:scale(.96)}.undo-toast__close{background:none;border:none;color:var(--text-muted);font-size:1rem;padding:4px;cursor:pointer;line-height:1;border-radius:50%;transition:background-color var(--transition-fast),color var(--transition-fast)}.undo-toast__close:hover{background:var(--bg-tertiary);color:var(--text-secondary)}@keyframes toastSlideUp{0%{transform:translate(-50%) translateY(100px);opacity:0}to{transform:translate(-50%) translateY(0);opacity:1}}@keyframes toastSlideDown{0%{transform:translate(-50%) translateY(0);opacity:1}to{transform:translate(-50%) translateY(100px);opacity:0}}.payment-item__text{display:flex;flex-direction:column;min-width:0}.payment-item__notes{font-size:.75rem;color:var(--text-muted);font-weight:400;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:2px}.add-payment-modal__textarea{resize:vertical;min-height:50px;max-height:150px}.payment-item__name-input{margin-bottom:4px}.compound-view{padding:24px;max-width:1200px;margin:0 auto;width:100%}.compound-view__header{margin-bottom:32px}.compound-view__header h2{font-size:24px;font-weight:700;margin-bottom:8px}.compound-view__subtitle{color:var(--text-secondary);font-size:14px}.compound-view__layout{display:grid;grid-template-columns:350px 1fr;gap:32px}@media(max-width:800px){.compound-view__layout{grid-template-columns:1fr}}.compound-view__controls{background:var(--bg-secondary);padding:24px;border-radius:12px;border:1px solid var(--border-subtle);box-shadow:0 4px 12px #0000000d;display:flex;flex-direction:column;gap:24px}.input-with-symbol{position:relative;display:flex;align-items:center}.currency-symbol{position:absolute;left:12px;color:var(--text-secondary);font-weight:500}.input-with-symbol input{padding-left:28px;width:100%;padding-top:12px;padding-bottom:12px;border:1px solid var(--border-subtle);border-radius:var(--radius-sm);background:var(--bg-tertiary);color:var(--text-primary);font-size:16px;font-family:inherit}.input-with-symbol input:focus{outline:none;border-color:var(--accent-saving)}.input-hint{display:block;margin-top:6px;font-size:12px;color:var(--text-secondary)}.compound-view__summary{margin-top:16px;padding-top:16px;border-top:1px solid var(--border-subtle);display:flex;flex-direction:column;gap:16px}.summary-stat{display:flex;flex-direction:column;gap:4px}.summary-stat span{font-size:13px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;font-weight:600}.summary-stat strong{font-size:20px;font-weight:700;color:var(--text-primary)}.summary-stat .stat-total{color:var(--accent-saving);font-size:28px}.summary-stat .stat-interest{color:var(--accent-nonessential)}.compound-view__chart{background:var(--bg-secondary);padding:24px;border-radius:12px;border:1px solid var(--border-subtle);box-shadow:0 4px 12px #0000000d;min-width:0}input[type=range]{-webkit-appearance:none;width:100%;background:transparent;margin:8px 0}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;height:20px;width:20px;border-radius:50%;background:var(--accent-saving);cursor:pointer;margin-top:-8px;box-shadow:0 2px 4px #0003}input[type=range]::-webkit-slider-runnable-track{width:100%;height:6px;cursor:pointer;background:var(--border-accent);border-radius:3px}.range-footer{display:flex;justify-content:space-between;align-items:center;margin-top:4px}.reset-rate-btn{background:none;border:none;color:var(--text-muted);font-size:11px;cursor:pointer;text-decoration:underline}.reset-rate-btn:hover{color:var(--text-primary)}.inflation-group{display:flex;flex-direction:column;gap:12px}.toggle-label{display:flex;align-items:center;gap:8px;cursor:pointer;font-weight:600}.toggle-label input[type=checkbox]{width:18px;height:18px;accent-color:var(--accent-saving);cursor:pointer}.inflation-group .input-hint{padding-left:26px;margin-top:-8px}.inflation-input{display:flex;align-items:center;gap:12px;padding-left:26px;margin-top:-4px}.input-with-symbol--right .percent-symbol{position:absolute;right:12px;left:auto;color:var(--text-secondary)}.input-with-symbol--right input{padding-left:12px;padding-right:28px;width:80px}.compound-tooltip{background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:8px;padding:12px 16px;box-shadow:var(--shadow-lg)}.compound-tooltip__year{font-weight:700;margin-bottom:8px;color:var(--text-primary);border-bottom:1px solid var(--border-subtle);padding-bottom:4px}.compound-tooltip__item{display:flex;justify-content:space-between;gap:24px;margin-bottom:4px;font-size:13px}.compound-tooltip__item strong{color:var(--text-primary)}.portfolio-select{width:100%;padding:10px 12px;border:1px solid var(--border-subtle);border-radius:8px;background:var(--bg-secondary);color:var(--text-primary);font-size:14px;cursor:pointer}.custom-portfolio-builder{background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:8px;padding:16px;margin-bottom:24px;display:flex;flex-direction:column;gap:12px}.custom-portfolio-builder>label{font-weight:600;margin-bottom:4px}.custom-asset-row{display:flex;gap:12px;align-items:center}.ticker-input{flex:1;min-width:0;padding:8px 12px;border:1px solid var(--border-subtle);border-radius:6px;background:var(--bg-primary);color:var(--text-primary);text-transform:uppercase}.weight-input-wrap{width:100px;position:relative;flex-shrink:0}.weight-input-wrap input{padding:8px 32px 8px 12px;border:1px solid var(--border-subtle);border-radius:6px;background:var(--bg-primary);color:var(--text-primary);width:100%}.weight-input-wrap input::-webkit-outer-spin-button,.weight-input-wrap input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.weight-input-wrap input[type=number]{-moz-appearance:textfield}.weight-input-wrap .percent-symbol{position:absolute;right:12px;top:50%;transform:translateY(-50%);color:var(--text-secondary);pointer-events:none}.remove-asset-btn{background:none;border:none;color:var(--text-muted);font-size:20px;cursor:pointer;padding:0 4px}.remove-asset-btn:hover:not(:disabled){color:var(--accent-warning)}.remove-asset-btn:disabled{opacity:.3;cursor:not-allowed}.custom-portfolio-footer{display:flex;justify-content:space-between;align-items:center;margin-top:8px;padding-top:12px;border-top:1px dashed var(--border-subtle)}.add-asset-btn{background:none;border:none;color:var(--accent-saving);font-weight:600;cursor:pointer;font-size:13px}.add-asset-btn:hover{text-decoration:underline}.weight-total{font-size:13px;font-weight:600;color:var(--text-secondary)}.weight-total--warning{color:var(--accent-warning)}.compound-view__analysis{margin-top:24px;display:flex;flex-direction:column;gap:24px}.milestones-container{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:16px}.milestone-card{background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:8px;padding:16px;display:flex;flex-direction:column;gap:8px;text-align:center;transition:all .2s ease}.milestone-card span{font-size:13px;color:var(--text-secondary)}.milestone-card strong{font-size:18px;color:var(--text-primary)}.milestone-card.achieved{border-color:var(--accent-saving);background:#2196f30d}.milestone-card.achieved strong{color:var(--accent-saving)}.milestone-card.target-card.achieved{border-color:var(--accent-warning);background:#ff98000d}.milestone-card.target-card.achieved strong{color:var(--accent-warning)}.data-table-container{max-height:400px;overflow-y:auto;border:1px solid var(--border-subtle);border-radius:8px;background:var(--bg-primary)}.data-table{width:100%;border-collapse:collapse;font-size:14px}.data-table th{position:sticky;top:0;background:var(--bg-secondary);padding:12px 16px;text-align:right;font-weight:600;color:var(--text-secondary);border-bottom:2px solid var(--border-subtle);z-index:10}.data-table th:first-child{text-align:left}.data-table td{padding:12px 16px;text-align:right;border-bottom:1px solid var(--border-subtle);color:var(--text-primary)}.data-table td:first-child{text-align:left;font-weight:600}.data-table tr:hover{background:var(--bg-secondary)}.data-table .font-semibold{font-weight:600}
