.auth-screen{position:fixed;inset:0;background:var(--background);display:flex;align-items:center;justify-content:center;padding:24px;z-index:2000}.auth-card{width:100%;max-width:420px;background:var(--card-background);border-radius:16px;box-shadow:var(--shadow);padding:24px}.auth-title{font-size:24px;font-weight:700;text-align:center;margin-bottom:8px}.auth-subtitle{text-align:center;color:var(--text-secondary);margin-bottom:16px}.auth-form .form-group{margin-bottom:20px}.auth-form .form-group label{display:block;margin-bottom:8px;font-weight:500;color:var(--text-secondary)}.auth-form .form-group input{width:100%;padding:12px;font-size:16px;border:1px solid var(--border-color);border-radius:8px;background:var(--card-background)}.auth-form .auth-actions{margin-top:12px;display:flex;flex-direction:column;gap:12px}.auth-form .auth-actions .btn-confirm{width:100%;padding:12px;background:#007aff!important;color:#fff!important;border:none!important;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;display:block!important;min-height:48px;visibility:visible!important;opacity:1!important;position:relative;z-index:1}.auth-form .auth-actions .btn-confirm:active{opacity:.8!important}.auth-form .auth-actions .link-btn{background:none;border:none;color:var(--primary-color);cursor:pointer;font-weight:600;padding:8px}.auth-error{color:#ff3b30;margin-top:12px;font-size:14px}.status-buttons{display:flex;gap:12px;justify-content:center}.status-btn{flex:1;padding:12px 16px;border:2px solid transparent;border-radius:8px;font-size:16px;font-weight:500;cursor:pointer;transition:all .2s;background:var(--background);color:var(--text-primary)}.status-btn.status-planned{border-color:var(--planned-color);color:var(--planned-color)}.status-btn.status-planned.active{background:var(--planned-color);border-color:var(--planned-color);color:#fff;font-weight:600}.status-btn.status-paid{border-color:var(--paid-color);color:var(--paid-color)}.status-btn.status-paid.active{background:var(--paid-color);border-color:var(--paid-color);color:#fff;font-weight:600}.status-btn.status-unsure{border-color:#ff3b30;color:#ff3b30}.status-btn.status-unsure.active{background:#ff3b30;border-color:#ff3b30;color:#fff;font-weight:600}.status-btn:hover{opacity:.8}.status-btn:active{transform:scale(.98)}.date-picker-modal{max-width:500px}.date-picker-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.month-button{padding:12px;border:2px solid var(--border-color);border-radius:8px;background:var(--background);color:var(--text-primary);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.month-button:hover{background:var(--card-background);border-color:var(--primary-color)}.month-button.selected{background:var(--primary-color);border-color:var(--primary-color);color:#fff;font-weight:600}.month-button.current{border-color:var(--primary-color);border-width:2px}.month-button:active{transform:scale(.98)}.btn-secondary{flex:1;padding:12px;font-size:16px;font-weight:600;border:2px solid var(--primary-color);border-radius:8px;background:var(--background);color:var(--primary-color);cursor:pointer;transition:opacity .2s}.btn-secondary:hover:not(:disabled){opacity:.8}.btn-secondary:active:not(:disabled){opacity:.6}.transaction-modal{max-width:600px;width:90vw;max-height:90vh;overflow-y:auto;overflow-x:hidden}@media(max-width:480px){.transaction-modal{width:95vw;padding:20px 16px;max-height:95vh}}.close-button{background:none;border:none;font-size:28px;color:var(--text-secondary);cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}.close-button:hover{background:var(--border-color);color:var(--text-primary)}.transaction-summary{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:20px;padding:12px;background:var(--background);border-radius:8px;border:1px solid var(--border-color)}.summary-item{text-align:center}.summary-label{font-size:10px;color:var(--text-secondary);margin-bottom:4px;text-transform:uppercase;font-weight:600;letter-spacing:.5px}.summary-value{font-size:14px;font-weight:700;color:var(--text-primary);word-break:break-word}.summary-value.spent{color:var(--text-secondary)}.summary-value.positive{color:var(--success-color)}.summary-value.negative{color:var(--danger-color)}.transaction-form{margin-bottom:16px;padding:16px;background:var(--background);border-radius:8px;border:1px solid var(--border-color)}@media(max-width:480px){.transaction-form{padding:12px}}.transaction-form .form-group{margin-bottom:16px}.transaction-form .form-group:last-child{margin-bottom:0}.transaction-form .form-group label{display:block;margin-bottom:8px;font-weight:600;font-size:14px;color:var(--text-primary)}.transaction-form .form-group input[type=text],.transaction-form .form-group input[type=number],.transaction-form .form-group input[type=date]{width:100%;padding:12px;font-size:16px;border:1px solid var(--border-color);border-radius:8px;background:var(--card-background);color:var(--text-primary);font-family:inherit;-webkit-appearance:none;appearance:none}.transaction-form .form-group input[type=text]:focus,.transaction-form .form-group input[type=number]:focus,.transaction-form .form-group input[type=date]:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #007aff1a}.transaction-form textarea{width:100%;padding:12px;border:1px solid var(--border-color);border-radius:8px;background:var(--card-background);color:var(--text-primary);font-size:16px;font-family:inherit;resize:vertical;min-height:80px}.transaction-form textarea:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #007aff1a}.transactions-list{max-height:400px;overflow-y:auto;margin-bottom:16px}.no-transactions{text-align:center;padding:40px 20px;color:var(--text-secondary)}.transaction-item{padding:12px;border:1px solid var(--border-color);border-radius:8px;margin-bottom:8px;background:var(--background);transition:all .2s}.transaction-item:hover{border-color:var(--primary-color);box-shadow:0 2px 8px #0000001a}.transaction-main{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:8px}.transaction-info{flex:1}.transaction-description{font-size:14px;font-weight:600;color:var(--text-primary);margin-bottom:4px}.transaction-date{font-size:12px;color:var(--text-secondary);margin-bottom:2px}.transaction-notes{font-size:12px;color:var(--text-secondary);font-style:italic;margin-top:4px}.transaction-amount{font-size:16px;font-weight:700;white-space:nowrap;margin-left:12px}.transaction-amount.positive{color:var(--success-color)}.transaction-amount.negative{color:var(--danger-color)}.transaction-actions{display:flex;gap:8px}.btn-action-small{padding:6px 12px;font-size:12px;font-weight:600;border:1px solid var(--border-color);border-radius:6px;background:var(--card-background);color:var(--text-primary);cursor:pointer;transition:all .2s}.btn-action-small:hover{background:var(--primary-color);border-color:var(--primary-color);color:#fff}.btn-action-small.btn-delete:hover{background:var(--danger-color);border-color:var(--danger-color);color:#fff}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;gap:12px}.modal-header h2{margin:0;flex:1;font-size:18px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media(max-width:480px){.modal-header{margin-bottom:16px}.modal-header h2{font-size:16px}}.modal-actions{display:flex;gap:12px;margin-top:20px}.modal-actions .btn-cancel,.modal-actions .btn-save{flex:1;padding:12px 20px;font-size:16px;font-weight:600;border-radius:8px;cursor:pointer;transition:all .2s;border:none}.modal-actions .btn-cancel{background:var(--background);color:var(--text-primary);border:2px solid var(--border-color)}.modal-actions .btn-cancel:active{background:var(--border-color)}.modal-actions .btn-save{background:var(--primary-color);color:#fff;border:2px solid var(--primary-color)}.modal-actions .btn-save:active{opacity:.8}@media(max-width:480px){.modal-actions{margin-top:16px}.modal-actions .btn-cancel,.modal-actions .btn-save{padding:14px 16px;font-size:16px}}.spreadsheet-fullpage{position:fixed;top:0;left:0;right:0;bottom:var(--navbar-height, 60px);background:var(--background);display:flex;flex-direction:column;z-index:100;overflow:hidden}body:has(.spreadsheet-fullpage){overflow:hidden}.spreadsheet-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:2px solid var(--border-color);background:var(--card-background);box-shadow:var(--shadow);position:relative;z-index:150;flex-shrink:0}.year-navigation button:active{opacity:.6}.spreadsheet-header h2{margin:0;font-size:20px;font-weight:600;color:var(--text-primary)}.header-actions{display:flex;align-items:center;gap:12px}.show-all-btn{background:var(--background);border:2px solid var(--primary-color);color:var(--primary-color);padding:8px 16px;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:6px}.show-all-btn:hover{background:var(--primary-color);color:#fff}.text-size-controls{display:flex;gap:4px}.text-size-btn{background:var(--background);border:2px solid var(--primary-color);color:var(--primary-color);padding:6px 12px;border-radius:8px;font-weight:700;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;min-width:40px;height:38px}.text-size-btn:hover:not(:disabled){background:var(--primary-color);color:#fff}.text-size-btn:disabled{opacity:.4;cursor:not-allowed;border-color:var(--border-color);color:var(--text-secondary)}.close-button{background:none;border:none;font-size:32px;color:var(--text-secondary);cursor:pointer;padding:0;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background .2s}.bulk-action-toolbar{z-index:200;display:flex;justify-content:space-between;align-items:center;gap:8px;padding:6px 12px;background:var(--primary-color);color:#fff;border-radius:8px;box-shadow:0 4px 12px #00000040;animation:slideDown .2s ease-out;white-space:nowrap}@keyframes slideDown{0%{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}.selection-info{font-size:12px;font-weight:600;display:flex;align-items:center;gap:8px}.selection-sum{font-size:11px;font-weight:500;opacity:.9}.bulk-actions{display:flex;gap:8px}.bulk-btn{padding:4px 10px;font-size:11px;font-weight:600;border:none;border-radius:4px;cursor:pointer;transition:all .2s;color:#fff}.bulk-btn:hover{opacity:.9;transform:translateY(-1px)}.bulk-btn:active{transform:translateY(0)}.paid-btn{background:var(--paid-color)}.planned-btn{background:var(--planned-color)}.unsure-btn{background:#ff3b30}.cancel-btn{background:#0000004d;border:1px solid white}.clickable-header{cursor:pointer;position:relative;-webkit-user-select:none;user-select:none}.clickable-header:hover{background:#007aff1a!important}.clickable-header:active{background:#007aff33!important}.spreadsheet-scroll{overflow:auto;flex:1;padding:0 0 16px;background:var(--background)}.spreadsheet-table{width:100%;border-collapse:collapse;font-size:13px}.spreadsheet-table[data-text-size=small]{font-size:11px}.spreadsheet-table[data-text-size=small] .category-name{font-size:8.8px}.spreadsheet-table[data-text-size=small] .category-total{font-size:7.04px}.spreadsheet-table[data-text-size=small] .totals-row td{font-size:12.1px}.spreadsheet-table[data-text-size=small] .grand-total{font-size:13.13px}.spreadsheet-table[data-text-size=small] .difference-row td{font-size:12.1px}.spreadsheet-table[data-text-size=large]{font-size:15px}.spreadsheet-table[data-text-size=large] .category-name{font-size:12px}.spreadsheet-table[data-text-size=large] .category-total{font-size:9.6px}.spreadsheet-table[data-text-size=large] .totals-row td{font-size:16.5px}.spreadsheet-table[data-text-size=large] .grand-total{font-size:17.88px}.spreadsheet-table[data-text-size=large] .difference-row td{font-size:16.5px}.spreadsheet-table thead{position:sticky;top:0;z-index:10;background:var(--background);box-shadow:0 2px 4px #0000001a;margin-top:0}.spreadsheet-table th{padding:8px 6px;text-align:left;font-weight:600;color:var(--text-primary);border-bottom:2px solid var(--border-color);background:var(--background);white-space:nowrap;position:relative;z-index:10}.spreadsheet-table th.expense-col{min-width:140px;position:sticky;left:0;z-index:11;background:var(--background)}.spreadsheet-table th.month-col{min-width:75px;text-align:right;background:var(--background);z-index:10}.spreadsheet-table th.total-col{min-width:85px;text-align:right;background:#ff9500;color:#fff;z-index:10}.spreadsheet-table tbody tr{border-bottom:1px solid var(--border-color)}.spreadsheet-table tbody tr:hover{background:#007aff0d}.income-row{background:#34c75914;border-bottom:2px solid var(--border-color)}.income-cell{padding:8px 6px;text-align:right;cursor:pointer;transition:all .2s;font-weight:600;color:var(--planned-color);position:relative;z-index:1}.income-cell:hover{background:#34c75940;transform:scale(1.05)}.income-separator-row{height:16px;background:var(--background);border-bottom:2px solid var(--border-color)}.category-header-row{background:linear-gradient(90deg,#007aff26,#007aff14);border-top:2px solid var(--primary-color);border-bottom:2px solid var(--primary-color)}.category-header-name{padding:12px 16px;font-weight:700;font-size:14px;color:var(--primary-color);display:flex;justify-content:space-between;align-items:center;position:relative}.category-add-expense-btn{background:var(--primary-color);color:#fff;border:none;border-radius:50%;width:24px;height:24px;font-size:18px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;line-height:1;transition:all .2s;margin-left:8px}.category-add-expense-btn:hover{background:var(--primary-color);opacity:.8;transform:scale(1.1)}.category-add-expense-btn:active{transform:scale(.95)}.category-header-text{font-size:15px;font-weight:700}.category-header-total{font-size:13px;font-weight:600;color:#ff9500}[data-theme=dark] .category-header-row{background:linear-gradient(90deg,#007aff33,#007aff1f)}.expense-cell{padding:8px 6px;font-weight:500;color:var(--text-primary);position:sticky;left:0;z-index:3;background:var(--card-background);border-right:1px solid var(--border-color);box-shadow:2px 0 4px #0000000d;display:flex;align-items:center;gap:6px}.expense-drag-handle{color:var(--text-secondary);font-size:14px;cursor:grab;-webkit-user-select:none;user-select:none;opacity:.5;transition:opacity .2s;flex-shrink:0}.expense-row-draggable:hover .expense-drag-handle{opacity:1}.expense-drag-handle:active{cursor:grabbing}.expense-name-text{flex:1}.expense-row-draggable{cursor:move}.expense-row-draggable.dragging{opacity:.5;background:#007aff1a}.income-name-cell{padding:8px 6px;font-weight:600;color:var(--planned-color);position:sticky;left:0;z-index:3;background:#34c75914;border-right:1px solid var(--border-color);box-shadow:2px 0 4px #0000000d}.amount-cell{padding:8px 6px;text-align:right;cursor:pointer;transition:all .2s;font-weight:500;position:relative;z-index:1;user-select:none;-webkit-user-select:none;overflow:visible}.inline-edit-input{position:absolute;inset:0;width:100%;height:100%;text-align:right;border:2px solid var(--primary-color);border-radius:4px;padding:4px 6px;font-size:inherit;font-weight:500;background:var(--card-background);color:var(--text-primary);outline:none;font-family:inherit;box-sizing:border-box;margin:0}.inline-edit-input:focus{border-color:var(--primary-color);box-shadow:0 0 0 2px #007aff33}.amount-cell:hover{background:#007aff26;transform:scale(1.05)}.amount-cell.has-note{padding-right:24px}.note-indicator{position:absolute;top:2px;right:2px;font-size:10px;opacity:.6;pointer-events:none}.note-tooltip{position:fixed;background:#000000e6;color:#fff;padding:12px 16px;border-radius:8px;font-size:14px;line-height:1.5;max-width:300px;z-index:1000;box-shadow:0 4px 12px #0000004d;pointer-events:none;white-space:pre-wrap;word-wrap:break-word}[data-theme=dark] .note-tooltip{background:#fffffff2;color:#1a1a1a}.month-tooltip{position:fixed;background:#000000e6;color:#fff;padding:12px 16px;border-radius:8px;font-size:14px;line-height:1.5;max-width:300px;z-index:1000;box-shadow:0 4px 12px #0000004d;pointer-events:none;white-space:nowrap}[data-theme=dark] .month-tooltip{background:#fffffff2;color:#1a1a1a}.amount-cell.paid{background:linear-gradient(90deg,rgba(100,210,255,.15) 0%,transparent 100%);color:var(--paid-color)}.amount-cell.planned{background:linear-gradient(90deg,rgba(52,199,89,.15) 0%,transparent 100%);color:var(--planned-color)}.amount-cell.unsure{background:linear-gradient(90deg,rgba(255,59,48,.15) 0%,transparent 100%);color:#ff3b30}.amount-cell.no-entry{opacity:.4;font-style:italic;color:var(--text-secondary)}.amount-cell.selected{outline:3px solid var(--primary-color);outline-offset:-3px;box-shadow:0 0 8px #007aff80;position:relative;z-index:5}.selection-indicator{position:absolute;top:2px;left:2px;font-size:12px;font-weight:700;color:var(--primary-color);background:#fff;border-radius:50%;width:18px;height:18px;display:flex;align-items:center;justify-content:center;pointer-events:none;box-shadow:0 1px 3px #0003}.total-cell{padding:8px 6px;text-align:right;font-weight:700;color:#ff9500;background:#ff95000d;border-left:2px solid var(--border-color)}.category-summary-row{background:#ff950014;border-top:2px solid var(--border-color);font-weight:600}.category-summary-label{padding:8px 6px;text-align:left;font-style:italic;color:var(--text-secondary);position:sticky;left:0;z-index:2;background:#ff950014;border-right:1px solid var(--border-color);box-shadow:2px 0 4px #0000000d}.category-summary-cell{padding:8px 6px;text-align:right;color:#ff9500;font-weight:600}.category-summary-total{padding:8px 6px;text-align:right;font-weight:700;color:#ff9500;border-left:2px solid var(--border-color)}.totals-row{font-weight:700;background:var(--background);border-top:3px solid var(--border-color)}.totals-row td{padding:10px 6px;font-size:14.3px}.month-total{text-align:right;color:var(--text-primary)}.grand-total{text-align:right;color:#fff;background:#ff9500;font-size:15.5px}.difference-row{font-weight:700;background:var(--background);border-top:3px solid var(--border-color);border-bottom:2px solid var(--border-color)}.difference-row td{padding:10px 6px;font-size:14.3px}.difference-label-cell{position:sticky;left:0;z-index:3;background:var(--background);border-right:1px solid var(--border-color);box-shadow:2px 0 4px #0000000d}.difference-label{display:flex;align-items:center;gap:6px;font-weight:700;color:var(--text-primary)}.difference-help-icon{font-size:14px;cursor:help;opacity:.6;transition:opacity .2s;-webkit-user-select:none;user-select:none}.difference-help-icon:hover{opacity:1}.difference-cell{text-align:right;font-weight:700}.difference-cell.positive{color:var(--planned-color)}.difference-cell.negative{color:#ff3b30}.difference-total{text-align:right;font-weight:700;color:var(--text-primary);background:#ff95000d;border-left:2px solid var(--border-color)}.difference-help-tooltip{position:fixed;background:#000000e6;color:#fff;padding:12px 16px;border-radius:8px;font-size:14px;line-height:1.5;max-width:300px;z-index:2000;box-shadow:0 4px 12px #0000004d;pointer-events:none;white-space:normal}[data-theme=dark] .difference-help-tooltip{background:#fffffff2;color:#1a1a1a}.spreadsheet-table tbody tr:hover .expense-cell{background:var(--card-background)}.spreadsheet-table tbody tr:hover .income-name-cell{background:#34c75914}.spreadsheet-table tbody tr:hover .category-summary-label{background:#ff950014}.spreadsheet-table tbody tr:hover .difference-label-cell{background:var(--background)}.loading{padding:40px;text-align:center;color:var(--text-secondary)}@media(max-width:768px){.btn-spreadsheet{display:none}}.budget-home{padding:0}.header{background:var(--card-background);padding:max(env(safe-area-inset-top),12px) 16px 12px;box-shadow:var(--shadow);margin:-16px -16px 12px;position:sticky;top:0;z-index:100}.month-navigation{display:flex;align-items:center;justify-content:space-between;gap:15px}.month-navigation button{background:var(--primary-color);border:none;color:#fff;width:36px;height:36px;border-radius:50%;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:opacity .2s}.month-navigation button:active{opacity:.6}.month-title{flex:1;text-align:center;font-size:18px;font-weight:600;cursor:pointer;padding:8px;border-radius:8px}.budget-select{width:100%;padding:12px;border:1px solid var(--border-color);border-radius:12px;background:var(--card-background);color:var(--text-primary);margin-bottom:12px;font-size:16px}.total-summary{background:linear-gradient(135deg,var(--primary-color),#0051d5);color:#fff;padding:14px 16px;border-radius:12px;margin-bottom:12px;box-shadow:var(--shadow)}.total-label{font-size:11px;opacity:.9;margin-bottom:6px}.total-amount{font-size:26px;font-weight:700}.total-subrow{display:flex;gap:10px;margin-top:6px;font-size:12px;opacity:.95}.total-chip{background:#ffffff26;padding:4px 8px;border-radius:999px}.loading,.error,.empty-state{text-align:center;padding:40px 20px;color:var(--text-secondary)}.error{color:#ff3b30}.empty-state h2{margin-bottom:8px;color:var(--text-primary)}.btn-expand-collapse.active{background:var(--primary-color);color:#fff;border-color:var(--primary-color)}.categories-container{padding:0}.category-card{background:var(--card-background);border-radius:12px;margin-bottom:10px;overflow:hidden;box-shadow:var(--shadow)}.category-header{padding:12px 16px;display:flex;justify-content:space-between;align-items:center;cursor:pointer;border-bottom:1px solid var(--background)}.category-name{font-size:16px;font-weight:600;margin-bottom:4px}.category-total{font-size:20px;font-weight:700;color:var(--primary-color)}.category-expand-icon{font-size:20px;color:var(--text-secondary);transition:transform .3s}.category-card.expanded .category-expand-icon{transform:rotate(180deg)}.category-copy-controls{display:flex;gap:8px;padding:8px 16px;background:var(--background);border-bottom:1px solid var(--border-color);flex-wrap:wrap}.category-copy-controls.bulk-actions{background:linear-gradient(90deg,rgba(0,122,255,.08) 0%,var(--background) 100%);border-bottom:2px solid var(--primary-color)}.btn-copy-category{flex:1;padding:6px 12px;font-size:12px;font-weight:600;border:1px solid var(--border-color);border-radius:8px;background:var(--card-background);color:var(--text-primary);cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:4px}.btn-copy-category:hover{background:var(--primary-color);color:#fff;border-color:var(--primary-color)}.btn-copy-category:active{transform:scale(.98)}.btn-copy-category:disabled{opacity:.4;cursor:not-allowed}.btn-copy-category.btn-multi-select{background:var(--card-background);color:var(--text-primary);border-color:var(--border-color)}.btn-copy-category.btn-multi-select:hover{background:var(--primary-color);color:#fff;border-color:var(--primary-color)}.btn-copy-category.btn-cancel-select{background:var(--background);color:var(--text-primary);border-color:var(--border-color)}.btn-copy-category.btn-status-planned{background:#34c7591a;color:var(--planned-color);border-color:var(--planned-color)}.btn-copy-category.btn-status-planned:hover:not(:disabled){background:var(--planned-color);color:#fff}.btn-copy-category.btn-status-paid{background:#64d2ff1a;color:var(--paid-color);border-color:var(--paid-color)}.btn-copy-category.btn-status-paid:hover:not(:disabled){background:var(--paid-color);color:#fff}.btn-copy-category.btn-status-unsure{background:#ff3b301a;color:#ff3b30;border-color:#ff3b30}.btn-copy-category.btn-status-unsure:hover:not(:disabled){background:#ff3b30;color:#fff}.expenses-list{display:none;padding:0}.category-card.expanded .expenses-list{display:block}.expense-item{padding:10px 16px;border-top:1px solid var(--background);display:flex;justify-content:space-between;align-items:center;cursor:pointer;transition:background .2s;gap:12px}.expense-item:active{background:var(--background)}.expense-item.selectable{border-left:3px solid var(--primary-color)}.expense-item.selectable.selected{background:#007aff1a;border-left:3px solid var(--primary-color)}.expense-checkbox{font-size:20px;min-width:24px;text-align:center;-webkit-user-select:none;user-select:none}.expense-item.planned{background:linear-gradient(90deg,rgba(52,199,89,.1) 0%,transparent 100%);border-left:4px solid var(--planned-color)}.expense-item.paid{background:linear-gradient(90deg,rgba(100,210,255,.15) 0%,transparent 100%);border-left:4px solid var(--paid-color)}.expense-item.unsure{background:linear-gradient(90deg,rgba(255,59,48,.15) 0%,transparent 100%);border-left:4px solid #ff3b30}.expense-name{font-size:14px}.expense-amount{font-size:16px;font-weight:600}.expense-item.planned .expense-amount{color:var(--planned-color)}.expense-item.paid .expense-amount{color:var(--paid-color)}.expense-item.unsure .expense-amount{color:#ff3b30}.expense-item[data-has-entry=false]{opacity:.5;background:none!important;border-left:4px dashed var(--border-color)!important}.expense-item[data-has-entry=false] .expense-amount{color:var(--text-secondary)!important;font-style:italic}.trackable-badge{font-size:14px;margin-left:6px;opacity:.7;display:inline-block}.expense-item.trackable{border-right:3px solid var(--primary-color)}.expense-item.trackable:hover{background:rgba(var(--primary-color-rgb),.05)}.income-section{background:var(--card-background);border-radius:12px;padding:16px;margin:0 16px 12px;box-shadow:var(--shadow)}.income-helper-text{font-size:12px;color:var(--text-secondary);background:#007aff14;padding:8px 12px;border-radius:8px;margin-bottom:12px;border-left:3px solid var(--primary-color)}.income-default-note{font-size:12px;color:var(--text-secondary);margin-bottom:12px;padding:8px;background:var(--background);border-radius:6px;text-align:center}.income-sources-list{margin-bottom:12px}.income-source-item{display:flex;justify-content:space-between;align-items:center;padding:12px;background:var(--background);border-radius:8px;margin-bottom:8px}.income-source-item.default-income{opacity:.7;border:2px dashed var(--border-color);background:none;transition:opacity .2s}.income-source-item.default-income:hover{opacity:1;background:var(--background)}.income-source-info{flex:1}.income-source-name{font-size:14px;font-weight:600;margin-bottom:2px}.default-badge{font-size:11px;font-weight:400;color:var(--text-secondary);margin-left:6px;font-style:italic}.income-source-notes{font-size:12px;color:var(--text-secondary)}.income-source-right{display:flex;align-items:center;gap:12px}.income-source-amount{font-size:16px;font-weight:700;color:var(--primary-color)}.income-source-actions{display:flex;gap:8px}.btn-icon{background:none;border:none;font-size:18px;cursor:pointer;color:var(--text-secondary);width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background .2s}.btn-icon:hover{background:var(--card-background)}.btn-icon.btn-delete{color:#ff3b30}.income-form{background:var(--background);padding:16px;border-radius:12px;margin-bottom:12px}.empty-income-message{text-align:center;padding:24px;color:var(--text-secondary);font-size:14px}.income-actions{display:flex;justify-content:center;gap:8px}.btn-action{background:var(--primary-color);color:#fff;border:none;padding:10px 20px;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:opacity .2s}.btn-action.btn-secondary{background:var(--background);color:var(--primary-color);border:2px solid var(--primary-color)}.fab-add-transaction{position:fixed;bottom:calc(var(--navbar-height) + 20px);right:20px;width:56px;height:56px;border-radius:50%;background:var(--primary-color);color:#fff;border:none;font-size:32px;font-weight:300;cursor:pointer;box-shadow:0 4px 12px #007aff66;display:flex;align-items:center;justify-content:center;z-index:90;transition:all .3s}.fab-add-transaction:hover{transform:scale(1.1);box-shadow:0 6px 16px #007aff80}.fab-add-transaction:active{transform:scale(.95)}.expense-selector-list{display:flex;flex-direction:column;gap:8px;padding:16px 0}.expense-selector-item{padding:16px;background:var(--card-background);border:2px solid var(--border-color);border-radius:12px;font-size:16px;font-weight:500;color:var(--text-primary);cursor:pointer;transition:all .2s;text-align:left}.expense-selector-item:hover{background:var(--primary-color);color:#fff;border-color:var(--primary-color);transform:translate(4px)}.expense-selector-item:active{transform:scale(.98)}.analytics-fullpage{position:fixed;top:0;left:0;right:0;bottom:var(--navbar-height, 60px);background:var(--background);display:flex;flex-direction:column;z-index:100;overflow:hidden}body:has(.analytics-fullpage){overflow:hidden}.analytics-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:2px solid var(--border-color);background:var(--card-background);box-shadow:var(--shadow)}.year-navigation{display:flex;align-items:center;gap:20px}.year-navigation button{background:var(--primary-color);border:none;color:#fff;width:36px;height:36px;border-radius:50%;font-size:24px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:opacity .2s;line-height:1}.year-navigation button:hover{opacity:.8}.year-title{font-size:20px;font-weight:600;color:var(--text-primary)}.analytics-tabs{display:flex;gap:8px;padding:16px 24px;background:var(--card-background);border-bottom:1px solid var(--border-color);overflow-x:auto}.tab-button{padding:8px 16px;background:var(--background);border:2px solid var(--border-color);border-radius:8px;color:var(--text-primary);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;white-space:nowrap}.tab-button:hover{background:var(--card-background)}.tab-button.active{background:var(--primary-color);border-color:var(--primary-color);color:#fff}.analytics-scroll{overflow-y:auto;flex:1;padding:24px;background:var(--background)}.analytics-content{max-width:1400px;margin:0 auto}.analytics-content h2{font-size:24px;font-weight:600;color:var(--text-primary);margin-bottom:24px}.analytics-content h3{font-size:18px;font-weight:600;color:var(--text-primary);margin:24px 0 16px}.highlight-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:16px;margin-bottom:32px}.highlight-card{background:var(--card-background);padding:20px;border-radius:12px;box-shadow:var(--shadow);text-align:center}.highlight-card.best{border:2px solid var(--planned-color)}.highlight-card.worst{border:2px solid #ff3b30}.card-label{font-size:12px;text-transform:uppercase;color:var(--text-secondary);margin-bottom:8px;font-weight:600}.card-month{font-size:20px;font-weight:600;color:var(--text-primary);margin-bottom:8px}.card-amount{font-size:24px;font-weight:700;color:var(--primary-color)}.chart-container{background:var(--card-background);padding:24px;border-radius:12px;box-shadow:var(--shadow);margin-bottom:32px}.bar-chart{display:flex;align-items:flex-end;gap:12px;height:300px;padding:20px 0;margin-top:16px}.bar-wrapper{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;height:100%;position:relative}.bar{width:100%;background:var(--primary-color);border-radius:4px 4px 0 0;position:relative;transition:all .3s;min-height:10px;display:flex;align-items:center;justify-content:center}.bar:hover{opacity:.8}.bar.best{background:var(--planned-color)}.bar.worst{background:#ff3b30}.bar-change{font-size:14px;font-weight:700;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.5);padding:4px 8px;border-radius:4px;background:#0003}.bar-change.increase{background:#ff3b304d}.bar-change.decrease{background:#34c7594d}.bar-amount{margin-top:4px;font-size:11px;color:var(--text-secondary);text-align:center;font-weight:500}.bar-label{margin-top:4px;font-size:12px;color:var(--text-secondary);text-align:center;font-weight:600}.category-evolution{background:var(--card-background);padding:24px;border-radius:12px;box-shadow:var(--shadow);margin-bottom:32px}.category-trend{margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid var(--border-color)}.category-trend:last-child{border-bottom:none}.category-trend-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.category-trend-name{font-weight:600;color:var(--text-primary)}.category-trend-total{font-weight:600;color:var(--primary-color)}.mini-bars{display:flex;gap:2px;height:20px}.mini-bar{flex:1;background:var(--primary-color);opacity:.3;border-radius:2px}.yoy-summary{display:flex;align-items:center;justify-content:center;gap:40px;margin:32px 0;padding:32px;background:var(--card-background);border-radius:12px;box-shadow:var(--shadow)}.yoy-card{text-align:center}.yoy-label{font-size:14px;color:var(--text-secondary);margin-bottom:8px;font-weight:600}.yoy-value{font-size:32px;font-weight:700;color:var(--text-primary)}.yoy-arrow{font-size:48px;color:var(--primary-color)}.yoy-change{text-align:center;padding:16px;border-radius:8px;margin-bottom:32px;font-size:18px}.yoy-change.increase{background:#ff3b301a;color:#ff3b30}.yoy-change.decrease{background:#34c7591a;color:var(--planned-color)}.change-label{font-weight:600;margin-right:12px}.change-value{font-weight:700;font-size:24px}.comparison-table{background:var(--card-background);padding:24px;border-radius:12px;box-shadow:var(--shadow);overflow-x:auto}.comparison-table table{width:100%;border-collapse:collapse}.comparison-table th{text-align:left;padding:12px;border-bottom:2px solid var(--border-color);font-weight:600;color:var(--text-primary)}.comparison-table td{padding:12px;border-bottom:1px solid var(--border-color);color:var(--text-primary)}.comparison-table tr:last-child td{border-bottom:none}.comparison-table td.increase{color:#ff3b30;font-weight:600}.comparison-table td.decrease{color:var(--planned-color);font-weight:600}.distribution-chart{background:var(--card-background);padding:24px;border-radius:12px;box-shadow:var(--shadow)}.distribution-item{margin-bottom:24px}.distribution-item:last-child{margin-bottom:0}.distribution-label{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.distribution-name{font-weight:600;color:var(--text-primary)}.distribution-percent{font-weight:600;color:var(--primary-color);font-size:14px}.distribution-bar-container{height:32px;background:var(--background);border-radius:8px;overflow:hidden;margin-bottom:4px}.distribution-bar{height:100%;background:linear-gradient(90deg,var(--primary-color),var(--paid-color));transition:width .3s}.distribution-amount{font-size:14px;color:var(--text-secondary);text-align:right}.forecast-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:16px;margin-bottom:32px}.forecast-card{background:var(--card-background);padding:24px;border-radius:12px;box-shadow:var(--shadow);text-align:center}.forecast-label{font-size:14px;color:var(--text-secondary);margin-bottom:12px;font-weight:600}.forecast-value{font-size:28px;font-weight:700;color:var(--primary-color)}.forecast-value.higher{color:#ff3b30}.forecast-value.lower{color:var(--planned-color)}.forecast-note{font-size:12px;color:var(--text-secondary);margin-top:8px}.savings-scenarios{background:var(--card-background);padding:24px;border-radius:12px;box-shadow:var(--shadow)}.scenario-card{padding:16px;background:var(--background);border-radius:8px;margin-bottom:12px;display:flex;justify-content:space-between;align-items:center}.scenario-card:last-child{margin-bottom:0}.scenario-label{font-weight:600;color:var(--text-primary)}.scenario-values{display:flex;gap:16px;align-items:center}.scenario-savings{color:var(--planned-color);font-weight:600;font-size:14px}.no-forecast{text-align:center;padding:60px 20px;color:var(--text-secondary);font-size:16px}@media(max-width:768px){.btn-analytics{display:none}}.year-selector-container{display:flex;gap:24px;justify-content:center;margin-bottom:32px;padding:20px;background:var(--card-background);border-radius:12px;box-shadow:var(--shadow)}.year-selector{display:flex;flex-direction:column;gap:8px}.year-selector label{font-size:12px;font-weight:600;color:var(--text-secondary);text-transform:uppercase}.year-selector select{padding:10px 16px;font-size:16px;font-weight:600;color:var(--text-primary);background:var(--background);border:2px solid var(--border-color);border-radius:8px;cursor:pointer;transition:all .2s}.year-selector select:hover{border-color:var(--primary-color)}.year-selector select:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #007aff1a}.category-breakdown{margin-top:32px}.breakdown-table-header{display:grid;grid-template-columns:2fr 1.2fr 1.2fr 1.5fr;gap:24px;padding:18px 28px;background:var(--primary-color);color:#fff;font-weight:700;font-size:16px;border-radius:12px 12px 0 0;margin-bottom:2px;text-align:left}.header-name{text-align:left}.header-year{text-align:right;font-size:18px}.header-change{text-align:right}.category-comparison-block{background:var(--card-background);border-radius:0;margin-bottom:2px;overflow:hidden;box-shadow:var(--shadow)}.category-comparison-block:last-child{border-radius:0 0 12px 12px}.category-comparison-header{padding:20px 28px;cursor:pointer;display:grid;grid-template-columns:2fr 1.2fr 1.2fr 1.5fr;gap:24px;align-items:center;transition:background .2s;border-bottom:1px solid var(--border-color)}.category-comparison-header:hover{background:var(--background)}.category-comparison-name{font-weight:600;font-size:17px;color:var(--text-primary);display:flex;align-items:center;gap:12px}.expand-icon{font-size:14px;color:var(--text-secondary)}.category-comparison-value-cell{font-weight:600;font-size:16px;color:var(--text-primary);text-align:right}.category-comparison-change-cell{font-weight:700;font-size:16px;text-align:right}.category-comparison-change-cell.increase{color:#ff3b30}.category-comparison-change-cell.decrease{color:var(--planned-color)}.expense-comparison-list{background:var(--background);padding:0}.expense-comparison-row{padding:16px 28px 16px 56px;display:grid;grid-template-columns:2fr 1.2fr 1.2fr 1.5fr;gap:24px;align-items:center;cursor:pointer;transition:background .2s;border-bottom:1px solid var(--border-color)}.expense-comparison-row:last-child{border-bottom:none}.expense-comparison-row:hover{background:#007aff14}.expense-comparison-name{font-weight:500;font-size:15px;color:var(--text-primary);display:flex;align-items:center;gap:8px}.view-details-icon{font-size:14px;opacity:.6}.expense-comparison-value-cell{font-weight:500;font-size:15px;color:var(--text-primary);text-align:right}.expense-comparison-change-cell{font-weight:600;font-size:15px;text-align:right}.expense-comparison-change-cell.increase{color:#ff3b30}.expense-comparison-change-cell.decrease{color:var(--planned-color)}.expense-comparison-modal{max-width:96vw!important;width:96vw!important;max-height:92vh!important;height:92vh!important;padding:0!important;display:flex!important;flex-direction:column!important}.expense-comparison-modal .modal-header{padding:24px 48px;border-bottom:2px solid var(--border-color);margin-bottom:0;background:var(--card-background);border-radius:12px 12px 0 0;flex-shrink:0}.expense-comparison-modal .modal-header h2{font-size:22px;font-weight:700}.expense-comparison-modal .modal-body{flex:1;overflow-y:auto;padding:32px;min-height:0}.expense-comparison-modal .detail-summary{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-bottom:32px}.expense-comparison-modal .detail-stat{background:var(--background);padding:24px 28px;border-radius:12px;border:2px solid var(--border-color)}.expense-comparison-modal .detail-label{font-size:13px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;margin-bottom:12px;display:block;letter-spacing:.5px}.expense-comparison-modal .detail-value{font-size:24px;font-weight:700;color:var(--text-primary)}.expense-comparison-modal .modal-section-title{font-size:18px;font-weight:700;color:var(--text-primary);margin:32px 0 20px}.recent-trend{background:var(--card-background);padding:24px;border-radius:12px;margin-bottom:24px;border:2px solid var(--primary-color)}.recent-trend h3{font-size:16px;margin:0 0 20px;color:var(--text-primary);font-weight:700}.trend-summary{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;margin-bottom:20px}.trend-stat{display:flex;flex-direction:column;gap:8px}.trend-label{font-size:12px;color:var(--text-secondary);font-weight:600;text-transform:uppercase;letter-spacing:.5px}.trend-value{font-size:20px;font-weight:700;color:var(--text-primary)}.trend-value.higher{color:#ff3b30}.trend-value.lower{color:var(--planned-color)}.trend-months{display:flex;gap:16px;margin-top:20px}.trend-month{flex:1;background:var(--background);padding:16px;border-radius:8px;text-align:center;border:1px solid var(--border-color)}.trend-month-name{font-size:12px;color:var(--text-secondary);margin-bottom:8px;font-weight:600}.trend-month-amount{font-size:16px;font-weight:700;color:var(--primary-color)}.monthly-comparison-table{background:var(--card-background);border-radius:12px;overflow:hidden;box-shadow:var(--shadow)}.comparison-table-header{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.5fr;gap:24px;padding:16px 24px;background:var(--card-background);font-weight:700;font-size:13px;color:var(--text-secondary);text-transform:uppercase;border-bottom:2px solid var(--border-color);letter-spacing:.5px}.comparison-row-item{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.5fr;gap:24px;padding:14px 24px;border-bottom:1px solid var(--border-color);transition:background .2s;font-size:15px}.comparison-row-item:hover{background:#007aff0d}.comparison-row-item:last-child{border-bottom:none}.comparison-col{display:flex;align-items:center}.row-month{font-weight:600;color:var(--text-primary)}.row-previous,.row-current{color:var(--text-primary);justify-content:flex-end}.row-change{font-weight:600;justify-content:flex-end}.row-change.higher{color:#ff3b30}.row-change.lower{color:var(--planned-color)}@media(max-width:1024px){.analytics-scroll{padding:16px}.bar-chart{height:250px}.yoy-value{font-size:24px}.yoy-arrow{font-size:36px}.breakdown-table-header,.category-comparison-header,.expense-comparison-row{grid-template-columns:1.5fr 1fr 1fr 1.2fr;gap:12px;padding:12px 16px;font-size:13px}.expense-comparison-row{padding-left:32px}.header-year{font-size:14px}.comparison-table-header,.comparison-row-item{grid-template-columns:1fr .8fr .8fr 1fr;gap:8px;font-size:12px}}.followup{padding:0 0 80px}.followup .header{background:var(--card-background);padding:12px 16px;box-shadow:var(--shadow);margin:-16px -16px 12px;position:sticky;top:0;z-index:100}.followup .month-navigation{display:flex;align-items:center;justify-content:space-between;gap:15px}.followup .month-navigation button{background:#f97316;border:none;color:#fff;width:36px;height:36px;border-radius:50%;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:opacity .2s}.followup .month-navigation button:active{opacity:.6}.followup .month-title{flex:1;text-align:center;font-size:18px;font-weight:600}.year-summary{background:linear-gradient(135deg,#f97316,#ea580c);color:#fff;padding:16px 20px;border-radius:12px;margin:0 0 12px;box-shadow:0 4px 12px #f973164d}.year-summary .summary-label{font-size:12px;opacity:.95;margin-bottom:6px;font-weight:500}.year-summary .summary-amount{font-size:28px;font-weight:700;margin-bottom:6px}.year-summary .summary-subtitle{font-size:14px;opacity:.95;font-weight:500}.expand-collapse-container{display:flex;gap:8px;margin:0 0 12px;justify-content:flex-end;padding:0 16px}.btn-expand-collapse{padding:6px 12px;font-size:12px;font-weight:600;border:1px solid var(--border-color);border-radius:8px;background:var(--card-background);color:var(--text-primary);cursor:pointer;transition:all .2s}.btn-expand-collapse:hover{background:var(--primary-color);color:#fff;border-color:var(--primary-color)}.btn-expand-collapse:active{transform:scale(.98)}.category-block{background:var(--card-background);border-radius:14px;margin:0 0 12px;box-shadow:var(--shadow);overflow:hidden;transition:all .3s}.category-block.expanded{box-shadow:0 4px 16px #00000026}.category-header{padding:16px;cursor:pointer;-webkit-user-select:none;user-select:none;display:flex;justify-content:space-between;align-items:center}.category-header:active{background:var(--background)}.category-info{flex:1}.category-name{font-size:18px;font-weight:600;color:var(--text-primary);margin-bottom:8px}.category-stats{display:flex;gap:20px}.stat-item{display:flex;flex-direction:column;gap:2px}.stat-label{font-size:11px;color:var(--text-secondary);text-transform:uppercase;font-weight:600;letter-spacing:.5px}.stat-value{font-size:16px;font-weight:700;color:var(--primary-color)}.category-expand-icon{font-size:16px;color:var(--text-secondary);transition:transform .3s;margin-left:12px}.category-block.expanded .category-expand-icon{transform:rotate(180deg)}.expenses-list{padding:0 16px 16px;background:var(--background)}.expense-detail{padding:16px;background:var(--card-background);border-radius:12px;margin-bottom:12px}.expense-detail:last-child{margin-bottom:0}.expense-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.expense-name{font-size:16px;font-weight:600;color:var(--text-primary)}.expense-total{font-size:18px;font-weight:700;color:var(--primary-color)}.expense-stats{display:flex;gap:12px;margin-bottom:12px}.expense-stat{font-size:12px;color:var(--text-secondary);font-weight:500}.expense-stat.pending{color:var(--planned-color)}.month-bars{display:flex;gap:4px;align-items:flex-end;height:80px;padding:8px 0}.month-bar-wrapper{flex:1;display:flex;flex-direction:column;align-items:center;height:100%;justify-content:flex-end}.month-bar{width:100%;min-height:4px;border-radius:4px 4px 0 0;transition:all .2s;background:var(--border-color);position:relative;cursor:pointer}.month-bar.paid{background:linear-gradient(to top,#64d2ff,#3b82f6)}.month-bar.planned{background:linear-gradient(to top,#86efac,#22c55e)}.month-bar.unsure{background:linear-gradient(to top,#ff6b6b,#ff3b30)}.month-bar:hover{opacity:.8;transform:scaleY(1.05)}.bar-tooltip{position:absolute;bottom:100%;left:50%;transform:translate(-50%) translateY(-8px);background:#000000e6;color:#fff;padding:8px 12px;border-radius:8px;white-space:nowrap;z-index:1000;pointer-events:none;box-shadow:0 4px 12px #0000004d;animation:tooltip-fade-in .2s ease-out}@keyframes tooltip-fade-in{0%{opacity:0;transform:translate(-50%) translateY(-4px)}to{opacity:1;transform:translate(-50%) translateY(-8px)}}[data-theme=dark] .bar-tooltip{background:#fffffff2;color:#1a1a1a}.tooltip-month{font-size:11px;font-weight:600;text-transform:uppercase;opacity:.9;margin-bottom:2px}.tooltip-amount{font-size:14px;font-weight:700}.month-label{font-size:10px;color:var(--text-secondary);margin-top:4px;text-transform:uppercase;font-weight:600}.comparison-toggle{margin-top:12px;display:flex;justify-content:center}.comparison-toggle label{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:14px;font-weight:500;color:var(--text-primary);-webkit-user-select:none;user-select:none}.comparison-toggle input[type=checkbox]{width:18px;height:18px;cursor:pointer}.comparison-data{margin-top:12px;padding-top:12px;border-top:1px solid rgba(255,255,255,.2);display:flex;flex-direction:column;gap:6px}.comparison-row{display:flex;justify-content:space-between;font-size:13px}.comparison-label{opacity:.9;font-weight:500}.comparison-value{font-weight:700}.comparison-value.higher{color:#ff6b6b}.comparison-value.lower{color:#51cf66}.stat-comparison{margin-left:8px;font-size:12px;font-weight:600;padding:2px 6px;border-radius:4px}.stat-comparison.higher{background:#ff6b6b26;color:#ff6b6b}.stat-comparison.lower{background:#51cf6626;color:#51cf66}.expense-detail.clickable{cursor:pointer;transition:all .2s;border:2px solid transparent}.expense-detail.clickable:hover{border-color:var(--primary-color);transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.expense-detail.clickable:active{transform:translateY(0)}.view-details-hint{margin-left:8px;font-size:14px;opacity:.6}.expense-detail.clickable:hover .view-details-hint{opacity:1}.expense-comparison{margin-left:8px;font-size:14px;font-weight:600;padding:2px 8px;border-radius:4px;display:inline-block}.expense-comparison.higher{background:#ff6b6b26;color:#ff6b6b}.expense-comparison.lower{background:#51cf6626;color:#51cf66}.expense-detail-modal{max-width:700px;width:90vw;max-height:90vh;overflow-y:auto}@media(max-width:480px){.expense-detail-modal{width:95vw;padding:20px 16px}}.modal-body{padding:0}.detail-summary{display:flex;gap:16px;margin-bottom:24px;flex-wrap:wrap}@media(max-width:480px){.detail-summary{flex-direction:column;gap:12px}}.detail-stat{flex:1;min-width:150px;display:flex;flex-direction:column;gap:4px;padding:12px;background:var(--background);border-radius:8px}.detail-label{font-size:12px;color:var(--text-secondary);font-weight:600;text-transform:uppercase}.detail-value{font-size:18px;font-weight:700;color:var(--primary-color)}.detail-value.higher{color:#ff6b6b}.detail-value.lower{color:#51cf66}.modal-section-title{font-size:16px;font-weight:600;margin-bottom:12px;color:var(--text-primary)}.monthly-comparison-table{display:flex;flex-direction:column;gap:8px}.comparison-row-item{display:grid;grid-template-columns:100px 1fr 1fr 1fr;gap:12px;padding:12px;background:var(--background);border-radius:8px;align-items:center}@media(max-width:480px){.comparison-row-item{grid-template-columns:80px 1fr;grid-template-rows:auto auto;gap:8px}.row-month{grid-column:1;grid-row:1 / 3}.row-current{grid-column:2;grid-row:1}.row-previous{grid-column:2;grid-row:2;font-size:12px;opacity:.7}.row-change{grid-column:2;grid-row:2;justify-self:end;font-size:12px!important}}.row-month,.row-current{font-weight:600;color:var(--text-primary)}.row-previous{font-size:14px;color:var(--text-secondary)}.row-change{font-weight:600;font-size:14px;text-align:right}.row-change.higher{color:#ff6b6b}.row-change.lower{color:#51cf66}.savings{padding:0;min-height:100vh}.savings-summary{background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff;padding:24px;border-radius:14px;margin:0 16px 16px;box-shadow:0 4px 12px #22c55e4d}.summary-label{font-size:14px;opacity:.95;margin-bottom:8px;font-weight:500}.summary-amount{font-size:36px;font-weight:700;margin-bottom:8px}.summary-count{font-size:14px;opacity:.9;font-weight:500}.savings-accounts{padding:0 16px;margin-bottom:80px}.savings-account-card{background:var(--card-background);border-radius:14px;padding:16px;margin-bottom:12px;box-shadow:var(--shadow);display:flex;align-items:center;gap:16px}.account-icon{font-size:36px;width:60px;height:60px;background:var(--primary-color);border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.account-details{flex:1}.account-bank{font-size:11px;color:var(--text-secondary);text-transform:uppercase;font-weight:600;letter-spacing:.5px;margin-bottom:4px}.account-name{font-size:16px;font-weight:600;color:var(--text-primary);margin-bottom:6px}.account-balance{font-size:20px;font-weight:700;color:var(--primary-color)}.account-actions{display:flex;flex-direction:column;gap:8px;flex-shrink:0}.btn-edit{padding:8px 16px;font-size:14px;font-weight:600;border:none;border-radius:8px;background:var(--background);color:var(--text-primary);cursor:pointer;transition:all .2s;border:1px solid var(--border-color)}.btn-edit:hover{background:var(--primary-color);color:#fff;border-color:var(--primary-color)}.btn-edit:active{transform:scale(.98)}.btn-delete-text{padding:8px 16px;font-size:14px;font-weight:600;border:none;border-radius:8px;background:transparent;color:var(--danger-color);cursor:pointer;transition:all .2s}.btn-delete-text:hover{background:var(--danger-color);color:#fff}.btn-delete-text:active{transform:scale(.98)}.savings-form-container{padding:0 16px 16px}.savings-form{background:var(--card-background);border-radius:14px;padding:20px;box-shadow:var(--shadow)}.savings-form .form-group{margin-bottom:16px}.savings-form .form-group:last-of-type{margin-bottom:0}.savings-form label{display:block;font-size:14px;font-weight:600;color:var(--text-primary);margin-bottom:6px}.savings-form input{width:100%;padding:12px;border:1px solid var(--border-color);border-radius:8px;background:var(--background);color:var(--text-primary);font-size:16px;transition:border-color .2s}.savings-form input:focus{outline:none;border-color:var(--primary-color)}.empty-state{text-align:center;padding:60px 20px;color:var(--text-secondary)}.bottom-actions{position:fixed;bottom:0;left:0;right:0;padding:16px;background:var(--background);border-top:1px solid var(--border-color);z-index:10}.btn-action{width:100%;padding:16px;font-size:16px;font-weight:600;border:none;border-radius:12px;background:var(--primary-color);color:#fff;cursor:pointer;transition:opacity .2s}.btn-action:hover{opacity:.9}.btn-action:active{opacity:.7}.bottom-nav{position:fixed;bottom:0;left:0;right:0;height:var(--navbar-height);background:var(--card-background);border-top:1px solid var(--border-color);display:flex;justify-content:space-around;padding-bottom:max(env(safe-area-inset-bottom),0px);box-shadow:0 -2px 10px #0000001a;z-index:1000}.nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;background:none;border:none;color:var(--text-secondary);cursor:pointer;transition:color .2s}.nav-item:active{opacity:.6}.nav-item.active{color:var(--primary-color)}.nav-icon{font-size:24px}.nav-label{font-size:11px;font-weight:500}.manage-data{padding:0 0 100px;min-height:calc(100vh - var(--navbar-height, 60px))}.data-list{display:flex;flex-direction:column;gap:8px;padding:16px 16px 140px}.category-block{background:var(--card-background);border-radius:12px;overflow:hidden;box-shadow:var(--shadow)}.category-item{display:flex;justify-content:space-between;align-items:center;padding:16px;border-bottom:1px solid var(--border-color);background:var(--card-background)}.category-block.expanded .category-item{background:var(--background)}.expenses-list{display:none;background:var(--background);padding:8px 0}.category-block.expanded .expenses-list{display:block}.expense-item{display:flex;justify-content:space-between;align-items:center;padding:12px 16px 12px 32px;background:var(--card-background);margin:4px 12px;border-radius:8px;border-left:3px solid var(--primary-color)}.empty-expenses{padding:20px;text-align:center;color:var(--text-secondary);font-size:14px}.item-left{display:flex;align-items:center;gap:12px;flex:1;cursor:pointer}.category-item .item-left{cursor:pointer}.expense-item .item-left{cursor:grab}.drag-handle{color:var(--text-secondary);font-size:18px;cursor:grab;-webkit-user-select:none;user-select:none}.item-name{font-size:16px;font-weight:500;cursor:pointer}.expense-count{color:var(--text-secondary);font-size:14px;margin-left:4px;cursor:pointer}.expand-icon{color:var(--text-secondary);font-size:12px;margin-left:auto;cursor:pointer}.item-actions{display:flex;gap:8px}.btn-icon{background:none;border:none;font-size:18px;padding:4px 8px;cursor:pointer;color:var(--text-secondary);border-radius:4px}.btn-icon:hover{background:var(--background)}.btn-icon:active{opacity:.6}.btn-delete{color:#ff3b30}.bottom-actions{position:fixed;bottom:calc(var(--navbar-height) + 16px);left:16px;right:16px;display:flex;gap:12px;z-index:10}.btn-action{flex:1;padding:14px;background:var(--primary-color);color:#fff;border:none;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;box-shadow:var(--shadow)}.btn-action:active{opacity:.8}.empty-state,.loading{text-align:center;padding:40px 20px;color:var(--text-secondary)}.csv-mapping-modal{background:var(--card-background);border-radius:12px;width:95%;max-width:1400px;max-height:95vh;display:flex;flex-direction:column;overflow:hidden}.csv-mapping-modal .modal-header{padding:24px;border-bottom:2px solid var(--border-color);background:var(--card-background)}.csv-mapping-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;padding:20px 24px;background:var(--background);border-bottom:1px solid var(--border-color)}.csv-mapping-stats .stat{display:flex;flex-direction:column;gap:4px}.csv-mapping-stats .stat-label{font-size:12px;font-weight:600;color:var(--text-secondary);text-transform:uppercase}.csv-mapping-stats .stat-value{font-size:24px;font-weight:700;color:var(--primary-color)}.search-bar{padding:16px 24px;background:var(--card-background);border-bottom:1px solid var(--border-color)}.search-bar input{width:100%;padding:12px 16px;font-size:16px;border:2px solid var(--border-color);border-radius:8px;background:var(--background);color:var(--text-primary);transition:border-color .2s}.search-bar input:focus{outline:none;border-color:var(--primary-color)}.csv-mapping-scroll{flex:1;overflow-y:auto;padding:0 24px 24px}.csv-mapping-table{width:100%;border-collapse:collapse;margin-top:16px}.csv-mapping-table thead{position:sticky;top:0;background:var(--card-background);z-index:10;box-shadow:0 2px 4px #0000001a}.csv-mapping-table th{padding:12px;text-align:left;font-weight:600;font-size:13px;color:var(--text-secondary);text-transform:uppercase;border-bottom:2px solid var(--border-color);background:var(--card-background)}.csv-mapping-table tbody tr{border-bottom:1px solid var(--border-color);transition:background .2s}.csv-mapping-table tbody tr:hover{background:#007aff0d}.csv-mapping-table tbody tr.skip-row{opacity:.5}.csv-mapping-table td{padding:16px 12px;vertical-align:middle}.expense-name-cell{min-width:200px}.expense-name{font-weight:600;color:var(--text-primary);margin-bottom:4px}.expense-preview{font-size:12px;color:var(--text-secondary)}.year-total-cell{font-weight:600;color:var(--text-primary);min-width:120px}.action-select,.category-select,.expense-select{width:100%;padding:8px 12px;font-size:14px;border:2px solid var(--border-color);border-radius:8px;background:var(--background);color:var(--text-primary);cursor:pointer;transition:border-color .2s}.action-select:focus,.category-select:focus,.expense-select:focus{outline:none;border-color:var(--primary-color)}.action-select{min-width:140px;font-weight:600}.category-select{min-width:160px}.expense-select{min-width:180px}.new-expense-input{width:100%;padding:8px 12px;font-size:14px;border:2px solid var(--planned-color);border-radius:8px;background:#34c7590d;color:var(--text-primary);transition:border-color .2s}.new-expense-input:focus{outline:none;border-color:var(--planned-color);box-shadow:0 0 0 3px #34c7591a}.new-expense-input::placeholder{color:var(--text-secondary);font-style:italic}.csv-mapping-modal .modal-actions{padding:20px 24px;border-top:2px solid var(--border-color);background:var(--card-background);display:flex;gap:12px;justify-content:flex-end}.csv-mapping-modal .btn-save{padding:12px 24px;font-size:16px;font-weight:600}.csv-mapping-modal .btn-cancel{padding:12px 24px;font-size:16px}@media(max-width:1200px){.csv-mapping-table{font-size:13px}.csv-mapping-table th,.csv-mapping-table td{padding:10px 8px}.action-select,.category-select,.expense-select,.new-expense-input{font-size:13px;padding:6px 10px}}@media(max-width:768px){.csv-mapping-modal{width:100%;max-width:100%;border-radius:0}.csv-mapping-stats{grid-template-columns:repeat(2,1fr)}}.modal-overlay.active{display:flex;align-items:center;justify-content:center}.form-group{margin-bottom:16px}.form-group select{width:100%;padding:12px;font-size:16px;border:1px solid var(--border-color);border-radius:8px;background:var(--card-background);color:var(--text-primary)}.btn-cancel,.btn-confirm{flex:1;padding:12px;font-size:16px;font-weight:500;border:none;border-radius:8px;cursor:pointer;transition:opacity .2s}.btn-confirm{background:var(--primary-color);color:#fff}.btn-cancel:active,.btn-confirm:active{opacity:.8}.settings-page{display:flex;flex-direction:column;height:100vh;background:var(--bg-primary)}.settings-section{background:var(--card-background);border-radius:12px;margin:0 16px 12px;overflow:hidden;box-shadow:var(--shadow)}.settings-header{padding:16px 20px;background:var(--background);font-weight:600;font-size:14px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.settings-item{padding:12px 16px;border-bottom:1px solid var(--background);cursor:pointer;background:var(--card-background)}.settings-item:last-child{border-bottom:none}.settings-item:active{background:var(--background)}#categoryManageList,#expenseManageList,#budgetManageList{padding:16px;min-height:200px}.category-manage-item,.expense-manage-item{padding:12px 16px;background:var(--card-background);margin-bottom:8px;border-radius:12px;display:flex;align-items:center;gap:12px;cursor:move;box-shadow:var(--shadow);border:2px solid transparent;-webkit-user-select:none;user-select:none}.category-manage-item.dragging,.expense-manage-item.dragging{opacity:.5;border-color:var(--primary-color)}.drag-handle{font-size:20px;color:var(--text-secondary);cursor:grab;-webkit-user-select:none;user-select:none;line-height:1}.drag-handle:active{cursor:grabbing}.category-manage-name{flex:1;font-size:16px;font-weight:500;color:var(--text-primary);cursor:pointer;-webkit-user-select:none;user-select:none}.delete-btn{padding:8px 16px;background:#ff3b30;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:opacity .2s;flex-shrink:0}.delete-btn:active{opacity:.8}.add-category-btn{width:100%;padding:12px;background:var(--primary-color);color:#fff;border:none;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;margin-top:12px;transition:opacity .2s}.add-category-btn:active{opacity:.8}.form-group{margin:16px}.form-group label{display:block;font-size:14px;font-weight:500;margin-bottom:8px;color:var(--text-primary)}.form-group select,.form-group input{width:100%;padding:12px;font-size:16px;border:1px solid var(--border-color);border-radius:8px;background:var(--card-background);color:var(--text-primary)}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:9999;padding:20px}.modal-content{background:var(--card-background);border-radius:16px;width:100%;max-width:400px;box-shadow:0 10px 40px #0000004d}.modal-header{padding:20px;border-bottom:1px solid var(--background)}.modal-header h2{margin:0;font-size:20px;font-weight:600;color:var(--text-primary)}.modal-content form{padding:20px}.modal-content .form-group{margin:0 0 16px}.modal-actions{display:flex;gap:12px;margin-top:24px}.btn-cancel,.btn-save{flex:1;padding:12px;font-size:16px;font-weight:600;border:none;border-radius:8px;cursor:pointer;transition:opacity .2s}.btn-cancel{background:var(--background);color:var(--text-primary)}.btn-save{background:var(--primary-color);color:#fff}.btn-cancel:active,.btn-save:active{opacity:.8}.app{min-height:100vh;display:flex;flex-direction:column}.content{flex:1;max-width:800px;width:100%;margin:0 auto;padding:16px;padding-bottom:calc(var(--navbar-height) + 16px)}.pull-to-refresh-indicator{position:fixed;top:0;left:50%;transform:translate(-50%);z-index:101;display:flex;align-items:center;justify-content:center;pointer-events:none}.refresh-spinner{width:40px;height:40px;background:var(--primary-color);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:24px;box-shadow:0 2px 8px #007aff4d;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}:root{--primary-color: #007aff;--background: #f2f2f7;--card-background: #ffffff;--text-primary: #000000;--text-secondary: #8e8e93;--border-color: #c6c6c8;--planned-color: #34c759;--paid-color: #64d2ff;--shadow: 0 2px 8px rgba(0, 0, 0, .1);--navbar-height: 72px}[data-theme=dark]{--primary-color: #0a84ff;--background: #000000;--card-background: #1c1c1e;--text-primary: #ffffff;--text-secondary: #8e8e93;--border-color: #38383a;--planned-color: #30d158;--paid-color: #64d2ff;--shadow: 0 2px 8px rgba(0, 0, 0, .3);--navbar-height: 72px}*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;background-color:var(--background);color:var(--text-primary);padding-bottom:var(--navbar-height);overflow-x:hidden}#root{min-height:100vh}.modal-overlay{display:none;position:fixed;inset:0;background:#00000080;z-index:1000;align-items:center;justify-content:center}.modal-overlay.active{display:flex}.modal-content{background:var(--card-background);border-radius:12px;padding:24px;max-width:400px;width:90%;max-height:90vh;overflow-y:auto}.modal-header{font-size:20px;font-weight:600;margin-bottom:20px;color:var(--text-primary);display:flex;justify-content:space-between;align-items:center}.modal-header h2{margin:0;flex:1}.close-button{background:none;border:none;font-size:32px;color:var(--text-secondary);cursor:pointer;padding:0;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background .2s;flex-shrink:0}.close-button:hover{background:var(--background)}@media(max-width:768px){.modal-content{max-height:95vh;width:95%;padding:20px}}
