:root{font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.5;font-weight:400;color:#1f2933;background-color:#f5f7fa;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;background-color:#f5f7fa;color:#1f2933}*{box-sizing:border-box}a{color:inherit}button{display:inline-flex;align-items:center;justify-content:center;gap:.35rem;border-radius:.5rem;border:1px solid transparent;padding:.55rem 1.1rem;font-size:.95rem;font-weight:600;font-family:inherit;background-color:#2563eb;color:#fff;cursor:pointer;transition:background-color .2s ease,transform .2s ease}button:hover{background-color:#1e4fc7}button:disabled{opacity:.7;cursor:not-allowed}input,select,textarea{width:100%;padding:.55rem .65rem;border-radius:.5rem;border:1px solid #cbd5e1;font-size:.95rem;font-family:inherit;background-color:#fff}label{font-weight:600;font-size:.85rem;color:#475569}form{display:grid;gap:.9rem}.card{background-color:#fff;border-radius:1rem;padding:1.5rem;box-shadow:0 10px 30px #0f172a14}.table{width:100%;border-collapse:collapse;font-size:.95rem}.table th,.table td{padding:.75rem 1rem;text-align:left;border-bottom:1px solid #e2e8f0}.table tbody tr:hover{background-color:#f8fafc}.badge{display:inline-flex;align-items:center;border-radius:999px;padding:.1rem .7rem;font-size:.8rem;background-color:#e0f2fe;color:#0369a1;font-weight:600}.tag{background-color:#ede9fe;color:#5b21b6;padding:.2rem .6rem;border-radius:999px;font-size:.75rem;font-weight:500}.grid{display:grid;gap:1.5rem}.grid.two-columns{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;gap:1rem}.page-header h1{margin:0;font-size:1.75rem}.actions{display:flex;gap:.75rem;flex-wrap:wrap}.empty-state{padding:2rem;text-align:center;color:#64748b;font-size:.95rem}.error{color:#dc2626;font-size:.85rem}.success{color:#15803d;font-size:.85rem}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1rem}.stat-card{background:linear-gradient(135deg,#2563eb,#4f46e5);color:#fff;border-radius:1rem;padding:1.1rem 1.3rem}.stat-card h3{margin:0;font-size:.95rem;opacity:.9}.stat-card p{margin:.1rem 0 0;font-size:1.8rem;font-weight:700}.speed-dial-container{position:fixed;bottom:2rem;right:2rem;z-index:1000;display:flex;flex-direction:column-reverse;align-items:flex-end;gap:1rem}.speed-dial-trigger{width:56px;height:56px;border-radius:50%;background-color:#2563eb;color:#fff;border:none;box-shadow:0 4px 12px #2563eb66;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .3s cubic-bezier(.175,.885,.32,1.275),background-color .2s}.speed-dial-trigger:hover{background-color:#1d4ed8;transform:scale(1.05)}.speed-dial-trigger.open{transform:rotate(45deg);background-color:#ef4444;box-shadow:0 4px 12px #ef444466}.speed-dial-actions{display:flex;flex-direction:column-reverse;gap:.75rem;align-items:flex-end;margin-bottom:.5rem}.speed-dial-action{display:flex;align-items:center;gap:.75rem;opacity:0;transform:translateY(20px) scale(.8);pointer-events:none;transition:all .2s cubic-bezier(.68,-.55,.265,1.55)}.speed-dial-container.open .speed-dial-action{opacity:1;transform:translateY(0) scale(1);pointer-events:auto}.speed-dial-container.open .speed-dial-action:nth-child(1){transition-delay:.05s}.speed-dial-container.open .speed-dial-action:nth-child(2){transition-delay:.1s}.speed-dial-container.open .speed-dial-action:nth-child(3){transition-delay:.15s}.speed-dial-container.open .speed-dial-action:nth-child(4){transition-delay:.2s}.speed-dial-container.open .speed-dial-action:nth-child(5){transition-delay:.25s}.speed-dial-container.open .speed-dial-action:nth-child(6){transition-delay:.3s}.speed-dial-container.open .speed-dial-action:nth-child(7){transition-delay:.35s}.speed-dial-container.open .speed-dial-action:nth-child(8){transition-delay:.4s}.action-btn{width:48px;height:48px;border-radius:50%;background-color:#fff;color:#475569;border:1px solid #e2e8f0;box-shadow:0 4px 6px #0000000d;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;text-decoration:none}.action-btn.active{background-color:#eff6ff;color:#2563eb;border-color:#2563eb}.action-btn:hover{background-color:#f8fafc;transform:scale(1.1);box-shadow:0 6px 12px #0000001a;color:#1e293b}.action-label{background-color:#fff;padding:.35rem .75rem;border-radius:.5rem;font-size:.85rem;font-weight:600;color:#334155;box-shadow:0 2px 8px #0000001a;white-space:nowrap;opacity:.9}.speed-dial-backdrop{position:fixed;top:0;left:0;width:100vw;height:100vh;background-color:#fffc;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:999;opacity:0;pointer-events:none;transition:opacity .3s ease}.speed-dial-backdrop.open{opacity:1;pointer-events:auto}.dashboard-container{max-width:1200px;margin:0 auto;padding-bottom:5rem}.dashboard-header{margin-bottom:2rem;display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:1rem}.dashboard-header h1{font-size:1.75rem;color:#0f172a;margin:0 0 .5rem}.dashboard-header p{color:#64748b;margin:0}.btn-refresh{background:#fff;border:1px solid #e2e8f0;color:#475569;padding:.5rem 1rem;border-radius:.75rem;font-weight:500;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:.5rem}.btn-refresh:hover{background:#f8fafc;border-color:#cbd5e1}.filter-bar{background:#fff;padding:1rem 1.5rem;border-radius:1rem;box-shadow:0 4px 6px -1px #0000000d;display:flex;align-items:flex-end;gap:1.5rem;margin-bottom:2rem;flex-wrap:wrap;animation:slideDown .3s ease-out}.filter-group{display:flex;flex-direction:column;gap:.5rem}.filter-group label{font-size:.8rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.5px}.filter-group input{padding:.6rem;border:1px solid #e2e8f0;border-radius:.5rem;color:#334155;font-family:inherit}.filter-actions{display:flex;gap:.75rem}.btn-apply{background:#3b82f6;color:#fff;border:none;padding:.6rem 1.25rem;border-radius:.5rem;font-weight:600;cursor:pointer}.btn-clear{background:transparent;color:#64748b;border:none;padding:.6rem 1rem;cursor:pointer;font-weight:500}.filter-info{margin-left:auto;color:#64748b;font-size:.9rem;background:#f1f5f9;padding:.5rem 1rem;border-radius:2rem}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.5rem;margin-bottom:2rem}.stat-card{background:#fff;padding:1.5rem;border-radius:1.25rem;color:#fff;display:flex;flex-direction:column;justify-content:space-between;box-shadow:0 10px 15px -3px #0000001a;min-height:120px;transition:transform .2s}.stat-card:hover{transform:translateY(-4px)}.stat-title{font-size:.9rem;font-weight:500;opacity:.9;letter-spacing:.5px}.stat-value{font-size:1.75rem;font-weight:700;margin:.5rem 0 0}.charts-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:1.5rem;margin-bottom:2rem}.chart-card{background:#fff;border-radius:1.25rem;padding:1.5rem;box-shadow:0 4px 6px -1px #0000000d}.chart-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.chart-header h2{font-size:1.15rem;margin:0;color:#334155}.chart-controls select{padding:.4rem .8rem;border-radius:.5rem;border:1px solid #e2e8f0;color:#475569;background-color:#f8fafc;font-size:.85rem}.full-width{grid-column:1 / -1}@media (max-width: 768px){.dashboard-header{flex-direction:column;align-items:flex-start}.filter-bar{flex-direction:column;align-items:stretch}.filter-actions,.filter-info{margin-left:0}}.modal-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background-color:#0f172a99;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:2000;opacity:0;animation:fadeIn .2s forwards}.modal-content{background:#fff;padding:1.5rem;border-radius:1rem;width:90%;max-width:400px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;transform:scale(.95);animation:scaleUp .2s forwards}@keyframes fadeIn{to{opacity:1}}@keyframes scaleUp{to{transform:scale(1)}}.modal-header{margin-bottom:1rem}.modal-title{font-size:1.25rem;font-weight:700;color:#0f172a;margin:0}.modal-body{color:#64748b;margin-bottom:1.5rem;font-size:1rem;line-height:1.5}.modal-actions{display:flex;gap:.75rem;justify-content:flex-end}.btn-cancel{background:#f1f5f9;color:#475569;border:none;padding:.6rem 1rem;border-radius:.5rem;font-weight:600;cursor:pointer;transition:background .2s}.btn-cancel:hover{background:#e2e8f0}.btn-confirm{color:#fff;border:none;padding:.6rem 1rem;border-radius:.5rem;font-weight:600;cursor:pointer;transition:background .2s;box-shadow:0 4px 6px -1px #0000001a}.btn-confirm.danger{background:#ef4444;box-shadow:0 4px 6px -1px #ef444433}.btn-confirm.danger:hover{background:#dc2626}.btn-confirm.primary{background:#2563eb;box-shadow:0 4px 6px -1px #2563eb33}.btn-confirm.primary:hover{background:#1d4ed8}.btn-confirm.success{background:#10b981;box-shadow:0 4px 6px -1px #10b98133}.btn-confirm.success:hover{background:#059669}.accounts-container{max-width:1200px;margin:0 auto;padding-bottom:5rem}.page-header{margin-bottom:2rem;display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:1rem}.page-header h1{font-size:1.75rem;color:#0f172a;margin:0 0 .5rem}.form-section{background:#fff;border-radius:1rem;padding:1.5rem;box-shadow:0 4px 6px -1px #0000000d;margin-bottom:2rem;animation:slideDown .3s ease-out}.form-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;cursor:pointer}.form-title{font-size:1.15rem;font-weight:600;color:#334155;margin:0;display:flex;align-items:center;gap:.5rem}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.25rem}.form-group label{font-size:.85rem;font-weight:600;color:#475569}.form-group input,.form-group select,.form-group textarea{padding:.75rem;border:1px solid #e2e8f0;border-radius:.5rem;font-size:.95rem;transition:border-color .2s;font-family:inherit}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#3b82f6;outline:none;box-shadow:0 0 0 2px #3b82f61a}.form-actions{display:flex;justify-content:flex-end;gap:1rem;margin-top:1.5rem}.btn-primary{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:.5rem;font-weight:600;cursor:pointer;transition:transform .1s,box-shadow .2s}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 6px -1px #2563eb4d}.accounts-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.account-card{background:#fff;border-radius:1.25rem;padding:1.5rem;box-shadow:0 4px 6px -1px #0000000d;transition:transform .2s,box-shadow .2s;display:flex;flex-direction:column;position:relative;overflow:hidden;border:1px solid #f1f5f9}.account-card:hover{transform:translateY(-4px);box-shadow:0 10px 15px -3px #0000001a}.card-header-row{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem}.bank-icon{width:48px;height:48px;border-radius:12px;background:#f1f5f9;display:flex;align-items:center;justify-content:center;font-size:1.5rem;color:#334155;box-shadow:inset 0 2px 4px #0000000d}.account-type-badge{font-size:.7rem;font-weight:600;text-transform:uppercase;padding:.25rem .5rem;border-radius:1rem;background:#e2e8f0;color:#475569}.account-name{font-size:1.15rem;font-weight:700;color:#0f172a;margin:0 0 .25rem}.account-institution{font-size:.9rem;color:#64748b;margin:0}.account-balance{margin-top:1.5rem}.balance-label{font-size:.8rem;color:#94a3b8;font-weight:500;text-transform:uppercase}.balance-amount{font-size:1.75rem;font-weight:700;color:#0f172a;letter-spacing:-.5px}.account-meta{margin-top:1.5rem;padding-top:1rem;border-top:1px solid #f1f5f9;display:flex;justify-content:space-between;align-items:center;font-size:.85rem;color:#64748b}.meta-house{display:flex;align-items:center;gap:.4rem}.account-actions{display:flex;gap:.5rem}.action-btn{background:transparent;border:none;padding:.4rem;border-radius:.375rem;cursor:pointer;color:#94a3b8;transition:all .2s;display:flex;align-items:center;justify-content:center}.action-btn:hover{background:#f1f5f9;color:#334155}.action-btn.delete:hover{background:#fee2e2;color:#ef4444}.action-btn.share:hover{background:#e0e7ff;color:#4f46e5}.account-card.credit{border-left:4px solid #f59e0b}.account-card.debit{border-left:4px solid #3b82f6}.account-card.savings{border-left:4px solid #10b981}.account-card.cash{border-left:4px solid #14b8a6}.categories-container{max-width:1200px;margin:0 auto}.category-form{display:flex;flex-direction:column;gap:1.25rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-weight:600;font-size:.9rem;color:#334155}.type-selector{display:flex;background-color:#f1f5f9;padding:.25rem;border-radius:.75rem;gap:.25rem}.type-option{flex:1;text-align:center;padding:.6rem;border-radius:.5rem;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s ease;border:1px solid transparent}.type-option.active{background-color:#fff;box-shadow:0 1px 3px #0000001a;color:#0f172a;border-color:#e2e8f0}.type-option:not(.active){color:#64748b}.type-option:not(.active):hover{background-color:#e2e8f0}.icon-section{border:1px solid #e2e8f0;padding:1rem;border-radius:.75rem;background-color:#f8fafc}.icon-mode-tabs{display:flex;gap:1rem;margin-bottom:1rem;border-bottom:1px solid #e2e8f0;padding-bottom:.5rem}.icon-mode-tab{font-size:.85rem;font-weight:600;color:#64748b;cursor:pointer;padding:.25rem 0;position:relative}.icon-mode-tab.active{color:#2563eb}.icon-mode-tab.active:after{content:"";position:absolute;bottom:-.6rem;left:0;width:100%;height:2px;background-color:#2563eb}.preset-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(50px,1fr));gap:.5rem}.icon-option{display:flex;align-items:center;justify-content:center;padding:.5rem;border-radius:.5rem;border:1px solid transparent;cursor:pointer;transition:all .15s ease}.icon-option:hover{background-color:#e2e8f0}.icon-option.selected{background-color:#eff6ff;border-color:#2563eb;color:#2563eb}.category-tree{display:flex;flex-direction:column;gap:1rem}.category-group{margin-bottom:2rem}.group-title{font-size:1.1rem;font-weight:700;color:#334155;margin-bottom:1rem;display:flex;align-items:center;gap:.5rem}.category-item{background-color:#fff;border:1px solid #e2e8f0;border-radius:.75rem;margin-bottom:.75rem;transition:all .2s ease;overflow:hidden}.category-item:hover{box-shadow:0 4px 12px #0000000d;transform:translateY(-1px)}.category-content{padding:1rem;display:flex;justify-content:space-between;align-items:center}.category-info{display:flex;align-items:center;gap:1rem}.category-icon{width:42px;height:42px;display:flex;align-items:center;justify-content:center;border-radius:10px;font-size:1.25rem;color:#fff;box-shadow:0 2px 5px #0000001a}.category-details h4{margin:0;font-size:1rem;color:#1e293b}.category-meta{font-size:.8rem;color:#64748b;display:flex;align-items:center;gap:.5rem}.badge-pill{font-size:.7rem;padding:.1rem .5rem;border-radius:99px;background-color:#f1f5f9;color:#475569;font-weight:600;letter-spacing:.02em}.category-actions{display:flex;gap:.5rem;opacity:.6;transition:opacity .2s}.category-item:hover .category-actions{opacity:1}.icon-btn{width:32px;height:32px;padding:0;border-radius:6px;background:transparent;color:#64748b;border:1px solid transparent}.icon-btn:hover{background-color:#f1f5f9;color:#334155}.icon-btn.delete:hover{background-color:#fee2e2;color:#b91c1c}.subcategory-list{background-color:#f8fafc;border-top:1px solid #e2e8f0;padding:.5rem .5rem .5rem 3.5rem}.subcategory-item{display:flex;justify-content:space-between;align-items:center;padding:.6rem 1rem;border-radius:.5rem;margin-bottom:.25rem}.subcategory-item:hover{background-color:#fff;box-shadow:0 1px 3px #0000000d}.empty-placeholder{text-align:center;padding:3rem 1rem;color:#94a3b8;border:2px dashed #e2e8f0;border-radius:1rem}.transactions-container{max-width:980px;margin:0 auto;padding-bottom:5rem}.page-header{margin-bottom:1.5rem}.page-header h1{font-size:1.75rem;color:#1e293b;margin:0 0 .45rem}.page-header p{color:#64748b;margin:0}.filters-bar{display:flex;gap:.9rem;margin-bottom:1.25rem;background:#fff;padding:.95rem;border-radius:1rem;box-shadow:0 4px 6px -1px #0000000d;flex-wrap:wrap;align-items:center}.filter-select{min-width:170px}.filters-total{margin-left:auto;font-weight:700;color:#0f172a;background:#f1f5f9;border-radius:999px;padding:.35rem .8rem;font-size:.85rem}.page-feedback{margin:0 0 1rem}.transactions-create-section{margin-bottom:1.25rem}.toggle-form-btn{background-color:#eff6ff;color:#2563eb;width:100%;padding:.9rem;border-radius:.9rem;border:2px dashed #bfdbfe;cursor:pointer;font-weight:600;margin-bottom:.9rem;transition:all .2s}.toggle-form-btn:hover{background-color:#dbeafe;border-color:#3b82f6}.transaction-form-card{background:#fff;border-radius:1rem;padding:1.25rem;margin-bottom:1.25rem;box-shadow:0 4px 6px -1px #00000014;animation:slideDown .25s ease-out}.transaction-form-head{display:flex;align-items:center;justify-content:space-between;gap:.75rem;margin-bottom:1rem}.transaction-form-head h3{margin:0;color:#0f172a;font-size:1.05rem}.transfer-mode-tag{font-size:.72rem;font-weight:700;color:#1d4ed8;background:#dbeafe;border-radius:999px;padding:.2rem .6rem;text-transform:uppercase}.transaction-mode-toggle{display:flex;align-items:center;gap:.6rem;margin-bottom:1rem}.mode-option{display:inline-flex;align-items:center;gap:.45rem;border:1px solid #cbd5e1;border-radius:999px;padding:.45rem .75rem;color:#475569;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s}.mode-option.active{background:#eff6ff;border-color:#93c5fd;color:#1d4ed8}.mode-option input{width:auto;margin:0}.mobile-transfer-banner{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem;background:#eff6ff;color:#1d4ed8;border-radius:.75rem;padding:.6rem .75rem;font-size:.85rem;font-weight:600}.mobile-transfer-banner button{border:none;background:transparent;color:#1d4ed8;padding:0;font-size:.82rem}.mobile-transfer-banner button:hover{text-decoration:underline;background:transparent}.transaction-form{display:flex;flex-direction:column;gap:.85rem}.transaction-quick-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.8rem 1rem}.field-group{display:flex;flex-direction:column;gap:.4rem}.amount-input{font-weight:700;font-size:1.05rem}.advanced-toggle{align-self:flex-start;background:transparent;color:#2563eb;border:1px solid #bfdbfe;border-radius:.65rem;font-size:.82rem;font-weight:600;padding:.4rem .7rem}.advanced-toggle:hover{background:#eff6ff;border-color:#93c5fd}.advanced-panel{background:#f8fafc;border:1px solid #e2e8f0;border-radius:.85rem;padding:.85rem;display:grid;gap:.85rem}.secondary-mode-btn{background:#fff;color:#1e40af;border:1px solid #bfdbfe;border-radius:.65rem;padding:.55rem .8rem;width:100%;justify-content:center}.secondary-mode-btn:hover{background:#eff6ff}.secondary-back{margin-top:.15rem}.save-transaction-btn{margin-top:.2rem;width:100%}.transaction-list{display:flex;flex-direction:column;gap:1.5rem}.list-loading{margin:0;font-size:.85rem;color:#64748b}.date-group{display:flex;flex-direction:column;gap:.75rem}.date-header{font-size:.85rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.05em;padding-left:.5rem}.transaction-card{background:#fff;border-radius:1rem;padding:1rem;display:flex;justify-content:space-between;align-items:center;box-shadow:0 1px 3px #0000000d;transition:transform .2s,box-shadow .2s;cursor:pointer;border:1px solid transparent}.transaction-card:hover{transform:translateY(-2px);box-shadow:0 10px 15px -3px #0000000d;border-color:#e2e8f0}.t-left{display:flex;align-items:center;gap:1rem}.t-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.2rem;color:#fff;flex-shrink:0}.t-details{display:flex;flex-direction:column;gap:.1rem}.t-desc{font-weight:600;color:#1e293b;font-size:1rem}.t-meta{font-size:.8rem;color:#64748b;display:flex;align-items:center;gap:.5rem}.t-meta span{display:inline-flex;align-items:center;gap:.25rem}.t-account{background-color:#f1f5f9;padding:.1rem .4rem;border-radius:4px}.t-right{text-align:right;display:flex;flex-direction:column;align-items:flex-end;gap:.25rem}.t-amount{font-weight:700;font-size:1.1rem}.amount-expense{color:#ef4444}.amount-income{color:#10b981}.amount-transfer{color:#3b82f6}.t-user{font-size:.75rem;color:#94a3b8;display:flex;align-items:center;gap:.25rem}.user-avatar-xs{width:16px;height:16px;border-radius:50%;background:#cbd5e1;font-size:9px;display:flex;align-items:center;justify-content:center;color:#fff}.delete-btn{opacity:0;color:#ef4444;background:none;border:none;cursor:pointer;padding:.5rem;border-radius:.5rem;transition:all .2s}.transaction-card:hover .delete-btn{opacity:1}.delete-btn:hover{background-color:#fee2e2}.empty-state{text-align:center;padding:4rem 2rem;color:#94a3b8}.empty-icon{font-size:3rem;margin-bottom:1rem;opacity:.5}@media (min-width: 769px){.toggle-form-btn{width:auto;margin-left:auto;margin-bottom:.9rem;border-style:solid}.transactions-create-section{margin-bottom:1.5rem}.transaction-list{gap:1.25rem}}@media (max-width: 768px){.transactions-container{max-width:100%;padding-bottom:6rem}.page-header{margin-bottom:1rem}.page-header h1{font-size:1.55rem}.page-header p{font-size:.88rem}.filters-bar{gap:.75rem;margin-bottom:1rem;padding:.8rem}.filter-select{min-width:0;flex:1}.filters-total{margin-left:0;width:100%;text-align:left}.toggle-form-btn{margin-bottom:.75rem}.transaction-form-card{padding:.95rem;border-radius:.9rem}.transaction-quick-grid{grid-template-columns:1fr;gap:.75rem}.advanced-toggle{width:100%;justify-content:center}.advanced-panel{padding:.75rem}.transaction-list{gap:1rem}.transaction-card{padding:.85rem;align-items:flex-start;gap:.6rem}.t-left{flex:1;min-width:0;gap:.75rem;align-items:flex-start}.t-icon{width:40px;height:40px;border-radius:10px;font-size:1rem}.t-details{min-width:0}.t-desc{font-size:.94rem;word-break:break-word}.t-meta{font-size:.72rem;flex-wrap:wrap}.t-right{min-width:max-content;gap:.35rem}.t-amount{font-size:.98rem}.delete-btn{opacity:1;padding:.38rem}}@media (hover: none){.transaction-card:hover{transform:none;box-shadow:0 1px 3px #0000000d;border-color:transparent}}.debts-container{max-width:1040px;margin:0 auto;padding-bottom:5rem}.debts-header{margin-bottom:1.5rem}.debts-header h1{font-size:1.75rem;color:#0f172a;margin:0 0 .45rem}.debts-header p{color:#64748b;margin:0}.debts-summary{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem;margin-bottom:1.25rem}.summary-card{background:#fff;padding:1.1rem 1.2rem;border-radius:1rem;box-shadow:0 4px 6px -1px #0000000d;display:flex;flex-direction:column}.summary-label{font-size:.8rem;font-weight:600;text-transform:uppercase;color:#64748b;margin-bottom:.45rem}.summary-amount{font-size:1.4rem;font-weight:700}.sum-red{color:#ef4444}.sum-green{color:#10b981}.sum-blue{color:#3b82f6}.page-feedback{margin:0 0 .9rem}.debts-create-section{margin-bottom:1.25rem}.debts-container .toggle-form-btn{width:100%;background-color:#eff6ff;color:#2563eb;border:2px dashed #bfdbfe;border-radius:.9rem;padding:.85rem;font-weight:600;margin-bottom:.85rem}.debts-container .toggle-form-btn:hover{background:#dbeafe;border-color:#93c5fd}.debt-form-card{background:#fff;border-radius:1rem;padding:1.1rem;margin-bottom:1rem;border:1px solid #e2e8f0;box-shadow:0 4px 6px -1px #0000000d;animation:slideDown .25s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.debt-form-head{margin-bottom:.9rem}.debt-form-head h3{margin:0;font-size:1.05rem;color:#0f172a}.debt-form{display:flex;flex-direction:column;gap:.85rem}.debt-quick-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.8rem 1rem}.debt-field-group{display:flex;flex-direction:column;gap:.4rem}.debt-advanced-toggle{align-self:flex-start;background:transparent;color:#2563eb;border:1px solid #bfdbfe;border-radius:.65rem;padding:.4rem .7rem;font-size:.82rem;font-weight:600}.debt-advanced-toggle:hover{background:#eff6ff;border-color:#93c5fd}.debt-advanced-panel{background:#f8fafc;border:1px solid #e2e8f0;border-radius:.85rem;padding:.8rem}.save-debt-btn{width:100%}.form-feedback{margin:.45rem 0 0}.debts-loading{margin:0 0 .9rem;font-size:.85rem;color:#64748b}.debts-lists{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1.4rem;align-items:start}.list-column h2{font-size:1.12rem;color:#334155;margin:0 0 .8rem;display:flex;align-items:center;justify-content:space-between}.count-badge{background:#e2e8f0;font-size:.74rem;padding:.2rem .55rem;border-radius:999px;color:#475569}.debt-card{background:#fff;border-radius:1rem;padding:.95rem;margin-bottom:.9rem;box-shadow:0 1px 2px #0000000d;display:flex;align-items:center;gap:.9rem;transition:transform .2s,box-shadow .2s;border:1px solid transparent}.debt-card:hover{transform:translateY(-2px);box-shadow:0 10px 15px -3px #0000000d;border-color:#cbd5e1}.debt-card.liquidated{opacity:.62;background-color:#f8fafc}.debt-avatar{width:46px;height:46px;border-radius:12px;background:#eff6ff;color:#2563eb;display:flex;align-items:center;justify-content:center;font-size:1.2rem;font-weight:700;flex-shrink:0}.debt-avatar.owed{background:#f0fdf4;color:#16a34a}.debt-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:.15rem}.debt-counterparty{font-weight:600;color:#0f172a;display:flex;align-items:center;gap:.4rem}.debt-desc{font-size:.82rem;color:#64748b;word-break:break-word}.debt-date{font-size:.74rem;color:#94a3b8}.overdue{color:#ef4444;font-weight:600}.debt-right{text-align:right;display:flex;flex-direction:column;align-items:flex-end;gap:.45rem}.debt-amount{font-weight:700;font-size:1.05rem;color:#0f172a}.debt-actions{display:flex;gap:.45rem}.btn-icon{width:32px;height:32px;border-radius:8px;border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.btn-check{background:#dcfce7;color:#166534}.btn-check:hover{background:#bbf7d0}.btn-delete{background:#fee2e2;color:#991b1b}.btn-delete:hover{background:#fecaca}.status-badge{font-size:.68rem;padding:.1rem .36rem;border-radius:4px;background:#f1f5f9;color:#475569}.status-badge.paid{background:#dcfce7;color:#166534}.debts-container .empty-state{padding:1rem .2rem;text-align:left}@media (min-width: 769px){.debts-container .toggle-form-btn{width:auto;margin-left:auto;border-style:solid;margin-bottom:.8rem}}@media (max-width: 768px){.debts-container{max-width:100%;padding-bottom:6rem}.debts-header{margin-bottom:1rem}.debts-header h1{font-size:1.55rem}.debts-header p{font-size:.88rem}.debts-summary{grid-template-columns:1fr;gap:.75rem;margin-bottom:1rem}.summary-card{padding:.95rem 1rem}.summary-amount{font-size:1.25rem}.debt-form-card{padding:.95rem}.debt-quick-grid{grid-template-columns:1fr;gap:.72rem}.debt-advanced-toggle{width:100%;justify-content:center}.debts-lists{grid-template-columns:1fr;gap:.95rem}.list-column h2{margin-bottom:.65rem}.debt-card{padding:.85rem;gap:.7rem}.debt-avatar{width:40px;height:40px;font-size:1rem;border-radius:10px}.debt-counterparty{font-size:.95rem;flex-wrap:wrap}.debt-desc{font-size:.76rem}.debt-date{font-size:.7rem}.debt-right{gap:.35rem}.debt-amount{font-size:.94rem}.btn-icon{width:30px;height:30px}}@media (hover: none){.debt-card:hover{transform:none;box-shadow:0 1px 2px #0000000d;border-color:transparent}}.fixed-expenses-container{max-width:900px;margin:0 auto;padding-bottom:5rem}.fx-header{margin-bottom:2rem;display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:1rem}.fx-header-title h1{font-size:1.75rem;color:#0f172a;margin:0 0 .5rem}.fx-header-title p{color:#64748b;margin:0}.fx-summary-card{background:#fff;padding:1rem 1.5rem;border-radius:1rem;box-shadow:0 4px 6px -1px #0000000d;display:flex;flex-direction:column;align-items:flex-end}.fx-total-label{font-size:.85rem;color:#64748b;font-weight:600;text-transform:uppercase}.fx-total-amount{font-size:1.5rem;font-weight:700;color:#0f172a}.fx-section-title{font-size:1.1rem;color:#334155;margin:2rem 0 1rem;font-weight:600;display:flex;align-items:center;gap:.5rem}.fx-badge{background:#e2e8f0;color:#475569;font-size:.75rem;padding:.15rem .5rem;border-radius:999px}.fx-form-card{background:#fff;border-radius:1rem;padding:1.5rem;margin-bottom:2rem;box-shadow:0 4px 6px -1px #0000000d;animation:slideDown .3s ease-out}.fx-card{background:#fff;border-radius:1rem;padding:1rem;display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem;box-shadow:0 1px 2px #0000000d;transition:all .2s;border:1px solid transparent}.fx-card:hover{transform:translateY(-2px);box-shadow:0 10px 15px -3px #0000000d;border-color:#cbd5e1}.fx-card.inactive{opacity:.75;background-color:#f8fafc}.fx-left{display:flex;align-items:center;gap:1rem;flex:1}.fx-date-box{background:#eff6ff;color:#2563eb;width:56px;height:56px;border-radius:12px;display:flex;flex-direction:column;align-items:center;justify-content:center;line-height:1;flex-shrink:0}.fx-date-box.due-soon{background:#fef3c7;color:#d97706}.fx-date-day{font-size:1.25rem;font-weight:700}.fx-date-label{font-size:.65rem;font-weight:600;text-transform:uppercase}.fx-info{display:flex;flex-direction:column;gap:.25rem}.fx-name{font-weight:600;color:#1e293b;font-size:1.05rem}.fx-notes{font-size:.85rem;color:#64748b;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px}.fx-right{display:flex;align-items:center;gap:1.5rem}.fx-amount{font-weight:700;font-size:1.1rem;color:#0f172a}.fx-actions{display:flex;align-items:center;gap:.5rem}.switch{position:relative;display:inline-block;width:44px;height:24px}.switch input{opacity:0;width:0;height:0}.slider{position:absolute;cursor:pointer;inset:0;background-color:#cbd5e1;transition:.4s;border-radius:24px}.slider:before{position:absolute;content:"";height:18px;width:18px;left:3px;bottom:3px;background-color:#fff;transition:.4s;border-radius:50%}input:checked+.slider{background-color:#10b981}input:checked+.slider:before{transform:translate(20px)}.fx-delete-btn{background:none;border:none;color:#ef4444;padding:.5rem;border-radius:.5rem;cursor:pointer;transition:background .2s;opacity:.8}.fx-delete-btn:hover{background:#fee2e2;opacity:1}@media (max-width: 600px){.fx-card{flex-direction:column;align-items:flex-start;gap:1rem}.fx-right{width:100%;justify-content:space-between}}.house-page-container{padding-bottom:2rem}.page-header p{margin:0;color:#64748b;font-size:.95rem}.error-banner{background-color:#fee2e2;color:#b91c1c;padding:1rem;border-radius:.75rem;margin-bottom:1.5rem;display:flex;justify-content:space-between;align-items:center}.close-btn{background:none;border:none;font-size:1.25rem;cursor:pointer;color:#b91c1c;padding:0}.actions-section{margin-bottom:2.5rem}.action-card{display:flex;flex-direction:column}.action-card h2{font-size:1.25rem;margin:0 0 .5rem;color:#1e293b}.action-card p{margin:0 0 1rem;color:#64748b;font-size:.9rem}.action-card form{margin-top:auto;display:flex;gap:.5rem}.secondary-btn{background-color:#10b981}.secondary-btn:hover{background-color:#059669}.section-title{font-size:1.5rem;margin-bottom:1.5rem;color:#334155}.house-card{padding:0;overflow:hidden;border:1px solid #e2e8f0;transition:transform .2s ease,box-shadow .2s ease}.house-card:hover{transform:translateY(-2px);box-shadow:0 12px 30px #2563eb1a}.house-header{background:linear-gradient(135deg,#1e293b,#334155);padding:1.25rem 1.5rem;color:#fff;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}.house-header h3{margin:0;font-size:1.25rem;font-weight:700}.invite-badge{background:#ffffff26;padding:.35rem .8rem;border-radius:.5rem;font-size:.85rem;display:flex;align-items:center;gap:.5rem;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.invite-badge code{font-family:Courier New,monospace;font-weight:700;background:#0003;padding:.1rem .4rem;border-radius:.3rem;color:#fbbf24;letter-spacing:1px}.house-body{padding:1.5rem;display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem}.house-body h4{margin:0 0 1rem;color:#64748b;font-size:.8rem;text-transform:uppercase;letter-spacing:.05em;font-weight:700}.members-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.8rem}.member-item{display:flex;align-items:center;gap:.75rem;padding:.5rem;border-radius:.5rem;transition:background-color .15s ease}.member-item:hover{background-color:#f8fafc}.member-avatar{width:2.5rem;height:2.5rem;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:1rem;box-shadow:0 2px 5px #0000001a}.member-info{display:flex;flex-direction:column}.member-name{font-weight:600;color:#1e293b;font-size:.95rem}.member-role{font-size:.75rem;color:#64748b}.invite-form{display:flex;gap:.5rem}.invite-form input{flex:1}.invite-form button{background-color:#0f172a;white-space:nowrap}.invite-form button:hover{background-color:#334155}.budget-page-container{padding:2rem;max-width:1200px;margin:0 auto}.loading-container{display:flex;justify-content:center;align-items:center;height:50vh;font-size:1.25rem;color:#64748b}.month-selector .current-month-badge{background:var(--surface-card);padding:.5rem 1rem;border-radius:999px;border:1px solid var(--border-color);font-weight:500;text-transform:capitalize}.wizard-container{background:var(--surface-card);border-radius:1rem;padding:2rem;border:1px solid var(--border-color);box-shadow:0 4px 6px -1px #0000001a;max-width:800px;margin:2rem auto}.wizard-steps{display:flex;justify-content:space-between;margin-bottom:2rem;position:relative}.step-indicator{display:flex;align-items:center;gap:.5rem;opacity:.5;transition:all .3s ease}.step-indicator.active{opacity:1;color:var(--primary-color);font-weight:600}.step-indicator.completed{opacity:1;color:var(--success-color)}.step-circle{width:32px;height:32px;border-radius:50%;background:var(--surface-ground);border:2px solid currentColor;display:flex;justify-content:center;align-items:center;font-size:.875rem}.wizard-content{margin-bottom:2rem;min-height:300px}.selection-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem}.account-select-card{border:2px solid var(--border-color);padding:1rem;border-radius:.75rem;cursor:pointer;transition:all .2s}.account-select-card.selected{border-color:var(--primary-color);background-color:#2563eb0d}.summary-table{width:100%;border-collapse:collapse;margin-top:1rem}.summary-table td{padding:.75rem;border-bottom:1px solid var(--border-color)}.summary-value{text-align:right;font-family:monospace;font-size:1.1rem}.wizard-actions{display:flex;justify-content:space-between;border-top:1px solid var(--border-color);padding-top:1.5rem}.budget-dashboard{display:flex;flex-direction:column;gap:2rem}.snapshot-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.snapshot-card{background:var(--surface-card);padding:1.5rem;border-radius:1rem;border:1px solid var(--border-color)}.snapshot-card h3{font-size:.875rem;color:#64748b;margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.05em}.snapshot-value{font-size:1.5rem;font-weight:700;color:var(--text-primary)}.weeks-table-container{background:var(--surface-card);border-radius:1rem;border:1px solid var(--border-color);overflow:hidden}.weeks-table{width:100%;border-collapse:collapse}.weeks-table th,.weeks-table td{padding:1rem;text-align:left;border-bottom:1px solid var(--border-color)}.weeks-table th{background:var(--surface-ground);font-weight:600;color:#64748b}.status-indicator{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:.5rem}.status-ok{background-color:var(--success-color)}.status-warning{background-color:var(--warning-color)}.status-danger{background-color:var(--danger-color)}
