:root{--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.875rem;--font-size-4xl: 2.25rem;--icon-size-sm: .875rem;--icon-size-base: 1rem;--icon-size-lg: 1.25rem;--icon-size-xl: 1.5rem}[data-font-size=large]{--font-size-xs: .875rem;--font-size-sm: 1rem;--font-size-base: 1.125rem;--font-size-lg: 1.25rem;--font-size-xl: 1.5rem;--font-size-2xl: 1.75rem;--font-size-3xl: 2.125rem;--font-size-4xl: 2.5rem;--icon-size-sm: 1rem;--icon-size-base: 1.125rem;--icon-size-lg: 1.375rem;--icon-size-xl: 1.625rem}[data-font-size=extra-large]{--font-size-xs: 1rem;--font-size-sm: 1.125rem;--font-size-base: 1.25rem;--font-size-lg: 1.5rem;--font-size-xl: 1.75rem;--font-size-2xl: 2rem;--font-size-3xl: 2.5rem;--font-size-4xl: 3rem;--icon-size-sm: 1.125rem;--icon-size-base: 1.25rem;--icon-size-lg: 1.5rem;--icon-size-xl: 1.75rem}:root,[data-theme=light]{--primary-color: #3b82f6;--primary-dark: #2563eb;--primary-light: #dbeafe;--success-color: #10b981;--success-light: #d1fae5;--danger-color: #ef4444;--danger-light: #fee2e2;--warning-color: #ea580c;--warning-light: #ffedd5;--accent-primary: #6366f1;--accent-secondary: #8b5cf6;--bg-primary: #ffffff;--bg-secondary: #f9fafb;--bg-gradient-start: #3b82f6;--bg-gradient-end: #8b5cf6;--text-primary: #111827;--text-secondary: #6b7280;--text-inverse: #ffffff;--header-text-color: #ffffff;--border-color: #e5e7eb;--border-focus: #3b82f6;--gray-50: #f9fafb;--gray-100: #f3f4f6;--gray-200: #e5e7eb;--gray-300: #d1d5db;--gray-400: #9ca3af;--gray-500: #6b7280;--gray-600: #4b5563;--gray-700: #374151;--gray-800: #1f2937;--gray-900: #111827;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .1)}[data-theme=dark]{--primary-color: #60a5fa;--primary-dark: #3b82f6;--primary-light: #1e3a8a;--success-color: #34d399;--success-light: #064e3b;--danger-color: #f87171;--danger-light: #7f1d1d;--warning-color: #fb923c;--warning-light: #7c2d12;--accent-primary: #818cf8;--accent-secondary: #a78bfa;--bg-primary: #1f2937;--bg-secondary: #111827;--bg-gradient-start: #1e293b;--bg-gradient-end: #0f172a;--text-primary: #f9fafb;--text-secondary: #9ca3af;--text-inverse: #111827;--header-text-color: #f9fafb;--border-color: #374151;--border-focus: #60a5fa;--gray-50: #111827;--gray-100: #1f2937;--gray-200: #374151;--gray-300: #4b5563;--gray-400: #6b7280;--gray-500: #9ca3af;--gray-600: #d1d5db;--gray-700: #e5e7eb;--gray-800: #f3f4f6;--gray-900: #f9fafb;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 6px rgba(0, 0, 0, .4);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .5)}[data-theme=professional]{--primary-color: #1e40af;--primary-dark: #1e3a8a;--primary-light: #dbeafe;--success-color: #059669;--success-light: #d1fae5;--danger-color: #dc2626;--danger-light: #fee2e2;--warning-color: #c2410c;--warning-light: #ffedd5;--accent-primary: #1e40af;--accent-secondary: #3b82f6;--bg-primary: #ffffff;--bg-secondary: #f8fafc;--bg-gradient-start: #1e40af;--bg-gradient-end: #475569;--text-primary: #0f172a;--text-secondary: #475569;--text-inverse: #ffffff;--header-text-color: #ffffff;--border-color: #cbd5e1;--border-focus: #1e40af;--gray-50: #f8fafc;--gray-100: #f1f5f9;--gray-200: #e2e8f0;--gray-300: #cbd5e1;--gray-400: #94a3b8;--gray-500: #64748b;--gray-600: #475569;--gray-700: #334155;--gray-800: #1e293b;--gray-900: #0f172a;--shadow-sm: 0 1px 2px rgba(15, 23, 42, .05);--shadow-md: 0 4px 6px rgba(15, 23, 42, .1);--shadow-lg: 0 10px 15px rgba(15, 23, 42, .15)}[data-theme=teal-pink]{--primary-color: #14b8a6;--primary-dark: #0d9488;--primary-light: #ccfbf1;--success-color: #10b981;--success-light: #d1fae5;--danger-color: #ec4899;--danger-light: #fce7f3;--warning-color: #db2777;--warning-light: #fce7f3;--accent-primary: #ec4899;--accent-secondary: #14b8a6;--bg-primary: #ffffff;--bg-secondary: #f0fdfa;--bg-gradient-start: #14b8a6;--bg-gradient-end: #ec4899;--text-primary: #134e4a;--text-secondary: #0f766e;--text-inverse: #ffffff;--header-text-color: #ffffff;--border-color: #99f6e4;--border-focus: #14b8a6;--gray-50: #f0fdfa;--gray-100: #ccfbf1;--gray-200: #99f6e4;--gray-300: #5eead4;--gray-400: #2dd4bf;--gray-500: #14b8a6;--gray-600: #0d9488;--gray-700: #0f766e;--gray-800: #115e59;--gray-900: #134e4a;--shadow-sm: 0 1px 2px rgba(20, 184, 166, .1);--shadow-md: 0 4px 6px rgba(20, 184, 166, .15);--shadow-lg: 0 10px 15px rgba(236, 72, 153, .2)}[data-theme=spa]{--primary-color: #84cc16;--primary-dark: #65a30d;--primary-light: #ecfccb;--success-color: #22c55e;--success-light: #dcfce7;--danger-color: #dc2626;--danger-light: #fee2e2;--warning-color: #ca8a04;--warning-light: #fef9c3;--accent-primary: #65a30d;--accent-secondary: #84cc16;--bg-primary: #fefce8;--bg-secondary: #f7fee7;--bg-gradient-start: #a3e635;--bg-gradient-end: #84cc16;--text-primary: #365314;--text-secondary: #4d7c0f;--text-inverse: #ffffff;--header-text-color: #365314;--border-color: #d9f99d;--border-focus: #84cc16;--gray-50: #fefce8;--gray-100: #fef9c3;--gray-200: #fef08a;--gray-300: #d9f99d;--gray-400: #bef264;--gray-500: #a3e635;--gray-600: #84cc16;--gray-700: #65a30d;--gray-800: #4d7c0f;--gray-900: #365314;--shadow-sm: 0 1px 2px rgba(132, 204, 22, .1);--shadow-md: 0 4px 6px rgba(132, 204, 22, .15);--shadow-lg: 0 10px 15px rgba(163, 230, 53, .2)}[data-theme=fun]{--primary-color: #f59e0b;--primary-dark: #d97706;--primary-light: #fef3c7;--success-color: #10b981;--success-light: #d1fae5;--danger-color: #ef4444;--danger-light: #fee2e2;--warning-color: #ea580c;--warning-light: #ffedd5;--accent-primary: #f59e0b;--accent-secondary: #fbbf24;--bg-primary: #fffbeb;--bg-secondary: #fef3c7;--bg-gradient-start: #f59e0b;--bg-gradient-end: #ef4444;--text-primary: #78350f;--text-secondary: #92400e;--text-inverse: #ffffff;--header-text-color: #ffffff;--border-color: #fde68a;--border-focus: #f59e0b;--gray-50: #fffbeb;--gray-100: #fef3c7;--gray-200: #fde68a;--gray-300: #fcd34d;--gray-400: #fbbf24;--gray-500: #f59e0b;--gray-600: #d97706;--gray-700: #b45309;--gray-800: #92400e;--gray-900: #78350f;--shadow-sm: 0 1px 2px rgba(245, 158, 11, .15);--shadow-md: 0 4px 6px rgba(245, 158, 11, .2);--shadow-lg: 0 10px 15px rgba(239, 68, 68, .25)}[data-theme=art-deco]{--primary-color: #d97706;--primary-dark: #b45309;--primary-light: #fef3c7;--success-color: #059669;--success-light: #d1fae5;--danger-color: #dc2626;--danger-light: #fee2e2;--warning-color: #b45309;--warning-light: #fef3c7;--accent-primary: #fbbf24;--accent-secondary: #d97706;--bg-primary: #1c1917;--bg-secondary: #292524;--bg-gradient-start: #78350f;--bg-gradient-end: #1c1917;--text-primary: #fbbf24;--text-secondary: #d97706;--text-inverse: #1c1917;--header-text-color: #fbbf24;--border-color: #78350f;--border-focus: #f59e0b;--gray-50: #1c1917;--gray-100: #292524;--gray-200: #44403c;--gray-300: #57534e;--gray-400: #78716c;--gray-500: #a8a29e;--gray-600: #d6d3d1;--gray-700: #e7e5e4;--gray-800: #f5f5f4;--gray-900: #fafaf9;--shadow-sm: 0 1px 2px rgba(251, 191, 36, .2);--shadow-md: 0 4px 6px rgba(217, 119, 6, .3);--shadow-lg: 0 10px 15px rgba(217, 119, 6, .4)}*{transition:background-color .3s ease,color .3s ease,border-color .3s ease}*{box-sizing:border-box;margin:0;padding:0}:root{--floating-card-max-width: 800px;--floating-card-side-gap: 20px;--floating-card-offset: calc(16px + env(safe-area-inset-top, 0px)) ;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.5;font-weight:400;color:var(--text-primary);background-color:var(--bg-secondary);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-height:100vh;background:linear-gradient(135deg,var(--bg-gradient-start) 0%,var(--bg-gradient-end) 100%)}#root{min-height:100vh;width:100%}button{border:none;border-radius:12px;padding:12px 24px;font-size:var(--font-size-base);font-weight:600;font-family:inherit;background:var(--primary-color);color:var(--text-inverse);cursor:pointer;transition:all .2s ease;touch-action:manipulation}button:hover{background:var(--primary-dark);transform:translateY(-1px)}button:active{transform:translateY(0)}button:disabled{opacity:.6;cursor:not-allowed;transform:none}input,textarea,select{width:100%;padding:12px 16px;border:2px solid var(--border-color);border-radius:8px;font-size:var(--font-size-base);font-family:inherit;background:var(--bg-primary);color:var(--text-primary);transition:border-color .2s ease}input:focus,textarea:focus,select:focus{outline:none;border-color:var(--border-focus)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}@media (max-width: 768px){:root{--floating-card-side-gap: 0px;--floating-card-offset: calc(12px + env(safe-area-inset-top, 0px)) }}.add-bill-button{width:min(var(--floating-card-max-width, 800px),calc(100% - (var(--floating-card-side-gap, 20px) * 2)));max-width:var(--floating-card-max-width, 800px);margin:20px auto;padding:16px;background:var(--bg-primary);color:var(--primary-color);border:2px dashed var(--primary-color);border-radius:16px;display:block;font-size:16px;font-weight:600;transition:all .2s ease;cursor:pointer;text-align:center;z-index:900;box-shadow:0 2px 8px #0000001a}.add-bill-button:hover{background:var(--primary-color);color:var(--text-inverse);border-color:var(--primary-color)}.add-bill-form{width:min(var(--floating-card-max-width, 800px),calc(100% - (var(--floating-card-side-gap, 20px) * 2)));max-width:var(--floating-card-max-width, 800px);margin:20px auto;background:var(--bg-primary);padding:24px;border-bottom:1px solid var(--gray-200);border-radius:0;box-shadow:0 4px 6px #0000001a}.form-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.form-header h2{font-size:20px;font-weight:700;color:var(--text-primary)}.close-button{width:36px;height:36px;border-radius:50%;background:var(--gray-200);color:var(--gray-600);font-size:24px;display:flex;align-items:center;justify-content:center;padding:0}.close-button:hover{background:var(--gray-300);color:var(--text-primary)}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;font-weight:600;color:var(--gray-700);font-size:14px}.form-group input{font-size:16px}.form-group input[type=number]{-webkit-appearance:none;-moz-appearance:textfield}.form-group .budget-select{width:100%;padding:12px 36px 12px 14px;font-size:16px;border:1px solid var(--gray-300);border-radius:8px;background:var(--bg-primary);color:var(--text-primary);cursor:pointer;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='%236b7280' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center}.form-group .budget-select:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #3b82f626}.form-group .budget-select option{padding:8px;background:var(--bg-primary);color:var(--text-primary)}.recurring-group{margin-bottom:20px}.recurring-label{display:flex;align-items:center;gap:12px;font-weight:600;color:var(--gray-700);cursor:pointer;position:relative}.recurring-checkbox{width:24px;height:24px;opacity:0;position:absolute;cursor:pointer;z-index:1}.checkmark{width:24px;height:24px;border:2px solid var(--gray-400);border-radius:50%;background:var(--bg-primary);position:relative;transition:all .2s ease;flex-shrink:0;display:flex;align-items:center;justify-content:center}.recurring-checkbox:checked+.checkmark{background:var(--primary-color);border-color:var(--primary-color)}.recurring-checkbox:checked+.checkmark:after{content:"";width:6px;height:10px;border:solid white;border-width:0 2px 2px 0;transform:rotate(45deg)}.form-actions{display:flex;gap:12px;margin-top:24px}.form-actions button{flex:1;padding:14px 20px;font-size:16px;font-weight:600;border-radius:12px}.submit-button{background:var(--primary-color);color:var(--text-inverse)}.submit-button:hover{background:var(--primary-dark)}@media (max-width: 768px){.add-bill-button{width:calc(100% - 40px);max-width:calc(100% - 40px);margin:20px}.add-bill-form{width:100%;max-width:100%;margin:0;padding:20px}.form-actions{flex-direction:column}}:root{--payday-bill-color: #0d9488;--payday-bill-color-light: #14b8a6;--payday-bill-color-dark: #0f766e;--payday-bill-bg: rgba(13, 148, 136, .1)}.add-payday-bill-button{width:min(var(--floating-card-max-width, 800px),calc(100% - (var(--floating-card-side-gap, 20px) * 2)));max-width:var(--floating-card-max-width, 800px);margin:20px auto;padding:16px;background:var(--bg-primary);color:var(--payday-bill-color);border:2px dashed var(--payday-bill-color);border-radius:16px;display:block;font-size:16px;font-weight:600;transition:all .2s ease;cursor:pointer;text-align:center;z-index:900;box-shadow:0 2px 8px #0000001a}.add-payday-bill-button:hover{background:var(--payday-bill-color);color:#fff;border-color:var(--payday-bill-color)}.add-payday-bill-form{width:min(var(--floating-card-max-width, 800px),calc(100% - (var(--floating-card-side-gap, 20px) * 2)));max-width:var(--floating-card-max-width, 800px);margin:20px auto;background:var(--bg-primary);padding:24px;border-left:4px solid var(--payday-bill-color);border-radius:16px;box-shadow:0 4px 6px #0000001a}.add-payday-bill-form .form-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.add-payday-bill-form .form-header h2{margin:0;font-size:20px;font-weight:600;color:var(--payday-bill-color)}.add-payday-bill-form .close-button{background:none;border:none;font-size:28px;color:var(--gray-500);cursor:pointer;padding:0;line-height:1;transition:color .2s ease}.add-payday-bill-form .close-button:hover{color:var(--gray-700)}.add-payday-bill-form .form-description{font-size:14px;color:var(--gray-600);margin-bottom:20px;line-height:1.5}.add-payday-bill-form .form-group{margin-bottom:20px}.add-payday-bill-form .form-group label{display:block;font-size:14px;font-weight:500;color:var(--text-primary);margin-bottom:8px}.add-payday-bill-form .form-group input[type=date],.add-payday-bill-form .form-group select{width:100%;padding:12px;font-size:16px;border:1px solid var(--gray-300);border-radius:8px;background:var(--bg-primary);color:var(--text-primary);transition:all .2s ease}.add-payday-bill-form .form-group input:hover,.add-payday-bill-form .form-group select:hover{border-color:var(--payday-bill-color)}.add-payday-bill-form .form-group input:focus,.add-payday-bill-form .form-group select:focus{outline:none;border-color:var(--payday-bill-color);box-shadow:0 0 0 3px var(--payday-bill-bg)}.add-payday-bill-form .field-help{display:block;margin-top:6px;font-size:13px;color:var(--gray-600);font-style:italic}.add-payday-bill-form .use-previous-button{width:100%;padding:10px 16px;margin-bottom:20px;background:var(--payday-bill-bg);color:var(--payday-bill-color);border:1px solid var(--payday-bill-color);border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.add-payday-bill-form .use-previous-button:hover{background:var(--payday-bill-color);color:#fff}.add-payday-bill-form .recurring-group{margin-bottom:20px}.add-payday-bill-form .recurring-label{display:flex;align-items:center;gap:10px;cursor:pointer;font-size:14px;font-weight:500;color:var(--text-primary)}.add-payday-bill-form .recurring-checkbox{width:18px;height:18px;accent-color:var(--payday-bill-color);cursor:pointer}.add-payday-bill-form .recurring-group .field-help{margin-left:28px}.add-payday-bill-form .allocations-section{margin-bottom:20px}.add-payday-bill-form .allocations-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;padding-bottom:8px;border-bottom:1px solid var(--gray-200)}.add-payday-bill-form .allocations-header h3{font-size:16px;font-weight:600;color:var(--text-primary);margin:0}.add-payday-bill-form .add-category-btn{display:flex;align-items:center;gap:6px;padding:6px 12px;background:var(--payday-bill-bg);color:var(--payday-bill-color);border:1px solid var(--payday-bill-color);border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease}.add-payday-bill-form .add-category-btn:hover{background:var(--payday-bill-color);color:#fff}.add-payday-bill-form .add-category-form{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px;padding:16px;background:var(--gray-50);border-radius:8px;border:1px solid var(--gray-200)}.add-payday-bill-form .add-category-form input[type=text]{flex:1;min-width:200px;padding:10px 14px;border:1px solid var(--gray-300);border-radius:6px;font-size:15px;background:var(--bg-primary);color:var(--text-primary)}.add-payday-bill-form .add-category-form input[type=text]:focus{outline:none;border-color:var(--payday-bill-color);box-shadow:0 0 0 3px var(--payday-bill-bg)}.add-payday-bill-form .confirm-btn,.add-payday-bill-form .cancel-btn{width:32px;height:32px;border:none;border-radius:6px;cursor:pointer;transition:background-color .2s ease;text-align:center;line-height:32px;padding:0}.add-payday-bill-form .confirm-btn{background:#0d9488}.add-payday-bill-form .confirm-btn svg{color:#fff;stroke:#fff;width:16px;height:16px;vertical-align:middle}.add-payday-bill-form .confirm-btn:hover:not(:disabled){background:#0f766e}.add-payday-bill-form .confirm-btn:disabled{opacity:.5;cursor:not-allowed}.add-payday-bill-form .cancel-btn{background:var(--gray-200)}.add-payday-bill-form .cancel-btn svg{color:var(--gray-700);stroke:var(--gray-700);width:16px;height:16px;vertical-align:middle}.add-payday-bill-form .cancel-btn:hover{background:var(--gray-300)}.add-payday-bill-form .no-categories-message{text-align:center;padding:24px;color:var(--gray-500);font-size:14px;background:var(--gray-50);border-radius:8px}.add-payday-bill-form .allocations-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px}.add-payday-bill-form .allocation-item{display:flex;flex-direction:column;gap:6px}.add-payday-bill-form .allocation-label-row{display:flex;align-items:center;justify-content:space-between;gap:8px;min-height:24px}.add-payday-bill-form .allocation-item label{font-size:13px;font-weight:500;color:var(--gray-700);flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.add-payday-bill-form .category-actions{display:flex;gap:4px;opacity:0;transition:opacity .15s ease}.add-payday-bill-form .allocation-item:hover .category-actions,.add-payday-bill-form .allocation-item:hover .remove-category-btn{opacity:1}.add-payday-bill-form .edit-category-btn,.add-payday-bill-form .remove-category-btn{display:flex;align-items:center;justify-content:center;width:24px;height:24px;padding:0;border:none;border-radius:4px;background:transparent;color:var(--gray-400);cursor:pointer;transition:all .15s ease;opacity:0}.add-payday-bill-form .allocation-item:hover .edit-category-btn,.add-payday-bill-form .allocation-item:hover .remove-category-btn{opacity:1}.add-payday-bill-form .edit-category-btn:hover{background:var(--payday-bill-bg);color:var(--payday-bill-color)}.add-payday-bill-form .remove-category-btn:hover{background:#ef44441a;color:#ef4444}.add-payday-bill-form .edit-category-inline{display:flex;align-items:center;gap:6px;flex:1}.add-payday-bill-form .edit-category-inline input{flex:1;padding:4px 8px;font-size:13px;border:1px solid var(--payday-bill-color);border-radius:4px;background:var(--bg-primary);color:var(--text-primary);outline:none}.add-payday-bill-form .edit-category-inline .confirm-btn,.add-payday-bill-form .edit-category-inline .cancel-btn{width:24px;height:24px;min-width:24px;line-height:24px}.add-payday-bill-form .edit-category-inline .confirm-btn svg,.add-payday-bill-form .edit-category-inline .cancel-btn svg{width:14px;height:14px;vertical-align:middle}.add-payday-bill-form .allocation-item.custom label{color:var(--gray-700)}.add-payday-bill-form .allocation-item label{text-transform:capitalize}.add-payday-bill-form .amount-input-wrapper{display:flex;align-items:center;border:1px solid var(--gray-300);border-radius:8px;background:var(--bg-primary);overflow:hidden;transition:all .2s ease}.add-payday-bill-form .amount-input-wrapper:hover{border-color:var(--payday-bill-color)}.add-payday-bill-form .amount-input-wrapper:focus-within{border-color:var(--payday-bill-color);box-shadow:0 0 0 3px var(--payday-bill-bg)}.add-payday-bill-form .currency-symbol{padding:10px 12px;background:var(--gray-100);color:var(--gray-600);font-size:14px;border-right:1px solid var(--gray-300)}.add-payday-bill-form .amount-input-wrapper input{flex:1;padding:10px 12px;border:none;background:transparent;font-size:14px;color:var(--text-primary);outline:none}.add-payday-bill-form .amount-input-wrapper input::placeholder{color:var(--gray-400)}.add-payday-bill-form .total-section{display:flex;justify-content:space-between;align-items:center;padding:16px;background:var(--payday-bill-bg);border-radius:12px;margin-bottom:20px}.add-payday-bill-form .total-label{font-size:16px;font-weight:600;color:var(--payday-bill-color-dark)}.add-payday-bill-form .total-amount{font-size:24px;font-weight:700;color:var(--payday-bill-color)}.add-payday-bill-form .form-actions{display:flex;gap:12px;justify-content:flex-end}.add-payday-bill-form .cancel-button{padding:12px 24px;background:var(--gray-100);color:var(--gray-700);border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.add-payday-bill-form .cancel-button:hover{background:var(--gray-200)}.add-payday-bill-form .submit-button{padding:12px 24px;background:var(--payday-bill-color);color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.add-payday-bill-form .submit-button:hover:not(:disabled){background:var(--payday-bill-color-dark)}.add-payday-bill-form .submit-button:disabled{opacity:.6;cursor:not-allowed}.add-payday-bill-form .category-groups{display:flex;flex-direction:column;gap:12px;margin-bottom:20px}.add-payday-bill-form .category-group{background:var(--gray-50);border-radius:12px;overflow:hidden;border:1px solid var(--gray-200)}.add-payday-bill-form .group-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;cursor:pointer;background:var(--gray-100);transition:background-color .15s ease}.add-payday-bill-form .group-header:hover{background:var(--gray-200)}.add-payday-bill-form .group-header-left{display:flex;align-items:center;gap:8px}.add-payday-bill-form .group-header-left svg{color:var(--gray-500)}.add-payday-bill-form .group-title{font-size:14px;font-weight:600;color:var(--text-primary)}.add-payday-bill-form .group-count{font-size:12px;color:var(--gray-500);font-weight:400}.add-payday-bill-form .add-to-group-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;border:none;border-radius:6px;background:transparent;color:var(--gray-400);cursor:pointer;transition:all .15s ease}.add-payday-bill-form .add-to-group-btn:hover{background:var(--payday-bill-bg);color:var(--payday-bill-color)}.add-payday-bill-form .group-content{padding:16px}.add-payday-bill-form .available-categories{display:flex;flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:16px;padding-bottom:12px;border-bottom:1px dashed var(--gray-200)}.add-payday-bill-form .available-label{font-size:12px;color:var(--gray-500);font-weight:500}.add-payday-bill-form .available-chips{display:flex;flex-wrap:wrap;gap:6px}.add-payday-bill-form .category-chip{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;background:var(--bg-primary);color:var(--gray-600);border:1px dashed var(--gray-300);border-radius:16px;font-size:12px;cursor:pointer;transition:all .15s ease}.add-payday-bill-form .category-chip:hover{background:var(--payday-bill-bg);color:var(--payday-bill-color);border-color:var(--payday-bill-color);border-style:solid}.add-payday-bill-form .category-chip svg{width:12px;height:12px}.add-payday-bill-form .no-categories-in-group{font-size:13px;color:var(--gray-500);font-style:italic;text-align:center;padding:12px}.add-payday-bill-form .add-custom-category-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:12px;margin-top:8px;background:var(--bg-primary);color:var(--payday-bill-color);border:2px dashed var(--payday-bill-color);border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.add-payday-bill-form .add-custom-category-btn:hover{background:var(--payday-bill-bg)}.add-payday-bill-form .add-category-form .group-select{min-width:160px;padding:10px 14px;border:1px solid var(--gray-300);border-radius:6px;font-size:15px;background:var(--bg-primary);color:var(--text-primary);cursor:pointer}.add-payday-bill-form .add-category-form .group-select:focus{outline:none;border-color:var(--payday-bill-color);box-shadow:0 0 0 3px var(--payday-bill-bg)}@media (max-width: 768px){.add-payday-bill-button{width:calc(100% - 40px);max-width:calc(100% - 40px);margin:20px}.add-payday-bill-form{width:100%;max-width:100%;margin:0;padding:20px;border-radius:0}.add-payday-bill-form .allocations-grid{grid-template-columns:1fr 1fr}.add-payday-bill-form .form-actions{flex-direction:column}.add-payday-bill-form .cancel-button,.add-payday-bill-form .submit-button{width:100%}}@media (max-width: 480px){.add-payday-bill-form .allocations-grid{grid-template-columns:1fr}.add-payday-bill-form .add-category-form{flex-wrap:wrap}.add-payday-bill-form .add-category-form .group-select{width:100%;min-width:100%}.add-payday-bill-form .category-chip{font-size:11px;padding:3px 8px}}.bill-item{background:var(--bg-primary);border-radius:16px;padding:20px;margin:12px 20px;display:flex;align-items:center;gap:16px;box-shadow:var(--shadow-sm);border-left:4px solid;transition:all .2s ease}.bill-item:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.bill-item.upcoming{border-left-color:var(--primary-color)}.bill-item.paid{border-left-color:var(--success-color);opacity:.8}.bill-item.overdue{border-left-color:var(--danger-color)}.bill-checkbox-container{flex-shrink:0}.bill-checkbox{width:28px;height:28px;border:2px solid var(--border-color);border-radius:50%;background:var(--bg-primary);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;padding:0}.bill-checkbox:hover{border-color:var(--primary-color);background:var(--primary-color);color:var(--text-inverse)}.bill-checkbox.checked{background:var(--success-color);border-color:var(--success-color);color:var(--text-inverse)}.bill-content{flex:1;min-width:0}.bill-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}.bill-name-container{display:flex;flex-direction:column;gap:4px;min-width:0}.bill-name{font-size:var(--font-size-lg);font-weight:600;color:var(--text-primary);margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:200px}.category-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:10px;font-size:var(--font-size-xs);font-weight:600;text-transform:uppercase;letter-spacing:.3px;width:fit-content}.category-badge.expense{background:var(--gray-100);color:var(--gray-600)}.category-badge.freedom{background:var(--primary-light);color:var(--primary-color)}.bill-amount-container{display:flex;flex-direction:row;align-items:center;gap:8px;flex-shrink:0}.budget-category-icon{display:flex;align-items:center;justify-content:center;color:#0d9488;cursor:help}[data-theme=dark] .budget-category-icon{color:#14b8a6}.bill-amount{font-size:var(--font-size-xl);font-weight:700;color:var(--text-primary);flex-shrink:0}.bill-details{display:flex;align-items:center;gap:12px}.bill-status{font-size:var(--font-size-sm);color:var(--gray-600);font-weight:500}.bill-item.overdue .bill-status{color:var(--danger-color);font-weight:600}.bill-item.paid .bill-status{color:var(--success-color);font-weight:600}.bill-item.upcoming .bill-status{color:var(--primary-color);font-weight:600}.bill-actions{display:flex;gap:8px;flex-shrink:0}.notification-toggle,.edit-button,.delete-button{width:36px;height:36px;border-radius:8px;padding:0;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.notification-toggle{background:var(--gray-100);color:var(--gray-600);border:2px solid transparent}.notification-toggle.enabled{background:var(--primary-light);color:var(--primary-color);border-color:var(--primary-color)}.notification-toggle.enabled:hover{background:var(--primary-color);color:var(--text-inverse);border-color:var(--primary-color)}.notification-toggle.disabled{background:var(--gray-100);color:var(--gray-400);border-color:transparent}.notification-toggle.disabled:hover{background:var(--gray-200);color:var(--gray-600);border-color:var(--gray-300)}.edit-button{background:var(--gray-100);color:var(--gray-600)}.delete-button{background:var(--gray-100);color:var(--gray-600)}.bill-item.editing{padding:16px 20px}.edit-form{width:100%;display:flex;flex-direction:column;gap:12px}.edit-group input{padding:10px 12px;font-size:14px;border-radius:8px}.edit-group.budget-category-row{display:flex;gap:8px;flex-wrap:wrap}.edit-group .budget-select{flex:1;min-width:120px;padding:10px 28px 10px 12px;font-size:14px;border:1px solid var(--gray-300);border-radius:8px;background:var(--bg-primary);color:var(--text-primary);cursor:pointer;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='%236b7280' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center}.edit-group .budget-select:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 2px #3b82f626}.edit-group .recurring-label{text-transform:none;font-size:15px}.edit-actions{display:flex;gap:8px;justify-content:flex-end}.save-button{background:var(--success-color);color:var(--text-inverse);width:36px;height:36px;padding:0;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:700}.save-button:hover{background:var(--success-color);opacity:.9;color:var(--text-inverse)}.edit-actions .cancel-button{background:var(--gray-200);color:var(--gray-600);width:36px;height:36px;padding:0;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:20px}.suggestion-notification{margin-top:12px;padding:12px;background:linear-gradient(135deg,#fef3c7,#fde68a);border-radius:8px;border-left:3px solid #f59e0b;display:flex;flex-direction:column;gap:10px}.suggestion-info{display:flex;align-items:center;gap:8px}.suggestion-icon{color:#f59e0b;flex-shrink:0}.suggestion-text{font-size:13px;color:#92400e;font-weight:500}.suggestion-actions-inline{display:flex;gap:8px;justify-content:flex-end}.btn-dismiss-suggestion{padding:6px 10px;border:none;border-radius:6px;background:#0000001a;color:#92400e;cursor:pointer;display:flex;align-items:center;gap:4px;font-size:13px;transition:all .2s ease}.btn-dismiss-suggestion:hover:not(:disabled){background:#0003}.btn-dismiss-suggestion:disabled{opacity:.5;cursor:not-allowed}.btn-mark-paid-suggestion{padding:6px 12px;border:none;border-radius:6px;background:var(--success-color);color:var(--text-inverse);cursor:pointer;display:flex;align-items:center;gap:4px;font-size:13px;font-weight:500;transition:all .2s ease}.btn-mark-paid-suggestion:hover:not(:disabled){background:var(--success-color);opacity:.9;transform:translateY(-1px);box-shadow:var(--shadow-sm)}.btn-mark-paid-suggestion:disabled{opacity:.6;cursor:not-allowed}@media (max-width: 480px){.bill-item{margin:8px 16px;padding:12px;gap:10px;display:flex!important;flex-direction:row!important;align-items:center!important;flex-wrap:nowrap!important}.bill-checkbox-container{flex-shrink:0}.bill-content{flex:1!important;min-width:0}.bill-header{display:flex!important;flex-direction:column!important;align-items:flex-start!important;gap:4px;width:100%}.bill-name-container,.bill-amount-container{width:100%}.bill-amount{font-size:var(--font-size-lg)}.bill-actions{display:flex!important;flex-direction:row!important;flex-shrink:0;gap:4px}.bill-checkbox{width:24px;height:24px}.bill-name{max-width:none}.notification-toggle,.edit-button,.delete-button{width:30px;height:30px}.category-badge{padding:2px 5px}.budget-category-icon svg{width:12px;height:12px}.edit-form{gap:10px}}.payday-bill-item{background:var(--bg-primary);border-radius:16px;margin:12px 20px;box-shadow:var(--shadow-sm);border-left:4px solid #0d9488;transition:all .2s ease;overflow:hidden}.payday-bill-item:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.payday-bill-item.paid{border-left-color:var(--success-color);opacity:.8}.payday-bill-item.overdue{border-left-color:var(--danger-color)}.payday-bill-item .payday-bill-main{padding:20px;display:flex;align-items:center;gap:16px}.payday-bill-item .bill-checkbox-container{flex-shrink:0}.payday-bill-item .bill-checkbox{width:28px;height:28px;border:2px solid var(--border-color);border-radius:50%;background:var(--bg-primary);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;padding:0}.payday-bill-item .bill-checkbox:hover{border-color:#0d9488;background:#0d9488;color:#fff}.payday-bill-item .bill-checkbox.checked{background:var(--success-color);border-color:var(--success-color);color:#fff}.payday-bill-item .bill-content{flex:1;min-width:0}.payday-bill-item .bill-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}.payday-bill-item .bill-name-container{display:flex;flex-direction:column;gap:4px;min-width:0}.payday-bill-item .bill-name{font-size:18px;font-weight:600;color:var(--text-primary);margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:200px}.payday-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:10px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.3px;width:fit-content;background:#0d948826;color:#0d9488}.payday-bill-item .bill-amount{font-size:20px;font-weight:700;color:var(--text-primary);flex-shrink:0}.payday-bill-item .bill-details{display:flex;align-items:center;gap:12px}.payday-bill-item .bill-status{font-size:14px;color:var(--gray-600);font-weight:500}.payday-bill-item.upcoming .bill-status{color:#0d9488;font-weight:600}.payday-bill-item.overdue .bill-status{color:var(--danger-color);font-weight:600}.payday-bill-item.paid .bill-status{color:var(--success-color);font-weight:600}.payday-bill-item .expand-toggle{display:inline-flex;align-items:center;gap:4px;padding:4px 8px;border:none;border-radius:6px;background:#0d94881a;color:#0d9488;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s ease}.payday-bill-item .expand-toggle:hover{background:#0d948833}.payday-bill-item .bill-actions{display:flex;gap:8px;flex-shrink:0}.payday-bill-item .edit-button,.payday-bill-item .delete-button{width:36px;height:36px;border-radius:8px;padding:0;display:flex;align-items:center;justify-content:center;transition:all .2s ease;border:none;cursor:pointer}.payday-bill-item .edit-button{background:var(--gray-100);color:var(--gray-600)}.payday-bill-item .edit-button:hover{background:#0d9488;color:#fff}.payday-bill-item .delete-button{background:var(--gray-100);color:var(--gray-600)}.payday-bill-item .delete-button:hover{background:var(--danger-color);color:#fff}.payday-bill-item .budget-breakdown{border-top:1px solid var(--gray-200);background:#0d948808;padding:16px 20px}.payday-bill-item .breakdown-header{font-size:13px;font-weight:600;color:#0f766e;margin-bottom:12px;text-transform:uppercase;letter-spacing:.5px}.payday-bill-item .breakdown-list{display:flex;flex-direction:column;gap:8px}.payday-bill-item .breakdown-item{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;background:var(--bg-primary);border-radius:8px}.payday-bill-item .breakdown-category{font-size:14px;color:var(--gray-700);font-weight:500}.payday-bill-item .breakdown-amount{font-size:14px;color:var(--text-primary);font-weight:600}.payday-bill-item .breakdown-total{display:flex;justify-content:space-between;align-items:center;margin-top:12px;padding-top:12px;border-top:1px dashed var(--gray-300);font-size:15px;font-weight:700;color:#0d9488}.payday-bill-item.editing{padding:16px 20px}.payday-bill-item .edit-form{width:100%;display:flex;flex-direction:column;gap:12px}.payday-bill-item .edit-group input{width:100%;padding:10px 12px;font-size:14px;border-radius:8px;border:1px solid var(--gray-300);background:var(--bg-primary);color:var(--text-primary);transition:all .2s ease}.payday-bill-item .edit-group input:focus{outline:none;border-color:#0d9488;box-shadow:0 0 0 3px #0d94881a}.payday-bill-item .edit-actions{display:flex;gap:8px;justify-content:flex-end}.payday-bill-item .edit-actions .save-button{padding:8px 16px;background:#0d9488;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.payday-bill-item .edit-actions .save-button:hover{background:#0f766e}.payday-bill-item .edit-actions .cancel-button{padding:8px 16px;background:var(--gray-200);color:var(--gray-600);border:none;border-radius:8px;font-size:14px;cursor:pointer;transition:all .2s ease}.payday-bill-item .edit-actions .cancel-button:hover{background:var(--gray-300)}@media (max-width: 480px){.payday-bill-item{margin:8px 16px}.payday-bill-item .payday-bill-main{padding:16px}.payday-bill-item .bill-header{flex-direction:column;align-items:flex-start;gap:4px}.payday-bill-item .bill-name{max-width:none}.payday-bill-item .bill-amount{font-size:18px}.payday-badge{font-size:10px;padding:2px 6px}.payday-bill-item .budget-breakdown{padding:12px 16px}.payday-bill-item .breakdown-item{padding:6px 10px}.payday-bill-item .edit-form{gap:10px}}.bill-list{padding-bottom:20px}.empty-state{text-align:center;padding:60px 20px;color:var(--gray-500)}.empty-icon{display:flex;justify-content:center;margin-bottom:20px;opacity:.6}.empty-state h3{font-size:20px;font-weight:600;color:var(--gray-700);margin-bottom:8px}.empty-state p{font-size:16px;color:var(--gray-500);max-width:300px;margin:0 auto;line-height:1.5}.empty-state.enhanced{padding:80px 24px;max-width:400px;margin:0 auto}.empty-state.enhanced .empty-icon{width:80px;height:80px;border-radius:50%;background:var(--primary-light);display:flex;align-items:center;justify-content:center;margin:0 auto 24px;opacity:1;color:var(--primary-color)}.empty-state.enhanced h3{font-size:22px;margin-bottom:12px}.empty-state.enhanced p{font-size:15px;max-width:340px;margin-bottom:20px}.empty-state-tips{display:flex;align-items:center;gap:8px;background:var(--gray-100);border-radius:8px;padding:12px 16px;font-size:13px;color:var(--gray-600);max-width:340px;margin:0 auto 24px;text-align:left}.empty-state-tips svg{color:#f59e0b;flex-shrink:0}.empty-state-cta{display:inline-flex;align-items:center;gap:8px;background:var(--primary-color);color:var(--text-inverse);border:none;border-radius:12px;padding:14px 24px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease}.empty-state-cta:hover{background:var(--primary-dark);transform:translateY(-2px);box-shadow:0 6px 20px #3b82f64d}.empty-state-cta:active{transform:translateY(0)}.example-bill-section{width:100%;max-width:340px;margin:24px auto;text-align:left}.example-label{display:block;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--gray-400);margin-bottom:8px;text-align:center}.bill-item.example{background:var(--card-bg);border-radius:12px;padding:16px;border:2px dashed var(--gray-300);pointer-events:none;opacity:.9}.bill-item.example .bill-main{display:flex;align-items:flex-start;gap:12px}.bill-item.example .bill-checkbox-area{flex-shrink:0}.bill-item.example .bill-checkbox{width:28px;height:28px;border:2px solid var(--gray-300);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--gray-300)}.bill-item.example .bill-info{flex:1;min-width:0}.bill-item.example .bill-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.bill-item.example .bill-label{font-size:16px;font-weight:600;color:var(--text-primary)}.bill-item.example .bill-amount{font-size:16px;font-weight:700;color:var(--text-primary)}.bill-item.example .bill-meta{display:flex;flex-wrap:wrap;gap:12px;font-size:12px;color:var(--gray-500)}.bill-item.example .bill-meta span{display:inline-flex;align-items:center;gap:4px}.bill-item.example .bill-due{color:var(--primary-color)}.bill-item.example .bill-notification.active{color:var(--success-color)}.bill-item.example .bill-tag{color:var(--gray-500)}.example-bill-legend{margin-top:12px;padding-top:12px;border-top:1px dashed var(--gray-200);display:flex;flex-direction:column;gap:6px}.legend-item{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--gray-500)}.legend-item .legend-paid{color:var(--success-color)}.legend-item .legend-overdue{color:var(--danger-color)}[data-theme=dark] .empty-state.enhanced .empty-icon{background:#3b82f633}[data-theme=dark] .empty-state-tips{background:var(--gray-800);color:var(--gray-400)}[data-theme=dark] .bill-item.example{border-color:var(--gray-600)}[data-theme=dark] .bill-item.example .bill-checkbox{border-color:var(--gray-500);color:var(--gray-500)}[data-theme=dark] .example-bill-legend{border-top-color:var(--gray-600)}.add-debt-button{width:min(var(--floating-card-max-width, 800px),calc(100% - (var(--floating-card-side-gap, 20px) * 2)));max-width:var(--floating-card-max-width, 800px);margin:20px auto;padding:16px;background:var(--bg-primary);color:var(--primary-color);border:2px dashed var(--primary-color);border-radius:16px;display:block;font-size:16px;font-weight:600;transition:all .2s ease;cursor:pointer;text-align:center;z-index:900;box-shadow:0 2px 8px #0000001a}.add-debt-button:hover{background:var(--primary-color);color:var(--text-inverse);border-color:var(--primary-color)}.add-debt-form{width:min(var(--floating-card-max-width, 800px),calc(100% - (var(--floating-card-side-gap, 20px) * 2)));max-width:var(--floating-card-max-width, 800px);margin:20px auto;background:var(--bg-primary);padding:24px;border-bottom:1px solid var(--gray-200);border-radius:0;box-shadow:0 4px 6px #0000001a}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.form-group select{width:100%;padding:12px;font-size:16px;border:1px solid var(--gray-300);border-radius:8px;background:var(--bg-primary);color:var(--text-primary);cursor:pointer}.form-group select:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #3b82f61a}.form-hint{display:block;margin-top:6px;font-size:12px;color:var(--gray-600);font-style:italic}.bill-dropdown-name{font-size:14px;color:var(--text-primary);font-weight:500}.bill-dropdown-amount{font-size:14px;color:var(--primary-color);font-weight:600}.linked-bill-display{display:flex;align-items:center;justify-content:space-between;padding:12px;background:var(--gray-100);border:1px solid var(--gray-300);border-radius:8px}.linked-bill-name{font-size:14px;color:var(--text-primary);font-weight:500}.create-bill-option{background:var(--gray-50);border-radius:12px;padding:16px;margin-top:8px}.create-bill-option .checkbox-label{display:flex;align-items:center;gap:10px;cursor:pointer;font-size:15px;font-weight:500;color:var(--text-primary)}.create-bill-option .checkbox-label input[type=checkbox]{width:20px;height:20px;accent-color:var(--primary-color);cursor:pointer}.create-bill-option .checkbox-label svg{color:var(--primary-color);flex-shrink:0}.create-bill-option .form-hint{margin-left:30px;margin-top:8px}.first-payment-date{margin-top:16px;padding-top:16px;border-top:1px dashed var(--gray-300)}.first-payment-date>label{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:500;color:var(--text-primary);margin-bottom:8px}.first-payment-date>label svg{color:var(--primary-color)}.first-payment-date input[type=date]{width:100%;padding:12px;font-size:16px;border:1px solid var(--gray-300);border-radius:8px;background:var(--bg-primary);color:var(--text-primary);cursor:pointer}.first-payment-date input[type=date]:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #3b82f61a}.first-payment-date .form-hint{margin-left:0}[data-theme=dark] .create-bill-option{background:var(--gray-800)}[data-theme=dark] .first-payment-date{border-top-color:var(--gray-600)}@media (max-width: 768px){.add-debt-button{width:calc(100% - 40px);max-width:calc(100% - 40px);margin:20px}.add-debt-form{width:100%;max-width:100%;margin:0;padding:20px}.form-row{grid-template-columns:1fr;gap:0}.form-actions{flex-direction:column}}.debt-item{background:var(--bg-primary);border-radius:16px;padding:20px;margin:12px 20px;display:flex;align-items:flex-start;gap:12px;box-shadow:0 2px 8px #0000000d;border-left:4px solid var(--primary-color);transition:all .2s ease;cursor:grab}.debt-item:hover{box-shadow:0 4px 16px #0000001a;transform:translateY(-1px)}.debt-item:active{cursor:grabbing}.debt-item.paid{border-left-color:var(--success-color);opacity:.7}.debt-item.dragging{opacity:.4;box-shadow:0 8px 24px #0003;transform:scale(1.02) rotate(2deg);cursor:grabbing}.debt-drag-handle{flex-shrink:0;cursor:grab;color:var(--gray-400);padding-top:4px}.debt-drag-handle:active{cursor:grabbing}.debt-drag-handle:hover{color:var(--gray-600)}.debt-content{flex:1;min-width:0}.debt-header{margin-bottom:12px}.debt-title-row{display:flex;align-items:center;gap:8px;margin-bottom:6px}.debt-name{font-size:18px;font-weight:600;color:var(--text-primary);margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.debt-category-badge{font-size:11px;font-weight:600;text-transform:uppercase;padding:3px 8px;border-radius:4px;white-space:nowrap;letter-spacing:.5px}.debt-category-badge.credit-card{background:#fef3c7;color:#92400e}.debt-category-badge.student-loan{background:#dbeafe;color:#1e40af}.debt-category-badge.auto-loan{background:#e0e7ff;color:#4338ca}.debt-category-badge.medical{background:#fce7f3;color:#9f1239}.debt-category-badge.personal-loan{background:#e9d5ff;color:#6b21a8}.debt-category-badge.mortgage{background:#d1fae5;color:#065f46}.debt-category-badge.other{background:#f3f4f6;color:#374151}.debt-balance{font-size:24px;font-weight:700;color:var(--text-primary)}.debt-details{display:flex;flex-direction:column;gap:6px;margin-bottom:12px}.debt-detail-row{display:flex;justify-content:space-between;align-items:center}.debt-detail-label{font-size:13px;color:var(--gray-600);font-weight:500}.debt-detail-value{font-size:14px;color:var(--text-primary);font-weight:600}.debt-progress-section{margin-top:12px}.debt-progress-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.debt-progress-label{font-size:13px;font-weight:600;color:var(--primary-color)}.debt-progress-percentage{font-size:12px;font-weight:600;color:var(--gray-600)}.debt-progress-bar{height:8px;background:var(--gray-200);border-radius:4px;overflow:hidden}.debt-progress-fill{height:100%;background:linear-gradient(90deg,#ef4444,#f59e0b,#10b981);transition:width .3s ease;border-radius:4px}.debt-item.paid .debt-progress-fill{background:var(--success-color)}.debt-actions{display:flex;flex-direction:column;gap:8px;flex-shrink:0}.edit-button,.delete-button{width:36px;height:36px;border-radius:8px;padding:0;display:flex;align-items:center;justify-content:center;transition:all .2s ease;background:var(--gray-100);color:var(--gray-600)}.debt-item.editing{padding:20px;flex-direction:column;align-items:stretch}.edit-form{width:100%;display:flex;flex-direction:column;gap:14px}.edit-group{display:flex;flex-direction:column;gap:6px}.edit-group label{font-size:12px;font-weight:600;color:var(--gray-700);text-transform:uppercase;letter-spacing:.5px}.edit-group input,.edit-group select{padding:10px 12px;font-size:14px;border-radius:8px;border:1px solid var(--gray-300);width:100%}.edit-group input:focus,.edit-group select:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #3b82f61a}.edit-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:8px}.save-button{background:var(--success-color);color:var(--text-inverse);padding:10px 20px;border-radius:8px;display:flex;align-items:center;gap:6px;font-weight:600;font-size:14px}.save-button:hover{background:#059669}.edit-actions .cancel-button{background:var(--gray-200);color:var(--gray-700);padding:10px 20px;border-radius:8px;font-weight:600;font-size:14px}.edit-actions .cancel-button:hover{background:var(--gray-300)}.bill-search-container{position:relative}.bill-dropdown{position:absolute;top:100%;left:0;right:0;background:var(--bg-primary);border:1px solid var(--gray-300);border-radius:8px;margin-top:4px;max-height:200px;overflow-y:auto;box-shadow:0 4px 12px #0000001a;z-index:10}.bill-dropdown-item{width:100%;padding:12px;display:flex;justify-content:space-between;align-items:center;border:none;background:var(--bg-primary);cursor:pointer;transition:background .2s ease;text-align:left}.bill-dropdown-item:hover{background:var(--gray-100)}.bill-dropdown-item:not(:last-child){border-bottom:1px solid var(--gray-200)}.bill-dropdown-name{font-size:13px;color:var(--text-primary);font-weight:500}.bill-dropdown-amount{font-size:13px;color:var(--primary-color);font-weight:600}.linked-bill-display{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;background:var(--gray-100);border:1px solid var(--gray-300);border-radius:8px}.linked-bill-name{font-size:13px;color:var(--text-primary);font-weight:500}.clear-bill-button{padding:4px;background:var(--bg-primary);border:1px solid var(--gray-300);border-radius:4px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;color:var(--gray-600)}.clear-bill-button:hover{background:var(--danger-color);color:var(--text-inverse);border-color:var(--danger-color)}.debt-linked-bill-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 8px;background:#3b82f61a;color:var(--primary-color);border-radius:6px;font-size:12px;font-weight:600;margin-top:8px}@media (max-width: 480px){.debt-item{margin:8px 16px;padding:16px}.debt-title-row{flex-wrap:wrap}.debt-balance{font-size:20px}.debt-actions{flex-direction:row}.edit-form{gap:12px}}.debt-list{width:100%;max-width:800px;margin:0 auto;padding-bottom:20px}.debt-list-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:var(--gray-400);text-align:center;min-height:300px}.debt-list-empty p{margin:16px 0 4px;font-size:18px;font-weight:600;color:var(--gray-600)}.debt-list-empty span{font-size:14px;color:var(--gray-500)}.debt-list-empty.enhanced{padding:80px 24px;max-width:400px;margin:0 auto;min-height:auto}.debt-list-empty.enhanced .empty-icon{width:80px;height:80px;border-radius:50%;background:var(--success-light, rgba(16, 185, 129, .1));display:flex;align-items:center;justify-content:center;margin-bottom:24px;color:var(--success-color)}.debt-list-empty.enhanced h3{font-size:22px;font-weight:600;color:var(--gray-700);margin-bottom:12px}.debt-list-empty.enhanced p{font-size:15px;color:var(--gray-500);max-width:340px;margin:0 auto 20px;line-height:1.5}.debt-list-empty .empty-state-tips{display:flex;align-items:center;gap:8px;background:var(--gray-100);border-radius:8px;padding:12px 16px;font-size:13px;color:var(--gray-600);max-width:340px;margin:0 auto 24px;text-align:left}.debt-list-empty .empty-state-tips svg{color:#f59e0b;flex-shrink:0}.debt-list-empty .empty-state-cta{display:inline-flex;align-items:center;gap:8px;background:var(--primary-color);color:var(--text-inverse);border:none;border-radius:12px;padding:14px 24px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease}.debt-list-empty .empty-state-cta:hover{background:var(--primary-dark);transform:translateY(-2px);box-shadow:0 6px 20px #3b82f64d}.debt-list-empty .empty-state-cta:active{transform:translateY(0)}[data-theme=dark] .debt-list-empty.enhanced .empty-icon{background:#10b98133}[data-theme=dark] .debt-list-empty.enhanced h3{color:var(--gray-200)}[data-theme=dark] .debt-list-empty .empty-state-tips{background:var(--gray-800);color:var(--gray-400)}.calculator-fab{position:fixed;bottom:30px;right:110px;width:60px;height:60px;border-radius:50%;background:linear-gradient(135deg,var(--primary-color) 0%,#2563eb 100%);color:var(--text-inverse);border:none;box-shadow:0 4px 12px #3b82f666,0 8px 24px #3b82f633;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease;z-index:998}.calculator-fab:hover{transform:scale(1.1) rotate(5deg);box-shadow:0 6px 16px #3b82f680,0 12px 32px #3b82f64d}.calculator-fab:active{transform:scale(.95)}@media (max-width: 768px){.calculator-fab{bottom:20px;right:90px;width:56px;height:56px}}.payoff-calculator-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:10000;padding:20px;overflow-y:auto}.payoff-calculator{background:var(--bg-primary);color:var(--text-primary);border-radius:20px;max-width:900px;width:100%;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000004d;animation:slideUp .3s ease-out}.calculator-header{display:flex;align-items:center;justify-content:space-between;padding:24px 28px;border-bottom:1px solid var(--gray-200)}.calculator-header h2{display:flex;align-items:center;gap:12px;font-family:Outfit,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:24px;font-weight:600;color:var(--text-primary);margin:0}.calculator-header .close-button{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:var(--gray-100);color:var(--gray-600);transition:all .2s ease;border:none;cursor:pointer}.calculator-header .close-button:hover{background:var(--danger-color);color:var(--text-inverse)}.calculator-body{flex:1;overflow-y:auto;padding:28px;display:flex;flex-direction:column;gap:32px;color:var(--text-primary)}.summary-section h3{font-family:Outfit,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:18px;font-weight:600;color:var(--text-primary);margin:0 0 16px}.summary-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:16px}.payoff-calculator .summary-card{background:linear-gradient(135deg,var(--primary-color) 0%,var(--primary-dark) 100%)!important;color:var(--header-text-color);padding:20px;border-radius:12px;display:flex;flex-direction:column;gap:8px;box-shadow:0 4px 12px #0000001a}.payoff-calculator .summary-card svg{color:var(--header-text-color);opacity:.95}.payoff-calculator .card-label{font-family:Outfit,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:13px;font-weight:600;color:var(--header-text-color);opacity:.9;text-transform:uppercase;letter-spacing:.5px}.payoff-calculator .card-value{font-family:Outfit,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:28px;font-weight:700;color:var(--header-text-color)}.payoff-calculator .card-detail{font-family:Outfit,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:14px;color:var(--header-text-color);opacity:.85}.strategy-section h3{font-family:Outfit,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:18px;font-weight:600;color:var(--text-primary);margin:0 0 8px}.section-description{font-family:Outfit,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:14px;color:var(--text-secondary);margin:0 0 16px}.strategy-comparison{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px}.payoff-calculator .strategy-card{background:var(--gray-50);border:2px solid var(--border-color);border-radius:12px;padding:20px;display:flex;flex-direction:column;gap:12px;transition:all .2s ease;color:var(--text-primary)}.payoff-calculator .strategy-card:hover{border-color:var(--primary-color);box-shadow:0 4px 12px #3b82f61a;transform:translateY(-2px)}.payoff-calculator .strategy-card.selected{border-color:var(--success-color);background:#10b9810d;box-shadow:0 4px 12px #10b98126}.payoff-calculator .strategy-header{display:flex;align-items:center;gap:8px;color:var(--primary-color)}.payoff-calculator .strategy-header .selected-icon{margin-left:auto;color:var(--success-color)}.payoff-calculator .strategy-header h4{font-family:Outfit,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:16px;font-weight:600;margin:0;color:var(--text-primary)}.payoff-calculator .strategy-description{font-family:Outfit,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:13px;color:var(--text-secondary);margin:0}.payoff-calculator .strategy-stats{display:flex;flex-direction:column;gap:12px;margin-top:8px}.payoff-calculator .stat{display:flex;justify-content:space-between;align-items:center;padding-bottom:12px;border-bottom:1px solid var(--gray-200)}.payoff-calculator .stat:last-child{border-bottom:none;padding-bottom:0}.payoff-calculator .stat-label{font-family:Outfit,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:13px;color:var(--text-secondary);font-weight:500}.payoff-calculator .stat-value{font-family:Outfit,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:16px;font-weight:700;color:var(--text-primary)}.payoff-calculator .savings-badge{font-family:Outfit,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--primary-color);color:var(--text-inverse);padding:8px 12px;border-radius:6px;font-size:13px;font-weight:600;text-align:center}.payoff-calculator .savings-badge.success{background:var(--success-color)}.payoff-calculator .select-strategy-button{width:100%;padding:10px 16px;border:2px solid var(--primary-color);background:var(--primary-color);color:var(--text-inverse);border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;font-family:Outfit,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.payoff-calculator .select-strategy-button:hover{background:var(--primary-dark, #4338ca);border-color:var(--primary-dark, #4338ca);transform:translateY(-1px)}.payoff-calculator .select-strategy-button.selected{background:var(--success-color);border-color:var(--success-color);cursor:default}.payoff-calculator .select-strategy-button.selected:hover{background:var(--success-color);border-color:var(--success-color);transform:none}.extra-payment-section h3{font-family:Outfit,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:18px;font-weight:600;color:var(--text-primary);margin:0 0 8px}.extra-payment-input{margin-top:16px}.extra-payment-input label{font-family:Outfit,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;display:block;font-size:14px;font-weight:600;color:var(--text-primary);margin-bottom:8px}.input-group{position:relative;max-width:300px}.input-prefix{font-family:Outfit,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;position:absolute;left:16px;top:50%;transform:translateY(-50%);font-size:18px;font-weight:600;color:var(--text-secondary);pointer-events:none}.input-group input{font-family:Outfit,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;width:100%;padding:12px 16px 12px 36px;font-size:18px;font-weight:600;color:var(--text-primary);background:var(--bg-primary);border:2px solid var(--border-color);border-radius:8px;transition:all .2s ease}.input-group input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #3b82f61a}.extra-payment-results{margin-top:20px;background:var(--gray-50);border:2px solid var(--success-color);border-radius:12px;padding:20px;display:flex;flex-direction:column;gap:16px;color:var(--text-primary)}.result-row{display:flex;justify-content:space-between;align-items:center;padding-bottom:16px;border-bottom:1px solid var(--gray-200)}.result-row:last-child{border-bottom:none;padding-bottom:0}.result-label{font-family:Outfit,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:14px;font-weight:500;color:var(--text-secondary)}.result-value{font-family:Outfit,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:18px;font-weight:700;color:var(--text-primary)}.result-value.highlight{color:var(--primary-color)}.result-value.success{color:var(--success-color)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center;color:var(--text-secondary)}.empty-state h3{font-family:Outfit,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:20px;font-weight:600;color:var(--text-primary);margin:16px 0 8px}.empty-state p{font-family:Outfit,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:14px;color:var(--text-secondary);max-width:400px;margin:0}@media (max-width: 768px){.payoff-calculator-overlay{padding:0;align-items:flex-end}.payoff-calculator{max-height:95vh;border-bottom-left-radius:0;border-bottom-right-radius:0}.calculator-header{padding:20px}.calculator-header h2{font-size:20px}.calculator-body{padding:20px;gap:24px}.summary-cards,.strategy-comparison{grid-template-columns:1fr}.card-value{font-size:24px}}.surplus-actions{margin-top:16px;padding:16px;background:#10b9811a;border-radius:8px;border:1px solid rgba(16,185,129,.2)}.surplus-info{font-family:Outfit,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;margin:0 0 12px;font-size:14px;color:var(--text-primary)}.surplus-info strong{color:var(--success-color);font-weight:700}.surplus-buttons{display:flex;gap:8px}.surplus-button{font-family:Outfit,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;flex:1;padding:10px 16px;border:2px solid var(--border-color);background:var(--bg-primary);border-radius:8px;font-size:13px;font-weight:600;color:var(--text-primary);cursor:pointer;transition:all .2s ease}.surplus-button:hover{background:var(--gray-50);border-color:var(--primary-color)}.surplus-button.primary{background:var(--success-color);color:var(--text-inverse);border-color:var(--success-color)}.surplus-button.primary:hover{background:var(--success-dark, #059669);border-color:var(--success-dark, #059669)}@media (max-width: 768px){.surplus-buttons{flex-direction:column}}.debt-selection-section{margin-bottom:8px}.debt-selection-toggle{width:100%;display:flex;align-items:center;justify-content:space-between;padding:14px 18px;background:var(--gray-50);border:2px solid var(--border-color);border-radius:12px;font-family:Outfit,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:15px;font-weight:600;color:var(--text-primary);cursor:pointer;transition:all .2s ease}.debt-selection-toggle:hover{border-color:var(--primary-color);background:var(--bg-primary)}.debt-selection-toggle .toggle-label{display:flex;align-items:center;gap:10px}.debt-selection-toggle .toggle-label svg{color:var(--primary-color)}.debt-selection-list{margin-top:12px;padding:16px;background:var(--gray-50);border:1px solid var(--border-color);border-radius:12px}.selection-actions{display:flex;gap:8px;margin-bottom:12px;padding-bottom:12px;border-bottom:1px solid var(--gray-200)}.selection-action-btn{padding:6px 12px;font-family:Outfit,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:13px;font-weight:500;color:var(--primary-color);background:var(--bg-primary);border:1px solid var(--primary-color);border-radius:6px;cursor:pointer;transition:all .2s ease}.selection-action-btn:hover{background:var(--primary-color);color:var(--text-inverse)}.debt-selection-item{display:flex;align-items:center;gap:12px;padding:12px;border-radius:8px;cursor:pointer;transition:background .2s ease}.debt-selection-item:hover{background:var(--bg-primary)}.debt-selection-item input[type=checkbox]{width:20px;height:20px;accent-color:var(--primary-color);cursor:pointer;flex-shrink:0}.debt-selection-item .debt-info{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}.debt-selection-item .debt-name{font-family:Outfit,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:15px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.debt-selection-item .debt-details{font-family:Outfit,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:13px;color:var(--text-secondary)}.snowball-timeline-section{background:var(--gray-50);border:2px solid var(--primary-color);border-radius:16px;padding:24px}.snowball-timeline-section h3{display:flex;align-items:center;flex-wrap:wrap;gap:10px;font-family:Outfit,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:18px;font-weight:600;color:var(--text-primary);margin:0 0 8px}.snowball-timeline-section h3 svg{color:var(--primary-color)}.timeline-subtitle{font-size:14px;font-weight:500;color:var(--success-color);background:#10b9811a;padding:4px 10px;border-radius:6px}.snowball-timeline{margin-top:20px}.timeline-header{display:flex;justify-content:space-between;align-items:center;padding:16px;background:linear-gradient(135deg,var(--primary-color) 0%,var(--primary-dark) 100%);border-radius:12px;margin-bottom:20px}.timeline-total-debt,.timeline-total-months{font-family:Outfit,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:15px;font-weight:600;color:var(--header-text-color)}.timeline-track{position:relative;padding-left:24px}.timeline-item{position:relative;padding-bottom:24px}.timeline-item:last-child{padding-bottom:0}.timeline-marker{position:absolute;left:-24px;top:0;width:32px;height:32px;background:var(--primary-color);border-radius:50%;display:flex;align-items:center;justify-content:center;z-index:2}.marker-number{font-family:Outfit,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:14px;font-weight:700;color:var(--text-inverse)}.timeline-connector{position:absolute;left:-8px;top:32px;width:2px;height:calc(100% - 32px);background:linear-gradient(to bottom,var(--primary-color),var(--gray-300))}.timeline-content{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:12px;padding:16px;margin-left:16px;transition:all .2s ease}.timeline-content:hover{border-color:var(--primary-color);box-shadow:0 4px 12px #00000014}.timeline-debt-name{font-family:Outfit,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:16px;font-weight:600;color:var(--text-primary);margin-bottom:6px}.timeline-debt-details{display:flex;gap:12px;margin-bottom:10px}.debt-balance{font-family:Outfit,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:14px;font-weight:600;color:var(--primary-color)}.debt-rate{font-family:Outfit,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:13px;color:var(--text-secondary);background:var(--gray-100);padding:2px 8px;border-radius:4px}.timeline-payoff-info{display:flex;align-items:center;gap:10px}.payoff-date{display:flex;align-items:center;gap:6px;font-family:Outfit,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:14px;font-weight:600;color:var(--success-color)}.payoff-date svg{color:var(--success-color)}.payoff-months{font-family:Outfit,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:13px;color:var(--text-secondary)}.timeline-interest{margin-top:8px;font-family:Outfit,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:13px;color:var(--text-secondary)}.timeline-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;margin-top:20px;padding-top:20px;border-top:2px dashed var(--gray-300)}.timeline-summary .summary-item{background:var(--bg-primary);padding:14px;border-radius:10px;border:1px solid var(--border-color)}.timeline-summary .summary-item.success{background:#10b9811a;border-color:var(--success-color)}.timeline-summary .summary-label{display:block;font-family:Outfit,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:12px;font-weight:500;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}.timeline-summary .summary-value{font-family:Outfit,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:18px;font-weight:700;color:var(--text-primary)}.timeline-summary .summary-item.success .summary-value{color:var(--success-color)}.timeline-empty{text-align:center;padding:40px 20px;color:var(--text-secondary)}.timeline-empty p{font-family:Outfit,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:14px;margin:0}[data-theme=dark] .debt-selection-toggle,[data-theme=dark] .debt-selection-list{background:var(--gray-800)}[data-theme=dark] .debt-selection-item:hover{background:var(--gray-700)}[data-theme=dark] .snowball-timeline-section{background:var(--gray-800)}[data-theme=dark] .timeline-content{background:var(--gray-700)}[data-theme=dark] .debt-rate{background:var(--gray-600)}[data-theme=dark] .timeline-summary .summary-item{background:var(--gray-700)}@media (max-width: 768px){.debt-selection-toggle{padding:12px 16px;font-size:14px}.snowball-timeline-section{padding:20px}.timeline-header{flex-direction:column;gap:8px;text-align:center}.timeline-track{padding-left:20px}.timeline-marker{left:-20px;width:28px;height:28px}.marker-number{font-size:12px}.timeline-content{margin-left:12px;padding:14px}.timeline-debt-details{flex-direction:column;gap:6px}.timeline-payoff-info{flex-direction:column;align-items:flex-start;gap:4px}.timeline-summary{grid-template-columns:1fr}}.credit-card-education{background:var(--bg-primary);border-radius:16px;padding:24px;box-shadow:0 2px 8px #0000000d}.education-header{display:flex;align-items:center;gap:16px;margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid var(--gray-200)}.education-icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:12px;background:linear-gradient(135deg,#6366f1,#4f46e5);color:#fff}.education-title h3{font-size:20px;font-weight:700;color:var(--text-primary);margin:0 0 4px}.education-title p{font-size:14px;color:var(--gray-500);margin:0}.education-sections{display:flex;flex-direction:column;gap:12px}.education-section{border-radius:12px;border:1px solid var(--gray-200);overflow:hidden;transition:all .3s ease}.education-section.expanded{border-color:var(--primary-color);box-shadow:0 4px 12px #6366f126}.section-header{display:flex;align-items:center;gap:12px;width:100%;padding:16px;background:none;border:none;cursor:pointer;transition:background .2s ease}.section-header:hover{background:var(--gray-50)}.section-icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:10px;flex-shrink:0}.section-info{display:flex;flex-direction:column;align-items:flex-start;flex:1}.section-title{font-size:15px;font-weight:600;color:var(--text-primary)}.section-subtitle{font-size:12px;color:var(--gray-500)}.section-toggle{color:var(--gray-400);transition:color .2s ease}.education-section.expanded .section-toggle{color:var(--primary-color)}.section-body{padding:0 16px 16px;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.section-content{display:flex;flex-direction:column;gap:16px}.content-text{font-size:14px;line-height:1.6;color:var(--gray-700);margin:0}.education-formula{background:var(--gray-50);border-radius:10px;padding:16px;text-align:center}.formula-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0}.formula-label{font-size:13px;color:var(--gray-600)}.formula-value{font-size:18px;font-weight:700;color:var(--text-primary)}.formula-divider{font-size:12px;color:var(--gray-500);padding:4px 0;border-top:1px dashed var(--gray-300);border-bottom:1px dashed var(--gray-300);margin:8px 0}.your-numbers{background:linear-gradient(135deg,#6366f10d,#4f46e505);border:1px solid rgba(99,102,241,.2);border-radius:12px;padding:16px}.your-numbers h4{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:600;color:var(--primary-color);margin:0 0 12px}.metric-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:12px}.metric-item{display:flex;flex-direction:column;gap:4px;padding:12px;background:var(--bg-primary);border-radius:8px;text-align:center}.metric-item.danger{background:#ef444414;border:1px solid rgba(239,68,68,.2)}.metric-item.warning{background:#f59e0b14;border:1px solid rgba(245,158,11,.2)}.metric-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.3px;color:var(--gray-500)}.metric-item .metric-value{font-size:18px;font-weight:700;color:var(--text-primary)}.metric-item.danger .metric-value{color:#ef4444}.metric-item.warning .metric-value{color:#d97706}.metric-context{font-size:10px;color:var(--gray-500)}.example-box{background:var(--gray-50);border-radius:10px;padding:16px}.example-box h4{font-size:13px;font-weight:600;color:var(--gray-700);margin:0 0 12px}.key-point{padding:12px 16px;background:#6366f114;border-left:3px solid var(--primary-color);border-radius:0 8px 8px 0;font-size:13px;color:var(--gray-700)}.key-point.warning{background:#ef444414;border-color:#ef4444}.key-point.success{background:#10b98114;border-color:#10b981}.scenario-comparison{display:flex;flex-direction:column;gap:12px}.scenario{border-radius:10px;padding:14px}.scenario.scenario-bad{background:#ef444414;border:1px solid rgba(239,68,68,.2)}.scenario-header{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:600;color:#ef4444;margin-bottom:12px}.scenario-stats{display:flex;flex-direction:column;gap:8px}.scenario-stat{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--gray-700)}.scenario-stat.interest{color:#ef4444;font-weight:600}.trap-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}.trap-list li{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--gray-700)}.trap-list li svg{color:var(--gray-500)}.visual-breakdown{background:var(--gray-50);border-radius:10px;padding:16px}.visual-breakdown h4{font-size:13px;font-weight:600;color:var(--gray-700);margin:0 0 12px}.payment-bar{display:flex;height:40px;border-radius:8px;overflow:hidden;font-size:11px;font-weight:600}.bar-interest{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;display:flex;align-items:center;justify-content:center}.bar-principal{background:linear-gradient(135deg,#10b981,#059669);color:#fff;display:flex;align-items:center;justify-content:center}.bar-caption{font-size:12px;color:var(--gray-500);text-align:center;margin:8px 0 0}.comparison-grid{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:16px}.comparison-card{padding:16px;border-radius:12px;text-align:center}.comparison-card.bad{background:#ef444414;border:1px solid rgba(239,68,68,.2)}.comparison-card.good{background:#10b98114;border:1px solid rgba(16,185,129,.2)}.comparison-card h4{font-size:13px;font-weight:600;margin:0 0 8px;color:var(--gray-600)}.comparison-amount{font-size:18px;font-weight:700;margin-bottom:12px}.comparison-card.bad .comparison-amount{color:#ef4444}.comparison-card.good .comparison-amount{color:#10b981}.comparison-vs{font-size:14px;font-weight:700;color:var(--gray-400)}.comparison-stats{display:flex;flex-direction:column;gap:6px;font-size:12px;color:var(--gray-600)}.comparison-stats div{display:flex;align-items:center;justify-content:center;gap:4px}.stat-interest{color:#ef4444;font-weight:600}.stat-savings{color:#10b981;font-weight:600}.savings-callout{display:flex;align-items:center;gap:16px;padding:16px;background:linear-gradient(135deg,#10b9811a,#14b8a60d);border:1px solid rgba(16,185,129,.2);border-radius:12px;color:#059669}.savings-callout svg{flex-shrink:0}.savings-text{display:flex;flex-direction:column;gap:2px}.savings-amount{font-size:18px;font-weight:700}.savings-time{font-size:13px}.custom-calculator{background:var(--gray-50);border-radius:12px;padding:16px}.custom-calculator h4{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:600;color:var(--gray-700);margin:0 0 12px}.calculator-input{display:flex;align-items:center;gap:12px;margin-bottom:16px}.calculator-input label{font-size:13px;color:var(--gray-600)}.input-wrapper{display:flex;align-items:center;background:var(--bg-primary);border:1px solid var(--gray-300);border-radius:8px;padding:0 12px;transition:border-color .2s ease}.input-wrapper:focus-within{border-color:var(--primary-color)}.currency-symbol{color:var(--gray-500);font-size:14px}.input-wrapper input{border:none;background:none;padding:10px 8px;font-size:16px;font-weight:600;width:100px;color:var(--text-primary)}.input-wrapper input:focus{outline:none}.calculator-results{display:flex;gap:16px}.calc-result{flex:1;display:flex;flex-direction:column;gap:4px;padding:12px;background:var(--bg-primary);border-radius:8px}.calc-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.3px;color:var(--gray-500)}.calc-value{font-size:16px;font-weight:700;color:var(--text-primary)}.calc-value.success{color:#10b981}.peasant-tax-summary{display:flex;flex-direction:column;gap:16px}.tax-header{display:flex;align-items:center;gap:12px}.tax-header svg{color:#f59e0b}.tax-header h4{font-size:16px;font-weight:600;color:var(--text-primary);margin:0}.tax-breakdown{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.tax-item{display:flex;flex-direction:column;gap:4px;padding:14px;background:#ef444414;border:1px solid rgba(239,68,68,.15);border-radius:10px;text-align:center}.tax-item.highlight{background:#ef44441f;border-color:#ef44444d}.tax-period{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.3px;color:var(--gray-500)}.tax-amount{font-size:18px;font-weight:700;color:#ef4444}.tax-item.highlight .tax-amount{font-size:22px}.what-could-be{background:linear-gradient(135deg,#10b98114,#14b8a60a);border:1px solid rgba(16,185,129,.2);border-radius:12px;padding:16px}.what-could-be h4{font-size:14px;font-weight:600;color:#059669;margin:0 0 12px}.possibilities{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:8px}.possibilities li{font-size:13px;color:var(--gray-700);padding:8px 0}.debt-inventory{background:var(--gray-50);border-radius:10px;padding:16px}.debt-inventory h4{font-size:13px;font-weight:600;color:var(--gray-600);margin:0 0 12px}.debt-row{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;background:var(--bg-primary);border-radius:8px;margin-bottom:8px}.debt-row:last-child{margin-bottom:0}.debt-info{display:flex;flex-direction:column;gap:2px}.debt-name{font-size:14px;font-weight:600;color:var(--text-primary)}.debt-apr{font-size:12px;color:var(--gray-500)}.daily-cost{font-size:14px;font-weight:700;color:#ef4444}.no-debt-congrats{text-align:center;padding:24px;background:linear-gradient(135deg,#10b98114,#14b8a60a);border:1px solid rgba(16,185,129,.2);border-radius:12px}.congrats-icon{font-size:48px;margin-bottom:12px}.no-debt-congrats h4{font-size:18px;font-weight:700;color:#059669;margin:0 0 8px}.no-debt-congrats p{font-size:14px;color:var(--gray-600);margin:0}.education-footer{margin-top:20px;padding-top:16px;border-top:1px solid var(--gray-200)}.education-footer p{font-size:13px;color:var(--gray-600);margin:0;text-align:center}@media (max-width: 768px){.credit-card-education{padding:16px}.education-header{flex-direction:column;text-align:center}.comparison-grid{grid-template-columns:1fr;gap:12px}.comparison-vs{display:none}.tax-breakdown{grid-template-columns:1fr}.calculator-input{flex-direction:column;align-items:stretch}.calculator-results{flex-direction:column}.savings-callout{flex-direction:column;text-align:center}.metric-grid{grid-template-columns:1fr}}@media (max-width: 480px){.section-header{padding:12px}.section-icon{width:36px;height:36px}.section-title{font-size:14px}.section-subtitle{font-size:11px}.payment-bar{height:32px;font-size:10px}.possibilities{grid-template-columns:1fr}}.auth-container{min-height:100vh;background:linear-gradient(135deg,var(--primary-color) 0%,#8b5cf6 100%);display:flex;align-items:center;justify-content:center;padding:20px}.auth-card{background:var(--bg-primary);border-radius:24px;padding:40px;width:100%;max-width:400px;box-shadow:0 20px 60px #0000001a}.auth-header{text-align:center;margin-bottom:32px}.auth-header h1{font-size:2.5rem;font-weight:800;color:var(--text-primary);margin-bottom:8px}.auth-header p{font-size:1.1rem;color:var(--gray-600);margin:0}.auth-header .daily-verse{font-size:.875rem;font-style:italic;color:var(--gray-600);margin:8px auto 0;max-width:500px;line-height:1.5}.auth-header .daily-verse a{color:var(--primary-color);text-decoration:none;transition:all .2s ease;display:inline-block}.auth-header .daily-verse a:hover{color:#6366f1;text-decoration:underline;text-underline-offset:2px}.auth-tabs{display:flex;background:var(--gray-100);border-radius:12px;padding:4px;margin-bottom:32px}.auth-tab{flex:1;padding:12px 20px;border:none;background:transparent;color:var(--gray-600);font-weight:600;border-radius:8px;cursor:pointer;transition:all .2s ease}.auth-tab.active{background:var(--bg-primary);color:var(--primary-color);box-shadow:0 2px 8px #0000001a}.auth-form{display:flex;flex-direction:column;gap:24px}.error-message{background:var(--danger-light);color:var(--danger-color);padding:12px 16px;border-radius:8px;font-size:14px;font-weight:500;border-left:4px solid var(--danger-color)}.success-message{background:#d1fae5;color:#065f46;padding:12px 16px;border-radius:8px;font-size:14px;font-weight:500;border-left:4px solid #10b981}.form-group label{display:block;margin-bottom:8px;font-weight:600;color:var(--gray-700)}.input-with-icon{position:relative;display:flex;align-items:center}.input-icon{position:absolute;left:16px;color:var(--gray-400);z-index:2;pointer-events:none}.input-with-icon input{padding-right:48px}.password-toggle{position:absolute;right:16px;background:none;border:none;color:var(--gray-400);cursor:pointer;padding:0;display:flex;align-items:center;justify-content:center;z-index:2}.password-toggle:hover{color:var(--gray-600);background:none;transform:none}.auth-submit-button{width:100%;padding:16px;font-size:16px;font-weight:600;margin-top:8px}.auth-submit-button:disabled{opacity:.6;cursor:not-allowed}.auth-divider{display:flex;align-items:center;text-align:center;margin:8px 0}.auth-divider:before,.auth-divider:after{content:"";flex:1;border-bottom:1px solid var(--gray-300)}.auth-divider span{padding:0 16px;color:var(--gray-500);font-size:14px;font-weight:500}.google-signin-button{width:100%;display:flex;align-items:center;justify-content:center;gap:12px;padding:14px 20px;background:#fff;border:1px solid var(--gray-300);border-radius:12px;color:var(--gray-700);font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease}.google-signin-button:hover{background:var(--gray-50);border-color:var(--gray-400);box-shadow:0 2px 8px #00000014}.google-signin-button:disabled{opacity:.6;cursor:not-allowed}.google-signin-button svg{flex-shrink:0}.auth-footer{text-align:center;margin-top:24px;padding-top:24px;border-top:1px solid var(--gray-200)}.auth-footer p{color:var(--gray-600);margin:0}.forgot-password{margin-top:12px!important;text-align:center}.link-button{background:none;border:none;color:var(--primary-color);font-weight:600;cursor:pointer;padding:0;text-decoration:underline}.link-button:hover{color:var(--primary-dark);background:none;transform:none}.legal-links{margin-top:16px;text-align:center;font-size:13px;color:var(--gray-600)}.legal-links a{color:var(--primary-color);text-decoration:underline;font-weight:600}.legal-links a:hover{color:var(--primary-dark)}.legal-links span{margin:0 8px}@media (max-width: 480px){.auth-container{padding:16px}.auth-card{padding:32px 24px}.auth-header h1{font-size:2rem}}.password-strength{margin-top:12px;padding:16px;background:var(--gray-50);border-radius:8px;border:1px solid var(--gray-200)}.strength-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.strength-label{font-size:13px;font-weight:600;color:var(--gray-700)}.strength-value{font-size:13px;font-weight:600}.strength-bar{height:4px;background:var(--gray-200);border-radius:2px;overflow:hidden;margin-bottom:12px}.strength-fill{height:100%;transition:width .3s ease,background-color .3s ease}.requirements-list{display:flex;flex-direction:column;gap:6px}.requirement{display:flex;align-items:center;gap:8px;font-size:12px}.requirement-icon{flex-shrink:0}.requirement-icon.success{color:#22c55e}.requirement-icon.error{color:#ef4444}.requirement-text{color:var(--gray-600)}.requirement.met .requirement-text{color:var(--gray-700)}.account-manager-modal{background:var(--bg-primary);border-radius:16px;box-shadow:0 20px 60px #0000004d;max-width:600px;width:90%;max-height:80vh;display:flex;flex-direction:column;overflow:hidden}.account-manager-header{display:flex;justify-content:space-between;align-items:center;padding:24px;border-bottom:1px solid #e5e7eb}.account-manager-header h2{margin:0;font-size:20px;font-weight:600;color:#111827}.close-button{background:transparent;border:none;color:#6b7280;cursor:pointer;padding:4px;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:all .2s}.close-button:hover{background:#f3f4f6;color:#111827}.account-manager-content{padding:24px;overflow-y:auto;flex:1}.no-accounts{text-align:center;padding:48px 24px;color:#6b7280}.no-accounts svg{color:#d1d5db;margin-bottom:16px}.no-accounts p{margin:8px 0}.no-accounts .hint{font-size:14px;color:#9ca3af}.account-selection-info{margin-bottom:20px;padding:12px 16px;background:#eff6ff;border:1px solid #bfdbfe;border-radius:8px;color:#1e40af;font-size:14px}.account-selection-info p{margin:0}.institution-group{margin-bottom:24px;border:1px solid #e5e7eb;border-radius:12px;overflow:hidden}.institution-header{display:flex;justify-content:space-between;align-items:center;padding:16px;background:#f9fafb;border-bottom:1px solid #e5e7eb}.institution-info{display:flex;align-items:center;gap:8px;color:#374151}.institution-name{font-weight:600;font-size:15px}.disconnect-button{display:flex;align-items:center;gap:6px;background:transparent;border:1px solid #dc2626;color:#dc2626;padding:6px 12px;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s}.disconnect-button:hover{background:#dc2626;color:var(--text-inverse)}.disconnect-button.confirm{background:#dc2626;color:var(--text-inverse);animation:pulse .5s ease-in-out}.accounts-list{background:var(--bg-primary)}.account-item{display:flex;align-items:center;gap:12px;padding:16px;border-bottom:1px solid #f3f4f6;transition:all .2s}.account-item:last-child{border-bottom:none}.account-item.selected{background:#f0fdf4;border-left:3px solid #10b981}.account-select-area{flex:1;display:flex;align-items:center;gap:12px;cursor:pointer}.account-select-checkbox{width:20px;height:20px;border:2px solid #d1d5db;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0}.account-item.selected .account-select-checkbox{background:#10b981;border-color:#10b981;color:var(--text-inverse)}.account-details{flex:1;min-width:0}.account-name-row{display:flex;align-items:center;gap:8px;margin-bottom:4px}.account-name{font-weight:500;color:#111827;font-size:15px}.account-mask{font-size:13px;color:#6b7280;font-family:monospace}.account-type{font-size:13px;color:#6b7280;text-transform:capitalize}.account-balance{font-weight:600;color:#059669;font-size:16px;margin-right:8px}.remove-account-button{background:transparent;border:1px solid #ef4444;color:#ef4444;padding:8px;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0}.remove-account-button:hover{background:#ef4444;color:var(--text-inverse)}.remove-account-button.confirm{background:#ef4444;color:var(--text-inverse);animation:pulse .5s ease-in-out}.account-manager-footer{margin-top:16px;padding-top:16px;border-top:1px solid #e5e7eb}.balance-mode-info{display:flex;align-items:center;gap:8px;padding:12px 16px;background:#f9fafb;border-radius:8px;font-size:14px;color:#374151}.success-icon{color:#10b981}@media (max-width: 768px){.account-manager-modal{width:95%;max-height:90vh}.account-manager-header,.account-manager-content{padding:20px}.institution-header{flex-direction:column;align-items:flex-start;gap:12px}.disconnect-button{width:100%;justify-content:center}.account-item{flex-wrap:wrap}.account-select-area{flex:1 1 100%}.remove-account-button{margin-left:32px}}.household-manager-modal{background:var(--bg-primary);border-radius:16px;box-shadow:0 20px 60px #0000004d;max-width:600px;width:90%;max-height:80vh;display:flex;flex-direction:column;overflow:hidden}.household-manager-header{display:flex;justify-content:space-between;align-items:center;padding:24px;border-bottom:1px solid #e5e7eb}.household-manager-header h2{margin:0;font-size:20px;font-weight:600;color:#111827;display:flex;align-items:center;gap:8px}.household-manager-content{padding:24px;overflow-y:auto;flex:1}.loading-message{text-align:center;padding:48px 24px;color:#6b7280}.error-message{display:flex;align-items:center;gap:8px;padding:12px 16px;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;color:#dc2626;font-size:14px;margin-bottom:16px}.no-household{text-align:center;padding:24px}.no-household svg{color:#d1d5db;margin-bottom:16px}.no-household h3{margin:16px 0 8px;font-size:18px;color:#111827}.no-household>p{color:#6b7280;margin-bottom:24px}.create-household-form{max-width:400px;margin:0 auto 32px;text-align:left}.create-household-form label{display:block;margin-bottom:8px;font-weight:500;color:#374151;font-size:14px}.create-household-form input{width:100%;padding:12px;border:1px solid #d1d5db;border-radius:8px;font-size:15px;margin-bottom:12px;transition:border-color .2s}.create-household-form input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.create-household-form input:disabled{background:#f3f4f6;color:#6b7280;cursor:not-allowed}.primary-button{width:100%;padding:12px 24px;background:#3b82f6;color:var(--text-inverse);border:none;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:8px}.primary-button:hover:not(:disabled){background:#2563eb}.primary-button:disabled{background:#9ca3af;cursor:not-allowed}.household-info{max-width:400px;margin:0 auto;padding:16px;background:#f9fafb;border-radius:8px;text-align:left}.household-info .info-title{font-weight:600;color:#111827;margin-bottom:12px}.household-info ul{margin:0;padding-left:20px;color:#6b7280;font-size:14px}.household-info li{margin-bottom:8px}.household-details{display:flex;flex-direction:column;gap:24px}.household-info-section{padding:16px;background:#f9fafb;border-radius:12px;border:1px solid #e5e7eb}.household-info-section h3{margin:0 0 12px;font-size:18px;color:#111827}.household-role{color:#6b7280;font-size:14px;margin:8px 0}.household-capacity{color:#6b7280;font-size:14px;margin:4px 0 0}.role-badge{display:inline-block;padding:4px 8px;border-radius:4px;font-size:12px;font-weight:600;text-transform:uppercase}.role-badge.owner{background:#dbeafe;color:#1e40af}.role-badge.member{background:#e5e7eb;color:#374151}.invite-section{padding:16px;background:#eff6ff;border:1px solid #bfdbfe;border-radius:12px}.invite-section h4{margin:0 0 12px;font-size:15px;color:#1e40af;display:flex;align-items:center;gap:8px}.invite-form{display:flex;gap:8px}.invite-form input{flex:1;padding:10px 12px;border:1px solid #bfdbfe;border-radius:8px;font-size:14px;transition:border-color .2s}.invite-form input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.invite-form input:disabled{background:#f3f4f6;color:#6b7280;cursor:not-allowed}.invite-form button{padding:10px 16px;white-space:nowrap}.permission-selector{display:flex;flex-direction:column;gap:6px;width:100%}.permission-selector label{display:flex;align-items:center;gap:4px;font-size:13px;font-weight:500;color:#1e40af}.permission-selector select{padding:10px 12px;border:1px solid #bfdbfe;border-radius:8px;font-size:14px;background:var(--bg-primary);color:#111827;cursor:pointer;transition:border-color .2s}.permission-selector select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.permission-selector select:disabled{background:#f3f4f6;color:#6b7280;cursor:not-allowed}.permission-description{font-size:12px;color:#6b7280;margin:0;font-style:italic}.capacity-warning{margin:12px 0 0;padding:8px 12px;background:#fef3c7;border:1px solid #fde68a;border-radius:6px;color:#92400e;font-size:13px}.members-section{padding:16px;background:var(--bg-primary);border:1px solid #e5e7eb;border-radius:12px}.members-section h4{margin:0 0 16px;font-size:15px;color:#111827}.members-list{display:flex;flex-direction:column;gap:12px}.member-item{display:flex;align-items:center;justify-content:space-between;padding:12px;background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;transition:all .2s}.member-item:hover{border-color:#d1d5db}.member-info{display:flex;align-items:center;gap:12px;flex:1;min-width:0}.member-email{color:#111827;font-size:14px;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.member-badges{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.permission-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 8px;border-radius:4px;font-size:11px;font-weight:600;text-transform:uppercase}.permission-badge.full-access{background:#dcfce7;color:#166534}.permission-badge.can-mark-paid{background:#fef3c7;color:#92400e}.permission-badge.view-only{background:#f3f4f6;color:#6b7280}.member-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}.edit-permission-btn{display:flex;align-items:center;gap:2px;padding:6px 10px;background:#f3f4f6;border:1px solid #d1d5db;border-radius:6px;color:#374151;cursor:pointer;transition:all .2s}.edit-permission-btn:hover{background:#e5e7eb;border-color:#9ca3af}.permission-edit{display:flex;align-items:center;gap:6px}.permission-edit select{padding:6px 10px;border:1px solid #3b82f6;border-radius:6px;font-size:13px;background:var(--bg-primary);color:#111827;cursor:pointer}.permission-edit select:focus{outline:none;box-shadow:0 0 0 3px #3b82f61a}.permission-edit select:disabled{background:#f3f4f6;cursor:not-allowed}.cancel-edit-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;background:#f3f4f6;border:1px solid #d1d5db;border-radius:6px;color:#6b7280;cursor:pointer;transition:all .2s}.cancel-edit-btn:hover:not(:disabled){background:#e5e7eb;color:#374151}.cancel-edit-btn:disabled{opacity:.5;cursor:not-allowed}.remove-button{display:flex;align-items:center;gap:6px;background:transparent;border:1px solid #ef4444;color:#ef4444;padding:6px 12px;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s;flex-shrink:0}.remove-button:hover:not(:disabled){background:#ef4444;color:var(--text-inverse)}.remove-button:disabled{opacity:.5;cursor:not-allowed}.remove-button.confirm{background:#ef4444;color:var(--text-inverse);animation:pulse .5s ease-in-out}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.household-actions{padding:16px;background:#fef2f2;border:1px solid #fecaca;border-radius:12px}.danger-button{width:100%;padding:12px 24px;background:transparent;border:2px solid #dc2626;color:#dc2626;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:8px}.danger-button:hover:not(:disabled){background:#dc2626;color:var(--text-inverse)}.danger-button:disabled{opacity:.5;cursor:not-allowed}.danger-button.confirm{background:#dc2626;color:var(--text-inverse);animation:pulse .5s ease-in-out}.confirm-warning{margin:12px 0 0;padding:12px;background:#fff7ed;border:1px solid #fed7aa;border-radius:6px;color:#9a3412;font-size:13px;text-align:center}@media (max-width: 768px){.household-manager-modal{width:95%;max-height:90vh}.household-manager-header,.household-manager-content{padding:20px}.invite-form{flex-direction:column}.invite-form button{width:100%}.member-item{flex-direction:column;align-items:flex-start;gap:12px}.member-info{width:100%;flex-direction:column;align-items:flex-start;gap:8px}.member-badges{margin-top:4px}.member-actions{width:100%;justify-content:flex-end}.remove-button{flex:1;justify-content:center}.permission-edit,.permission-edit select{flex:1}.permission-selector{margin-bottom:8px}}.page-switcher{display:flex;gap:8px;padding:12px 16px;border-bottom:1px solid var(--gray-200)}.page-switcher-button{flex:1;padding:10px 16px;font-size:14px;font-weight:500;color:var(--gray-600);background-color:transparent;border:1px solid var(--gray-300);border-radius:8px;cursor:pointer;transition:all .2s ease}.page-switcher-button:hover{background-color:var(--gray-50);border-color:var(--gray-400)}.page-switcher-button.active{color:var(--text-inverse);background-color:var(--primary-color);border-color:var(--primary-color)}.page-switcher-button.active:hover{background-color:var(--primary-color);opacity:.9}.theme-switcher{padding:12px 0}.theme-switcher-header{display:flex;align-items:center;gap:8px;padding:0 16px 12px;font-size:14px;font-weight:600;color:var(--text-secondary)}.theme-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;padding:0 16px}.theme-option{display:flex;flex-direction:column;align-items:center;gap:8px;padding:12px;background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:8px;cursor:pointer;transition:all .2s ease}.theme-option:hover{transform:translateY(-2px);border-color:var(--primary-color);background:var(--bg-primary)}.theme-option.active{border-color:var(--primary-color);background:var(--primary-light);box-shadow:0 0 0 3px #3b82f61a}.theme-preview{width:100%;height:40px;border-radius:6px;overflow:hidden;position:relative}.theme-color-strip{width:100%;height:100%}[data-theme-preview=light] .theme-color-strip{background:linear-gradient(135deg,#3b82f6,#8b5cf6)}[data-theme-preview=dark] .theme-color-strip{background:linear-gradient(135deg,#1e293b,#0f172a)}[data-theme-preview=professional] .theme-color-strip{background:linear-gradient(135deg,#1e40af,#475569)}[data-theme-preview=teal-pink] .theme-color-strip{background:linear-gradient(135deg,#14b8a6,#ec4899)}[data-theme-preview=spa] .theme-color-strip{background:linear-gradient(135deg,#a3e635,#84cc16)}[data-theme-preview=fun] .theme-color-strip{background:linear-gradient(135deg,#f59e0b,#ef4444)}[data-theme-preview=art-deco] .theme-color-strip{background:linear-gradient(135deg,#78350f,#1c1917)}.theme-label{font-size:12px;font-weight:600;color:var(--text-primary);text-align:center}.font-size-switcher{padding:12px 0}.font-size-switcher-header{display:flex;align-items:center;gap:8px;padding:0 16px 12px;font-size:var(--font-size-sm);font-weight:600;color:var(--text-secondary)}.font-size-options{display:flex;gap:8px;padding:0 16px}.font-size-option{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px;padding:12px 8px;background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:8px;cursor:pointer;transition:all .2s ease}.font-size-option:hover{transform:translateY(-2px);border-color:var(--primary-color);background:var(--bg-primary)}.font-size-option.active{border-color:var(--primary-color);background:var(--primary-light);box-shadow:0 0 0 3px #3b82f61a}.font-size-preview{font-weight:700;color:var(--text-primary);line-height:1}.font-size-preview-normal{font-size:16px}.font-size-preview-large{font-size:20px}.font-size-preview-extra-large{font-size:24px}.font-size-label{font-size:11px;font-weight:600;color:var(--text-secondary);text-align:center;white-space:nowrap}@media (max-width: 360px){.font-size-options{flex-direction:column}.font-size-option{flex-direction:row;justify-content:flex-start;gap:12px;padding:10px 12px}}.user-dropdown{position:relative}.user-dropdown-trigger{display:flex;align-items:center;gap:8px;background:#fff3;border:1px solid rgba(255,255,255,.3);color:var(--text-inverse);padding:8px 12px;border-radius:12px;cursor:pointer;transition:all .2s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.user-dropdown-trigger:hover{background:#ffffff4d;transform:none}.user-avatar{width:32px;height:32px;background:#fff3;border-radius:50%;display:flex;align-items:center;justify-content:center}.user-email{font-size:14px;font-weight:500;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chevron{transition:transform .2s ease}.chevron.open{transform:rotate(180deg)}.dropdown-menu{position:absolute;top:calc(100% + 8px);right:0;background:var(--bg-primary);border-radius:16px;box-shadow:0 10px 40px #00000026;border:1px solid var(--gray-200);min-width:280px;max-height:400px;overflow-y:auto;z-index:1000}.dropdown-section{padding:16px}.dropdown-label{font-size:12px;font-weight:600;color:var(--gray-500);text-transform:uppercase;letter-spacing:.5px;margin-bottom:12px}.month-selector{display:flex;flex-direction:column;gap:4px;max-height:200px;overflow-y:auto}.month-option{display:flex;align-items:center;gap:12px;padding:12px;background:none;border:none;border-radius:8px;color:var(--gray-700);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;text-align:left;width:100%}.month-option:hover{background:var(--gray-100);transform:none}.month-option.active{background:var(--primary-color);color:var(--text-inverse)}.dropdown-divider{height:1px;background:var(--gray-200);margin:8px 0}.user-info{display:flex;align-items:center;gap:12px}.user-avatar-large{width:48px;height:48px;background:var(--gray-100);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--gray-600)}.user-details{flex:1;min-width:0}.user-name{font-size:16px;font-weight:600;color:var(--text-primary);margin-bottom:2px}.user-email-full{font-size:14px;color:var(--gray-500);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dropdown-item{display:flex;align-items:center;gap:12px;width:100%;padding:12px 16px;background:none;border:none;color:var(--gray-700);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;text-align:left;border-radius:8px;margin:0 8px 8px}.dropdown-item:hover{background:var(--gray-100);transform:none}.logout-item{color:var(--danger-color)}.logout-item:hover{background:var(--danger-light);color:var(--danger-color)}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}@media (max-width: 480px){.user-email{display:none}.dropdown-menu{min-width:260px;right:-20px}.month-selector{max-height:160px}.modal-overlay{padding:20px}}.balance-editor{display:flex;gap:8px;align-items:center}.balance-input{flex:1;padding:8px 12px;border:1px solid #333;border-radius:8px;font-size:14px;background:var(--bg-primary);color:#333;font-weight:500}.balance-input:focus{outline:2px solid #333;border-color:#333;box-shadow:none}.balance-submit{padding:8px 12px;background:var(--primary-color);color:var(--text-inverse);border:none;border-radius:6px;font-size:12px;font-weight:500;cursor:pointer;transition:background .2s}.balance-submit:hover{background:var(--primary-dark)}.notification-toggle{display:flex;align-items:center;gap:12px;position:relative}.notification-toggle.enabled{color:var(--primary-color)}.notification-toggle:hover{background:var(--gray-100)}.notification-blocked{margin-left:auto;font-size:11px;color:var(--danger-color);font-weight:600}.notification-info{font-size:12px;color:var(--gray-500);padding:8px 0 0;line-height:1.4}.balance-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:12px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;margin-left:8px}.plaid-badge{background:#00d395;color:var(--text-inverse)}.plaid-balance-display{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px;background:var(--gray-50);border-radius:8px;margin-bottom:12px}.balance-amount{font-size:24px;font-weight:700;color:var(--text-primary)}.refresh-button{display:flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;background:var(--bg-primary);border:1px solid var(--gray-300);border-radius:8px;cursor:pointer;transition:all .2s ease;color:var(--gray-600)}.refresh-button:hover:not(:disabled){background:var(--gray-100);border-color:var(--gray-400);transform:none}.refresh-button:disabled{opacity:.5;cursor:not-allowed}.refresh-button .spinning{animation:spin 1s linear infinite}.plaid-accounts-list{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}.plaid-account-item{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;background:var(--gray-50);border-radius:6px;font-size:13px}.account-name{color:var(--gray-700);font-weight:500}.account-balance{color:var(--text-primary);font-weight:600}.plaid-connections-info{display:flex;flex-direction:column;gap:6px;margin-bottom:12px;padding:8px 0}.connection-item{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--gray-600);font-weight:500;padding:4px;border-radius:4px;transition:all .2s ease}.connection-item svg{color:var(--primary-color)}.connection-item.error{background:var(--danger-light);color:var(--danger-color)}.connection-item.error svg{color:var(--danger-color)}.connection-error{margin-left:auto;display:flex;align-items:center}.plaid-error-messages{margin-top:12px;padding:12px;background:var(--danger-light);border-radius:8px;display:flex;flex-direction:column;gap:8px}.plaid-error-item{display:flex;align-items:center;gap:8px;color:var(--danger-color);font-size:13px;font-weight:500;line-height:1.4}.plaid-error-item svg{flex-shrink:0}.connect-bank-button{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:10px 16px;background:var(--primary-color);color:var(--text-inverse);border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;margin-top:12px}.connect-bank-button:hover:not(:disabled){background:var(--primary-dark);transform:translateY(-1px);box-shadow:0 4px 12px #00000026}.connect-bank-button:disabled{opacity:.5;cursor:not-allowed}.manage-accounts-button{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:10px 16px;background:#6366f1;color:var(--text-inverse);border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;margin-top:8px}.manage-accounts-button:hover{background:#4f46e5;transform:translateY(-1px);box-shadow:0 4px 12px #6366f14d}.plaid-error{margin-top:8px;padding:8px 12px;background:var(--danger-light);color:var(--danger-color);border-radius:6px;font-size:12px;font-weight:500;line-height:1.4}.refresh-limit-message{font-size:11px;color:#ff9800;background:#fff3e0;padding:6px 10px;border-radius:6px;margin-top:-6px;margin-bottom:12px;text-align:center;font-weight:500}.household-member-count{margin-left:6px;font-size:12px;color:#6b7280;font-weight:400}.tips-toggle{display:flex;align-items:center;gap:12px;position:relative}.tips-toggle.enabled{color:var(--primary-color)}.tips-toggle span{flex:1}.toggle-switch{width:40px;height:22px;background:var(--gray-300);border-radius:11px;position:relative;transition:all .2s ease;flex-shrink:0}.toggle-switch.on{background:var(--primary-color)}.toggle-thumb{position:absolute;top:2px;left:2px;width:18px;height:18px;background:#fff;border-radius:50%;transition:all .2s ease;box-shadow:0 1px 3px #0003}.toggle-switch.on .toggle-thumb{left:20px}.reset-tips-button{color:var(--primary-color)}.reset-tips-button:hover{background:var(--primary-light)}[data-theme=dark] .toggle-switch{background:var(--gray-600)}[data-theme=dark] .toggle-switch.on{background:var(--primary-color)}.gdpr-compliance{background:var(--bg-primary);border-radius:16px;padding:24px;max-width:600px;width:90vw;max-height:80vh;overflow-y:auto;box-shadow:0 20px 40px #0003}.gdpr-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid var(--gray-200)}.gdpr-header h3{font-size:20px;font-weight:700;color:var(--text-primary);margin:0}.gdpr-section{display:flex;flex-direction:column;gap:24px}.gdpr-option{display:flex;gap:16px;padding:20px;border:1px solid var(--gray-200);border-radius:12px;background:var(--gray-50)}.option-icon{flex-shrink:0;width:40px;height:40px;background:var(--bg-primary);border-radius:8px;display:flex;align-items:center;justify-content:center;color:var(--primary-color)}.option-content{flex:1}.option-content h4{font-size:16px;font-weight:600;color:var(--text-primary);margin:0 0 8px}.option-content p{color:var(--gray-600);font-size:14px;line-height:1.5;margin:0 0 16px}.gdpr-button{padding:10px 20px;border-radius:8px;font-weight:600;font-size:14px;cursor:pointer;transition:all .2s ease;border:2px solid}.gdpr-button.primary{background:var(--primary-color);color:var(--text-inverse);border-color:var(--primary-color)}.gdpr-button.primary:hover:not(:disabled){background:var(--primary-dark);border-color:var(--primary-dark)}.gdpr-button.danger{background:#ef4444;color:var(--text-inverse);border-color:#ef4444}.gdpr-button.danger:hover:not(:disabled){background:#dc2626;border-color:#dc2626}.gdpr-button.secondary{background:var(--bg-primary);color:var(--gray-700);border-color:var(--gray-300)}.gdpr-button.secondary:hover:not(:disabled){background:var(--gray-50);border-color:var(--gray-400)}.gdpr-button:disabled{opacity:.6;cursor:not-allowed}.delete-confirmation{margin-top:16px;padding:16px;background:#fef2f2;border:1px solid #fecaca;border-radius:8px}.warning-message{display:flex;align-items:center;gap:8px;color:#dc2626;font-weight:600;font-size:14px;margin-bottom:16px}.form-group{margin-bottom:16px}.form-group label{display:block;font-weight:600;color:var(--gray-700);margin-bottom:6px;font-size:14px}.form-group input,.form-group select{width:100%;padding:8px 12px;border:1px solid var(--gray-300);border-radius:6px;font-size:14px}.confirmation-actions{display:flex;gap:12px;justify-content:flex-end}.gdpr-footer{margin-top:24px;padding-top:16px;border-top:1px solid var(--gray-200);text-align:center}.gdpr-footer p{color:var(--gray-600);font-size:12px;margin:4px 0}.household-invitation-banner{background:linear-gradient(135deg,#dbeafe,#bfdbfe);border-bottom:2px solid #3b82f6;padding:16px 20px;position:relative;z-index:100}.household-invitation-content{max-width:1200px;margin:0 auto;display:flex;align-items:center;gap:16px}.household-invitation-icon{color:#3b82f6;display:flex;align-items:center;justify-content:center;flex-shrink:0}.household-invitation-text{flex:1;color:#1e3a8a;display:flex;flex-direction:column;gap:4px}.household-invitation-text strong{color:#1e3a8a;font-weight:700;font-size:15px}.household-invitation-text span{font-size:14px;color:#1e40af}.household-invitation-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}.accept-button{display:flex;align-items:center;gap:6px;background:#3b82f6;color:var(--text-inverse);border:none;padding:8px 16px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.accept-button:hover:not(:disabled){background:#2563eb;transform:translateY(-1px)}.accept-button:disabled{opacity:.6;cursor:not-allowed}.dismiss-button{background:transparent;border:none;color:#1e40af;padding:4px;cursor:pointer;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.dismiss-button:hover:not(:disabled){background:#1e3a8a1a;color:#1e3a8a}.dismiss-button:disabled{opacity:.6;cursor:not-allowed}.household-invitation-error{max-width:1200px;margin:8px auto 0;padding:12px 16px;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;color:#dc2626;font-size:14px}@media (max-width: 768px){.household-invitation-banner{padding:12px 16px}.household-invitation-content{flex-direction:column;align-items:flex-start;gap:12px}.household-invitation-actions{width:100%;justify-content:space-between}.accept-button{flex:1}}.add-income-button{width:min(var(--floating-card-max-width, 800px),calc(100% - (var(--floating-card-side-gap, 20px) * 2)));max-width:var(--floating-card-max-width, 800px);margin:20px auto;padding:16px;background:var(--bg-primary);color:var(--primary-color);border:2px dashed var(--primary-color);border-radius:16px;display:block;font-size:16px;font-weight:600;transition:all .2s ease;cursor:pointer;text-align:center;z-index:900;box-shadow:0 2px 8px #0000001a}.add-income-button:hover{background:var(--primary-color);color:var(--text-inverse);border-color:var(--primary-color)}.add-income-form{width:min(var(--floating-card-max-width, 800px),calc(100% - (var(--floating-card-side-gap, 20px) * 2)));max-width:var(--floating-card-max-width, 800px);margin:20px auto;background:var(--bg-primary);padding:24px;border-bottom:1px solid var(--gray-200);border-radius:0;box-shadow:0 4px 6px #0000001a}.add-income-form .form-group select{width:100%;padding:12px;font-size:16px;border:1px solid var(--gray-300);border-radius:8px;background:var(--bg-primary);color:var(--text-primary);cursor:pointer;transition:all .2s ease}.add-income-form .form-group select:hover{border-color:var(--primary-color)}.add-income-form .form-group select:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px rgba(var(--primary-rgb),.1)}.field-help{display:block;margin-top:6px;font-size:13px;color:var(--gray-600);font-style:italic}@media (max-width: 768px){.add-income-button{width:calc(100% - 40px);max-width:calc(100% - 40px);margin:20px}.add-income-form{width:100%;max-width:100%;margin:0;padding:20px}}.income-item{background:var(--bg-primary);border-radius:12px;padding:20px;box-shadow:0 2px 4px #0000001a;transition:all .2s ease;border-left:4px solid var(--success-color)}.income-item.inactive{opacity:.6;border-left-color:var(--gray-400)}.income-item:hover{box-shadow:0 4px 8px #00000026}.income-item.editing{border-left-color:var(--primary-color)}.income-main{display:flex;justify-content:space-between;align-items:flex-start;gap:16px}.income-info{flex:1;min-width:0}.income-label{font-size:18px;font-weight:600;color:var(--text-primary);margin:0 0 8px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}.plaid-badge{display:inline-flex;align-items:center;padding:2px 8px;background:var(--primary-color);color:var(--text-inverse);font-size:11px;font-weight:600;border-radius:4px;text-transform:uppercase;letter-spacing:.5px}.income-details{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:4px}.income-amount{font-size:20px;font-weight:700;color:var(--success-color)}.income-frequency{font-size:14px;color:var(--gray-600);background:var(--gray-100);padding:4px 10px;border-radius:12px;font-weight:500}.income-notes{font-size:13px;color:var(--gray-600);margin:8px 0 0;font-style:italic}.income-actions{display:flex;gap:8px;flex-shrink:0}.action-button{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;transition:all .2s ease;cursor:pointer;background:var(--gray-100);color:var(--gray-600)}.action-button:hover{background:var(--gray-200);color:var(--text-primary)}.edit-button:hover{background:var(--primary-color);color:var(--text-inverse)}.delete-button:hover{background:var(--danger-color);color:var(--text-inverse)}.income-edit-form{width:100%}.edit-field{margin-bottom:16px}.edit-field label{display:block;margin-bottom:6px;font-size:13px;font-weight:600;color:var(--gray-700)}.edit-field input{width:100%;padding:10px 12px;font-size:15px;border:1px solid var(--gray-300);border-radius:8px;background:var(--bg-primary);color:var(--text-primary)}.edit-field input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px rgba(var(--primary-rgb),.1)}.edit-actions{display:flex;gap:8px;margin-top:16px}.edit-actions button{flex:1;padding:10px 16px;border-radius:8px;font-size:14px;font-weight:600;display:flex;align-items:center;justify-content:center;gap:6px;transition:all .2s ease;cursor:pointer}.save-button{background:var(--success-color);color:#fff}.save-button:hover{background:var(--success-dark, #16a34a)}.cancel-button{background:var(--gray-200);color:var(--gray-700)}.cancel-button:hover{background:var(--gray-300);color:var(--text-primary)}@media (max-width: 768px){.income-main{flex-direction:column;gap:12px}.income-actions{align-self:flex-end;width:100%;justify-content:flex-end}.edit-actions{flex-direction:column}}.income-list{width:min(var(--floating-card-max-width, 800px),calc(100% - (var(--floating-card-side-gap, 20px) * 2)));max-width:var(--floating-card-max-width, 800px);margin:0 auto 20px;display:flex;flex-direction:column;gap:12px}.empty-state{width:min(var(--floating-card-max-width, 800px),calc(100% - (var(--floating-card-side-gap, 20px) * 2)));max-width:var(--floating-card-max-width, 800px);margin:40px auto;text-align:center;padding:60px 20px;background:var(--bg-primary);border-radius:16px;box-shadow:0 2px 8px #0000001a}.empty-icon{display:flex;justify-content:center;margin-bottom:20px;color:var(--gray-400)}.empty-state h3{font-size:20px;font-weight:600;color:var(--text-primary);margin-bottom:8px}.empty-state p{font-size:14px;color:var(--gray-600)}@media (max-width: 768px){.income-list{width:calc(100% - 40px);max-width:calc(100% - 40px);margin:0 20px 20px}.empty-state{width:calc(100% - 40px);max-width:calc(100% - 40px);margin:20px}}.info-icon-container{position:relative;display:inline-flex;align-items:center}.info-icon-button{width:24px;height:24px;border-radius:50%;border:none;background:transparent;color:var(--gray-400);cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;transition:all .2s ease}.info-icon-button:hover,.info-icon-button.active{color:var(--primary-color);background:var(--primary-light)}.info-tooltip-overlay{position:fixed;inset:0;background:#0006;z-index:10000;animation:infoOverlayFadeIn .2s ease-out}@keyframes infoOverlayFadeIn{0%{opacity:0}to{opacity:1}}.info-tooltip{background:var(--bg-primary);border-radius:12px;padding:16px;min-width:240px;max-width:300px;box-shadow:0 8px 32px #00000026;border:1px solid var(--border-color);z-index:10001;animation:infoTooltipSlideIn .2s ease-out}.info-tooltip.desktop{position:absolute;transform:translate(-50%)}@keyframes infoTooltipSlideIn{0%{opacity:0;transform:translate(-50%) translateY(-4px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.info-tooltip.mobile{position:fixed;inset:auto 20px 20px;transform:none;min-width:auto;max-width:none;animation:infoTooltipSlideUpMobile .25s ease-out}@keyframes infoTooltipSlideUpMobile{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.info-tooltip-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.info-tooltip-title{font-family:Outfit,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:15px;font-weight:600;color:var(--text-primary);margin:0}.info-tooltip-close{width:28px;height:28px;border-radius:50%;border:none;background:transparent;color:var(--gray-400);cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;transition:all .2s ease;flex-shrink:0;margin:-4px -4px -4px 0}.info-tooltip-close:hover{background:var(--gray-100);color:var(--gray-600)}.info-tooltip-message{font-size:14px;line-height:1.5;color:var(--gray-600);margin:0}[data-theme=dark] .info-tooltip{box-shadow:0 8px 32px #0006}[data-theme=dark] .info-tooltip-close:hover{background:var(--gray-800);color:var(--gray-300)}[data-theme=dark] .info-tooltip-message{color:var(--gray-400)}@media (max-width: 768px){.info-icon-button{width:32px;height:32px}.info-tooltip-close{width:36px;height:36px}.info-tooltip-title{font-size:16px}.info-tooltip-message{font-size:15px}}.income-summary{padding:20px;margin-bottom:8px}.summary-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}@media (max-width: 768px){.summary-grid{grid-template-columns:1fr}}.summary-card{background:var(--bg-primary);border-radius:16px;padding:20px;display:flex;align-items:center;gap:16px;box-shadow:0 2px 8px #0000000d;transition:transform .2s ease,box-shadow .2s ease;position:relative;cursor:default}.summary-card:hover{transform:translateY(-1px);box-shadow:0 4px 16px #0000001a;z-index:100}.card-help-icon{position:absolute;top:8px;right:8px;z-index:5}.card-help-icon .info-icon-button{color:var(--gray-400);opacity:.6;transition:opacity .2s ease,color .2s ease}.summary-card:hover .card-help-icon .info-icon-button{opacity:1}.card-help-icon .info-icon-button:hover,.card-help-icon .info-icon-button.active{color:var(--primary-color);opacity:1}.summary-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.summary-card.current-balance .summary-icon{background:linear-gradient(135deg,var(--primary-color),var(--primary-dark));color:var(--text-inverse)}.summary-card.forecasted-balance .summary-icon{background:linear-gradient(135deg,var(--success-color),var(--primary-color));color:var(--text-inverse)}.summary-card.next-paycheck .summary-icon{background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));color:var(--text-inverse)}.summary-card.next-paycheck.editable:not(.editing){cursor:pointer}.summary-value-row{display:flex;align-items:center;gap:8px}.paycheck-edit-btn{padding:4px;border:none;background:transparent;color:var(--gray-400);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:color .2s ease,transform .2s ease,background .2s ease;border-radius:4px;opacity:0}.summary-card:hover .paycheck-edit-btn{opacity:1}.paycheck-edit-btn:hover{color:var(--primary-color);background:#6366f11a;transform:scale(1.1)}.paycheck-edit-btn:active{transform:scale(.95)}.edit-paycheck-btn{background:#6366f1;border:none;border-radius:6px;padding:6px 10px;cursor:pointer;color:#fff;display:flex;align-items:center;justify-content:center;gap:4px;font-size:12px;font-weight:600;transition:background .2s ease,transform .2s ease;position:relative;z-index:10;margin-top:8px}.edit-paycheck-btn:hover{background:#4f46e5;transform:scale(1.02)}.paycheck-edit-form{display:flex;flex-direction:column;gap:8px}.edit-input-row{display:flex;align-items:center;background:var(--gray-50);border:2px solid var(--primary-color);border-radius:8px;padding:4px 8px}.currency-prefix{font-size:16px;font-weight:600;color:var(--gray-500);margin-right:2px}.edit-input-row input{border:none;background:transparent;font-size:18px;font-weight:700;color:var(--text-primary);width:100%;outline:none}.edit-input-row input::-webkit-outer-spin-button,.edit-input-row input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.edit-input-row input[type=number]{-moz-appearance:textfield}.edit-actions{display:flex;gap:6px}.edit-btn{flex:1;border:none;border-radius:6px;padding:6px 10px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-weight:500;transition:background .2s ease,opacity .2s ease}.edit-btn:disabled{opacity:.5;cursor:not-allowed}.edit-btn.save{background:var(--success-color);color:#fff}.edit-btn.save:hover:not(:disabled){background:#059669}.edit-btn.cancel{background:var(--gray-200);color:var(--gray-600)}.edit-btn.cancel:hover:not(:disabled){background:var(--gray-300)}.use-previous-btn{display:flex;align-items:center;justify-content:center;gap:6px;background:#6366f11a;border:1px dashed var(--primary-color);border-radius:6px;padding:6px 10px;color:var(--primary-color);font-size:12px;font-weight:500;cursor:pointer;transition:background .2s ease}.use-previous-btn:hover:not(:disabled){background:#6366f133}.use-previous-btn:disabled{opacity:.5;cursor:not-allowed}.amount-modified{font-size:10px;color:var(--primary-color);font-weight:500}.summary-card.next-paycheck.editing{background:var(--bg-primary);box-shadow:0 4px 16px #6366f133;border:2px solid var(--primary-color)}.summary-card.safe-to-spend .summary-icon{background:linear-gradient(135deg,var(--success-color),#059669);color:var(--text-inverse)}.summary-card.safe-to-spend.healthy .summary-value{color:var(--success-color)}.summary-card.safe-to-spend.caution .summary-icon{background:linear-gradient(135deg,var(--warning-color),#c2410c)}.summary-card.safe-to-spend.caution .summary-value{color:var(--warning-color)}.summary-card.safe-to-spend.danger .summary-icon{background:linear-gradient(135deg,var(--danger-color),#dc2626)}.summary-card.safe-to-spend.danger .summary-value{color:var(--danger-color)}.summary-card.bill-alerts .summary-icon{background:linear-gradient(135deg,var(--warning-color),#c2410c);color:var(--text-inverse)}.summary-card.bill-alerts.healthy .summary-icon{background:linear-gradient(135deg,var(--success-color),#059669);color:var(--text-inverse)}.summary-card.bill-alerts.healthy .summary-value{color:var(--success-color)}.summary-card.bill-alerts.caution .summary-value{color:var(--warning-color)}.summary-card.bill-alerts.warning .summary-icon{background:linear-gradient(135deg,var(--warning-color),var(--danger-color))}.summary-card.bill-alerts.warning .summary-value{color:var(--danger-color)}.summary-card.bill-alerts.danger .summary-icon{background:linear-gradient(135deg,var(--danger-color),#dc2626)}.summary-card.bill-alerts.danger .summary-value{color:var(--danger-color)}.summary-card.paycheck-bills .summary-icon{background:linear-gradient(135deg,var(--primary-color),#7c3aed);color:var(--text-inverse)}.summary-card.paycheck-bills.warning .summary-icon{background:linear-gradient(135deg,var(--danger-color),#dc2626)}.summary-card.paycheck-bills.warning .summary-value{color:var(--danger-color)}.summary-content{flex:1;min-width:0}.summary-value{font-size:24px;font-weight:700;color:var(--text-primary);margin-bottom:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.summary-label{font-size:14px;font-weight:600;color:var(--gray-600);margin-bottom:2px}.summary-date{font-size:12px;font-weight:500;color:var(--gray-500)}.summary-sublabel{font-size:12px;font-weight:500;color:var(--gray-500);margin-top:2px}.card-tooltip{position:absolute;top:calc(100% + 8px);left:0;right:0;background:var(--bg-primary);border-radius:12px;padding:16px;box-shadow:0 8px 24px #00000026;border:1px solid var(--gray-200);opacity:0;visibility:hidden;transform:translateY(-4px);transition:opacity .2s ease,transform .2s ease,visibility .2s ease;z-index:1000;cursor:default}.summary-card:hover .card-tooltip{opacity:1;visibility:visible;transform:translateY(0)}.tooltip-header{font-size:12px;font-weight:600;color:var(--gray-500);text-transform:uppercase;letter-spacing:.5px;margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid var(--gray-200)}.tooltip-row{display:flex;justify-content:space-between;align-items:center;padding:4px 0;font-size:13px}.tooltip-label{display:flex;align-items:center;gap:6px;color:var(--gray-700)}.tooltip-row.subtraction .tooltip-label{color:var(--gray-500)}.tooltip-row.subtraction .tooltip-label svg{color:var(--danger-color)}.tooltip-row:not(.subtraction):not(.result):not(.overdue):not(.today) .tooltip-label svg{color:var(--success-color)}.tooltip-row.overdue .tooltip-label{color:var(--danger-color)}.tooltip-row.overdue .tooltip-label svg{color:var(--danger-color)}.tooltip-row.today .tooltip-label{color:var(--warning-color)}.tooltip-row.today .tooltip-label svg{color:var(--warning-color)}.tooltip-amount{font-weight:600;color:var(--text-primary);display:flex;align-items:center;gap:8px}.tooltip-row.subtraction .tooltip-amount{color:var(--danger-color)}.tooltip-days{font-size:11px;font-weight:500;color:var(--gray-500);background:var(--gray-100);padding:2px 6px;border-radius:4px}.tooltip-row.overdue .tooltip-days{background:#ef44441a;color:var(--danger-color)}.tooltip-row.today .tooltip-days{background:#ea580c1a;color:var(--warning-color)}.tooltip-more{font-size:12px;color:var(--gray-500);text-align:center;padding:4px 0;font-style:italic}.tooltip-row.result{border-top:1px dashed var(--gray-300);margin-top:8px;padding-top:8px}.tooltip-row.result .tooltip-label{font-weight:600;color:var(--text-primary)}.tooltip-row.result .tooltip-amount{font-weight:700}.tooltip-row.result.negative .tooltip-amount{color:var(--danger-color)}.summary-card.safe-to-spend.healthy .tooltip-row.result .tooltip-amount{color:var(--success-color)}.summary-card.safe-to-spend.caution .tooltip-row.result .tooltip-amount{color:var(--warning-color)}.summary-card.safe-to-spend.danger .tooltip-row.result .tooltip-amount{color:var(--danger-color)}.tooltip-divider{height:1px;background:var(--gray-200);margin:8px 0}.tooltip-section-label{font-size:10px;font-weight:600;color:var(--gray-500);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}.edited-badge{font-size:9px;font-weight:500;color:var(--primary-color);background:#6366f11a;padding:1px 4px;border-radius:3px;margin-left:4px}.summary-card.forecasted-balance.warning .summary-icon{background:linear-gradient(135deg,var(--warning-color),#c2410c)}.summary-card.forecasted-balance.warning .summary-value{color:var(--warning-color)}.summary-card.forecasted-balance.danger .summary-icon{background:linear-gradient(135deg,var(--danger-color),#dc2626)}.summary-card.forecasted-balance.danger .summary-value{color:var(--danger-color)}@media (max-width: 480px){.income-summary{padding:16px}.summary-grid{gap:12px}.summary-card{padding:16px;gap:12px}.summary-icon{width:40px;height:40px}.summary-icon svg{width:20px;height:20px}.summary-value{font-size:20px}.summary-label{font-size:12px}.summary-date{font-size:11px}.card-tooltip{padding:12px}}.net-worth-card{background:var(--bg-primary);border-radius:16px;padding:24px;box-shadow:0 2px 8px #0000000d}.net-worth-card .card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.net-worth-card h3{font-size:18px;font-weight:600;color:var(--text-primary);margin:0}.net-worth-card .info-icon-button{color:var(--gray-400);transition:color .2s ease}.net-worth-card .info-icon-button:hover,.net-worth-card .info-icon-button.active{color:var(--primary-color)}.net-worth-summary{display:flex;align-items:center;gap:16px;padding:20px;border-radius:12px;margin-bottom:20px}.net-worth-summary.positive{background:linear-gradient(135deg,#10b9811a,#0596690d);border:1px solid rgba(16,185,129,.2)}.net-worth-summary.negative{background:linear-gradient(135deg,#ef44441a,#dc26260d);border:1px solid rgba(239,68,68,.2)}.net-worth-summary.neutral{background:var(--gray-50);border:1px solid var(--gray-200)}.net-worth-icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:12px}.net-worth-summary.positive .net-worth-icon{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.net-worth-summary.negative .net-worth-icon{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff}.net-worth-summary.neutral .net-worth-icon{background:var(--gray-200);color:var(--gray-600)}.net-worth-value{display:flex;flex-direction:column;gap:4px}.net-worth-label{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--gray-600)}.net-worth-amount{font-size:28px;font-weight:700}.net-worth-summary.positive .net-worth-amount{color:var(--success-color)}.net-worth-summary.negative .net-worth-amount{color:var(--danger-color)}.net-worth-summary.neutral .net-worth-amount{color:var(--gray-700)}.net-worth-breakdown{display:flex;flex-direction:column;gap:16px}.breakdown-section{padding:16px;border-radius:12px;background:var(--gray-50)}.breakdown-header{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:600;color:var(--gray-700);margin-bottom:12px}.breakdown-total{margin-left:auto;font-size:16px;font-weight:700}.breakdown-total.positive{color:var(--success-color)}.breakdown-total.negative{color:var(--danger-color)}.breakdown-items{display:flex;flex-direction:column;gap:8px}.breakdown-item{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;background:var(--bg-primary);border-radius:8px}.breakdown-item .item-label{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--gray-700)}.breakdown-item .item-value{font-size:14px;font-weight:600;color:var(--text-primary)}.breakdown-item .item-value.negative{color:var(--danger-color)}.debt-category-dot{width:8px;height:8px;border-radius:50%;background:var(--danger-color)}.breakdown-item.more-items{background:transparent;padding:4px 12px}.breakdown-item.more-items .item-label{font-size:13px;color:var(--gray-500);font-style:italic}.net-worth-visual{margin-top:20px}.visual-bar{display:flex;height:12px;border-radius:6px;overflow:hidden;background:var(--gray-100)}.visual-bar-fill{height:100%;transition:width .3s ease}.visual-bar-fill.assets-fill{background:linear-gradient(90deg,#10b981,#059669)}.visual-bar-fill.debt-fill{background:linear-gradient(90deg,#ef4444,#dc2626)}.visual-legend{display:flex;justify-content:center;gap:24px;margin-top:12px}.legend-item{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--gray-600)}.legend-dot{width:10px;height:10px;border-radius:50%}.legend-dot.assets{background:#10b981}.legend-dot.liabilities{background:#ef4444}@media (max-width: 768px){.net-worth-card,.net-worth-summary{padding:16px}.net-worth-icon{width:40px;height:40px}.net-worth-amount{font-size:24px}.breakdown-section{padding:12px}}.payday-countdown{background:var(--bg-primary);border-radius:16px;padding:24px;box-shadow:0 2px 8px #0000000d;border:2px solid var(--gray-200)}.payday-countdown.payday{border-color:var(--success-color);background:linear-gradient(135deg,#10b9810d,#05966905)}.payday-countdown.soon{border-color:var(--accent-primary);background:linear-gradient(135deg,#6366f10d,#8b5cf605)}.payday-countdown.upcoming{border-color:var(--primary-color);background:linear-gradient(135deg,#6366f10d,#4f46e505)}.countdown-header{display:flex;align-items:center;gap:12px;margin-bottom:20px}.countdown-help{margin-left:auto}.countdown-help .info-icon-button{color:var(--gray-400);transition:color .2s ease}.countdown-help .info-icon-button:hover,.countdown-help .info-icon-button.active{color:var(--primary-color)}.countdown-icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:12px;background:linear-gradient(135deg,var(--primary-color),var(--primary-dark));color:#fff}.payday-countdown.payday .countdown-icon{background:linear-gradient(135deg,#10b981,#059669)}.payday-countdown.soon .countdown-icon{background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary))}.countdown-info{display:flex;flex-direction:column;gap:2px}.countdown-label{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--gray-500)}.countdown-source{font-size:16px;font-weight:600;color:var(--text-primary)}.countdown-main{text-align:center;padding:24px 0;margin-bottom:20px;background:var(--gray-50);border-radius:12px}.countdown-days{display:flex;align-items:baseline;justify-content:center;gap:8px;margin-bottom:8px}.days-number{font-size:56px;font-weight:800;line-height:1;background:linear-gradient(135deg,var(--primary-color),var(--primary-dark));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.payday-countdown.payday .days-number,.payday-countdown.payday .days-today{background:linear-gradient(135deg,#10b981,#059669);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.payday-countdown.soon .days-number{background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.days-today{font-size:42px;font-weight:800;line-height:1}.days-label{font-size:20px;font-weight:600;color:var(--gray-500)}.countdown-message{font-size:14px;color:var(--gray-600)}.countdown-details{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:20px}.detail-item{display:flex;align-items:center;gap:10px;padding:12px;background:var(--gray-50);border-radius:10px}.detail-icon{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:8px;background:var(--bg-primary);color:var(--gray-500)}.detail-item.budget .detail-icon{background:#10b9811a;color:var(--success-color)}.detail-content{display:flex;flex-direction:column;gap:2px;min-width:0}.detail-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.3px;color:var(--gray-500)}.detail-value{font-size:14px;font-weight:700;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.detail-value.warning{color:var(--warning-color)}.countdown-progress{margin-top:8px}.progress-bar{height:8px;background:var(--gray-100);border-radius:4px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,var(--primary-color),var(--primary-dark));border-radius:4px;transition:width .3s ease}.payday-countdown.payday .progress-fill{background:linear-gradient(90deg,#10b981,#059669)}.payday-countdown.soon .progress-fill{background:linear-gradient(90deg,var(--accent-primary),var(--accent-secondary))}.progress-labels{display:flex;justify-content:space-between;margin-top:6px}.progress-labels span{font-size:11px;color:var(--gray-500)}@media (max-width: 768px){.payday-countdown{padding:16px}.countdown-icon{width:40px;height:40px}.days-number{font-size:42px}.days-today{font-size:32px}.countdown-details{grid-template-columns:1fr}.detail-item{padding:10px}}@media (max-width: 480px){.countdown-header{flex-direction:column;text-align:center}.countdown-info{align-items:center}}.activity-feed{background:var(--bg-primary);border-radius:16px;padding:20px;box-shadow:0 2px 8px #0000000d}.activity-feed-header{display:flex;align-items:center;gap:10px;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--gray-100)}.activity-feed-header h3{font-size:16px;font-weight:600;color:var(--text-primary);margin:0}.activity-feed-header svg{color:var(--primary-color)}.activity-feed-loading,.activity-feed-error{text-align:center;padding:24px 16px;color:var(--gray-500);font-size:14px}.activity-feed-error{color:var(--danger-color)}.activity-feed-empty{text-align:center;padding:32px 16px}.activity-feed-empty p{font-size:15px;font-weight:500;color:var(--gray-600);margin:0 0 4px}.activity-feed-empty span{font-size:13px;color:var(--gray-500)}.activity-list{display:flex;flex-direction:column;gap:2px}.activity-item{display:flex;align-items:flex-start;gap:12px;padding:10px 8px;border-radius:8px;transition:background-color .15s ease}.activity-item:hover{background:var(--gray-50)}.activity-icon{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:var(--gray-100);border-radius:50%}.activity-icon .icon-success{color:var(--success-color)}.activity-icon .icon-warning{color:#f59e0b}.activity-icon .icon-danger{color:var(--danger-color)}.activity-icon .icon-info{color:var(--primary-color)}.activity-content{flex:1;min-width:0}.activity-text{font-size:14px;color:var(--gray-700);margin:0 0 2px;line-height:1.4}.activity-user{font-weight:600;color:var(--text-primary)}.activity-time{font-size:12px;color:var(--gray-500)}@media (max-width: 768px){.activity-feed{padding:16px}.activity-item{padding:8px 4px}.activity-icon{width:28px;height:28px}.activity-icon svg{width:14px;height:14px}.activity-text{font-size:13px}}.cash-flow-card.enhanced{background:var(--bg-primary);border-radius:16px;padding:24px;box-shadow:0 2px 8px #0000000d}.card-header-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.cash-flow-card.enhanced h3{font-size:18px;font-weight:600;color:var(--text-primary);margin:0;display:flex;align-items:center;gap:8px}.cash-flow-card.enhanced h3 svg{color:var(--primary-color)}.month-label{font-size:13px;font-weight:500;color:var(--gray-500);background:var(--gray-100);padding:4px 10px;border-radius:12px}.header-right{display:flex;align-items:center;gap:12px}.header-right .info-icon-button{color:var(--gray-400);transition:color .2s ease}.header-right .info-icon-button:hover,.header-right .info-icon-button.active{color:var(--primary-color)}.month-progress{margin-bottom:20px}.progress-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.progress-label{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:500;color:var(--gray-600)}.progress-days{font-size:12px;font-weight:600;color:var(--primary-color)}.progress-bar{height:8px;background:var(--gray-100);border-radius:4px;position:relative;overflow:visible}.progress-fill{height:100%;background:linear-gradient(90deg,var(--primary-color),var(--primary-dark, #4f46e5));border-radius:4px;transition:width .3s ease}.progress-marker{position:absolute;top:-3px;width:14px;height:14px;background:var(--primary-color);border:2px solid white;border-radius:50%;box-shadow:0 2px 4px #0003;transform:translate(-50%)}.balance-waterfall{display:flex;align-items:center;gap:12px;padding:16px;background:var(--gray-50);border-radius:12px;margin-bottom:20px}.waterfall-item{display:flex;align-items:center;gap:10px;padding:12px 16px;background:var(--bg-primary);border-radius:10px;box-shadow:0 1px 3px #00000014}.waterfall-item.start,.waterfall-item.end{flex-shrink:0}.waterfall-item.healthy .waterfall-icon{color:var(--success-color)}.waterfall-item.caution .waterfall-icon{color:#d97706}.waterfall-item.danger .waterfall-icon{color:var(--danger-color)}.waterfall-item.healthy .waterfall-amount{color:var(--success-color)}.waterfall-item.caution .waterfall-amount{color:#d97706}.waterfall-item.danger .waterfall-amount{color:var(--danger-color)}.waterfall-icon{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:var(--gray-100);border-radius:8px;color:var(--gray-600)}.waterfall-content{display:flex;flex-direction:column}.waterfall-label{font-size:11px;font-weight:600;color:var(--gray-500);text-transform:uppercase;letter-spacing:.3px}.waterfall-amount{font-size:18px;font-weight:700;color:var(--text-primary)}.waterfall-flow{flex:1;display:flex;flex-direction:column;gap:4px;min-width:0}.waterfall-flow .flow-item{display:flex;align-items:center;gap:6px;font-size:12px}.waterfall-flow .flow-item.income{color:var(--success-color)}.waterfall-flow .flow-item.expense{color:var(--danger-color)}.flow-sign{font-size:14px;font-weight:700}.flow-value{font-weight:600}.flow-desc{color:var(--gray-500);font-weight:400}.waterfall-arrow{color:var(--gray-400);flex-shrink:0}.stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-bottom:20px}.stat-column{background:var(--gray-50);border-radius:12px;padding:16px}.column-header{display:flex;align-items:center;gap:8px;margin-bottom:12px;padding-bottom:10px;border-bottom:1px solid var(--gray-200)}.column-header svg{color:var(--gray-500)}.column-header span:first-of-type{font-size:14px;font-weight:600;color:var(--text-primary)}.column-total{margin-left:auto;font-size:14px;font-weight:700;color:var(--text-primary)}.stat-row{display:flex;align-items:center;gap:8px;padding:6px 0}.stat-indicator{width:22px;height:22px;display:flex;align-items:center;justify-content:center;border-radius:50%}.stat-indicator.received,.stat-indicator.paid{background:#10b98126;color:var(--success-color)}.stat-indicator.upcoming,.stat-indicator.unpaid{background:#6366f126;color:var(--primary-color)}.stat-indicator.overdue{background:#ef444426;color:var(--danger-color)}.stat-label.danger,.stat-value.danger{color:var(--danger-color)}.stat-label{flex:1;font-size:13px;color:var(--gray-600)}.stat-value{font-size:13px;font-weight:600;color:var(--text-primary)}.next-item{display:flex;justify-content:space-between;margin-top:8px;padding:8px 10px;border-radius:8px;font-size:12px;color:var(--primary-color);font-weight:500}.daily-metrics{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px;margin-bottom:20px}.metric-card{background:var(--gray-50);border-radius:12px;padding:14px;text-align:center}.metric-header{display:flex;align-items:center;justify-content:center;gap:6px;margin-bottom:8px;font-size:12px;font-weight:600;color:var(--gray-600)}.metric-header svg{color:var(--gray-500)}.metric-value{font-size:22px;font-weight:700;color:var(--text-primary);display:flex;align-items:baseline;justify-content:center;gap:2px}.metric-value.danger{color:var(--danger-color)}.metric-value.caution,.metric-value.warning{color:#d97706}.metric-unit{font-size:12px;font-weight:500;color:var(--gray-500)}.metric-context{font-size:11px;color:var(--gray-500);margin-top:4px}.flow-result{padding:16px;border-radius:12px;border:2px solid var(--gray-200)}.flow-result.positive{background:#10b98114;border-color:var(--success-color)}.flow-result.negative{background:#ef444414;border-color:var(--danger-color)}.flow-result.neutral{background:var(--gray-50);border-color:var(--gray-300)}.result-header{display:flex;justify-content:space-between;align-items:center}.result-label{display:flex;align-items:center;gap:8px;font-size:16px;font-weight:600}.flow-result.positive .result-label{color:var(--success-color)}.flow-result.negative .result-label{color:var(--danger-color)}.flow-result.neutral .result-label{color:var(--gray-700)}.result-amount{font-size:22px;font-weight:700}.flow-result.positive .result-amount{color:var(--success-color)}.flow-result.negative .result-amount{color:var(--danger-color)}.flow-result.neutral .result-amount{color:var(--gray-700)}.result-hint{margin-top:8px;font-size:12px;color:var(--gray-600)}.result-hint.warning{color:var(--danger-color)}@media (max-width: 768px){.cash-flow-card.enhanced{padding:16px}.balance-waterfall{flex-direction:column;gap:8px}.waterfall-item{width:100%;justify-content:flex-start}.waterfall-flow{width:100%;flex-direction:row;justify-content:space-around;padding:8px 0}.waterfall-arrow{transform:rotate(90deg)}.stats-grid,.daily-metrics{grid-template-columns:1fr}.metric-value{font-size:20px}}@media (max-width: 480px){.card-header-row{flex-direction:column;align-items:flex-start;gap:8px}.waterfall-amount{font-size:16px}.result-label{font-size:14px}.result-amount{font-size:18px}}.surplus-recommendations{background:var(--bg-primary);border-radius:16px;padding:24px;grid-column:1 / -1;box-shadow:0 2px 8px #00000014}.financial-health-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;padding-bottom:20px;border-bottom:2px solid var(--gray-200)}.health-score{display:flex;flex-direction:column;gap:6px}.health-stars{display:flex;gap:4px;font-size:20px}.health-star{color:var(--gray-300);transition:color .2s ease}.health-star.filled{color:var(--warning-color)}.health-label{font-size:13px;font-weight:600;color:var(--gray-600);text-transform:uppercase;letter-spacing:.5px}.surplus-amount{display:flex;flex-direction:column;align-items:flex-end;gap:4px}.surplus-label{font-size:13px;font-weight:600;color:var(--gray-600);text-transform:uppercase;letter-spacing:.5px}.surplus-value{font-size:24px;font-weight:700;color:var(--primary-color);font-family:Outfit,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.priority-section{margin-bottom:32px}.priority-header{display:flex;align-items:center;gap:12px;margin-bottom:12px;color:var(--primary-color)}.priority-header h3{font-family:Outfit,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:20px;font-weight:600;margin:0;color:var(--text-primary)}.priority-reasoning{font-size:15px;color:var(--gray-700);margin:0 0 24px;line-height:1.5}.allocation-card{background:var(--gray-50);border-radius:12px;padding:20px;margin-bottom:16px;border-left:4px solid var(--primary-color)}.allocation-card.emergency{border-left-color:var(--primary-color)}.allocation-card.debt{border-left-color:var(--danger-color)}.allocation-card.wealth{border-left-color:var(--success-color)}.allocation-header{display:flex;align-items:center;gap:12px;margin-bottom:16px}.allocation-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;background:var(--primary-light);color:var(--primary-color);flex-shrink:0}.allocation-card.emergency .allocation-icon{background:var(--primary-light);color:var(--primary-color)}.allocation-card.debt .allocation-icon{background:var(--danger-light);color:var(--danger-color)}.allocation-card.wealth .allocation-icon{background:var(--success-light);color:var(--success-color)}.allocation-info{flex:1}.allocation-info h4{font-family:Outfit,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:16px;font-weight:600;margin:0 0 4px;color:var(--text-primary)}.allocation-amount{font-size:14px;font-weight:600;color:var(--primary-color);margin:0}.allocation-split{font-size:13px;color:var(--gray-600);margin:0}.debt-balance-badge{font-size:14px;font-weight:700;color:var(--gray-700);padding:4px 12px;background:var(--gray-200);border-radius:12px}.allocation-reasoning{font-size:13px;color:var(--gray-600);margin-bottom:12px;font-style:italic}.allocation-progress{margin-bottom:12px}.progress-bar{height:12px;background:var(--gray-200);border-radius:6px;overflow:hidden;margin-bottom:8px}.progress-fill{height:100%;background:linear-gradient(90deg,var(--primary-color),var(--success-color));border-radius:6px;transition:width .3s ease}.progress-labels{display:flex;justify-content:space-between;align-items:center;font-size:12px}.progress-current{font-weight:700;color:var(--text-primary);display:flex;align-items:center;gap:6px}.progress-goal{color:var(--gray-600)}.emergency-fund-edit{display:flex;align-items:center;gap:6px}.currency-symbol{font-weight:700;color:var(--text-primary)}.emergency-fund-input{width:100px;padding:6px 8px;border:2px solid var(--primary-color);border-radius:6px;font-size:14px;font-weight:700;color:var(--text-primary);background:var(--bg-primary);font-family:Outfit,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.emergency-fund-input:focus{outline:none;border-color:var(--primary-dark, #4338ca)}.emergency-fund-input:disabled{opacity:.6;cursor:not-allowed}.edit-icon-button{background:none;border:none;color:var(--gray-600);cursor:pointer;padding:4px;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.edit-icon-button:hover{color:var(--primary-color);background:var(--gray-100)}.edit-action-button{border:none;padding:6px;border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;font-weight:600}.edit-action-button.save{background:var(--success-color);color:#fff}.edit-action-button.save:hover{background:var(--success-dark, #059669)}.edit-action-button.cancel{background:var(--gray-300);color:var(--gray-700)}.edit-action-button.cancel:hover{background:var(--gray-400)}.edit-action-button:disabled{opacity:.6;cursor:not-allowed}.allocation-impact{display:flex;align-items:center;gap:8px;padding:12px;background:var(--bg-primary);border-radius:8px;font-size:14px;color:var(--gray-700)}.allocation-impact svg{color:var(--success-color);flex-shrink:0}.allocation-impact.wealth{background:var(--success-light);color:var(--success-color)}.allocation-impact.wealth svg{color:var(--success-color)}.allocation-impacts{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}.impact-item{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--gray-700)}.impact-item svg{color:var(--success-color);flex-shrink:0}.impact-item.payoff-time{background:var(--primary-light);padding:8px 12px;border-radius:8px;font-weight:600;color:var(--primary-color)}.impact-item.payoff-time svg{color:var(--primary-color)}.action-button{display:flex;align-items:center;gap:8px;padding:12px 20px;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;width:100%;justify-content:center;font-family:Outfit,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;margin-top:12px}.action-button.primary{background:var(--primary-color);color:#fff}.action-button.primary:hover:not(:disabled){background:var(--primary-dark, #4338ca);transform:translateY(-1px)}.action-button.delete{background:var(--danger-light);color:var(--danger-color);border:2px solid var(--danger-color)}.action-button.delete:hover:not(:disabled){background:var(--danger-color);color:#fff}.action-button:disabled{opacity:.6;cursor:not-allowed}.debt-action-buttons{display:flex;gap:12px;margin-top:16px}.debt-action-buttons .action-button{flex:1;margin-top:0}.debt-action-buttons .calculator-button{flex:1;background:var(--gray-200);color:var(--gray-700)}.debt-action-buttons .calculator-button:hover{background:var(--gray-300)}.calculator-button{display:flex;align-items:center;gap:6px;padding:10px 16px;background:var(--primary-color);color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;width:100%;justify-content:center;font-family:Outfit,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.calculator-button:hover{background:var(--primary-dark, #4338ca);transform:translateY(-1px)}.payment-comparison{background:var(--bg-primary);border-radius:8px;padding:12px;margin-bottom:12px}.payment-row{display:flex;justify-content:space-between;align-items:center;padding:6px 0}.payment-row:first-child{border-bottom:1px solid var(--gray-200);padding-bottom:8px;margin-bottom:4px}.payment-label{font-size:13px;color:var(--gray-600)}.payment-value{font-size:14px;font-weight:600;color:var(--text-primary)}.payment-row.recommended .payment-label{color:var(--success-color);font-weight:600}.payment-row.recommended .payment-value{color:var(--success-color);font-weight:700}.payment-row.total{border-top:1px dashed var(--gray-300);padding-top:8px;margin-top:4px}.payment-row.total .payment-label{color:var(--primary-color);font-weight:600}.payment-row.total .payment-value{color:var(--primary-color);font-weight:700}.existing-bill-info{display:flex;align-items:center;gap:8px;padding:12px;background:var(--success-light);border-radius:8px;font-size:13px;color:var(--success-color);margin-top:12px}.existing-bill-info svg{flex-shrink:0}.allocation-card.celebration{background:linear-gradient(135deg,var(--success-light) 0%,var(--primary-light) 100%);border-left-color:var(--success-color)}.allocation-card.celebration .allocation-icon.celebration{background:var(--success-color);color:#fff}.allocation-card.celebration .allocation-amount.success{color:var(--success-color)}.celebration-message{font-size:14px;color:var(--gray-700);line-height:1.5;margin:0 0 16px}.financial-journey{position:relative;display:flex;justify-content:space-between;align-items:flex-start;padding:24px 0 0;margin-top:32px;border-top:2px solid var(--gray-200)}.journey-step-line{position:absolute;top:50px;left:10%;right:10%;height:2px;background:var(--gray-200);z-index:0}.journey-step{display:flex;flex-direction:column;align-items:center;gap:8px;flex:1;position:relative;z-index:1;background:none;border:none;cursor:pointer;padding:8px 4px;border-radius:12px;transition:all .2s ease}.journey-step:hover{background:var(--gray-50)}.journey-step:hover .step-info-icon{opacity:1}.step-info-icon{opacity:.4;color:var(--gray-500);transition:opacity .2s ease}.step-circle{width:40px;height:40px;border-radius:50%;background:var(--gray-200);color:var(--gray-600);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;transition:all .3s ease;border:3px solid var(--bg-primary)}.journey-step.completed .step-circle{background:var(--success-color);color:#fff}.journey-step.current .step-circle{background:var(--primary-color);color:#fff;box-shadow:0 0 0 4px var(--primary-light);animation:pulse 2s ease-in-out infinite}.journey-step.next .step-circle{background:var(--gray-300);color:var(--gray-700)}@keyframes pulse{0%,to{box-shadow:0 0 0 4px var(--primary-light)}50%{box-shadow:0 0 0 8px var(--primary-light)}}.step-label{font-size:11px;font-weight:600;color:var(--gray-600);text-align:center;max-width:80px;line-height:1.2}.journey-step.completed .step-label{color:var(--success-color)}.journey-step.current .step-label{color:var(--primary-color)}.journey-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.journey-modal{background:var(--bg-primary);border-radius:20px;max-width:500px;width:100%;max-height:90vh;overflow-y:auto;padding:28px;position:relative;box-shadow:0 20px 60px #0000004d;animation:slideUp .3s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.journey-modal-close{position:absolute;top:16px;right:16px;background:var(--gray-100);border:none;border-radius:50%;width:36px;height:36px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--gray-600);transition:all .2s ease}.journey-modal-close:hover{background:var(--gray-200);color:var(--text-primary)}.journey-modal-header{display:flex;align-items:flex-start;gap:16px;margin-bottom:20px}.journey-modal-icon{width:56px;height:56px;border-radius:14px;display:flex;align-items:center;justify-content:center;background:var(--gray-100);color:var(--gray-600);flex-shrink:0}.journey-modal-icon.completed{background:var(--success-light);color:var(--success-color)}.journey-modal-title{flex:1}.journey-modal-step{font-size:12px;font-weight:700;color:var(--gray-500);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px;display:block}.journey-modal-title h3{font-family:Outfit,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:22px;font-weight:700;color:var(--text-primary);margin:0 0 8px}.journey-modal-status{display:inline-flex;align-items:center;gap:4px;font-size:12px;font-weight:600;padding:4px 10px;border-radius:12px}.journey-modal-status.completed{background:var(--success-light);color:var(--success-color)}.journey-modal-status.current{background:var(--primary-light);color:var(--primary-color)}.journey-modal-description{font-size:15px;color:var(--gray-700);line-height:1.6;margin:0 0 24px}.journey-modal-recommendations{background:var(--gray-50);border-radius:12px;padding:20px;margin-bottom:20px}.journey-modal-recommendations h4{font-family:Outfit,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:14px;font-weight:700;color:var(--text-primary);margin:0 0 16px;text-transform:uppercase;letter-spacing:.5px}.journey-modal-recommendations ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:12px}.journey-modal-recommendations li{display:flex;align-items:flex-start;gap:10px;font-size:14px;color:var(--gray-700);line-height:1.5}.journey-modal-recommendations li svg{color:var(--primary-color);flex-shrink:0;margin-top:2px}.journey-modal-tip{display:flex;align-items:flex-start;gap:12px;padding:16px;background:linear-gradient(135deg,var(--primary-light) 0%,var(--success-light) 100%);border-radius:12px;border-left:4px solid var(--primary-color)}.journey-modal-tip svg{color:var(--primary-color);flex-shrink:0;margin-top:2px}.journey-modal-tip p{font-size:14px;font-weight:500;color:var(--gray-800);line-height:1.5;margin:0;font-style:italic}@media (max-width: 768px){.surplus-recommendations{padding:16px}.financial-health-header{flex-direction:column;gap:16px;align-items:flex-start}.surplus-amount{align-items:flex-start}.priority-header h3{font-size:18px}.allocation-card{padding:16px}.allocation-header{flex-wrap:wrap}.debt-balance-badge{flex-basis:100%;text-align:center}.financial-journey{overflow-x:auto;padding-bottom:16px}.journey-step{min-width:60px}.step-circle{width:32px;height:32px;font-size:12px}.step-label{font-size:10px;max-width:60px}.step-info-icon{display:none}.journey-modal{padding:20px;margin:10px;max-height:85vh}.journey-modal-header{flex-direction:column;align-items:center;text-align:center}.journey-modal-title h3{font-size:18px}.journey-modal-recommendations{padding:16px}}@media (max-width: 480px){.surplus-value{font-size:20px}.allocation-icon{width:32px;height:32px}.allocation-info h4{font-size:14px}.calculator-button{font-size:13px;padding:8px 12px}}.budget-vs-actual-card{background:var(--bg-primary);border-radius:16px;padding:20px;box-shadow:0 2px 8px #0000000d}.card-header{display:flex;align-items:center;gap:10px;margin-bottom:16px;color:var(--gray-600)}.card-header h3{font-size:16px;font-weight:600;color:var(--text-primary);margin:0;flex:1}.header-help{margin-left:auto}.header-help .info-icon-button{color:var(--gray-400);transition:color .2s ease}.header-help .info-icon-button:hover,.header-help .info-icon-button.active{color:var(--primary-color)}.empty-state{text-align:center;padding:20px;color:var(--gray-500);font-size:14px}.budget-summary{display:flex;justify-content:space-between;align-items:center;padding:16px;background:var(--gray-50);border-radius:12px;margin-bottom:0;transition:all .2s ease}.budget-summary.clickable{cursor:pointer}.budget-summary.clickable:hover{background:var(--gray-100)}.summary-expand{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:6px;color:var(--gray-400);transition:all .3s ease;flex-shrink:0}.summary-expand.expanded{transform:rotate(180deg);color:var(--primary-color)}.budget-summary.clickable:hover .summary-expand{background:var(--gray-200)}.categories-container{max-height:0;overflow:hidden;opacity:0;transition:max-height .4s ease,opacity .3s ease,margin .3s ease;margin-top:0}.categories-container.expanded{max-height:1500px;opacity:1;margin-top:16px}.summary-item{display:flex;flex-direction:column;gap:4px}.summary-label{font-size:12px;font-weight:600;color:var(--gray-600);text-transform:uppercase;letter-spacing:.5px}.summary-value{font-size:16px;font-weight:700;color:var(--text-primary);display:flex;align-items:center;gap:4px}.summary-value.positive{color:var(--success-color)}.summary-value.negative{color:var(--danger-color)}.summary-item.variance{text-align:right}.category-wrapper{border-radius:12px;transition:all .3s ease;overflow:hidden}.category-wrapper.expanded{background:var(--gray-50);box-shadow:0 2px 12px #0000000f}.category-row{display:flex;align-items:center;gap:12px;padding:12px;border-radius:12px;transition:all .2s ease}.category-row.clickable{cursor:pointer}.category-row.clickable:hover{background:var(--gray-100)}.category-wrapper.expanded .category-row{background:transparent}.category-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0;box-shadow:0 2px 8px #00000026}.category-main{flex:1;min-width:0;display:flex;flex-direction:column;gap:6px}.category-header{display:flex;align-items:center;justify-content:space-between;gap:8px}.category-name{font-size:14px;font-weight:600;color:var(--text-primary)}.bill-count{font-size:11px;font-weight:500;color:var(--gray-500);background:var(--gray-200);padding:2px 8px;border-radius:10px}.bill-count.all-paid{background:#10b98126;color:#059669}.category-bar{height:6px;background:var(--gray-200);border-radius:3px;overflow:hidden}.bar-fill{height:100%;border-radius:3px;transition:width .5s ease}.category-footer{display:flex;justify-content:space-between;align-items:center}.category-amounts{font-size:12px;color:var(--gray-500)}.category-percent{font-size:11px;font-weight:600;display:flex;align-items:center;gap:3px}.category-percent.under{color:var(--success-color)}.category-percent.near{color:#d97706}.category-percent.over{color:var(--danger-color)}.expand-toggle{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:8px;color:var(--gray-400);transition:all .3s ease;flex-shrink:0}.expand-toggle.expanded{transform:rotate(180deg);color:var(--primary-color);background:#6366f11a}.category-row.clickable:hover .expand-toggle{background:var(--gray-200)}.category-wrapper.expanded .category-row.clickable:hover .expand-toggle.expanded{background:#6366f11a}.category-bills-container{max-height:0;overflow:hidden;transition:max-height .4s ease,opacity .3s ease;opacity:0}.category-bills-container.expanded{max-height:600px;opacity:1}.category-bills{padding:0 12px 12px;display:flex;flex-direction:column;gap:8px}.bills-header{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--gray-500);padding:8px 0 4px;border-bottom:1px dashed var(--gray-300);margin-bottom:4px}.bill-card{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px;background:var(--bg-primary);border-radius:10px;border:1px solid var(--gray-200);transition:all .2s ease}.bill-card:hover{border-color:var(--gray-300);box-shadow:0 2px 8px #0000000f;transform:translateY(-1px)}.bill-card.paid{background:linear-gradient(135deg,#10b9810d,#14b8a60d);border-color:#10b98133}.bill-card.overdue{background:linear-gradient(135deg,#ef44440d,#f973160d);border-color:#ef444433}.bill-card-main{display:flex;align-items:center;gap:10px;flex:1;min-width:0}.bill-card-icon{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.bill-card-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px}.bill-card-name{font-size:13px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.bill-card-meta{display:flex;gap:6px;flex-wrap:wrap}.bill-tag{display:inline-flex;align-items:center;gap:4px;font-size:10px;font-weight:500;padding:2px 6px;border-radius:4px;background:var(--gray-100);color:var(--gray-600)}.bill-tag.recurring{background:#6366f11a;color:#6366f1}.bill-tag.due{background:#3b82f61a;color:#3b82f6}.bill-tag.due.today{background:#f59e0b26;color:#d97706}.bill-tag.due.overdue{background:#ef44441a;color:#ef4444}.bill-card-right{display:flex;flex-direction:column;align-items:flex-end;gap:4px;flex-shrink:0}.bill-card-amount{font-size:14px;font-weight:700;color:var(--text-primary)}.bill-status-badge{display:inline-flex;align-items:center;gap:4px;font-size:10px;font-weight:600;padding:3px 8px;border-radius:12px}.bill-status-badge.paid{background:linear-gradient(135deg,#10b98126,#14b8a626);color:#059669}.bill-status-badge.pending{background:var(--gray-100);color:var(--gray-600)}.bill-status-badge.overdue{background:linear-gradient(135deg,#ef444426,#f9731626);color:#dc2626}@media (max-width: 768px){.budget-vs-actual-card{padding:16px}.budget-summary{flex-direction:column;gap:12px}.summary-item.variance{text-align:left;padding-top:12px;border-top:1px solid var(--gray-200)}.category-row{padding:10px}.category-icon{width:36px;height:36px}.bill-card{flex-direction:column;align-items:flex-start;gap:10px}.bill-card-right{flex-direction:row;justify-content:space-between;width:100%;align-items:center}}@media (max-width: 480px){.summary-value{font-size:14px}.category-icon{width:32px;height:32px}.category-name{font-size:13px}.category-bar{height:5px}.bill-card{padding:10px}.bill-card-icon{width:32px;height:32px}.bill-card-name{font-size:12px}.bill-card-amount{font-size:13px}}.spending-summary-card{background:var(--bg-primary);border-radius:16px;padding:24px;box-shadow:0 2px 8px #0000000d}.spending-summary-card .card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.spending-summary-card .card-header h3{display:flex;align-items:center;gap:10px;font-size:18px;font-weight:600;color:var(--text-primary);margin:0;flex:1}.spending-summary-card .header-help .info-icon-button{color:var(--gray-400);transition:color .2s ease}.spending-summary-card .header-help .info-icon-button:hover,.spending-summary-card .header-help .info-icon-button.active{color:var(--primary-color)}.spending-summary-card .refresh-btn{background:none;border:none;padding:8px;border-radius:8px;cursor:pointer;color:var(--gray-500);transition:all .2s ease}.spending-summary-card .refresh-btn:hover{background:var(--gray-100);color:var(--gray-700)}.spending-summary-card .refresh-btn:disabled{opacity:.5;cursor:not-allowed}.spending-summary-card .refresh-btn .spinning{animation:spin 1s linear infinite}.spending-summary-card.loading .loading-skeleton{display:flex;flex-direction:column;gap:12px}.spending-summary-card .skeleton-bar{height:20px;background:linear-gradient(90deg,var(--gray-100) 25%,var(--gray-200) 50%,var(--gray-100) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:4px}.spending-summary-card .skeleton-bar.short{width:60%}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.spending-summary-card.error .error-state,.spending-summary-card.empty .empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:32px 16px;text-align:center;color:var(--gray-500);gap:12px}.spending-summary-card .retry-button{margin-top:8px;padding:8px 16px;background:var(--primary-color);color:#fff;border:none;border-radius:8px;font-weight:500;cursor:pointer;transition:background .2s ease}.spending-summary-card .retry-button:hover{background:var(--primary-hover)}.spending-summary-card .empty-hint{font-size:13px;color:var(--gray-400)}.spending-stats{display:flex;gap:16px;margin-bottom:16px}.spending-stats .stat-item{flex:1;padding:16px;background:var(--gray-50);border-radius:12px;display:flex;flex-direction:column;gap:4px}.spending-stats .stat-label{font-size:12px;font-weight:600;color:var(--gray-500);text-transform:uppercase;letter-spacing:.5px}.spending-stats .stat-value{font-size:24px;font-weight:700;color:var(--text-primary)}.spending-stats .stat-value.warning{color:var(--warning-color, #f59e0b)}.spending-stats .stat-value.success{color:var(--success-color, #10b981)}.spending-stats .stat-hint{font-size:12px;color:var(--gray-500)}.spending-stats .stat-item.expandable{padding:0;overflow:hidden}.spending-stats .stat-header-btn{width:100%;padding:16px;background:none;border:none;cursor:pointer;display:flex;justify-content:space-between;align-items:flex-start;text-align:left;transition:background .2s ease}.spending-stats .stat-header-btn:hover{background:var(--gray-100)}.spending-stats .stat-main{display:flex;flex-direction:column;gap:4px}.spending-stats .stat-meta{display:flex;flex-direction:column;align-items:flex-end;gap:4px;color:var(--gray-500)}.spending-stats .stat-item.tracked{border-left:3px solid var(--success-color, #10b981)}.spending-stats .stat-item.untracked{border-left:3px solid var(--warning-color, #f59e0b)}.spending-stats .stat-item.expandable.expanded{background:var(--gray-100)}.spending-stats .transaction-list{padding:0 12px 12px;display:flex;flex-direction:column;gap:6px;max-height:300px;overflow-y:auto}.spending-stats .transaction-list .transaction-row{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;background:#fff;border-radius:8px;font-size:13px}.spending-stats .transaction-list .tx-info{display:flex;flex-direction:column;gap:2px;min-width:0;flex:1}.spending-stats .transaction-list .tx-merchant{color:var(--gray-700);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:500}.spending-stats .transaction-list .tx-category{font-size:11px;color:var(--gray-500)}.spending-stats .transaction-list .tx-details{display:flex;flex-direction:column;align-items:flex-end;gap:2px;flex-shrink:0}.spending-stats .transaction-list .tx-amount{font-weight:600;color:var(--text-primary)}.spending-stats .transaction-list .tx-date{font-size:11px;color:var(--gray-500)}.rate-limit-notice{display:flex;align-items:center;gap:8px;padding:8px 12px;background:#6366f11a;border:1px solid rgba(99,102,241,.2);border-radius:8px;margin-bottom:16px;font-size:12px;color:#4f46e5}.rate-limit-notice svg{flex-shrink:0}.untracked-alert{display:flex;align-items:flex-start;gap:12px;padding:12px 0;background:transparent;border:none;margin-bottom:20px;font-size:13px;color:var(--text-primary)}.untracked-alert svg{flex-shrink:0;margin-top:0;color:var(--warning-color);width:20px;height:20px;stroke-width:2.5}.category-breakdown h4{font-size:14px;font-weight:600;color:var(--gray-600);margin:0 0 12px;text-transform:uppercase;letter-spacing:.5px}.category-list{display:flex;flex-direction:column;gap:8px}.category-row{background:var(--gray-50);border-radius:10px;overflow:hidden;transition:background .2s ease}.category-row:hover,.category-row.expanded{background:var(--gray-100)}.category-header{display:flex;justify-content:space-between;align-items:center;width:100%;padding:12px 14px;background:none;border:none;cursor:pointer;text-align:left}.category-info{display:flex;align-items:center;gap:10px}.category-icon{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:#fff;border-radius:6px;box-shadow:0 1px 3px #0000001a}.category-name{font-size:14px;font-weight:500;color:var(--text-primary)}.category-stats{display:flex;align-items:center;gap:12px}.category-amount{font-size:14px;font-weight:600;color:var(--text-primary)}.category-percentage{font-size:12px;color:var(--gray-500);min-width:32px;text-align:right}.category-bar{height:4px;background:var(--gray-200);margin:0 14px 8px;border-radius:2px;overflow:hidden}.category-bar-fill{height:100%;border-radius:2px;transition:width .3s ease}.category-transactions{padding:0 14px 12px;display:flex;flex-direction:column;gap:6px}.transaction-row{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;background:#fff;border-radius:6px;font-size:13px}.tx-merchant{color:var(--gray-700);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px}.tx-amount{font-weight:500;color:var(--text-primary)}.more-transactions,.more-categories{font-size:12px;color:var(--gray-500);text-align:center;padding:8px}@media (max-width: 768px){.spending-summary-card{padding:16px}.spending-stats{flex-direction:column;gap:12px}.spending-stats .stat-item{padding:14px}.spending-stats .stat-value{font-size:20px}.category-name{font-size:13px}.tx-merchant{max-width:150px}}.spending-stats .transaction-list .transaction-row.selectable{cursor:pointer;user-select:none;-webkit-user-select:none;transition:all .15s ease}.spending-stats .transaction-list .transaction-row.selectable:hover{background:var(--gray-100)}.spending-stats .transaction-list .transaction-row.selectable.selected{background:#6366f11a;border:1px solid rgba(99,102,241,.3)}.spending-stats .transaction-list .tx-checkbox{display:flex;align-items:center;justify-content:center;width:20px;height:20px;margin-right:10px;flex-shrink:0}.spending-stats .transaction-list .tx-checkbox .checkbox-empty{width:18px;height:18px;border:2px solid var(--gray-300);border-radius:4px;background:#fff}.spending-stats .transaction-list .tx-checkbox svg{color:var(--primary-color, #6366f1)}.selection-action-bar{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:var(--gray-800, #1f2937);border-radius:12px;margin-bottom:16px;animation:slideUp .2s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.selection-action-bar .selection-info{color:#fff;font-size:14px;font-weight:500}.selection-action-bar .selection-actions{display:flex;gap:8px}.selection-action-bar .action-btn{display:flex;align-items:center;gap:6px;padding:8px 14px;border:none;border-radius:8px;font-size:13px;font-weight:500;cursor:pointer;transition:all .15s ease}.selection-action-bar .action-btn.bill{background:var(--success-color, #10b981);color:#fff}.selection-action-bar .action-btn.bill:hover{background:#059669}.selection-action-bar .action-btn.discretionary{background:var(--warning-color, #f59e0b);color:#fff}.selection-action-bar .action-btn.discretionary:hover{background:#d97706}.selection-action-bar .action-btn.cancel{background:var(--gray-600, #4b5563);color:#fff;padding:8px}.selection-action-bar .action-btn.cancel:hover{background:var(--gray-500, #6b7280)}.selection-action-bar .action-btn:disabled{opacity:.6;cursor:not-allowed}@media (max-width: 768px){.selection-action-bar{flex-direction:column;gap:12px;padding:14px}.selection-action-bar .selection-actions{width:100%;justify-content:center}.selection-action-bar .action-btn span{display:none}.selection-action-bar .action-btn{padding:10px 14px}}.overview-dashboard{width:100%;max-width:100%;padding-bottom:40px}.overview-header{width:min(var(--floating-card-max-width, 800px),calc(100% - (var(--floating-card-side-gap, 20px) * 2)));max-width:var(--floating-card-max-width, 800px);margin:30px auto 20px;text-align:center}.overview-header h1{font-family:Outfit,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:28px;font-weight:500;letter-spacing:-.02em;color:var(--text-primary);margin:0 0 8px}.overview-header p{font-family:Outfit,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:15px;font-weight:400;letter-spacing:-.01em;color:var(--gray-600);margin:0}.overview-balance{margin-top:20px;padding:16px 24px;background:linear-gradient(135deg,var(--primary-color) 0%,var(--primary-dark, #4338ca) 100%);border-radius:12px;display:flex;flex-direction:column;align-items:center;gap:4px;box-shadow:0 4px 12px #0000001a}.balance-label{font-size:13px;font-weight:600;color:#ffffffe6;text-transform:uppercase;letter-spacing:.5px}.balance-amount{font-size:32px;font-weight:700;color:#fff}.analytics-section,.countdown-section,.net-worth-section,.activity-section,.cashflow-section,.budget-comparison-section,.spending-section,.achievements-section,.surplus-section{width:min(var(--floating-card-max-width, 800px),calc(100% - (var(--floating-card-side-gap, 20px) * 2)));max-width:var(--floating-card-max-width, 800px);margin:30px auto}.income-section{margin:30px 0}.income-section h2{font-family:Outfit,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;width:min(var(--floating-card-max-width, 800px),calc(100% - (var(--floating-card-side-gap, 20px) * 2)));max-width:var(--floating-card-max-width, 800px);margin:0 auto 16px;font-size:20px;font-weight:500;letter-spacing:-.01em;color:var(--text-primary)}.loading-state{width:min(var(--floating-card-max-width, 800px),calc(100% - (var(--floating-card-side-gap, 20px) * 2)));max-width:var(--floating-card-max-width, 800px);margin:60px auto;text-align:center;padding:40px 20px;background:var(--bg-primary);border-radius:16px;color:var(--gray-600);font-size:16px}.coming-soon{width:min(var(--floating-card-max-width, 800px),calc(100% - (var(--floating-card-side-gap, 20px) * 2)));max-width:var(--floating-card-max-width, 800px);margin:30px auto;padding:20px;background:linear-gradient(135deg,var(--primary-color) 0%,var(--primary-dark, #4338ca) 100%);color:#fff;border-radius:12px;text-align:center;box-shadow:0 4px 12px #00000026}.coming-soon p{margin:0;font-size:15px;font-weight:500}@media (max-width: 768px){.overview-header{width:calc(100% - 40px);margin:20px}.overview-header h1{font-size:24px}.countdown-section,.net-worth-section,.activity-section,.cashflow-section,.income-section h2,.analytics-section,.budget-comparison-section,.spending-section,.achievements-section,.surplus-section,.loading-state,.coming-soon{width:calc(100% - 40px);margin-left:20px;margin-right:20px}}.coach-mark-overlay{position:fixed;inset:0;background:#0009;z-index:10000;animation:coachMarkFadeIn .3s ease-out}@keyframes coachMarkFadeIn{0%{opacity:0}to{opacity:1}}.coach-mark-spotlight{position:fixed;border-radius:12px;box-shadow:0 0 0 9999px #0009;border:2px solid var(--primary-color);pointer-events:none;animation:coachMarkPulse 2s ease-in-out infinite;z-index:10001}@keyframes coachMarkPulse{0%,to{box-shadow:0 0 0 9999px #0009,0 0 20px var(--primary-color)}50%{box-shadow:0 0 0 9999px #0009,0 0 30px var(--primary-color)}}.coach-mark-tooltip{position:fixed;background:var(--bg-primary);border-radius:16px;padding:20px;max-width:320px;box-shadow:0 10px 40px #0000004d;z-index:10002;animation:coachMarkSlideUp .3s ease-out}@keyframes coachMarkSlideUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.coach-mark-tooltip.mobile{position:fixed;inset:auto 20px 20px;max-width:none;transform:none;animation:coachMarkSlideUpMobile .3s ease-out}@keyframes coachMarkSlideUpMobile{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.coach-mark-header{display:flex;align-items:center;gap:12px;margin-bottom:12px}.coach-mark-icon{width:36px;height:36px;border-radius:10px;background:var(--primary-light);color:var(--primary-color);display:flex;align-items:center;justify-content:center;flex-shrink:0}.coach-mark-header h3{font-family:Outfit,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:18px;font-weight:600;color:var(--text-primary);margin:0;flex:1}.coach-mark-close{width:32px;height:32px;border-radius:50%;background:transparent;border:none;color:var(--gray-400);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;flex-shrink:0}.coach-mark-close:hover{background:var(--gray-100);color:var(--gray-700)}.coach-mark-message{font-size:15px;line-height:1.6;color:var(--gray-700);margin:0 0 20px}.coach-mark-got-it{width:100%;padding:14px;background:var(--primary-color);color:var(--text-inverse);border:none;border-radius:10px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease}.coach-mark-got-it:hover{background:var(--primary-dark);transform:translateY(-1px)}.coach-mark-got-it:active{transform:translateY(0)}[data-theme=dark] .coach-mark-overlay{background:#000000bf}[data-theme=dark] .coach-mark-spotlight{box-shadow:0 0 0 9999px #000000bf}[data-theme=dark] .coach-mark-message{color:var(--gray-300)}[data-theme=dark] .coach-mark-close:hover{background:var(--gray-800);color:var(--gray-200)}@media (max-width: 768px){.coach-mark-close{width:44px;height:44px}.coach-mark-got-it{padding:16px;font-size:17px}}.app{min-height:100vh;display:flex;flex-direction:column}.app-header{background:linear-gradient(135deg,var(--bg-gradient-start) 0%,var(--bg-gradient-end) 100%);color:var(--header-text-color);padding:40px 20px;position:sticky;top:0;z-index:999;box-shadow:var(--shadow-md)}.app-header .user-dropdown{position:absolute;top:20px;right:20px;z-index:10}.app-header .user-dropdown-trigger{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:50%;width:40px;height:40px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s}.app-header .user-dropdown-trigger:hover{background:#fff3}.app-header .user-dropdown-trigger .user-email,.app-header .user-dropdown-trigger .chevron{display:none}.app-header .user-dropdown-trigger .user-avatar{margin:0;background:none;border-radius:0}.header-content{display:flex;flex-direction:column;align-items:center;max-width:800px;margin:0 auto;gap:16px}.balance-row{display:flex;justify-content:space-between;width:100%;align-items:center}.header-left{text-align:left;position:relative;display:flex;align-items:center}.header-center{display:flex;flex-direction:column;align-items:center;text-align:center}.header-right{text-align:right;display:flex;align-items:center;justify-content:flex-end}.header-center h1{font-family:Outfit,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:2.5rem;font-weight:500;letter-spacing:-.02em;text-shadow:0 2px 8px rgba(0,0,0,.08);margin:0 0 8px}.header-center p{font-family:Outfit,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:1.1rem;opacity:.9;margin:0 0 16px;font-weight:400;letter-spacing:-.01em}.daily-verse{font-size:.875rem;font-style:italic;opacity:.85;margin:0 0 16px;max-width:600px;line-height:1.5}.daily-verse a{color:inherit;text-decoration:none;transition:opacity .2s ease;display:inline-block}.daily-verse a:hover{opacity:1;text-decoration:underline;text-decoration-color:#ffffff80;text-underline-offset:2px}.balance-info{display:flex;flex-direction:column;gap:4px;margin-top:8px}.date-display,.account-balance,.bill-balance{font-family:Outfit,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:var(--header-text-color);font-weight:600;font-size:1.3rem;letter-spacing:-.01em;text-shadow:0 2px 8px rgba(0,0,0,.08);margin:0;padding:0}.mybills-balance-stack{display:flex;flex-direction:column;align-items:flex-end;gap:2px;font-family:Outfit,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.mybills-balance-stack .balance-row{display:flex;align-items:center;gap:8px;line-height:1.2}.mybills-balance-stack .balance-label{font-size:.7rem;font-weight:500;color:var(--header-text-color);opacity:.7;text-transform:uppercase;letter-spacing:.5px}.mybills-balance-stack .balance-amount{font-weight:600;color:var(--header-text-color);text-shadow:0 2px 8px rgba(0,0,0,.08)}.mybills-balance-stack .balance-row.total .balance-amount{font-size:1.3rem;font-weight:700}.mybills-balance-stack .balance-row.paid .balance-amount{font-size:1rem;opacity:.85}.mybills-balance-stack .balance-row.remaining .balance-amount{font-size:1.1rem;font-weight:700;border-top:1px solid rgba(255,255,255,.3);padding-top:2px}.account-balance{font-size:1.3rem}.account-balance-wrapper{display:flex;align-items:center;gap:8px}.balance-refresh-btn{background:#fff3;border:1px solid rgba(255,255,255,.3);color:var(--header-text-color);padding:6px;border-radius:8px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.balance-refresh-btn:hover:not(:disabled){background:#ffffff4d;transform:scale(1.05)}.balance-refresh-btn:disabled{opacity:.5;cursor:not-allowed}.balance-refresh-btn .spinning{animation:spin 1s linear infinite}.bill-balance{font-size:1.4rem;text-align:right}.overview-stats{display:flex;flex-direction:column;gap:8px;align-items:flex-end}.stat-item{display:flex;gap:8px;align-items:center}.stat-label{font-family:Outfit,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:var(--header-text-color);font-weight:400;font-size:.9rem;opacity:.9;letter-spacing:-.01em}.stat-value{font-family:Outfit,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:var(--header-text-color);font-weight:600;font-size:1.1rem;text-shadow:0 2px 8px rgba(0,0,0,.08);letter-spacing:-.01em}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;background:var(--gray-50);color:var(--gray-600)}.loading-spinner{width:40px;height:40px;border:4px solid var(--gray-200);border-top:4px solid var(--primary-color);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:16px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.app-main{flex:1;background:var(--gray-50);padding-bottom:40px;transition:opacity .2s ease-in-out;overflow-y:auto;height:calc(100vh - var(--header-height, 220px))}.add-fab{position:fixed;bottom:30px;right:30px;width:60px;height:60px;border-radius:50%;background:linear-gradient(135deg,var(--primary-color) 0%,#2563eb 100%);color:var(--text-inverse);border:none;box-shadow:0 4px 12px #3b82f666,0 8px 24px #3b82f633;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease;z-index:997}.add-fab:hover{transform:scale(1.1) rotate(90deg);box-shadow:0 6px 16px #3b82f680,0 12px 32px #3b82f64d}.add-fab:active{transform:scale(.95)}.app{touch-action:pan-y;user-select:none;-webkit-user-select:none}@media (max-width: 768px){.app-header{padding:20px 16px 40px}.app-header .user-dropdown{top:15px;right:15px}.add-fab{bottom:20px;right:20px;width:56px;height:56px}.header-content{display:flex;flex-direction:column;gap:16px;align-items:center;text-align:center;margin-top:15px}.header-center{order:1}.header-center h1{font-size:2rem;margin-bottom:4px}.header-center p{font-size:1rem;margin-bottom:16px}.balance-row{order:2;display:flex;justify-content:space-between;width:100%;max-width:320px}.header-left,.header-right{position:static;display:flex;align-items:center}.header-left{justify-content:flex-start}.header-right{justify-content:flex-end}.balance-info{margin:0;gap:6px}.date-display,.account-balance,.bill-balance{font-size:1.1rem;font-weight:600}}@media (max-width: 480px){.app-header{padding:15px 12px 35px}.header-center h1{font-size:1.8rem}.header-center p{font-size:.9rem}.balance-row{justify-content:space-between;width:100%;gap:16px}.header-left{justify-content:flex-start;text-align:left}.header-right{justify-content:flex-end;text-align:right}.balance-info{flex-direction:column;gap:4px;align-items:flex-start}.date-display,.account-balance,.bill-balance{font-size:1.1rem;font-weight:700}.bill-balance{text-align:right}}
