*{margin:0;padding:0;box-sizing:border-box}:root{--bg-primary: #f5f2ed;--bg-secondary: #ffffff;--bg-card: #ffffff;--bg-card-hover: #faf8f5;--bg-surface: #eae6e0;--bg-accent-card: #c4a96a;--bg-accent-card-2: #a68b5b;--bg-accent-card-3: #8b7345;--text-primary: #2d2a26;--text-secondary: #6b6560;--text-muted: #9c958e;--text-on-accent: #ffffff;--border-color: #e8e4de;--border-subtle: #f0ece6;--accent: #8b7345;--accent-light: #c4a96a;--accent-hover: #a68b5b;--green: #5a8a5e;--green-light: #e8f2e8;--red: #c45c4a;--red-light: #fceae7;--shadow-card: 0 2px 12px rgba(0, 0, 0, .04);--shadow-elevated: 0 8px 24px rgba(0, 0, 0, .08);--radius-lg: 1.25rem;--radius-md: 1rem;--radius-sm: .625rem;--transition-smooth: cubic-bezier(.4, 0, .2, 1)}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;background:var(--bg-primary);color:var(--text-primary);min-height:100vh;line-height:1.5}.app-layout{display:flex;min-height:100vh}.sidebar{width:72px;background:var(--bg-secondary);border-right:1px solid var(--border-color);display:flex;flex-direction:column;align-items:center;padding:1.5rem 0;position:fixed;top:0;left:0;height:100vh;z-index:100}.sidebar-nav{display:flex;flex-direction:column;gap:.5rem;align-items:center}.sidebar-btn{display:flex;flex-direction:column;align-items:center;gap:.2rem;background:transparent;border:none;padding:.6rem .5rem;border-radius:var(--radius-md);cursor:pointer;transition:background .2s,color .2s;color:var(--text-muted);width:60px}.sidebar-btn:hover,.sidebar-btn.active{background:var(--bg-surface);color:var(--accent)}.sidebar-icon{font-size:1.25rem}.sidebar-label{font-size:.6rem;font-weight:500;white-space:nowrap}.main-wrapper{flex:1;margin-left:72px;display:flex;flex-direction:column;min-height:100vh}.top-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 2rem;background:var(--bg-secondary);border-bottom:1px solid var(--border-color);position:sticky;top:0;z-index:50}.header-left{display:flex;align-items:center}.logo{display:flex;align-items:center;gap:.5rem}.logo-img{width:64px;height:64px;border-radius:8px;object-fit:contain;margin:-18px 0}.logo-text{font-size:1.25rem;font-weight:700;color:var(--text-primary)}.header-nav{display:flex;gap:0}.header-tab{background:transparent;border:none;padding:.6rem 1rem;font-size:.85rem;font-weight:500;color:var(--text-muted);cursor:pointer;border-bottom:2px solid transparent;transition:color .2s,border-color .2s}.header-tab:hover{color:var(--accent)}.header-tab.active{color:var(--accent);border-bottom-color:var(--accent);font-weight:600}.header-right{display:flex;align-items:center;gap:.75rem}.avatar-circle{width:36px;height:36px;border-radius:50%;background:var(--bg-surface);border:1px solid var(--border-color);display:flex;align-items:center;justify-content:center;font-size:1rem}.logout-btn{background:transparent;color:var(--text-secondary);border:none;padding:.4rem .75rem;font-size:.85rem;cursor:pointer;transition:color .2s;display:flex;align-items:center;gap:.25rem}.logout-btn:hover{color:var(--red)}.desktop-only{display:inline-flex}.user-menu-wrapper{position:relative;display:none}.user-menu-trigger{display:flex;align-items:center;gap:.4rem;background:transparent;border:none;cursor:pointer;padding:.25rem;border-radius:var(--radius-sm);transition:background .2s}.user-menu-trigger:hover{background:var(--bg-surface)}.user-menu-dropdown{position:absolute;top:calc(100% + .5rem);right:0;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-sm);box-shadow:var(--shadow-elevated);min-width:120px;z-index:500;overflow:hidden;animation:menu-fade-in .15s ease-out}@keyframes menu-fade-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.user-menu-item{display:block;width:100%;padding:.7rem 1rem;background:transparent;border:none;color:var(--text-primary);font-size:.85rem;text-align:left;cursor:pointer;transition:background .2s}.user-menu-item:hover{background:var(--red-light);color:var(--red)}.dropdown-chevron{font-size:1.2rem;transform:rotate(90deg);color:var(--text-muted)}.page-content{flex:1;padding:2rem;max-width:1400px;width:100%}.fab-add-transaction{position:fixed;bottom:2rem;right:2rem;background:var(--accent);color:#fff;border:none;padding:.85rem 1.5rem;border-radius:2rem;font-size:.9rem;font-weight:600;cursor:pointer;box-shadow:0 4px 16px #8b73454d;transition:transform .3s var(--transition-smooth),box-shadow .3s,opacity .3s;z-index:200}.fab-add-transaction:hover{transform:translateY(-2px);box-shadow:0 6px 24px #8b734566}.fab-add-transaction.fab-hidden{transform:translateY(100px);opacity:0;pointer-events:none}.fab-icon{display:none}.fab-text{display:inline}.dashboard{display:flex;flex-direction:column;gap:1.5rem;margin-bottom:1rem}.dashboard-loading,.dashboard-error{text-align:center;padding:3rem 1rem;color:var(--text-secondary)}.dashboard-error{color:var(--red)}.dashboard-month-selector{display:flex;align-items:center;justify-content:space-between}.month-prev-link,.month-next-link{background:transparent;border:none;color:var(--text-muted);font-size:.85rem;cursor:pointer}.month-prev-link:hover,.month-next-link:hover{color:var(--accent)}.month-center{display:flex;align-items:center;gap:.75rem}.month-selector{display:flex;align-items:center;justify-content:center;gap:1rem}.month-nav-btn{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-sm);width:2.25rem;height:2.25rem;font-size:1.25rem;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text-secondary);transition:background .2s,border-color .2s}.month-nav-btn:hover{background:var(--bg-surface);border-color:var(--accent);color:var(--accent)}.month-label{font-size:1.1rem;font-weight:600;color:var(--text-primary);min-width:160px;text-align:center}.summary-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}.summary-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:1.25rem;position:relative;min-height:110px;display:flex;flex-direction:column;justify-content:space-between;transition:transform .3s var(--transition-smooth),box-shadow .3s;box-shadow:var(--shadow-card)}.summary-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-elevated)}.card-top{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.card-label{font-size:.75rem;font-weight:500;color:var(--text-muted);flex-shrink:0}.card-badge{font-size:.65rem;font-weight:600;padding:.2rem .6rem;border-radius:1rem;white-space:nowrap}.badge-good{background:var(--green-light);color:var(--green)}.badge-danger,.badge-warning{background:var(--red-light);color:var(--red)}.card-value{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin-top:.5rem}.card-icon{position:absolute;right:1rem;bottom:1rem;font-size:1.5rem;opacity:.15}.card-income .card-badge{background:var(--green-light);color:var(--green)}.card-expenses .card-badge{background:var(--red-light);color:var(--red)}.mini-donut{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);opacity:.6}.mini-donut circle:first-child{stroke:var(--border-color)}.mini-donut circle:last-child{stroke:var(--accent)}.budget-progress-section{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:1.25rem 1.5rem;box-shadow:var(--shadow-card)}.budget-progress-header{display:flex;justify-content:space-between;font-size:.85rem;color:var(--text-secondary);margin-bottom:.75rem}.progress-bar{width:100%;height:.6rem;background:var(--bg-surface);border-radius:.3rem;overflow:hidden}.progress-fill{height:100%;border-radius:.3rem;background:var(--accent-light);transition:width .4s ease}.progress-fill.below-threshold{background:#d4a04a}.progress-fill.over-budget{background:var(--red)}.pacing-info{margin-top:.6rem;font-size:.8rem;color:var(--text-muted)}.pacing-good{color:var(--green);font-weight:600}.pacing-warning{color:#d4a04a;font-weight:600}.pacing-danger{color:var(--red);font-weight:600}.over-budget-indicator{margin-top:.75rem;padding:.75rem 1rem;background:var(--red-light);border:1px solid #f0c4bc;border-radius:var(--radius-sm);color:var(--red);font-weight:600;font-size:.85rem;text-align:center}.dashboard-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}.accounts-card,.breakdown-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:1.5rem;box-shadow:var(--shadow-card);transition:transform .3s var(--transition-smooth),box-shadow .3s}.accounts-card:hover,.breakdown-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-elevated)}.card-section-title{font-size:1.05rem;font-weight:700;color:var(--text-primary);margin-bottom:1rem}.accounts-grid{display:flex;flex-direction:column;gap:.75rem}.account-tile{background:var(--bg-accent-card);border-radius:var(--radius-md);padding:1rem 1.25rem;color:var(--text-on-accent);transition:transform .2s}.account-tile:nth-child(2){background:var(--bg-accent-card-2)}.account-tile:nth-child(3){background:var(--bg-accent-card-3)}.account-tile:nth-child(n+4){background:#6b6050}.account-tile:hover{transform:translateY(-2px)}.account-tile-icon{font-size:1rem;margin-bottom:.25rem;opacity:.8}.account-tile-name{font-size:.85rem;font-weight:600;opacity:.9}.account-tile-balance{font-size:1.2rem;font-weight:700;margin-top:.25rem}.account-tile-balance.negative{color:#ffccc5}.accounts-footer{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border-color)}.total-net-balance{display:flex;justify-content:space-between;align-items:center}.total-net-balance span:first-child{font-size:.85rem;color:var(--text-secondary)}.total-balance-value{font-size:1.3rem;font-weight:800;color:var(--accent)}.donut-chart-container{display:flex;justify-content:center;margin-bottom:1rem}.donut-svg{display:block}.donut-center-percent{font-size:1rem;font-weight:700;fill:var(--text-primary)}.donut-center-name{font-size:.6rem;font-weight:600;fill:var(--text-secondary)}.donut-center-amount{font-size:.8rem;font-weight:700;fill:var(--text-primary)}.breakdown-content{display:flex;flex-direction:column;align-items:center}.breakdown-legend{width:100%;display:flex;flex-direction:column;gap:.6rem}.legend-item{display:grid;grid-template-columns:12px 1fr auto;align-items:center;gap:.6rem}.legend-dot{width:12px;height:12px;border-radius:50%}.legend-name{font-size:.85rem;color:var(--text-secondary)}.legend-amount{font-size:.85rem;font-weight:600;color:var(--text-primary)}.legend-bar-track{grid-column:1 / -1;height:3px;background:var(--bg-surface);border-radius:2px;overflow:hidden;margin-top:-.2rem}.legend-bar-fill{height:100%;border-radius:2px;transition:width .3s ease}.no-data-text{color:var(--text-muted);font-size:.9rem;text-align:center;padding:1rem 0}.login-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1rem;background:var(--bg-primary);position:relative}.login-glow{position:absolute;top:-100px;left:50%;transform:translate(-50%);width:300px;height:300px;background:radial-gradient(circle,rgba(196,169,106,.1) 0%,transparent 70%);pointer-events:none}.login-card{background:var(--bg-card);border-radius:var(--radius-lg);padding:2.5rem 2rem 2rem;width:100%;max-width:360px;text-align:center;box-shadow:var(--shadow-elevated);border:1px solid var(--border-color)}.login-logo{margin-bottom:1rem}.login-logo-img{width:80px;height:80px;object-fit:cover;border-radius:16px}.login-brand{font-size:1.75rem;font-weight:800;color:var(--accent);margin-bottom:.25rem}.login-tagline{color:var(--text-muted);font-size:.85rem;font-style:italic}.login-divider{width:40px;height:2px;background:var(--accent-light);opacity:.5;margin:1.25rem auto;border-radius:1px}.login-subtitle{color:var(--text-secondary);font-size:.9rem;margin-bottom:1.25rem}.login-error{color:var(--red);font-size:.8rem;margin:.5rem 0}.login-loading{color:var(--text-muted);font-size:.8rem;margin:.5rem 0}.pin-dots{display:flex;justify-content:center;gap:1rem;margin-bottom:1.5rem}.pin-dot{width:16px;height:16px;border-radius:50%;border:2px solid var(--border-color);background:transparent;transition:background .2s,border-color .2s,transform .2s}.pin-dot.filled{background:var(--accent);border-color:var(--accent);transform:scale(1.1);box-shadow:0 0 8px #8b73454d}.pin-shake{animation:shake .4s ease-in-out}@keyframes shake{0%,to{transform:translate(0)}20%{transform:translate(-8px)}40%{transform:translate(8px)}60%{transform:translate(-6px)}80%{transform:translate(6px)}}.pin-keypad{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem;max-width:260px;margin:0 auto}.keypad-btn{width:64px;height:64px;border-radius:50%;border:1px solid var(--border-color);background:var(--bg-primary);color:var(--text-primary);font-size:1.4rem;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;margin:0 auto;transition:background .15s,border-color .15s,transform .1s}.keypad-btn:hover:not(:disabled){background:var(--bg-surface);border-color:var(--accent-light)}.keypad-btn:active:not(:disabled){transform:scale(.92);background:var(--bg-surface)}.keypad-btn:disabled{opacity:.4;cursor:not-allowed}.keypad-delete{font-size:1.2rem;border-color:transparent;background:transparent}.keypad-delete:hover:not(:disabled){background:var(--red-light)}.keypad-spacer{width:64px;height:64px}.signup-form{display:flex;flex-direction:column;gap:.75rem;text-align:left}.auth-field{display:flex;flex-direction:column;gap:.3rem}.auth-field label{font-size:.75rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.03em}.auth-field input{padding:.65rem .75rem;border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:.9rem;color:var(--text-primary);background:var(--bg-primary);outline:none;transition:border-color .2s}.auth-field input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #8b73451a}.auth-submit-btn{width:100%;padding:.75rem;background:var(--accent);color:#fff;border:none;border-radius:var(--radius-sm);font-size:.9rem;font-weight:600;cursor:pointer;transition:background .2s;margin-top:.5rem}.auth-submit-btn:hover:not(:disabled){background:var(--accent-hover)}.auth-submit-btn:disabled{opacity:.5;cursor:not-allowed}.auth-switch{margin-top:1.25rem;font-size:.8rem;color:var(--text-muted)}.auth-switch-btn{background:none;border:none;color:var(--accent);font-weight:600;cursor:pointer;font-size:.8rem}.auth-switch-btn:hover{text-decoration:underline}.transaction-list{display:flex;flex-direction:column;gap:1rem;margin-top:1rem;margin-bottom:1rem}.transaction-list-loading,.transaction-list-error{text-align:center;padding:3rem 1rem;color:var(--text-secondary)}.transaction-list-error{color:var(--red)}.transaction-list-empty{text-align:center;padding:2rem 1rem;color:var(--text-muted)}.transaction-date-group{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);overflow:hidden}.transaction-date-header{font-size:.75rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.03em;padding:.6rem 1rem;background:var(--bg-primary);border-bottom:1px solid var(--border-color)}.transaction-items{list-style:none}.transaction-item{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;border-bottom:1px solid var(--border-subtle);gap:.75rem;transition:background .2s}.transaction-item:hover{background:var(--bg-card-hover)}.transaction-item:last-child{border-bottom:none}.transaction-item.excluded{background:#fdf8f0;border-left:3px solid var(--accent-light)}.transaction-info{display:flex;flex-direction:column;gap:.2rem;min-width:0;flex:1}.transaction-primary{display:flex;align-items:center;gap:.5rem}.transaction-category{font-size:.9rem;font-weight:600;color:var(--text-primary)}.excluded-badge{font-size:.6rem;font-weight:700;text-transform:uppercase;background:#f5edd8;color:var(--accent);padding:.1rem .4rem;border-radius:.25rem}.transaction-secondary{display:flex;align-items:center;gap:.5rem;font-size:.8rem;color:var(--text-muted)}.transaction-account{white-space:nowrap}.transaction-note{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:150px}.transaction-note:before{content:"· "}.transaction-right{display:flex;flex-direction:column;align-items:flex-end;gap:.3rem;flex-shrink:0}.transaction-amount{font-size:.95rem;font-weight:700}.transaction-amount.income{color:var(--green)}.transaction-amount.expense{color:var(--red)}.transaction-actions{display:flex;gap:.25rem}.txn-edit-btn,.txn-delete-btn{background:transparent;border:none;cursor:pointer;font-size:.85rem;padding:.2rem .35rem;border-radius:.25rem;transition:background .2s}.txn-edit-btn:hover{background:#e8f0ff}.txn-delete-btn:hover{background:var(--red-light)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000004d;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal-content{background:var(--bg-card);border-radius:var(--radius-lg);width:100%;max-width:440px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-elevated);border:1px solid var(--border-color);animation:modal-slide-in .2s ease-out}@keyframes modal-slide-in{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem .75rem;border-bottom:1px solid var(--border-color)}.modal-header h2{font-size:1.15rem;font-weight:700;color:var(--text-primary)}.modal-close-btn{background:transparent;border:none;font-size:1.5rem;color:var(--text-muted);cursor:pointer;padding:.25rem;border-radius:.25rem}.modal-close-btn:hover{color:var(--text-primary);background:var(--bg-surface)}.transaction-form{padding:1.25rem 1.5rem 1.5rem;display:flex;flex-direction:column;gap:1rem}.form-field{display:flex;flex-direction:column;gap:.3rem}.form-field label{font-size:.8rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.03em}.form-field input,.form-field select{padding:.6rem .75rem;border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:.95rem;color:var(--text-primary);background:var(--bg-primary);outline:none;transition:border-color .2s}.form-field input:focus,.form-field select:focus{border-color:var(--accent);box-shadow:0 0 0 3px #8b73451a}.field-error{font-size:.78rem;color:var(--red)}.form-submit-error{font-size:.85rem;color:var(--red);text-align:center}.form-actions{display:flex;gap:.75rem;margin-top:.5rem}.form-cancel-btn{flex:1;padding:.65rem 1rem;background:transparent;border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:.9rem;color:var(--text-secondary);cursor:pointer}.form-cancel-btn:hover{background:var(--bg-surface)}.form-save-btn{flex:1;padding:.65rem 1rem;background:var(--accent);border:none;border-radius:var(--radius-sm);font-size:.9rem;font-weight:600;color:#fff;cursor:pointer}.form-save-btn:hover:not(:disabled){background:var(--accent-hover)}.form-save-btn:disabled{opacity:.5;cursor:not-allowed}.category-manager{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:1.5rem;box-shadow:var(--shadow-card)}.category-manager-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.category-manager-header h2{font-size:1.15rem;font-weight:700;color:var(--text-primary)}.category-manager-loading,.category-manager-error{text-align:center;padding:2rem 1rem;color:var(--text-secondary)}.category-manager-error{color:var(--red)}.category-add-form{display:flex;gap:.5rem;margin-bottom:1rem}.category-add-form input{flex:1;padding:.5rem .75rem;border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:.9rem;background:var(--bg-primary);color:var(--text-primary);outline:none}.category-add-form input:focus{border-color:var(--accent)}.category-add-btn{padding:.5rem 1rem;background:var(--accent);color:#fff;border:none;border-radius:var(--radius-sm);font-size:.85rem;font-weight:600;cursor:pointer;white-space:nowrap}.category-add-btn:hover:not(:disabled){background:var(--accent-hover)}.category-add-btn:disabled{opacity:.5;cursor:not-allowed}.category-form-error{font-size:.8rem;color:var(--red);margin:.25rem 0 .5rem}.category-list{list-style:none;display:flex;flex-direction:column}.category-item{padding:.6rem 0;border-bottom:1px solid var(--border-subtle)}.category-item:last-child{border-bottom:none}.category-display-row{display:flex;align-items:center;justify-content:space-between;gap:.75rem}.category-name{font-size:.9rem;color:var(--text-primary);font-weight:500}.category-controls{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.exclusion-toggle{display:flex;align-items:center;gap:.3rem;cursor:pointer;font-size:.75rem;color:var(--text-muted);-webkit-user-select:none;user-select:none}.exclusion-toggle input[type=checkbox]{width:1rem;height:1rem;cursor:pointer;accent-color:var(--accent)}.exclusion-label{white-space:nowrap}.category-edit-btn,.category-delete-btn{background:transparent;border:none;cursor:pointer;font-size:.85rem;padding:.2rem .35rem;border-radius:.25rem}.category-edit-btn:hover{background:#e8f0ff}.category-delete-btn:hover{background:var(--red-light)}.category-edit-row{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.category-edit-row input{flex:1;min-width:120px;padding:.4rem .6rem;border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:.9rem;background:var(--bg-primary);color:var(--text-primary);outline:none}.category-edit-row input:focus{border-color:var(--accent)}.category-save-btn{padding:.35rem .75rem;background:var(--green);color:#fff;border:none;border-radius:var(--radius-sm);font-size:.8rem;font-weight:600;cursor:pointer}.category-cancel-btn{padding:.35rem .75rem;background:transparent;color:var(--text-secondary);border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:.8rem;cursor:pointer}.category-conflict-body{padding:1.25rem 1.5rem 1.5rem;display:flex;flex-direction:column;gap:.75rem}.category-conflict-body p{font-size:.9rem;color:var(--text-secondary)}.category-conflict-body .form-save-btn{align-self:flex-end;width:auto;padding:.5rem 1.5rem}.account-manager{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:1.5rem;box-shadow:var(--shadow-card)}.account-manager-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.account-manager-header h2{font-size:1.15rem;font-weight:700;color:var(--text-primary)}.account-manager-loading,.account-manager-error{text-align:center;padding:2rem 1rem;color:var(--text-secondary)}.account-manager-error{color:var(--red)}.account-add-form{display:flex;gap:.5rem;margin-bottom:1rem}.account-add-form input{flex:1;padding:.5rem .75rem;border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:.9rem;background:var(--bg-primary);color:var(--text-primary);outline:none}.account-add-form input:focus{border-color:var(--accent)}.account-add-btn{padding:.5rem 1rem;background:var(--accent);color:#fff;border:none;border-radius:var(--radius-sm);font-size:.85rem;font-weight:600;cursor:pointer;white-space:nowrap}.account-add-btn:hover:not(:disabled){background:var(--accent-hover)}.account-add-btn:disabled{opacity:.5;cursor:not-allowed}.account-form-error{font-size:.8rem;color:var(--red);margin:.25rem 0 .5rem}.account-list{list-style:none;display:flex;flex-direction:column}.account-manager-item{padding:.6rem 0;border-bottom:1px solid var(--border-subtle)}.account-manager-item:last-child{border-bottom:none}.account-display-row{display:flex;align-items:center;justify-content:space-between;gap:.75rem}.account-info{display:flex;flex-direction:column;gap:.15rem}.account-manager-name{font-size:.9rem;color:var(--text-primary);font-weight:500}.account-manager-balance{font-size:.8rem;color:var(--green);font-weight:600}.account-controls{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.account-edit-btn,.account-delete-btn{background:transparent;border:none;cursor:pointer;font-size:.85rem;padding:.2rem .35rem;border-radius:.25rem}.account-edit-btn:hover{background:#e8f0ff}.account-delete-btn:hover{background:var(--red-light)}.account-edit-row{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.account-edit-row input{flex:1;min-width:100px;padding:.4rem .6rem;border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:.9rem;background:var(--bg-primary);color:var(--text-primary);outline:none}.account-save-btn{padding:.35rem .75rem;background:var(--green);color:#fff;border:none;border-radius:var(--radius-sm);font-size:.8rem;font-weight:600;cursor:pointer}.account-cancel-btn{padding:.35rem .75rem;background:transparent;color:var(--text-secondary);border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:.8rem;cursor:pointer}.account-conflict-body{padding:1.25rem 1.5rem 1.5rem;display:flex;flex-direction:column;gap:.75rem}.account-conflict-body p{font-size:.9rem;color:var(--text-secondary)}.account-conflict-body .form-save-btn{align-self:flex-end;width:auto;padding:.5rem 1.5rem}.budget-settings{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:1.5rem;box-shadow:var(--shadow-card)}.budget-settings-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem}.budget-settings-header h2{font-size:1.15rem;font-weight:700;color:var(--text-primary)}.budget-settings-section{padding:1rem 0;border-bottom:1px solid var(--border-subtle)}.budget-settings-section:last-child{border-bottom:none;padding-bottom:0}.budget-settings-section-title{font-size:.95rem;font-weight:600;color:var(--text-primary);margin-bottom:.75rem}.budget-settings-description{font-size:.85rem;color:var(--text-muted);margin-bottom:.75rem}.budget-settings-form{display:flex;flex-direction:column;gap:.75rem;margin-top:.75rem}.budget-settings-form input{padding:.5rem .75rem;border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:.9rem;background:var(--bg-primary);color:var(--text-primary);outline:none}.budget-settings-form input:focus{border-color:var(--accent)}.budget-settings-save-btn{align-self:flex-start;padding:.55rem 1.25rem;background:var(--accent);color:#fff;border:none;border-radius:var(--radius-sm);font-size:.85rem;font-weight:600;cursor:pointer}.budget-settings-save-btn:hover:not(:disabled){background:var(--accent-hover)}.budget-settings-save-btn:disabled{opacity:.5;cursor:not-allowed}.budget-settings-error{font-size:.8rem;color:var(--red)}.budget-settings-success{font-size:.8rem;color:var(--green);font-weight:500}.offline-banner{position:fixed;top:0;left:0;right:0;background:#fdf8f0;border-bottom:1px solid var(--accent-light);color:var(--accent);font-size:.85rem;font-weight:500;text-align:center;padding:.5rem 1rem;z-index:9999}.sync-banner{position:fixed;top:0;left:0;right:0;background:#e8f2e8;border-bottom:1px solid var(--green);color:var(--green);font-size:.85rem;font-weight:500;text-align:center;padding:.5rem 1rem;z-index:9999}.bottom-nav{display:none;position:fixed;bottom:0;left:0;right:0;background:var(--bg-secondary);border-top:1px solid var(--border-color);padding:.6rem 0 .8rem;z-index:300;justify-content:space-around;align-items:center}.bottom-nav-btn{display:flex;flex-direction:column;align-items:center;gap:.25rem;background:transparent;border:none;padding:.5rem .75rem;cursor:pointer;color:var(--text-muted);transition:color .2s;min-width:56px}.bottom-nav-btn.active{color:var(--accent)}.bottom-nav-icon{font-size:1.5rem}.bottom-nav-label{font-size:.7rem;font-weight:600;white-space:nowrap}@media (max-width: 1024px){.dashboard-grid{grid-template-columns:1fr}.summary-cards{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.sidebar{display:none}.main-wrapper{margin-left:0}.header-nav{display:none}.top-header{padding:.75rem 1rem;margin:.5rem;border-radius:var(--radius-lg);border:1px solid var(--border-color);background:var(--bg-card)}.desktop-only{display:none}.user-menu-wrapper{display:block}.page-content{padding:1rem 1rem 5rem}.fab-add-transaction{bottom:7rem;right:1.5rem;padding:0;width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.75rem;font-weight:300}.fab-text{display:none}.fab-icon{display:inline;line-height:1}.bottom-nav{display:flex}}@media (max-width: 480px){.summary-cards{grid-template-columns:1fr 1fr}.card-value{font-size:1.2rem}.dashboard-month-selector{flex-direction:column;gap:.5rem}.month-prev-link,.month-next-link{display:none}.account-manager,.category-manager,.budget-settings{padding:1rem}.account-add-form,.category-add-form{flex-direction:column}.account-add-form input,.account-add-btn,.category-add-form input,.category-add-btn{width:100%}.account-edit-row,.category-edit-row{flex-direction:column;align-items:stretch}.account-edit-row input,.category-edit-row input{min-width:unset;width:100%}.budget-settings-save-btn{align-self:stretch;text-align:center}.transaction-item{padding:.6rem .75rem}.transaction-note{max-width:80px}.modal-content{max-width:100%;margin:.5rem;border-radius:var(--radius-md)}.transaction-form{padding:1rem}}
