.main-content{display:inline-block;margin-left:240px;padding:24px;min-height:100vh;background-color:#f9fafb}.content-wrapper{max-width:1400px;margin:0 auto}.empty-state-container{position:fixed;top:0;left:240px;right:0;bottom:0;display:flex;align-items:center;justify-content:center;padding:40px 20px;background-color:#f9fafb}.mobile-month-header{display:none;align-items:center;justify-content:space-between;padding:16px 20px;background-color:#fff;border-bottom:1px solid #e5e7eb;position:fixed;top:60px;left:0;right:0;z-index:99;gap:16px;width:100%;margin:0}.mobile-month-title{flex:1;text-align:center;margin:0;font-size:20px;font-weight:700;color:#111827}.mobile-month-nav{padding:8px 12px;border:none;background-color:transparent;color:#111827;font-size:28px;font-weight:300;cursor:pointer;line-height:1;transition:background-color .2s;border-radius:6px}.mobile-month-nav:hover{background-color:#f3f4f6}.mobile-month-nav:disabled{color:#d1d5db;cursor:not-allowed}.mobile-month-nav:disabled:hover{background-color:transparent}.sidebar{width:240px;height:100vh;background-color:#1f2937;position:fixed;left:0;top:0;display:flex;flex-direction:column;color:#fff}.sidebar-header{padding:24px 20px;border-bottom:1px solid #374151}.sidebar-logo-container{display:flex;align-items:center;justify-content:center;gap:12px}.sidebar-logo{height:50px;width:auto}.sidebar-title{font-size:24px;font-weight:700;margin:0;color:#fff}.sidebar-nav{flex:1;padding:16px 0}.sidebar-nav-item{width:100%;padding:12px 20px;border:none;background-color:transparent;color:#d1d5db;text-align:left;cursor:pointer;display:flex;align-items:center;gap:12px;font-size:14px;font-weight:400;transition:all .2s}.sidebar-nav-item:hover{background-color:#2d3748}.sidebar-nav-item.active{background-color:#374151;color:#60a5fa;font-weight:600}.sidebar-nav-item-icon{font-size:18px}.sidebar-account-section{border-top:1px solid #374151;padding:16px}.sidebar-account-button{width:100%;padding:12px;border:1px solid #374151;border-radius:8px;background-color:#374151;color:#d1d5db;cursor:pointer;display:flex;align-items:center;gap:12px;font-size:14px}.sidebar-account-button.active{border-color:#2563eb;background-color:#1d4ed8;color:#e0f2fe}.sidebar-account-avatar{width:32px;height:32px;border-radius:50%;background-color:#4b5563;display:flex;align-items:center;justify-content:center;font-size:16px}.sidebar-account-info{flex:1;text-align:left}.sidebar-account-name{font-size:13px;font-weight:500}.sidebar-account-subtitle{font-size:11px;color:#9ca3af}.sidebar-account-menu{position:absolute;bottom:100%;left:0;right:0;margin-bottom:8px;background-color:#374151;border:1px solid #4b5563;border-radius:8px;overflow:hidden;box-shadow:0 -4px 12px #0000004d}.sidebar-account-menu-item{width:100%;padding:12px 16px;border:none;background-color:transparent;color:#d1d5db;text-align:left;cursor:pointer;font-size:14px;display:flex;align-items:center;gap:8px}.sidebar-account-menu-item:hover{background-color:#4b5563}.header{background-color:#fff;padding:20px 24px;border-radius:12px;box-shadow:0 1px 3px #0000001a;margin-bottom:24px}.header-row{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:24px}.month-year-controls{display:flex;align-items:center;gap:8px;flex:0 1 auto}.header-goal{flex:0 0 100%;order:10}.header-new-month{margin-left:auto}.month-selector{min-width:140px}.year-selector{min-width:100px}.btn{padding:8px 16px;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;border:none;transition:all .2s ease}.btn:disabled{opacity:.4;cursor:not-allowed}.btn-primary{background-color:#2563eb;color:#fff;border:none}.btn-primary:hover:not(:disabled){background-color:#1d4ed8}.btn-secondary{background-color:#fff;color:#374151;border:1px solid #d1d5db}.btn-secondary:hover:not(:disabled){background-color:#f9fafb}.btn--disabled{opacity:.5;cursor:not-allowed}.btn--min-width{min-width:120px}.btn-danger{background-color:#dc2626;color:#fff;border:none}.btn-danger:hover:not(:disabled){background-color:#b91c1c}.btn-transparent{background-color:transparent;color:#374151;border:none}.btn-transparent:hover:not(:disabled){background-color:#f9fafb}.btn-icon{padding:8px 12px;font-size:18px;line-height:1}.nav-arrow{padding:8px 12px;border:1px solid #d1d5db;border-radius:8px;background-color:#fff;cursor:pointer;font-size:18px;color:#374151}.nav-arrow:disabled{opacity:.4;cursor:not-allowed}.dropdown{position:relative}.dropdown-menu{position:absolute;top:100%;right:0;margin-top:4px;background-color:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 10px 25px #0000001a;min-width:180px;z-index:1000}.dropdown-item{width:100%;padding:12px 16px;border:none;background-color:transparent;text-align:left;cursor:pointer;font-size:14px;color:#374151;display:flex;align-items:center;gap:8px}.dropdown-item:hover{background-color:#f9fafb}.dropdown-item.danger{color:#dc2626;border-top:1px solid #e5e7eb}.dropdown-item.danger:hover{background-color:#fef2f2}.dropdown-item.active{background-color:#eff6ff;color:#2563eb;font-weight:600}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:16px;margin-bottom:24px}.stats-container{background-color:#f9fafb;border:1px solid #e5e7eb;padding:16px;border-radius:8px}.stats-container h3{margin:0 0 16px;font-size:16px;font-weight:600;color:#374151}.stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.stat-item{display:flex;flex-direction:column;align-items:center;text-align:center}.stat-label{font-size:14px;color:#374151;font-weight:500;margin-bottom:4px}.stat-value{font-size:24px;font-weight:700;color:#4b5563}.stat-value.income{color:#2563eb}.stat-value.expense{color:#dc2626}.stat-value.fee{color:#4b5563}.stat-value.net-positive{color:#16a34a}.stat-value.net-negative{color:#dc2626}.stats-header{color:#fff;padding:8px;border-radius:8px 8px 0 0;text-align:center;font-weight:700;font-size:16px;margin:-16px -16px 16px}.stats-header.expected{background-color:#ef4444}.stats-header.actual{background-color:#10b981}.goal-notes-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:16px;margin-bottom:24px}.goal-button,.notes-display{padding:16px;border-radius:8px;background-color:#fff;border:1px solid #e5e7eb;cursor:pointer;text-align:left;font-size:14px;color:#374151;transition:all .2s ease}.goal-button:hover,.notes-display:hover{background-color:#f9fafb;border-color:#d1d5db}.goal-button{font-style:italic}.goal-label,.notes-label{font-weight:600;font-style:normal;margin-right:4px}.notes-content{white-space:pre-wrap;word-wrap:break-word;max-height:120px;overflow-y:auto}.table-container{background-color:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;overflow:hidden}table{width:100%;border-collapse:collapse;font-size:14px}thead{background-color:#f9fafb;border-bottom:2px solid #e5e7eb}th{padding:12px 16px;text-align:left;font-weight:600;color:#374151;white-space:nowrap}td{padding:12px 16px;border-bottom:1px solid #e5e7eb;color:#1f2937}tr:last-child td{border-bottom:none}tbody tr:hover{background-color:#f9fafb}.checkbox-cell{width:40px;text-align:center}.actions-cell{text-align:right;white-space:nowrap}.table-button{padding:4px 8px;margin:0 2px;border:none;background-color:transparent;cursor:pointer;font-size:16px;border-radius:4px;transition:background-color .2s ease}.table-button:hover{background-color:#e5e7eb}.table-button.edit{color:#2563eb}.table-button.delete{color:#dc2626}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:3000;padding:16px}.modal-container{background-color:#fff;padding:0;border-radius:12px;width:90%;max-width:500px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 50px #0000004d}.modal-container>div:not(.modal-header),.modal-container>form{padding-left:24px;padding-right:24px}.modal-container>*:last-child{padding-bottom:24px}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;margin-left:0;margin-right:0;border-radius:12px 12px 0 0;padding-left:24px;padding-right:24px}.modal-title{font-size:20px;font-weight:600;color:#1f2937;margin:0}.modal-close{background:none;border:none;font-size:24px;cursor:pointer;color:#6b7280;padding:4px;line-height:1}.modal-close:hover{color:#374151}.modal-body{margin-bottom:20px}.modal-footer{display:flex;gap:12px;justify-content:flex-end}.modal-footer--with-checkbox{justify-content:space-between;align-items:center}.modal-footer-checkbox{font-size:14px;color:#374151}.modal-footer-checkbox .form-checkbox{margin-right:8px}.modal-footer-buttons{display:flex;gap:12px}.modal-container--wide{max-width:700px}.modal-container--medium{max-width:560px}.modal-header--padded{padding:20px 24px}.modal-header--bill{background-color:#fee2e2;border-bottom:2px solid #dc2626}.modal-header--bill .modal-title,.modal-header--bill .modal-close{color:#991b1b}.modal-header--spending{background-color:#fef3c7;border-bottom:2px solid #f59e0b}.modal-header--spending .modal-title,.modal-header--spending .modal-close{color:#92400e}.modal-header--income{background-color:#d1fae5;border-bottom:2px solid #10b981}.modal-header--income .modal-title,.modal-header--income .modal-close{color:#065f46}.modal-header--reimbursement{background-color:#f3e8ff;border-bottom:2px solid #8b5cf6}.modal-header--reimbursement .modal-title,.modal-header--reimbursement .modal-close{color:#6b21a8}.modal-header--neutral{background-color:#f3f4f6;border-bottom:2px solid #9ca3af}.modal-header--neutral .modal-title,.modal-header--neutral .modal-close{color:#374151}.modal-description{font-size:14px;font-style:italic;color:#6b7280;margin:0 0 20px}.form-row{display:grid;gap:16px;margin-bottom:16px}.form-row--three-col{grid-template-columns:1fr 1fr 1fr}.form-row--two-col{grid-template-columns:1fr 1fr}.form-row .form-group{margin:0}.form-required{color:#dc2626}.form-checkbox-label{display:flex;align-items:center;gap:8px;cursor:pointer}.form-checkbox-label .form-label{margin:0}.spending-total-box{border-radius:8px;padding:12px 16px;margin-bottom:20px;display:flex;justify-content:space-between;align-items:center}.spending-total-box--changed,.spending-total-box--unchanged{background-color:#f3f4f6;border:1px solid #d1d5db}.spending-total-label{font-size:12px;font-weight:600;color:#6b7280;text-transform:uppercase}.spending-total-value{font-size:24px;font-weight:700}.spending-total-value--changed,.spending-total-value--unchanged{color:#111827}.spending-original{text-align:right}.spending-original-label{font-size:12px;color:#6b7280}.spending-original-value{font-size:16px;color:#9ca3af;text-decoration:line-through}.spending-entry-form{display:grid;grid-template-columns:100px 1fr auto;gap:8px;margin-bottom:16px;align-items:end}.spending-entry-form .form-group{margin:0}.spending-entry-form .form-label{font-size:12px}.spending-entry-form .form-input{font-size:16px;font-weight:600}.spending-list{border:1px solid #e5e7eb;border-radius:8px;max-height:280px;overflow-y:auto}.spending-list-empty{padding:24px;text-align:center;color:#9ca3af}.spending-list-empty-title{font-size:14px;margin-bottom:4px}.spending-list-empty-subtitle{font-size:12px}.spending-list-table{width:100%;border-collapse:collapse}.spending-list-row{border-bottom:1px solid #f3f4f6}.spending-list-row:last-child{border-bottom:none}.spending-list-amount{padding:10px 12px;width:120px;min-width:120px;font-weight:600;color:#374151}.spending-list-notes{padding:10px 12px;color:#6b7280;font-size:14px}.spending-list-notes--empty{font-style:italic;color:#9ca3af}.spending-list-delete{padding:10px 12px;width:40px;text-align:right}.spending-list-delete-btn{border:none;background:none;color:#dc2626;cursor:pointer;padding:4px 8px;border-radius:4px;font-size:18px;line-height:1}.spending-list-delete-btn:hover{background-color:#fef2f2}.spending-summary{margin-top:12px;padding:8px 12px;background-color:#f9fafb;border-radius:6px;font-size:13px;color:#6b7280;display:flex;justify-content:space-between}.spending-summary-total{color:#374151;font-weight:600}.spending-calculator{background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;padding:16px;margin-bottom:16px}.spending-calculator-header{margin-bottom:12px}.spending-calculator-title{font-size:14px;font-weight:600;color:#374151;margin:0 0 4px}.spending-calculator-subtitle{font-size:13px;color:#6b7280;margin:0}.spending-manual-amount{margin-top:12px;padding-top:12px;border-top:1px dashed #e5e7eb}.spending-list-empty-hint{font-size:13px;color:#9ca3af;font-style:italic;text-align:center;padding:12px}.spending-list-clickable{cursor:pointer}.spending-list-clickable:hover{background-color:#f3f4f6}.spending-list-edit-input{padding:6px 10px;font-size:14px;width:100%;box-sizing:border-box}.spending-list-amount .spending-list-edit-input{width:100px}.spending-list-actions{padding:10px 8px;width:60px;text-align:right;white-space:nowrap}.spending-list-action-btn{border:none;background:none;cursor:pointer;padding:4px 6px;border-radius:4px;font-size:16px;line-height:1;margin-left:2px}.spending-list-action-btn--save{color:#16a34a}.spending-list-action-btn--save:hover{background-color:#dcfce7}.spending-list-action-btn--cancel{color:#6b7280}.spending-list-action-btn--cancel:hover{background-color:#f3f4f6}.form-group{margin-bottom:16px}.form-label{display:block;font-size:14px;font-weight:500;color:#374151;margin-bottom:6px}.form-input,.form-select,.form-textarea{width:100%;padding:10px 12px;border:1px solid #d1d5db;border-radius:8px;font-size:14px;color:#1f2937;transition:all .2s ease}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.form-textarea{resize:vertical;min-height:80px;font-family:inherit}.form-checkbox{width:18px;height:18px;cursor:pointer}.form-error{color:#dc2626;font-size:13px;margin-top:4px}.form-hint{color:#6b7280;font-size:13px;margin-top:4px}.form-select-filter{padding:8px 10px;border:1px solid #d1d5db;border-radius:6px;font-size:12px;background-color:#fff;min-width:140px}.fab-container{position:fixed;bottom:24px;right:24px;z-index:1500}.fab-button{width:60px;height:60px;border-radius:50%;background-color:#2563eb;color:#fff;border:none;font-size:30px;cursor:pointer;box-shadow:0 4px 12px #2563eb66;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.fab-button:hover{background-color:#1d4ed8;transform:scale(1.05)}.fab-menu{position:absolute;bottom:70px;right:0;display:flex;flex-direction:column;gap:12px;align-items:flex-end}.alert{padding:12px 16px;border-radius:8px;margin-bottom:16px;display:flex;align-items:center;gap:8px;font-size:14px}.alert-info{background-color:#eff6ff;border:1px solid #bfdbfe;color:#1e40af}.alert-warning{background-color:#fef3c7;border:1px solid #fde68a;color:#92400e}.alert-error{background-color:#fee2e2;border:1px solid #fecaca;color:#991b1b}.alert-success{background-color:#d1fae5;border:1px solid #a7f3d0;color:#065f46}.text-center{text-align:center}.text-right{text-align:right}.text-muted{color:#6b7280}.font-bold{font-weight:700}.font-semibold{font-weight:600}.italic{font-style:italic}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.mt-2{margin-top:8px}.mt-3{margin-top:12px}.mt-4{margin-top:16px}.mb-2{margin-bottom:8px}.mb-3{margin-bottom:12px}.mb-4{margin-bottom:16px}.p-2{padding:8px}.p-3{padding:12px}.p-4{padding:16px}.text-danger{color:#dc2626}.text-success{color:#10b981}.text-warning{color:#f59e0b}.text-purple{color:#8b5cf6}.text-dark{color:#111827}.text-medium{color:#374151}.bg-danger{background-color:#dc2626}.bg-success{background-color:#10b981}.bg-warning{background-color:#f59e0b}.bg-purple{background-color:#8b5cf6}.bg-danger-light{background-color:#fee2e2}.bg-success-light{background-color:#d1fae5}.bg-warning-light{background-color:#fef3c7}.bg-info-light{background-color:#dbeafe}.bg-gray-light{background-color:#f9fafb}.border-rounded{border-radius:8px}.border-rounded-lg{border-radius:12px}.border-rounded-full{border-radius:9999px}.justify-start{justify-content:flex-start}.justify-end{justify-content:flex-end}.items-start{align-items:flex-start}.font-medium{font-weight:500}.text-uppercase{text-transform:uppercase}.text-nowrap{white-space:nowrap}.w-full{width:100%}.min-w-100{min-width:100px}.min-w-140{min-width:140px}.max-h-240{max-height:240px}.max-h-320{max-height:320px}.mb-0{margin-bottom:0}.p-0{padding:0}.hidden{display:none}.fab-btn{padding:14px 24px;color:#fff;border:none;border-radius:24px;box-shadow:0 4px 12px #00000026;white-space:nowrap;transition:transform .2s,box-shadow .2s;font-size:16px;font-weight:600;cursor:pointer}.fab-btn:hover{transform:translateY(-2px);box-shadow:0 6px 16px #0003}.fab-btn--danger{background-color:#dc2626}.fab-btn--danger:hover{background-color:#b91c1c}.fab-btn--success{background-color:#10b981}.fab-btn--success:hover{background-color:#059669}.fab-btn--purple{background-color:#8b5cf6}.fab-btn--purple:hover{background-color:#7c3aed}.fab-btn--warning{background-color:#f59e0b}.fab-btn--warning:hover{background-color:#d97706}.table-header-cell{padding:12px 16px;text-align:left;font-size:12px;font-weight:500;color:#6b7280;text-transform:uppercase;cursor:default}.table-header-cell--sortable{cursor:pointer}.table-header-cell--sortable:hover{color:#374151}.table-cell-amount{padding:12px 16px;font-size:14px;font-weight:700}.table-cell-amount--positive{color:#166534}.table-cell-amount--negative{color:#991b1b}.badge{display:inline-block;padding:4px 8px;border-radius:4px;font-size:12px;font-weight:500}.badge--status-paid{background-color:#bbf7d0;color:#166534}.badge--status-unpaid{background-color:#fef08a;color:#854d0e}.badge--income{background-color:#d1fae5;color:#166534}.badge--expense{background-color:#fee2e2;color:#991b1b}.badge--tag{margin-top:4px;padding:2px 8px;background-color:#dbeafe;color:#1e40af}.yearly-container{padding:24px;max-width:1400px;margin:0 auto}.yearly-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;gap:12px;flex-wrap:wrap}.yearly-title{margin:0;font-size:26px;font-weight:800;color:#0f172a}.yearly-subtitle{margin:6px 0 0;color:#475569}.yearly-year-selector-group{display:flex;align-items:center;gap:12px}.yearly-year-label{font-weight:600;color:#0f172a}.yearly-year-select{padding:8px 12px;border-radius:8px;border:1px solid #cbd5e1;background-color:#fff;font-size:14px}.yearly-stats-section{display:flex;flex-direction:column;gap:12px;margin-bottom:20px}.yearly-stats-grid{display:grid;grid-template-columns:1fr 1fr 1fr 1fr;gap:12px}.yearly-stat-card{border-radius:12px;padding:14px;box-shadow:0 4px 10px #0f172a0f;border:1px solid #e2e8f0}.yearly-stat-card.income{background-color:#ecfdf3}.yearly-stat-card.expense{background-color:#fef2f2}.yearly-stat-card.net{padding:14px}.yearly-stat-label{font-size:13px;font-weight:700;color:#475569;margin-bottom:4px}.yearly-stat-value{font-size:24px;font-weight:800}.yearly-stat-value.income{color:#0f766e}.yearly-stat-value.expense{color:#b91c1c}.yearly-stat-value.net-positive{color:#166534}.yearly-stat-value.net-negative{color:#991b1b}.yearly-stat-value.expected-positive{color:#1d4ed8}.yearly-stat-value.expected-negative{color:#c2410c}.yearly-table-wrapper{background-color:#fff;border-radius:12px;border:1px solid #e2e8f0;box-shadow:0 10px 20px #0f172a0d;overflow-x:auto}.yearly-table-header{padding:16px 16px 8px;border-bottom:1px solid #e2e8f0}.yearly-table-title{margin:0;font-size:18px;font-weight:800;color:#0f172a}.yearly-table-description{margin:6px 0 0;color:#475569;font-size:14px}.yearly-table{width:100%;border-collapse:collapse;min-width:900px}.yearly-table thead{background-color:#f8fafc;text-transform:uppercase;font-size:12px;letter-spacing:.3px}.yearly-table th{padding:12px 14px;border-bottom:1px solid #e2e8f0;color:#475569}.yearly-table th.text-left{text-align:left}.yearly-table th.text-right{text-align:right;padding:12px 10px}.yearly-table th.quarter-q1{color:#1d4ed8;background-color:#eff6ff}.yearly-table th.quarter-q2{color:#ca8a04;background-color:#fefce8}.yearly-table th.quarter-q3{color:#15803d;background-color:#ecfdf3}.yearly-table th.quarter-q4{color:#b91c1c;background-color:#fef2f2}.yearly-table th.total-header{background-color:#111827;color:#f8fafc;padding:12px 14px}.yearly-table tbody tr{border-top:1px solid #f1f5f9;background-color:#fff}.yearly-table td{padding:12px 14px;color:#0f172a}.yearly-table td.category-cell{font-weight:600}.yearly-table td.amount-cell{padding:12px 10px;text-align:right}.yearly-table td.quarter-cell{padding:12px 10px;text-align:right;font-weight:700}.yearly-table td.quarter-q1{color:#1d4ed8}.yearly-table td.quarter-q2{color:#ca8a04}.yearly-table td.quarter-q3{color:#15803d}.yearly-table td.quarter-q4{color:#b91c1c}.yearly-table td.total-cell{padding:12px 14px;text-align:right;font-weight:800;background-color:#0f172a;color:#f8fafc}.yearly-table tfoot tr{border-top:2px solid #e2e8f0;background-color:#f8fafc}.yearly-table tfoot td{padding:12px 14px;font-weight:800;color:#0f172a}.yearly-table tfoot td.total-label{font-weight:800}.yearly-table tfoot td.amount-total{padding:12px 10px;text-align:right;font-weight:700}.yearly-table tfoot td.quarter-total{padding:12px 10px;text-align:right;font-weight:800}.yearly-table tfoot td.grand-total{padding:12px 14px;text-align:right;font-weight:900;color:#f8fafc;background-color:#0f172a}.yearly-empty-state{padding:18px;text-align:center;color:#6b7280}.settings-container{max-width:1200px;margin:0 auto}.settings-page-header{margin-bottom:32px}.settings-page-title{font-size:32px;font-weight:700;color:#111827;margin:0 0 8px}.settings-page-subtitle{color:#6b7280;margin:0}.settings-tabs-container{border-bottom:2px solid #e5e7eb;margin-bottom:32px}.settings-tabs-list{display:flex;gap:24px}.settings-tab{padding:12px 16px;border:none;background-color:transparent;border-bottom:2px solid transparent;color:#6b7280;font-weight:500;font-size:15px;cursor:pointer;margin-bottom:-2px;transition:all .2s}.settings-tab.active{border-bottom:2px solid #2563eb;color:#2563eb;font-weight:600}.settings-tab-icon{margin-right:8px}.settings-panel{background-color:#fff;border-radius:12px;padding:24px;box-shadow:0 1px 3px #0000001a}.settings-panel-title{font-size:20px;font-weight:600;color:#111827;margin-top:0;margin-bottom:16px}.settings-panel-description{color:#6b7280;margin-bottom:24px}.settings-grid{display:grid;grid-template-columns:1fr 2fr auto;gap:12px;align-items:center}.settings-category-list{display:grid;gap:12px}.settings-category-item{padding:16px;border:1px solid #e5e7eb;border-radius:8px;display:flex;justify-content:space-between;align-items:center}.settings-category-name{font-weight:500;color:#111827}.settings-category-description{font-size:14px;color:#6b7280;margin-top:4px}.settings-category-badge{padding:4px 12px;background-color:#f3f4f6;border-radius:4px;font-size:12px;color:#6b7280;font-weight:500}.settings-tag-list{display:grid;gap:8px}.settings-tag-item{padding:14px 16px;border:1px solid #e5e7eb;border-radius:8px;background-color:#f9fafb;display:flex;align-items:center;gap:16px}.settings-tag-item--editable{background-color:#fff}.settings-tag-info{flex:1;min-width:0}.settings-tag-badges{display:flex;gap:8px;align-items:center;flex-shrink:0}.settings-tag-name{font-weight:600;color:#111827;margin-bottom:2px}.settings-tag-description{color:#6b7280;font-size:13px}.settings-tag-badge{padding:4px 10px;background-color:#e5e7eb;border-radius:6px;font-size:11px;text-align:center;color:#6b7280;font-weight:500}.settings-type-badge{padding:4px 10px;border-radius:6px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.3px}.settings-type-badge--bills{background-color:#fef3c7;color:#92400e}.settings-type-badge--spending{background-color:#dbeafe;color:#1e40af}.settings-type-badge--income{background-color:#dcfce7;color:#166534}.settings-type-badge--reimbursements{background-color:#f3e8ff;color:#7c3aed}.settings-type-badge--unset{background-color:#fef2f2;color:#dc2626}.settings-add-tag-form{margin-bottom:24px;padding:16px;background-color:#f9fafb;border-radius:8px;border:1px solid #e5e7eb}.settings-add-tag-row{display:grid;grid-template-columns:1fr 1.5fr 140px auto;gap:12px;align-items:center}.settings-tags-section{margin-bottom:24px}.settings-section-title{font-size:14px;font-weight:600;color:#374151;margin:0 0 4px}.settings-section-subtitle{font-size:13px;color:#6b7280;margin:0 0 12px}.settings-tag-edit-form{display:grid;grid-template-columns:1fr 1.5fr 140px;gap:12px;flex:1}.settings-tag-input{padding:8px 12px;border:1px solid #2563eb;border-radius:6px;font-size:14px;font-weight:500}.settings-tag-input-description{padding:8px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:14px}.settings-tag-actions{display:flex;gap:8px;justify-content:flex-end}.settings-btn-save{padding:6px 12px;background-color:#2563eb;border:none;border-radius:6px;cursor:pointer;font-size:13px;font-weight:600;color:#fff}.settings-btn-cancel,.settings-btn-edit{padding:6px 12px;background-color:#f3f4f6;border:none;border-radius:6px;cursor:pointer;font-size:13px;font-weight:500;color:#374151}.settings-btn-delete{padding:6px 12px;background-color:#fef2f2;border:none;border-radius:6px;cursor:pointer;font-size:13px;font-weight:500;color:#dc2626}.settings-empty-state{text-align:center;padding:48px;color:#6b7280}.settings-data-section{display:grid;gap:24px}.settings-data-card{padding:20px;border:1px solid #e5e7eb;border-radius:8px}.settings-data-card.warning{padding:20px;border:2px solid #fecaca;border-radius:8px;background-color:#fef2f2}.settings-data-card-title{font-size:16px;font-weight:600;color:#111827;margin-top:0;margin-bottom:8px}.settings-data-card-title.danger{color:#dc2626}.settings-data-card-description{color:#6b7280;margin-bottom:16px;font-size:14px}.settings-data-card-description.danger{color:#991b1b}.settings-btn-export{padding:10px 20px;background-color:#2563eb;color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer;font-size:14px}.settings-btn-import{display:inline-block;padding:10px 20px;background-color:#f59e0b;color:#fff;border-radius:8px;font-weight:600;cursor:pointer;font-size:14px}.settings-btn-clear{padding:10px 20px;background-color:#dc2626;color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer;font-size:14px}.mobile-view-toggle{display:none;margin-bottom:12px;padding:4px;background-color:#f3f4f6;border-radius:8px;gap:4px}.mobile-view-toggle-btn{flex:1;padding:8px 16px;border:none;background-color:transparent;color:#6b7280;font-size:14px;font-weight:600;border-radius:6px;cursor:pointer;transition:all .2s}.mobile-view-toggle-btn.active{background-color:#fff;color:#111827;box-shadow:0 1px 2px #0000000d}.mobile-cards-container{display:none}.mobile-card{background-color:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:16px;margin-bottom:12px;box-shadow:0 1px 3px #0000001a;cursor:pointer;transition:box-shadow .2s}.mobile-card:hover{box-shadow:0 4px 12px #00000026}.mobile-card.paid{opacity:.7;background-color:#f3f4f6}.mobile-card-header{margin-bottom:12px}.mobile-card-title-row{display:flex;align-items:flex-start;gap:12px;margin-bottom:8px}.mobile-card-checkbox{margin-top:4px;flex-shrink:0;position:relative;z-index:10;pointer-events:auto}.mobile-card-title{flex:1;margin:0;font-size:18px;font-weight:600;color:#111827;line-height:1.3}.mobile-card-status{flex-shrink:0;padding:4px 12px;border-radius:12px;font-size:13px;font-weight:600;white-space:nowrap}.mobile-card-status.paid{background-color:#d1fae5;color:#166534}.mobile-card-status.unpaid{background-color:#fef08a;color:#854d0e}.mobile-card-status.overdue{background-color:#fee2e2;color:#991b1b}.mobile-card-subtitle{font-size:13px;color:#6b7280;margin-left:32px}.mobile-card-amount{font-size:28px;font-weight:700;color:#111827;margin-bottom:12px}.mobile-card-fee{font-size:14px;color:#dc2626;font-weight:600;margin-top:4px}.mobile-card-dates{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:16px;padding:12px;background-color:#f9fafb;border-radius:8px}.mobile-card-date-item{display:flex;flex-direction:column}.mobile-card-date-item--full{grid-column:1 / -1;text-align:center}.mobile-card-date-label{font-size:12px;color:#6b7280;font-weight:500;margin-bottom:4px}.mobile-card-date-value{font-size:14px;color:#111827;font-weight:600}.mobile-card-actions{display:flex;gap:8px;position:relative;z-index:10;pointer-events:auto}.mobile-card-btn{width:100%;padding:12px 16px;border-radius:8px;border:none;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s;min-height:44px;position:relative;z-index:10;pointer-events:auto}.mobile-card-btn-pay{background-color:#2563eb;color:#fff}.mobile-card-btn-pay:active{background-color:#1d4ed8}.mobile-card-btn-unpay{background-color:#fff;border:2px solid #dc2626;color:#dc2626}.mobile-card-btn-unpay:active{background-color:#fef2f2}.mobile-card-condensed{background-color:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:12px 16px;margin-bottom:8px;display:flex;align-items:center;justify-content:space-between;gap:12px;cursor:pointer;transition:box-shadow .2s;min-height:64px}.mobile-card-condensed:active,.mobile-card-condensed.paid{background-color:#f9fafb}.mobile-card-condensed.paid .mobile-card-condensed-title{color:#9ca3af}.mobile-card-condensed.paid .mobile-card-condensed-meta{color:#d1d5db}.mobile-card-condensed.paid .mobile-card-condensed-amount{color:#9ca3af}.mobile-card-condensed-left{display:flex;align-items:center;gap:12px;flex:1;min-width:0}.mobile-card-condensed-info{flex:1;min-width:0}.mobile-card-condensed-title{margin:0;font-size:16px;font-weight:600;color:#111827;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mobile-card-condensed-meta{margin-top:2px;font-size:13px;color:#6b7280}.mobile-card-condensed-due{font-size:13px;color:#6b7280}.mobile-card-condensed.overdue .mobile-card-condensed-due{color:#dc2626;font-weight:600}.mobile-card-condensed-right{display:flex;flex-direction:column;align-items:flex-end;gap:8px}.mobile-card-condensed-amount{font-size:20px;font-weight:700;color:#111827;white-space:nowrap}.mobile-card-condensed-actions{display:flex;align-items:center;gap:8px;position:relative;z-index:10;pointer-events:auto}.mobile-card-condensed-status{font-size:12px;font-weight:600;padding:4px 8px;border-radius:8px;white-space:nowrap}.mobile-card-condensed-status.paid{background-color:#d1fae5;color:#166534}.mobile-card-condensed-status.unpaid{background-color:#fef08a;color:#854d0e}.mobile-card-condensed-status.overdue{background-color:#fee2e2;color:#991b1b}.mobile-card-condensed-btn{padding:6px 16px;border-radius:6px;border:none;background-color:#2563eb;color:#fff;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap;position:relative;z-index:10;pointer-events:auto}.mobile-card-condensed-btn:active{background-color:#1d4ed8}.mobile-card-condensed-btn-unpay{background-color:#fff;border:2px solid #dc2626;color:#dc2626;padding:5px 16px}.mobile-card-condensed-btn-unpay:active{background-color:#fef2f2}.placeholder-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;padding:40px}.placeholder-icon{font-size:64px;margin-bottom:16px}.placeholder-title{font-size:24px;font-weight:700;color:#111827;margin-bottom:8px}.placeholder-description{font-size:16px;color:#6b7280;text-align:center;max-width:400px}.placeholder-emphasis{margin-top:12px;font-style:italic;color:#9ca3af}.placeholder-hint{margin-top:24px;font-size:14px;color:#6b7280}.meeting-guide-tab{position:fixed;right:0;top:50%;transform:translateY(-50%);background-color:#2563eb;color:#fff;padding:16px 8px;border-radius:8px 0 0 8px;cursor:pointer;writing-mode:vertical-rl;text-orientation:mixed;display:flex;align-items:center;gap:8px;font-weight:600;font-size:14px;z-index:100;box-shadow:-2px 0 8px #0000001a;transition:background-color .2s}.meeting-guide-tab:hover{background-color:#1d4ed8}.meeting-guide-tab-icon{writing-mode:horizontal-tb;font-size:16px}.meeting-guide-tab-text{writing-mode:vertical-rl}.meeting-guide-sidebar{position:fixed;right:0;top:0;bottom:0;width:360px;background-color:#fff;box-shadow:-4px 0 20px #0000001a;z-index:200;display:flex;flex-direction:column;animation:slideInRight .3s ease-out}@keyframes slideInRight{0%{transform:translate(100%)}to{transform:translate(0)}}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.05)}}@keyframes loading-bar{0%{transform:translate(-100%)}50%{transform:translate(0)}to{transform:translate(100%)}}.meeting-guide-header{padding:20px;background-color:#eff6ff;border-bottom:3px solid #2563eb;display:flex;justify-content:space-between;align-items:flex-start}.meeting-guide-header-content{flex:1}.meeting-guide-title{margin:0;font-size:20px;font-weight:700;color:#1e40af}.meeting-guide-streak{margin-top:4px;font-size:12px;color:#6b7280}.meeting-guide-header-actions{display:flex;gap:8px}.meeting-guide-collapse-btn,.meeting-guide-close-btn{padding:4px 8px;border:none;background:none;cursor:pointer;font-size:16px;color:#6b7280;border-radius:4px;transition:background-color .2s}.meeting-guide-collapse-btn:hover,.meeting-guide-close-btn:hover{background-color:#dbeafe;color:#1e40af}.meeting-guide-body{flex:1;overflow-y:auto;padding:20px}.meeting-guide-start{display:flex;flex-direction:column;gap:20px}.meeting-guide-welcome{text-align:center;padding:20px 0}.meeting-guide-welcome-icon{color:#2563eb;margin-bottom:16px}.meeting-guide-welcome-title{margin:0 0 8px;font-size:18px;font-weight:600;color:#111827}.meeting-guide-welcome-text{margin:0;font-size:14px;color:#6b7280;line-height:1.5}.meeting-guide-start-btn{width:100%;padding:14px 20px;background-color:#2563eb;color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:background-color .2s}.meeting-guide-start-btn:hover{background-color:#1d4ed8}.meeting-guide-setup-btn{width:100%;padding:12px 20px;background-color:#fff;color:#374151;border:1px solid #d1d5db;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.meeting-guide-setup-btn:hover{background-color:#f9fafb;border-color:#9ca3af}.meeting-guide-tips{padding:16px;background-color:#f9fafb;border-radius:8px;border:1px solid #e5e7eb}.meeting-guide-tips-title{margin:0 0 12px;font-size:14px;font-weight:600;color:#374151}.meeting-guide-tips-list{margin:0;padding-left:20px;font-size:13px;color:#6b7280;line-height:1.6}.meeting-guide-tips-list li{margin-bottom:6px}.meeting-guide-steps{display:flex;flex-direction:column;gap:24px}.meeting-guide-progress{display:flex;justify-content:space-between;align-items:center;padding:0 10px}.meeting-guide-progress-step{display:flex;align-items:center;flex:1}.meeting-guide-progress-step:last-child{flex:0}.meeting-guide-progress-dot{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;background-color:#e5e7eb;color:#6b7280;flex-shrink:0}.meeting-guide-progress-step.active .meeting-guide-progress-dot{background-color:#2563eb;color:#fff}.meeting-guide-progress-step.completed .meeting-guide-progress-dot{background-color:#10b981;color:#fff}.meeting-guide-progress-line{flex:1;height:2px;background-color:#e5e7eb;margin:0 8px}.meeting-guide-progress-line.completed{background-color:#10b981}.meeting-guide-current-step{padding:16px;background-color:#f9fafb;border-radius:8px}.meeting-guide-step-title{margin:0 0 8px;font-size:16px;font-weight:600;color:#111827}.meeting-guide-step-desc{margin:0 0 16px;font-size:14px;color:#6b7280}.meeting-guide-step-content{margin-top:16px}.meeting-guide-step-tip{margin:0 0 16px;padding:12px;background-color:#eff6ff;border-radius:8px;font-size:13px;color:#1e40af;line-height:1.5;border-left:3px solid #2563eb}.meeting-guide-checklist{display:flex;flex-direction:column;gap:10px}.meeting-guide-check-item{display:flex;align-items:center;gap:10px;padding:10px 12px;background-color:#fff;border-radius:6px;cursor:pointer;transition:background-color .2s}.meeting-guide-check-item:hover{background-color:#eff6ff}.meeting-guide-check-item input[type=checkbox]{width:18px;height:18px;cursor:pointer}.meeting-guide-check-item span{font-size:14px;color:#374151}.meeting-guide-setup-actions{display:flex;flex-direction:column;gap:10px;margin-bottom:16px}.meeting-guide-setup-btn{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px 16px;border:2px dashed #d1d5db;border-radius:8px;background-color:#fff;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.meeting-guide-setup-btn.income{color:#059669;border-color:#a7f3d0}.meeting-guide-setup-btn.income:hover{background-color:#ecfdf5;border-color:#059669}.meeting-guide-setup-btn.bill{color:#dc2626;border-color:#fecaca}.meeting-guide-setup-btn.bill:hover{background-color:#fef2f2;border-color:#dc2626}.meeting-guide-setup-btn.import{color:#7c3aed;border-color:#ddd6fe}.meeting-guide-setup-btn.import:hover{background-color:#f5f3ff;border-color:#7c3aed}.meeting-guide-setup-hint{padding:12px;background-color:#fefce8;border-radius:8px;font-size:13px;color:#713f12;line-height:1.5}.meeting-guide-add-more{display:flex;justify-content:center;gap:16px;margin-top:12px;padding-top:12px;border-top:1px solid #e5e7eb}.meeting-guide-add-link{padding:0;border:none;background:none;font-size:13px;color:#2563eb;cursor:pointer;transition:color .2s}.meeting-guide-action-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;margin-top:16px;padding:12px 16px;background-color:#fef3c7;border:2px solid #f59e0b;border-radius:8px;font-size:14px;font-weight:500;color:#92400e;cursor:pointer;transition:all .2s}.meeting-guide-action-btn:hover{background-color:#fde68a;border-color:#d97706}.meeting-guide-add-link:hover{color:#1d4ed8;text-decoration:underline}.meeting-guide-wrap-up{display:flex;flex-direction:column;gap:16px}.meeting-guide-wrap-up-intro{margin:0;font-size:14px;color:#374151;text-align:center}.meeting-guide-rating{text-align:center}.meeting-guide-rating-label{display:block;margin-bottom:12px;font-size:14px;font-weight:500;color:#374151}.meeting-guide-stars{display:flex;justify-content:center;gap:8px}.meeting-guide-star{padding:4px;border:none;background:none;cursor:pointer;color:#d1d5db;transition:color .2s,transform .2s}.meeting-guide-star:hover{transform:scale(1.1)}.meeting-guide-star.active{color:#f59e0b}.meeting-guide-field{display:flex;flex-direction:column;gap:6px}.meeting-guide-field-label{font-size:13px;font-weight:500;color:#374151}.meeting-guide-textarea{width:100%;padding:10px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;resize:none;font-family:inherit}.meeting-guide-textarea:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.meeting-guide-nav{display:flex;gap:12px;justify-content:flex-end;padding-top:16px;border-top:1px solid #e5e7eb}.meeting-guide-nav-btn{padding:10px 20px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.meeting-guide-nav-prev{background-color:#fff;border:1px solid #d1d5db;color:#374151}.meeting-guide-nav-prev:hover{background-color:#f9fafb}.meeting-guide-nav-next{background-color:#2563eb;border:none;color:#fff}.meeting-guide-nav-next:hover{background-color:#1d4ed8}.meeting-guide-nav-complete{background-color:#10b981;border:none;color:#fff}.meeting-guide-nav-complete:hover{background-color:#059669}.meeting-guide-nav-complete:disabled{background-color:#9ca3af;cursor:not-allowed}.setup-progress{display:flex;justify-content:center;gap:24px;margin-bottom:24px}.setup-progress-step{display:flex;flex-direction:column;align-items:center;gap:8px}.setup-progress-dot{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600;background-color:#e5e7eb;color:#6b7280}.setup-progress-step.active .setup-progress-dot{background-color:#2563eb;color:#fff}.setup-progress-label{font-size:12px;color:#6b7280}.setup-progress-step.active .setup-progress-label{color:#2563eb;font-weight:500}.setup-step{min-height:280px}.setup-step-header{margin-bottom:20px;text-align:center}.setup-step-title{margin:0 0 8px;font-size:18px;font-weight:600;color:#111827}.setup-step-desc{margin:0;font-size:14px;color:#6b7280;line-height:1.5}.setup-frequency-intro{margin:0 0 12px;padding:12px;background-color:#eff6ff;border-radius:8px;font-size:13px;color:#1e40af;line-height:1.5;border-left:3px solid #2563eb}.setup-frequency-options{display:flex;flex-direction:column;gap:10px}.setup-frequency-option{display:flex;align-items:center;gap:12px;padding:14px 16px;border:2px solid #e5e7eb;border-radius:8px;cursor:pointer;transition:all .2s}.setup-frequency-option:hover{border-color:#93c5fd;background-color:#f0f9ff}.setup-frequency-option.selected{border-color:#2563eb;background-color:#eff6ff}.setup-frequency-option input[type=radio]{display:none}.setup-frequency-content{display:flex;flex-direction:column;gap:2px}.setup-frequency-label{font-size:14px;font-weight:600;color:#111827}.setup-frequency-desc{font-size:12px;color:#6b7280}.setup-categories{display:flex;flex-wrap:wrap;justify-content:center;gap:8px;margin-bottom:16px}.setup-category-chip{padding:8px 14px;border:2px solid #e5e7eb;border-radius:20px;background-color:#fff;font-size:14px;color:#374151;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:6px}.setup-category-chip:hover{border-color:#93c5fd;background-color:#f0f9ff}.setup-category-chip.selected{border-color:#2563eb;background-color:#eff6ff;color:#1e40af}.setup-category-chip.custom{background-color:#fef3c7;border-color:#fbbf24;color:#92400e}.setup-category-check{color:#2563eb}.setup-category-remove{color:#dc2626;font-weight:700}.setup-custom-categories{margin-bottom:16px}.setup-custom-label{font-size:12px;color:#6b7280;margin-bottom:8px;text-align:center}.setup-add-custom{display:flex;justify-content:center;gap:8px;max-width:320px;margin:0 auto}.setup-hint{font-size:13px;color:#6b7280;font-style:italic;text-align:center;margin-top:8px}.setup-summary{background-color:#f9fafb;border-radius:8px;padding:16px;display:flex;flex-direction:column;gap:16px}.setup-summary-item{display:flex;flex-direction:column;gap:4px}.setup-summary-label{font-size:12px;font-weight:500;color:#6b7280;text-transform:uppercase}.setup-summary-value{font-size:14px;color:#111827}.setup-summary-categories{display:flex;flex-wrap:wrap;gap:6px}.setup-summary-category{padding:4px 10px;background-color:#dbeafe;color:#1e40af;border-radius:12px;font-size:12px}.setup-encouragement{display:flex;align-items:flex-start;gap:12px;padding:16px;background-color:#ecfdf5;border-radius:8px;margin-top:16px}.setup-encouragement-icon{color:#10b981;flex-shrink:0}.setup-encouragement-text{margin:0;font-size:14px;color:#065f46;line-height:1.5}.app-layout{display:flex;min-height:100vh}.app-layout--meeting-open .main-content{margin-right:360px;transition:margin-right .3s ease-out}@media (max-width: 768px){.meeting-guide-sidebar{width:100%;max-width:100%}.meeting-guide-tab{top:auto;bottom:80px;right:16px;transform:none;writing-mode:horizontal-tb;padding:12px 16px;border-radius:24px}.meeting-guide-tab-text{writing-mode:horizontal-tb}.app-layout--meeting-open .main-content{margin-right:0}}.auth-vision-panel{display:none}@media (min-width: 768px){.auth-vision-panel{display:flex!important}.mobile-auth-header{display:none!important}.desktop-auth-header{display:block!important}.mobile-encouragement{display:none!important}}.mobile-app-header{display:none}@media (max-width: 768px){.mobile-app-header{display:flex;align-items:center;justify-content:center;gap:12px;padding:12px 60px;background-color:#1f2937;border-bottom:1px solid #374151;position:fixed;top:0;left:0;right:0;width:100%;z-index:1000;height:60px}.mobile-app-logo{height:48px;width:auto}.mobile-app-title{font-size:24px;font-weight:700;color:#fff;margin:0}.main-content{margin-left:0!important;width:100%!important;padding:140px 12px 12px!important;padding-bottom:max(16px,env(safe-area-inset-bottom))!important}.empty-state-container{left:0;top:60px}.sidebar{position:fixed;left:-240px;top:60px;height:calc(100vh - 60px);transition:left .3s ease;z-index:2000}.sidebar.mobile-open{left:0}.month-year-controls{flex-wrap:wrap;gap:8px!important}.month-selector,.year-selector{min-width:110px!important}.stats-grid{grid-template-columns:1fr!important;gap:16px!important}.stats-row{grid-template-columns:repeat(2,1fr)!important}.stats-container{padding:12px!important}.stat-label{font-size:12px!important}.stat-value{font-size:20px!important}.stats-header{font-size:14px!important;padding:6px!important}.goal-notes-grid{grid-template-columns:1fr!important;gap:12px!important}.header-row{display:flex!important;flex-wrap:wrap!important;gap:8px!important;justify-content:center!important}.month-year-controls{order:1;flex:0 0 100%!important;justify-content:center!important}.header-starting-balance{order:2;flex:1 1 auto}.header-new-month{order:3;flex:0 1 auto}.header-actions-menu{order:4;flex:0 1 auto}.header-goal{order:5;flex:0 0 100%!important}.btn{white-space:nowrap}.header{padding:16px 12px!important}.mobile-month-header{display:flex!important}.month-year-controls,.desktop-table{display:none!important}.mobile-view-toggle{display:flex!important}.mobile-cards-container{display:block!important}.modal-title{font-size:18px!important}.form-label{font-size:13px!important}.form-input,input[type=text],input[type=number],input[type=date],input[type=email],textarea,select{font-size:16px!important}.button-text{font-size:15px!important}.modal-container{width:calc(100% - 32px)!important;max-width:calc(100vw - 32px)!important;margin:16px!important;padding:0!important}.modal-header{margin-left:0!important;margin-right:0!important;border-radius:12px 12px 0 0!important;padding:16px 20px!important;margin-bottom:12px!important}.modal-container>div:not(.modal-header),.modal-container>form{padding-left:20px!important;padding-right:20px!important}.modal-container>*:last-child{padding-bottom:16px!important}.form-group{margin-bottom:10px!important}.form-label{margin-bottom:4px!important}.modal-body{padding:0!important}.fab-container{bottom:max(16px,calc(env(safe-area-inset-bottom) + 8px))!important;right:16px!important}.fab-button{width:56px!important;height:56px!important;font-size:28px!important}button,.mobile-touch-target{min-height:44px;min-width:44px}input[type=checkbox],input[type=radio]{width:20px;height:20px;min-width:20px;min-height:20px;cursor:pointer}input:focus,textarea:focus,select:focus{outline:2px solid #2563eb;outline-offset:2px}.sidebar-header{display:none!important}.sidebar-nav-item{padding:14px 16px!important;font-size:13px!important;min-height:44px}.yearly-header h1{font-size:22px!important}.yearly-stats-grid{grid-template-columns:1fr!important}.yearly-stats-grid>div{padding:12px!important}.yearly-stats-grid .stat-value{font-size:20px!important}.yearly-table td,.yearly-table th{padding:10px!important}.settings-container{padding:16px!important}.settings-grid{grid-template-columns:1fr!important}.settings-tab{font-size:14px!important;padding:10px 16px!important;min-height:44px}}@media (max-width: 480px){.action-buttons{flex-direction:column;width:100%}.action-buttons button{width:100%}.modal-container{padding:0!important;margin:12px!important}.modal-header{padding-left:16px!important;padding-right:16px!important}.modal-container>div:not(.modal-header),.modal-container>form{padding-left:16px!important;padding-right:16px!important}.modal-container>*:last-child{padding-bottom:16px!important}.fab-button{width:52px!important;height:52px!important;font-size:26px!important}}@media (max-width: 390px){.main-content{padding:8px!important}.modal-container{padding:0!important;margin:8px!important}.modal-header{padding-left:12px!important;padding-right:12px!important}.modal-container>div:not(.modal-header),.modal-container>form{padding-left:12px!important;padding-right:12px!important}.modal-container>*:last-child{padding-bottom:12px!important}.stats-grid>div{padding:12px!important}.stats-row{grid-template-columns:1fr!important}.stat-value{font-size:20px!important}}@media (min-width: 769px) and (max-width: 1024px){.sidebar{width:200px}.main-content{margin-left:200px}.yearly-stats-grid{grid-template-columns:1fr 1fr!important}}.mobile-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background-color:#00000080;z-index:1999}.mobile-overlay.active{display:block}.mobile-menu-button{display:none;position:fixed;top:8px;left:12px;z-index:2001;padding:8px;background-color:transparent;border:1px solid #4b5563;border-radius:6px;cursor:pointer;color:#fff;min-width:44px;min-height:44px}@media (max-width: 768px){.mobile-menu-button{display:block}}.mobile-full-width{width:100%!important}.mobile-stack{flex-direction:column!important}.mobile-text-center{text-align:center!important}.toast-container{position:fixed;top:20px;right:20px;z-index:10000;display:flex;flex-direction:column;gap:12px;max-width:400px}.toast{display:flex;align-items:center;gap:12px;padding:16px;border-radius:8px;box-shadow:0 4px 12px #00000026;cursor:pointer;animation:slideIn .3s ease-out;min-width:300px;background:#fff}.toast-icon{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:16px;flex-shrink:0}.toast-message{flex:1;font-size:14px;line-height:1.5}.toast-success{border-left:4px solid #10b981}.toast-success .toast-icon{background-color:#d1fae5;color:#065f46}.toast-error{border-left:4px solid #ef4444}.toast-error .toast-icon{background-color:#fee2e2;color:#991b1b}.toast-warning{border-left:4px solid #f59e0b}.toast-warning .toast-icon{background-color:#fef3c7;color:#92400e}.toast-info{border-left:4px solid #3b82f6}.toast-info .toast-icon{background-color:#dbeafe;color:#1e40af}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@media (max-width: 768px){.toast-container{left:20px;right:20px;max-width:none}.toast{min-width:auto}}*{box-sizing:border-box}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}button,input,select,textarea{font-family:inherit}
