@import "https://fonts.googleapis.com/css2?family=Heebo:wght@400;500;600;700;800&display=swap";:root{--bg:#f5f6f8;--bg-alt:#eef1f4;--bg-card:#fff;--surface:#fff;--surface-raised:#f5f6f8;--hover-bg:#eef1f4;--border:#e3e7ec;--border-strong:#cfd6de;--text:#1a1a1a;--text-primary:#1a1a1a;--text-muted:#6e7480;--text-secondary:#6e7480;--text-on-accent:#fff;--text-heading:#0a1f44;--brand-navy:#0a1f44;--accent:#2a7de1;--accent-hover:#1f66c0;--accent-light:#e8f1fc;--accent-ring:#2a7de14d;--primary:#2a7de1;--primary-light:#e8f1fc;--success:#1fa871;--success-bg:#dcf3ea;--success-text:#127a52;--danger:#e0533d;--danger-bg:#fde6e1;--danger-text:#b23420;--warning:#b06a00;--warning-bg:#fdf2dc;--warning-text:#8a5200;--accent-2:#6d4ad6;--accent-2-bg:#ece7fb;--accent-coral:#f0654e;--accent-teal:#2bb39b;--sage:#dde7e0;--r-xs:6px;--r-sm:8px;--r-md:16px;--r-lg:20px;--r-pill:999px;--radius:16px;--s-1:4px;--s-2:8px;--s-3:12px;--s-4:16px;--s-5:20px;--s-6:24px;--s-8:32px;--s-10:40px;--shadow-sm:0 1px 2px #0a1f440a, 0 1px 3px #0a1f440d;--shadow-md:0 2px 6px #0a1f440a, 0 6px 16px #0a1f4412;--shadow-lg:0 4px 12px #0a1f440f, 0 18px 40px #0a1f441a;--shadow-focus:0 0 0 3px var(--accent-ring);--t-fast:.15s;--t-base:.2s;--t-slow:.3s;--ease:cubic-bezier(.4,0,.2,1);--font-body:"Heebo",system-ui,-apple-system,sans-serif;--font-display:"Heebo",system-ui,-apple-system,sans-serif;--sidebar-width:210px;font:400 15px/1.6 var(--font-body);color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;text-rendering:optimizelegibility}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body,#root{min-height:100svh}.app-layout{min-height:100svh;display:flex}.sidebar{width:var(--sidebar-width);background:var(--surface);box-shadow:-1px 0 0 var(--border);flex-direction:column;gap:2px;padding:20px 10px;display:flex;position:fixed;top:0;bottom:0;right:0}.sidebar-title{color:var(--text-heading);border-bottom:1px solid var(--border);letter-spacing:-.01em;margin-bottom:6px;padding:4px 10px 16px;font-size:15px;font-weight:700}.nav-link{border-radius:var(--r-sm);color:var(--text-muted);align-items:center;gap:10px;padding:7px 10px;font-size:14px;font-weight:500;text-decoration:none;transition:background .12s,color .12s;display:flex}.nav-link:hover{background:var(--bg);color:var(--text)}.nav-link.active{background:var(--accent-light);color:var(--accent);font-weight:600}.main-content{margin-right:var(--sidebar-width);flex:1;max-width:900px;padding:32px}.bottom-nav{display:none}.bottom-nav-link{min-height:52px;color:var(--text-muted);border-radius:var(--r-sm);transition:color var(--t-fast) var(--ease), background var(--t-fast) var(--ease);-webkit-tap-highlight-color:transparent;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:3px;padding:6px 2px;text-decoration:none;display:flex}.bottom-nav-link:active{background:var(--hover-bg)}.bottom-nav-link.active{color:var(--accent)}.bottom-nav-label{font-size:10.5px;font-weight:500;line-height:1}.bottom-nav-link.active .bottom-nav-label{font-weight:600}.mobile-header{display:none}.hamburger-btn{cursor:pointer;color:var(--text);border-radius:var(--r-sm);background:0 0;border:none;justify-content:center;align-items:center;padding:6px;transition:background .12s;display:flex}.hamburger-btn:hover{background:var(--bg)}.mobile-header-title{color:var(--text);font-size:15px;font-weight:700}.drawer-overlay{z-index:199;background:#00000059;animation:.18s fade-in;display:none;position:fixed;inset:0}.drawer{background:var(--surface);z-index:200;flex-direction:column;gap:2px;width:240px;padding:16px 10px;transition:transform .22s;display:none;position:fixed;top:0;bottom:0;right:0;transform:translate(100%);box-shadow:-4px 0 24px #00000024}.drawer.drawer-open{transform:translate(0)}.drawer-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;margin-bottom:4px;padding:4px 6px 14px;display:flex}.drawer-title{color:var(--text);font-size:15px;font-weight:700}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.page{flex-direction:column;gap:20px;display:flex}.page-header{justify-content:space-between;align-items:center;display:flex}.page-header h1{color:var(--text-heading);letter-spacing:-.01em;font-size:22px;font-weight:700}.btn-primary{background:var(--accent);color:#fff;border-radius:var(--r-pill);cursor:pointer;transition:background var(--t-fast) var(--ease), box-shadow var(--t-fast) var(--ease);border:none;padding:9px 20px;font-family:inherit;font-size:14px;font-weight:600}.btn-primary:hover{background:var(--accent-hover)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-secondary{background:var(--surface);color:var(--text);border:1px solid var(--border);border-radius:var(--r-pill);cursor:pointer;transition:background var(--t-fast) var(--ease), box-shadow var(--t-fast) var(--ease);padding:9px 20px;font-family:inherit;font-size:14px;font-weight:500}.btn-secondary:hover{background:var(--bg)}.btn-icon{cursor:pointer;border-radius:var(--r-xs);min-width:44px;min-height:44px;color:var(--text-muted);transition:transform var(--t-fast) var(--ease);background:0 0;border:none;justify-content:center;align-items:center;padding:0;font-size:14px;display:inline-flex}.btn-icon:hover{background:var(--bg)}.btn-icon.danger:hover{color:var(--danger)}.btn-icon.receipt-btn{color:var(--accent)}.btn-icon.receipt-btn:hover{background:var(--accent-light)}.filters{gap:8px;display:flex}.filters select,select,input[type=text],input[type=number],input[type=date]{border:1px solid var(--border);border-radius:var(--r-xs);background:var(--surface);color:var(--text);padding:6px 10px;font-family:inherit;font-size:14px}input[type=date]{min-width:0}.filters select:focus,select:focus,input[type=text]:focus,input[type=number]:focus,input[type=date]:focus{border-color:var(--accent);box-shadow:var(--shadow-focus);outline:none}.summary-cards{grid-template-columns:repeat(3,1fr);gap:12px;display:grid}.summary-card{background:var(--surface);box-shadow:var(--shadow-sm);border-radius:var(--r-md);border:1px solid var(--border);padding:18px}.summary-label{color:var(--text-muted);margin-bottom:6px;font-size:13px}.summary-amount{color:var(--text);font-size:20px;font-weight:600}.summary-amount.positive{color:var(--success)}.summary-amount.negative{color:var(--danger)}.modal-overlay{z-index:200;background:#0e1f2a73;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.modal{background:var(--surface);border-radius:var(--r-lg);width:100%;max-width:460px;box-shadow:var(--shadow-lg);padding:28px}.modal-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.modal-header h2{font-size:17px;font-weight:600}.form{flex-direction:column;gap:14px;display:flex}.form-row{flex-direction:column;gap:6px;display:flex}.form-row label{color:var(--text-muted);font-size:13px;font-weight:500}.form-row input,.form-row select{width:100%}.form-error{color:var(--danger);font-size:13px}.sync-warning{color:var(--warning);background:var(--warning-bg);border:1px solid var(--warning);border-radius:var(--r-xs);max-width:640px;margin-bottom:8px;padding:8px 12px;font-size:13px}.form-actions{justify-content:flex-end;gap:8px;margin-top:4px;display:flex}.form-section-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border);margin-top:4px;padding-bottom:4px;font-size:12px;font-weight:600}.form-2col{grid-template-columns:1fr 1fr;gap:12px;display:grid}.form-3col{grid-template-columns:1fr 1fr 1fr;gap:12px;display:grid}.toggle-group{background:var(--bg-alt);border-radius:var(--r-pill);border:none;gap:2px;width:fit-content;padding:3px;display:flex}.toggle-btn{border-radius:var(--r-pill);cursor:pointer;color:var(--text-muted);transition:background var(--t-fast) var(--ease), color var(--t-fast) var(--ease), box-shadow var(--t-fast) var(--ease);background:0 0;border:none;padding:7px 18px;font-family:inherit;font-size:14px;font-weight:500}.toggle-btn.active{background:var(--surface);color:var(--text-heading);font-weight:600;box-shadow:0 1px 3px #0e1f2a1f}.toggle-group.small .toggle-btn{padding:5px 14px;font-size:12px}.table-wrapper{background:var(--surface);box-shadow:var(--shadow-sm);border-radius:var(--r-md);border:1px solid var(--border);overflow:hidden}.data-table{border-collapse:collapse;width:100%;font-size:14px}.data-table th{text-align:right;color:var(--text-muted);border-bottom:1px solid var(--border);background:var(--bg);padding:10px 14px;font-size:12px;font-weight:500}.data-table td{border-bottom:1px solid var(--border);vertical-align:middle;padding:12px 14px}.data-table tr:last-child td{border-bottom:none}.data-table tr:hover td{background:var(--bg)}.text-muted{color:var(--text-muted)}.amount{font-weight:500}.amount.income{color:var(--success)}.amount.expense{color:var(--danger)}.fin-list{background:var(--surface);box-shadow:var(--shadow-sm);border-radius:var(--r-md);border:1px solid var(--border);overflow:hidden}.fin-list-items{flex-direction:column;margin:0;padding:0;list-style:none;display:flex}.fin-item{border-bottom:1px solid var(--border);align-items:center;gap:12px;padding:12px 14px;display:flex}.fin-item:last-child{border-bottom:none}.fin-item.virtual{border-inline-start:2px dashed var(--border-strong);background:color-mix(in srgb, var(--bg) 55%, transparent)}.fin-item-main{flex-direction:column;flex:1;gap:3px;min-width:0;display:flex}.fin-item-top{flex-wrap:wrap;align-items:baseline;gap:8px;display:flex}.fin-item-cat{color:var(--text-primary);font-size:14px;font-weight:600}.fin-item.virtual .fin-item-cat{color:var(--text-muted);font-weight:500}.fin-item-date{color:var(--text-muted);font-size:12px}.fin-item-meta{color:var(--text-muted);flex-wrap:wrap;align-items:center;gap:8px;font-size:12px;display:flex}.fin-item-side{flex-direction:column;flex-shrink:0;align-items:flex-start;gap:6px;display:flex}.fin-item-amount{white-space:nowrap;font-size:15px;font-weight:600}.fin-item-amount.income{color:var(--success)}.fin-item-amount.expense{color:var(--danger)}.fin-item.virtual .fin-item-amount{opacity:.7;font-weight:500}.fin-item-actions{align-items:center;gap:2px;display:flex}.row-actions{justify-content:flex-end;gap:4px;display:flex}.empty-state{text-align:center;color:var(--text-muted);padding:48px 0;font-size:15px}.empty-state.small{padding:20px 0;font-size:14px}.section{flex-direction:column;gap:10px;display:flex}.section-title{color:var(--text-muted);font-size:15px;font-weight:600}.badge{border-radius:var(--r-pill);padding:2px 8px;font-size:12px;font-weight:500;display:inline-block}.badge.automatic{background:var(--success-bg);color:var(--success-text)}.badge.requires_approval{background:var(--warning-bg);color:var(--warning-text)}.dashboard-page .summary-cards{margin-bottom:24px}.dashboard-sections{flex-direction:column;gap:20px;max-width:700px;display:flex}.dashboard-section{background:var(--surface);box-shadow:var(--shadow-sm);border-radius:var(--r-md);border:1px solid var(--border);padding:18px 20px}.dashboard-section-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.dashboard-section-header h2{color:var(--text);margin:0;font-size:15px;font-weight:600}.btn-link{color:var(--accent);cursor:pointer;background:0 0;border:none;align-items:center;min-height:44px;padding:4px 8px;font-size:13px;text-decoration:none;display:inline-flex}.btn-link:hover{text-decoration:underline}.dashboard-task-list,.dashboard-tx-list{flex-direction:column;gap:8px;margin:0;padding:0;list-style:none;display:flex}.dashboard-task-item{border-bottom:1px solid var(--border);cursor:pointer;border-radius:var(--r-xs);transition:background var(--t-base) var(--ease), transform var(--t-base) var(--ease);justify-content:space-between;align-items:center;gap:8px;padding:6px 4px;display:flex}.dashboard-task-item:hover{background:var(--hover-bg);transform:translate(-2px)}.dashboard-task-item:active{transform:scale(.995)}.dashboard-task-item:last-child{border-bottom:none}.dashboard-task-item.overdue .dashboard-task-title{color:var(--danger)}.dashboard-task-title{flex:1;font-size:14px}.dashboard-task-due{color:var(--text-muted);white-space:nowrap;font-size:12px}.dashboard-task-item.overdue .dashboard-task-due{color:var(--danger)}.dashboard-tx-item{border-bottom:1px solid var(--border);cursor:pointer;border-radius:var(--r-sm);transition:background var(--t-base) var(--ease), transform var(--t-base) var(--ease);align-items:center;gap:12px;padding:8px 6px;font-size:14px;display:flex}.tx-tile{border-radius:11px;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;display:flex}.tx-tile.income{background:var(--success-bg);color:var(--success-text)}.tx-tile.expense{background:var(--danger-bg);color:var(--danger-text)}.dashboard-tx-cat .tx-cat-name{color:var(--text);font-weight:500;line-height:1.3;display:block}.dashboard-tx-cat .tx-cat-date{color:var(--text-muted);font-size:12px;line-height:1.3;display:block}.dashboard-tx-item:hover{background:var(--hover-bg);transform:translate(-2px)}.dashboard-tx-item:active{transform:scale(.995)}.dashboard-tx-item:last-child{border-bottom:none}.dashboard-tx-date{color:var(--text-muted);white-space:nowrap;min-width:64px;font-size:12px}.dashboard-tx-cat{color:var(--text);flex:1}.dashboard-tx-amount{white-space:nowrap;font-weight:600}.dashboard-tx-amount.positive{color:var(--success)}.dashboard-tx-amount.negative{color:var(--danger)}.property-page{max-width:700px}.prop-section{margin-bottom:28px}.prop-accordion{flex-direction:column;gap:12px;display:flex}.prop-accordion-item{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);box-shadow:var(--shadow-sm);overflow:hidden}.prop-accordion-item.open{border-color:var(--border-strong);box-shadow:var(--shadow-md)}.prop-accordion-header{cursor:pointer;width:100%;font:inherit;color:var(--text);min-height:44px;transition:background var(--t-base) var(--ease);background:0 0;border:none;justify-content:space-between;align-items:center;gap:12px;padding:16px 18px;display:flex}.prop-accordion-header:hover{background:var(--bg)}.prop-accordion-title{align-items:center;gap:10px;font-size:16px;font-weight:600;display:flex}.prop-accordion-title svg{color:var(--accent)}.prop-accordion-chevron{color:var(--text-muted);transition:transform var(--t-base) var(--ease);flex-shrink:0}.prop-accordion-item.open .prop-accordion-chevron{transform:rotate(180deg)}.prop-accordion-panel{border-top:1px solid var(--border);padding:4px 18px 18px}.prop-accordion-panel .prop-section{margin-bottom:0}.prop-accordion-panel .mortgage-page>.summary-cards:first-child,.prop-accordion-panel .prop-section-header:first-child{margin-top:12px}.prop-section-hint{color:var(--text-muted);margin:12px 0 14px;font-size:13px}.prop-section-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.prop-section-header h2{margin:0;font-size:16px;font-weight:600}.prop-card{background:var(--surface);box-shadow:var(--shadow-sm);border-radius:var(--r-md);flex-direction:column;gap:10px;padding:18px 20px;display:flex}.prop-field-row{align-items:baseline;gap:12px;font-size:14px;display:flex}.prop-field-label{color:var(--text-muted);flex-shrink:0;min-width:80px}.contract-card{background:var(--surface);box-shadow:var(--shadow-sm);border-radius:var(--r-md);margin-bottom:12px;padding:18px 20px}.contract-card.expired{opacity:.65}.contract-card-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.contract-title{align-items:center;gap:10px;display:flex}.contract-company{font-size:15px;font-weight:600}.contract-status-badge{border-radius:var(--r-pill);background:var(--success-bg);color:var(--success-text);padding:2px 8px;font-size:12px;font-weight:500}.contract-status-badge.warning{background:var(--warning-bg);color:var(--warning-text)}.contract-status-badge.urgent{background:var(--danger-bg);color:var(--danger-text)}.contract-status-badge.expired-badge{background:var(--bg);color:var(--text-muted)}.contract-card-actions{gap:4px;display:flex}.contract-fields{flex-direction:column;gap:8px;margin-bottom:16px;display:flex}.utilities-section{border-top:1px solid var(--border);padding-top:14px}.utilities-title{color:var(--text-muted);margin-bottom:10px;font-size:13px;font-weight:600}.utilities-grid{flex-direction:column;gap:8px;display:flex}.utility-row{flex-wrap:wrap;align-items:center;gap:8px;font-size:14px;display:flex}.utility-name{flex:1}.utility-amount-input{border:1px solid var(--border);border-radius:var(--r-sm);background:var(--bg);width:80px;color:var(--text);text-align:center;padding:3px 8px;font-size:13px}.docs-grid{flex-direction:column;gap:10px;max-width:700px;display:flex}.doc-card{background:var(--surface);box-shadow:var(--shadow-sm);border-radius:var(--r-md);align-items:center;gap:14px;padding:14px 18px;display:flex}.doc-icon{flex-shrink:0;font-size:26px;line-height:1}.doc-info{flex:1;min-width:0}.doc-name{white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:500;overflow:hidden}.doc-meta{align-items:center;gap:8px;margin-top:4px;display:flex}.doc-type-badge{background:var(--accent-light);color:var(--accent);border-radius:var(--r-pill);padding:2px 8px;font-size:12px;font-weight:500}.doc-date{color:var(--text-muted);font-size:12px}.doc-actions{flex-shrink:0;gap:4px;display:flex}.settings-page{max-width:600px}.settings-sections{flex-direction:column;gap:20px;display:flex}.settings-section{background:var(--surface);box-shadow:var(--shadow-sm);border-radius:var(--r-md);padding:18px 20px}.settings-section h2{margin:0 0 14px;font-size:15px;font-weight:600}.settings-row{border-bottom:1px solid var(--border);gap:12px;padding:6px 0;font-size:14px;display:flex}.settings-row:last-of-type{border-bottom:none}.settings-label{color:var(--text-muted);min-width:80px}.settings-value{color:var(--text)}.settings-note{color:var(--text-muted);margin:0 0 14px;font-size:13px;line-height:1.6}.settings-actions{gap:8px;margin-top:14px;display:flex}.tasks-page .page-header{align-items:center}.gtasks-list{flex-direction:column;max-width:640px;display:flex}.gtask-item{border-radius:var(--r-sm);cursor:default;transition:background var(--t-fast) var(--ease);align-items:flex-start;gap:12px;padding:10px 8px;display:flex;position:relative}.gtask-item:hover{background:var(--bg)}.gtask-item:hover .gtask-delete{opacity:1}.gtask-check{border:2px solid var(--border);cursor:pointer;color:#fff;box-sizing:content-box;background:0 0;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;margin:-12px;padding:12px;transition:border-color .15s,background .15s;display:flex}.gtask-check:hover{border-color:var(--accent)}.gtask-check.checked{background:var(--accent);border-color:var(--accent)}.gtask-check svg{width:11px;height:11px}.gtask-body{cursor:pointer;flex:1;min-width:0}.gtask-title{color:var(--text);font-size:14px;line-height:1.4}.gtask-done .gtask-title{color:var(--text-muted);text-decoration:line-through}.gtask-meta{flex-wrap:wrap;align-items:center;gap:8px;margin-top:2px;display:flex}.gtask-due{color:var(--text-muted);font-size:12px}.gtask-due.overdue{color:var(--danger)}.gtask-cat{color:var(--text-muted);font-size:12px}.gtask-cat:before{content:"·";margin-left:4px}.gtask-source-badge{border-radius:var(--r-pill);background:var(--accent-light);color:var(--accent);padding:1px 6px;font-size:11px}.gtask-delete{cursor:pointer;opacity:0;width:28px;height:28px;color:var(--text-muted);transition:background var(--t-fast) var(--ease), color var(--t-fast) var(--ease), opacity var(--t-fast) var(--ease);background:0 0;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.gtask-delete:hover{background:var(--danger-bg);color:var(--danger)}.gtask-delete svg{width:14px;height:14px}.gtask-empty{color:var(--text-muted);text-align:center;padding:32px 8px;font-size:14px}.gtask-add-form{border-radius:var(--r-sm);align-items:flex-start;gap:12px;margin-top:4px;padding:8px;display:flex}.gtask-add-check{border:2px dashed var(--border);cursor:default;background:0 0;border-radius:50%;flex-shrink:0;width:20px;height:20px;margin-top:2px}.gtask-add-body{flex-direction:column;flex:1;gap:8px;display:flex}.gtask-add-input{color:var(--text);background:0 0;border:none;border-bottom:1px solid #0000;outline:none;width:100%;padding:2px 0;font-size:14px;transition:border-color .15s}.gtask-add-input:focus{border-bottom-color:var(--accent)}.gtask-add-input::placeholder{color:var(--text-muted)}.gtask-add-details{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.gtask-add-date,.gtask-add-cat{border:1px solid var(--border);border-radius:var(--r-xs);color:var(--text);background:var(--surface);padding:4px 8px;font-size:13px}.gtask-add-actions{gap:8px;margin-right:auto;display:flex}.app-loading{min-height:100svh;color:var(--text-muted);justify-content:center;align-items:center;font-size:15px;display:flex}.login-page{background:var(--bg);justify-content:center;align-items:center;min-height:100svh;display:flex}.login-card{background:var(--surface);box-shadow:var(--shadow-md);text-align:center;border-radius:20px;flex-direction:column;align-items:center;gap:16px;min-width:340px;padding:52px 44px;display:flex}.login-logo{font-size:40px}.login-card h1{font-size:22px;font-weight:700}.login-subtitle{color:var(--text-muted);margin-bottom:8px;font-size:14px}.btn-google{border:1px solid var(--border);border-radius:var(--r-pill);background:var(--surface);color:var(--text);cursor:pointer;align-items:center;gap:10px;padding:10px 20px;font-size:14px;font-weight:500;transition:background .15s,border-color .15s;display:flex}.btn-google:hover{background:var(--bg);border-color:#aaa}.login-manager-link{color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:4px;font-size:13px;text-decoration:underline}.login-manager-link:hover{color:var(--text)}.login-manager-form{flex-direction:column;align-items:stretch;gap:10px;width:100%;display:flex}.login-manager-form input{border:1px solid var(--border);border-radius:var(--r-pill);text-align:center;background:var(--surface);color:var(--text);padding:10px 14px;font-size:15px}.login-manager-form input:focus{border-color:var(--accent);outline:none}.btn-manager{border-radius:var(--r-pill);background:var(--accent);color:#fff;cursor:pointer;border:none;padding:10px 20px;font-size:14px;font-weight:600;transition:opacity .15s}.btn-manager:disabled{opacity:.5;cursor:default}.login-error{color:var(--danger);font-size:13px}.sidebar-footer{border-top:1px solid var(--border);flex-direction:column;gap:8px;margin-top:auto;padding-top:12px;display:flex}.sidebar-user{color:var(--text-muted);word-break:break-all;font-size:11px}.btn-signout{border:1px solid var(--border);border-radius:var(--r-xs);color:var(--text-muted);cursor:pointer;text-align:center;background:0 0;padding:6px 10px;font-size:13px;transition:background .15s,color .15s}.btn-signout:hover{background:var(--bg);color:var(--danger);border-color:var(--danger)}.badge.recurring_item{background:var(--accent-2-bg);color:var(--accent-2)}.badge.renewal{color:#9d174d;background:#fce7f3}.file-upload{align-items:center;gap:8px;display:flex}.onboarding-wrap{background:var(--bg);min-height:100svh;padding:40px 24px env(safe-area-inset-bottom,80px);padding-bottom:max(80px, env(safe-area-inset-bottom,80px));justify-content:center;align-items:flex-start;display:flex}.onboarding-card{background:var(--surface);box-shadow:var(--shadow-lg);border-radius:20px;width:100%;max-width:500px;padding:44px 40px 36px}.onboarding-dots{justify-content:center;gap:6px;margin-bottom:36px;display:flex}.onboarding-dot{background:var(--border);border-radius:3px;width:6px;height:6px;transition:width .25s,background .25s}.onboarding-dot.active{background:var(--accent);width:22px}.onboarding-dot.done{background:var(--accent);opacity:.35}.onboarding-icon{text-align:center;margin-bottom:14px;font-size:44px;line-height:1}.onboarding-title{color:var(--text);text-align:center;letter-spacing:-.02em;margin-bottom:8px;font-size:22px;font-weight:700}.onboarding-subtitle{color:var(--text-muted);text-align:center;margin-bottom:32px;font-size:14px;line-height:1.65}.onboarding-form{flex-direction:column;gap:14px;margin-bottom:28px;display:flex}.onboarding-field{flex-direction:column;gap:5px;display:flex}.onboarding-field label{color:var(--text-muted);letter-spacing:.04em;text-transform:uppercase;font-size:12px;font-weight:600}.onboarding-field input{box-sizing:border-box;border:1.5px solid var(--border);border-radius:var(--r-sm);width:100%;color:var(--text);background:var(--surface);padding:10px 14px;font-family:inherit;font-size:15px;transition:border-color .15s,box-shadow .15s}.onboarding-field input[type=date]{appearance:none;line-height:normal}.onboarding-field input:focus{border-color:var(--accent);box-shadow:var(--shadow-focus);outline:none}.onboarding-row{grid-template-columns:1fr 1fr;gap:12px;display:grid}.onboarding-recurring-list{flex-direction:column;gap:10px;margin-bottom:28px;display:flex}.onboarding-recurring-item{border:1.5px solid var(--border);border-radius:var(--r-md);cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:12px;padding:13px 16px;transition:border-color .15s,background .15s;display:flex}.onboarding-recurring-item.on{border-color:var(--accent);background:var(--accent-light)}.onboarding-check{border:2px solid var(--border);background:var(--surface);color:#fff;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;font-size:11px;font-weight:700;transition:border-color .15s,background .15s;display:flex}.onboarding-recurring-item.on .onboarding-check{border-color:var(--accent);background:var(--accent)}.onboarding-recurring-label{color:var(--text);flex:1;font-size:14px;font-weight:500}.onboarding-recurring-amount{border:1.5px solid var(--border);text-align:left;background:var(--surface);width:96px;color:var(--text);border-radius:7px;padding:7px 10px;font-family:inherit;font-size:14px;transition:border-color .15s}.onboarding-recurring-item.on .onboarding-recurring-amount{border-color:var(--accent)}.onboarding-recurring-amount:focus{border-color:var(--accent);outline:none}.onboarding-insurance-detail{background:var(--surface);border:1.5px solid var(--accent);border-top:none;border-radius:0 0 10px 10px;margin-top:-6px;margin-bottom:4px;padding:14px 14px 6px}.onboarding-actions{justify-content:space-between;align-items:center;display:flex}.btn-onboard-primary{background:var(--accent);color:#fff;border-radius:var(--r-pill);cursor:pointer;transition:background var(--t-fast) var(--ease), box-shadow var(--t-fast) var(--ease);border:none;padding:11px 28px;font-family:inherit;font-size:15px;font-weight:600}.btn-onboard-primary:hover{background:var(--accent-hover)}.btn-onboard-primary:disabled{opacity:.5;cursor:not-allowed}.btn-onboard-skip{color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:4px 0;font-family:inherit;font-size:14px}.btn-onboard-skip:hover{color:var(--text)}.onboarding-error{color:var(--danger);margin-top:-8px;margin-bottom:8px;font-size:13px}.choice-grid{grid-template-rows:1fr 1fr;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:28px;display:grid}.choice-card{border:1.5px solid var(--border);border-radius:var(--r-lg);cursor:pointer;text-align:center;-webkit-user-select:none;user-select:none;flex-direction:column;justify-content:center;align-items:center;gap:10px;padding:18px 14px;transition:border-color .15s,background .15s,box-shadow .15s;display:flex}.choice-card:hover{border-color:var(--accent);background:var(--accent-light);box-shadow:var(--shadow-focus)}.choice-card-left{grid-row:span 2}.choice-card-sm{min-height:76px}.choice-card-muted{background:var(--bg)}.choice-card-muted:hover{border-color:var(--text-muted);background:var(--bg);box-shadow:none}.choice-card-muted .choice-label{color:var(--text-muted)}.choice-icon{font-size:26px;line-height:1}.choice-label{color:var(--text);font-size:13px;font-weight:600;line-height:1.4}.onboarding-file-field{border:1.5px dashed var(--border);border-radius:var(--r-sm);background:var(--bg);cursor:pointer;align-items:center;gap:12px;margin-top:4px;padding:11px 14px;transition:border-color .15s,background .15s;display:flex}.onboarding-file-field:hover{border-color:var(--accent);background:var(--accent-light)}.onboarding-file-label{color:var(--text-muted);white-space:nowrap;font-size:12.5px;font-weight:600}.onboarding-file-name{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;flex:1;font-size:13px;overflow:hidden}.toggle-row{color:var(--text);cursor:pointer;align-items:center;gap:8px;font-size:13.5px;display:flex}.toggle-row input[type=checkbox]{width:16px;height:16px;accent-color:var(--accent);cursor:pointer;flex-shrink:0}.onboarding-checkbox-row{color:var(--text);cursor:pointer;align-items:center;gap:10px;padding:6px 0;font-size:13.5px;display:flex}.onboarding-checkbox-row input[type=checkbox]{width:16px;height:16px;accent-color:var(--accent);cursor:pointer;flex-shrink:0}.onboarding-file-row{border:1.5px solid var(--border);border-radius:var(--r-sm);background:var(--bg);align-items:center;gap:10px;padding:9px 14px;display:flex}.onboarding-extracting{color:var(--text-muted);justify-content:center;align-items:center;gap:10px;padding:18px;font-size:14px;display:flex}.onboarding-extracting-spinner{border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;flex-shrink:0;width:16px;height:16px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.onboarding-extract-banner{background:var(--accent-light);border:1px solid var(--accent-ring);border-radius:var(--r-sm);color:var(--accent);padding:9px 13px;font-size:12.5px;font-weight:500}.onboarding-done-icon{text-align:center;margin-bottom:20px;font-size:64px;line-height:1}@media (width<=520px){.onboarding-card{padding:32px 24px 28px}.onboarding-row{grid-template-columns:1fr}}.investment-page{max-width:700px}.inv-sub-label{color:var(--text-muted);margin-top:4px;font-size:11px}.inv-costs-section{flex-direction:column;gap:12px;display:flex}.inv-costs-header{justify-content:space-between;align-items:center;display:flex}.inv-costs-header h2{margin:0;font-size:16px;font-weight:600}.inv-cost-row{border-bottom:1px solid var(--border);align-items:center;gap:10px;padding:6px 0;font-size:14px;display:flex}.inv-cost-row:last-of-type{border-bottom:none}.inv-cost-label{color:var(--text);flex:1}.inv-cost-input-wrap{align-items:center;gap:4px;display:flex}.inv-cost-currency{color:var(--text-muted);font-size:13px}.inv-cost-input{text-align:left;width:110px;font-family:inherit;font-weight:500}.inv-cost-total{border-top:2px solid var(--border);justify-content:space-between;align-items:center;margin-top:4px;padding-top:12px;font-size:14px;font-weight:600;display:flex}.inv-cost-total-amount{color:var(--text);font-size:18px;font-weight:700}.inv-add-row{align-items:center;gap:8px;display:flex}.inv-add-input{flex:1;max-width:260px}.inv-flow-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.inv-flow-header h2{margin:0}.inv-flow-row{border-bottom:1px solid var(--border);align-items:center;gap:10px;padding:10px 0;display:flex}.inv-flow-row:last-child{border-bottom:none}.inv-flow-sign{text-align:center;flex-shrink:0;width:16px;font-size:1rem;font-weight:700}.inv-flow-label{color:var(--text);flex:1;font-size:.9rem}.inv-flow-amount{font-size:.95rem;font-weight:600}.inv-flow-divider{border-top:2px solid var(--border);margin:4px 0}.inv-flow-total .inv-flow-label{font-weight:600}.inv-flow-total .inv-flow-amount{font-size:1.05rem}.inv-flow-sublabel{color:var(--text-muted);margin-right:4px;font-size:.75rem;font-weight:400}.inv-collapse-header{cursor:pointer;text-align:right;background:0 0;border:none;justify-content:space-between;align-items:center;width:100%;padding:10px 0;display:flex}.inv-collapse-header h2{margin:0}.inv-collapse-right{align-items:center;gap:10px;display:flex}.inv-collapse-total{color:var(--text-muted);font-size:.9rem;font-weight:500}.inv-collapse-chevron{color:var(--text-muted);font-size:1.2rem;transition:transform .2s;display:inline-block;transform:rotate(90deg)}.inv-collapse-chevron.open{transform:rotate(-90deg)}@media (width<=640px){.sidebar{display:none}.bottom-nav{padding:4px 6px;padding-bottom:max(4px, env(safe-area-inset-bottom));background:color-mix(in srgb, var(--surface) 92%, transparent);-webkit-backdrop-filter:saturate(180%)blur(12px);backdrop-filter:saturate(180%)blur(12px);box-shadow:0 -1px 0 var(--border), 0 -8px 24px #0e1f2a0f;z-index:100;gap:2px;display:flex;position:fixed;bottom:0;left:0;right:0}.main-content{padding:16px;padding-bottom:calc(56px + env(safe-area-inset-bottom) + 16px);box-sizing:border-box;width:100%;max-width:100%;margin-left:0;margin-right:0;overflow-x:hidden}}@media (width<=480px){html,body,#root,.app-layout{max-width:100%;overflow-x:hidden}input,select,textarea{box-sizing:border-box;max-width:100%;font-size:16px!important}.page{min-width:0;max-width:100%}.page-header{flex-wrap:wrap;gap:8px}.page-header h1{font-size:18px}.summary-cards{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.summary-card{min-width:0;padding:12px 8px}.summary-label{font-size:11px}.summary-amount{font-size:15px}.form-2col,.form-3col{grid-template-columns:1fr}.table-wrapper{-webkit-overflow-scrolling:touch;overflow-x:auto}.data-table{min-width:400px;font-size:12px}.data-table th,.data-table td{padding:8px}.hub-tabs{-webkit-overflow-scrolling:touch;box-sizing:border-box;flex-wrap:nowrap;width:100%;overflow-x:auto}.hub-tab{white-space:nowrap;flex-shrink:0;padding:6px 10px;font-size:13px}.sub-page-actions,.filters{flex-wrap:wrap;gap:6px}.filters select{flex:1;min-width:0}.overview-grid{grid-template-columns:1fr}.investment-page{max-width:100%}.inv-cost-row{flex-wrap:wrap;gap:6px}.inv-cost-label{flex:100%;min-width:0}.inv-cost-input{flex:0 110px;width:auto;min-width:0;max-width:140px}.inv-add-row{flex-wrap:wrap}.inv-add-input{flex:1;max-width:100%}.mortgage-page{max-width:100%}.mortgage-track-row{gap:8px}.mortgage-track-info{flex:100%;min-width:0}.mortgage-track-numbers{flex:100%;gap:8px;font-size:12px}.mortgage-track-actions{flex:none}.mortgage-schedule-section{-webkit-overflow-scrolling:touch;overflow-x:auto}.mortgage-schedule-table{min-width:500px;font-size:11px}.mortgage-schedule-table th,.mortgage-schedule-table td{padding:6px}.settings-page{max-width:100%}.settings-row{flex-wrap:wrap}.settings-label,.login-card{width:100%;min-width:0}.gtasks-list{max-width:100%}.modal{margin:0;padding:20px 16px}.onboarding-card{box-sizing:border-box;max-width:100%}.onboarding-row{grid-template-columns:1fr}}.mortgage-page{max-width:860px}.mortgage-section-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.mortgage-section-header h2{margin:0}.mortgage-tracks-section,.mortgage-schedule-section{margin-top:28px}.mortgage-track-card{margin-bottom:10px}.mortgage-track-row{flex-wrap:wrap;align-items:center;gap:16px;display:flex}.mortgage-track-info{flex-direction:column;gap:2px;min-width:140px;display:flex}.mortgage-track-type{font-size:14px;font-weight:600}.mortgage-track-label{color:var(--text-muted);font-size:12px}.mortgage-track-numbers{flex-wrap:wrap;flex:1;gap:16px;font-size:13px;display:flex}.mortgage-track-meta{color:var(--text-muted);font-size:12px}.mortgage-track-actions{align-items:center;gap:8px;margin-right:auto;display:flex}.btn-sm{padding:4px 10px;font-size:13px}.mortgage-inline-edit{flex-direction:column;gap:10px;display:flex}.mortgage-inline-edit-top{justify-content:flex-start;margin-bottom:2px;display:flex}.mortgage-delete-btn{opacity:.6;padding:2px 7px;font-size:18px;line-height:1}.mortgage-delete-btn:hover{opacity:1}.mortgage-delete-confirm{align-items:center;gap:6px;font-size:13px;display:inline-flex}.mortgage-delete-confirm-label{color:var(--danger);font-weight:600}.btn-danger-solid{background:var(--danger);color:#fff;border-radius:var(--r-xs);cursor:pointer;border:none;padding:2px 10px;font-family:inherit;font-size:12px}.btn-danger-solid:hover{filter:brightness(.9)}.mortgage-inline-fields{flex-direction:column;gap:10px;display:flex}.mortgage-inline-row{flex-wrap:wrap;gap:12px;display:flex}.mortgage-inline-field{flex-direction:column;flex:1;gap:3px;min-width:120px;display:flex}.mortgage-inline-label{color:var(--text-muted);font-size:11px;font-weight:500}.mortgage-inline-select{padding:4px 8px;font-size:13px}.mortgage-inline-computed{justify-content:center}.mortgage-effective-rate-inline{color:var(--primary);padding:4px 0;font-size:15px;font-weight:700}.mortgage-inline-payment{border-top:1px solid var(--border);align-items:center;gap:8px;padding:6px 0 2px;font-size:13px;display:flex}.mortgage-inline-payment-label{color:var(--text-muted)}.mortgage-inline-grace{padding-top:4px}.mortgage-inline-error{margin-top:4px;padding:4px 8px;font-size:12px}.mortgage-form-card{padding:20px}.mortgage-form-card h3{margin:0 0 16px;font-size:16px}.mortgage-effective-rate{background:var(--bg-alt);border-radius:var(--r-xs);margin-bottom:8px;padding:8px 12px;font-size:14px}.mortgage-payment-preview{background:var(--primary-light);border-radius:var(--r-xs);margin-top:8px;margin-bottom:8px;padding:10px 14px;font-size:15px}.mortgage-schedule-table{border-collapse:collapse;width:100%;font-size:13px}.mortgage-schedule-table th{text-align:right;border-bottom:1px solid var(--border);color:var(--text-muted);padding:8px 10px;font-weight:600}.mortgage-schedule-table td{border-bottom:1px solid var(--border);padding:7px 10px}.mortgage-year-row{cursor:pointer;background:var(--bg-alt)}.mortgage-year-row:hover{background:var(--hover-bg)}.mortgage-expand-btn{width:24px;color:var(--text-muted);font-size:11px}.mortgage-month-row td{background:var(--surface);color:var(--text-muted);font-size:12px}.mortgage-month-label{padding-right:20px}.mortgage-track-filter{width:auto;padding:4px 8px;font-size:13px}.mortgage-note{color:var(--text-muted);margin-top:12px;font-size:12px}.mortgage-future-note{margin-top:32px;font-style:italic}.mortgage-page .mortgage-summary-cards{grid-template-columns:repeat(2,1fr)}.mortgage-add-track-btn{width:100%;margin-top:8px}.grace-months-label{color:var(--text-muted);white-space:nowrap;font-size:12px}.grace-inline-actions{align-items:center;gap:4px;margin-right:auto;display:flex}.btn-ghost-danger{cursor:pointer;color:var(--danger);border-radius:var(--r-xs);background:0 0;border:none;padding:2px 6px;font-family:inherit;font-size:12px}.btn-ghost-danger:hover{background:var(--danger-bg,color-mix(in srgb, var(--danger) 10%, transparent))}.grace-badge-readonly{cursor:default}.grace-checkbox-label{cursor:pointer;align-items:center;gap:6px;margin-bottom:6px;font-weight:500;display:flex}.grace-badge{border-radius:var(--r-pill);margin-top:4px;padding:2px 8px;font-size:11px;font-weight:600;display:inline-block}.grace-badge-clickable{background:var(--warning-bg);color:var(--warning-text);border:1px solid var(--warning);cursor:pointer}.grace-badge-clickable:hover{background:var(--warning-bg);filter:brightness(.95)}.grace-badge-empty{color:var(--text-muted);border:1px dashed var(--border);cursor:pointer;background:0 0}.grace-badge-empty:hover{color:var(--primary);border-color:var(--primary)}.mortgage-payment-split{justify-content:space-between;align-items:baseline;gap:6px;margin-top:4px;display:flex}.mortgage-payment-split-label{color:var(--text-muted);white-space:nowrap;font-size:11px}.mortgage-payment-split .summary-amount{font-size:16px}.grace-inline-edit{flex-wrap:wrap;align-items:center;gap:6px;margin-top:4px;display:flex}.grace-months-input{border:1px solid var(--border);border-radius:var(--r-xs);text-align:center;width:56px;padding:2px 6px;font-size:13px}.btn-xs{padding:2px 8px;font-size:12px}.virtual-tx-row{background:color-mix(in srgb, var(--accent) 4%, transparent);border-right:3px solid var(--accent)}.virtual-badge{background:var(--accent);color:#fff;vertical-align:middle;opacity:.8;border-radius:4px;margin-right:4px;padding:1px 5px;font-size:10px}.hub-tabs{background:var(--surface-raised);border-radius:var(--r-md);border:1px solid var(--border);gap:2px;padding:3px;display:flex}.hub-tab{color:var(--text-secondary);white-space:nowrap;border-radius:8px;padding:6px 16px;font-size:14px;font-weight:500;text-decoration:none;transition:background .15s,color .15s}.hub-tab:hover{color:var(--text-primary)}.hub-tab.active{background:var(--accent);color:#fff}.sub-page-actions{justify-content:flex-start;align-items:center;gap:8px;padding:12px 0 4px;display:flex}.sub-page-summary{color:var(--text-muted);margin-right:auto;font-size:.85rem}.overview-grid{grid-template-columns:repeat(2,1fr);gap:16px;padding-top:8px;display:grid}.overview-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);cursor:pointer;text-align:right;width:100%;font:inherit;color:inherit;transition:box-shadow var(--t-base) var(--ease), border-color var(--t-base) var(--ease), transform var(--t-base) var(--ease);flex-direction:column;gap:6px;padding:20px;display:flex}.overview-card:hover{box-shadow:var(--shadow-md);border-color:var(--border-strong);transform:translateY(-1px)}.overview-card:active{transform:translateY(0)scale(.995)}.overview-card-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.03em;font-size:.78rem;font-weight:500}.overview-card-value{color:var(--text-primary);font-size:1.5rem;font-weight:700;line-height:1.2}.overview-card-sub{color:var(--text-muted);font-size:.8rem}.overview-card-split{flex-wrap:wrap;align-items:baseline;gap:.25rem;font-size:1rem;display:flex}.overview-card-slash{color:var(--text-muted);font-weight:400}.empty-state-cta{text-align:center;color:var(--text-muted);flex-direction:column;align-items:center;gap:12px;padding:48px 24px;display:flex}.empty-state-cta-icon{font-size:2.5rem}.empty-state-cta p{margin:0;font-size:1rem}.onboarding-optional{color:var(--text-muted);margin-top:-8px;font-size:.82rem}.onboarding-field-hint{color:var(--text-muted);opacity:.75;margin-top:3px;font-size:11px;display:block}.input-ph-grey{color:var(--text-muted)!important}.onboarding-step-count{color:var(--text-muted);text-align:center;letter-spacing:.02em;margin-top:-24px;margin-bottom:20px;font-size:11.5px}.onboarding-expander-toggle{border:none;border-top:1px solid var(--border);cursor:pointer;width:100%;color:var(--text-muted);text-align:right;background:0 0;justify-content:space-between;align-items:center;padding:10px 0;font-family:inherit;font-size:13px;font-weight:600;transition:color .15s;display:flex}.onboarding-expander-toggle:hover{color:var(--text)}.onboarding-expander-chevron{color:var(--text-muted);font-size:1.1rem;line-height:1;transition:transform .2s;display:inline-block;transform:rotate(90deg)}.onboarding-expander-chevron.open{transform:rotate(-90deg)}.onboarding-expander-body{flex-direction:column;gap:14px;padding-bottom:4px;display:flex}.btn-onboard-link{color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:4px 0;font-family:inherit;font-size:13px;text-decoration:none}.btn-onboard-link:hover{color:var(--text);text-decoration:underline}.btn-onboard-link:disabled{opacity:.5;cursor:not-allowed}.onboarding-list{flex-direction:column;gap:6px;margin-bottom:16px;display:flex}.onboarding-list-row{background:var(--accent-light);border:1px solid var(--border);border-radius:var(--r-md);font-size:13px;overflow:hidden}.onboarding-list-row-header{cursor:pointer;-webkit-user-select:none;user-select:none;justify-content:space-between;align-items:center;gap:8px;padding:9px 12px;display:flex}.onboarding-list-row-actions{flex-shrink:0;align-items:center;gap:4px;display:flex}.onboarding-track-summary{flex-direction:column;flex:1;gap:3px;min-width:0;display:flex}.onboarding-track-summary-top{justify-content:space-between;align-items:baseline;gap:8px;display:flex}.onboarding-track-payment{color:var(--text);white-space:nowrap;font-size:14px;font-weight:600}.onboarding-track-summary-sub{color:var(--text-muted);flex-wrap:wrap;gap:5px;font-size:12px;display:flex}.onboarding-list-edit{cursor:pointer;color:var(--text-muted);background:0 0;border:none;border-radius:5px;padding:2px 5px;font-size:14px;line-height:1;transition:color .15s,background .15s}.onboarding-list-edit:hover{color:var(--accent);background:var(--accent-light)}.onboarding-list-row-detail{border-top:1px solid var(--border);background:var(--bg-card,var(--bg));flex-direction:column;gap:6px;padding:10px 14px;display:flex}.onboarding-list-detail-row{color:var(--text-muted);justify-content:space-between;font-size:13px;display:flex}.onboarding-list-detail-row span:last-child,.onboarding-list-detail-row strong{color:var(--text)}.onboarding-list-total{border-top:1px solid var(--border);color:var(--text-muted);justify-content:space-between;align-items:center;margin-top:2px;padding:8px 12px;font-size:13px;display:flex}.onboarding-list-total strong{color:var(--text);font-size:14px}.onboarding-mortgage-summary{background:var(--accent-light);border:1px solid var(--border);border-radius:var(--r-md);margin-bottom:16px;overflow:hidden}.onboarding-list-row-info{color:var(--text-muted);flex-wrap:wrap;flex:1;align-items:center;gap:8px;min-width:0;display:flex}.onboarding-list-row-type{color:var(--text);font-weight:600}.onboarding-list-remove{cursor:pointer;color:var(--text-muted);background:0 0;border:none;border-radius:5px;flex-shrink:0;padding:2px 6px;font-size:13px;line-height:1;transition:color .15s,background .15s}.onboarding-list-remove:hover{color:var(--danger);background:var(--danger-bg)}.onboarding-inline-form{background:var(--bg);border:1.5px dashed var(--border);border-radius:var(--r-md);flex-direction:column;gap:12px;margin-bottom:20px;padding:16px;display:flex}.onboarding-running-total{color:var(--text-muted);margin:0;font-size:13px;line-height:1.5}.onboarding-running-total strong{color:var(--text)}.onboarding-add-btn{align-self:flex-start;font-weight:600;color:var(--accent)!important}.form-input{border:1.5px solid var(--border);border-radius:var(--r-sm);width:100%;color:var(--text);background:var(--surface);padding:10px 14px;font-family:inherit;font-size:15px;transition:border-color .15s}.form-input:focus{border-color:var(--accent);box-shadow:var(--shadow-focus);outline:none}.dash-section-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:-8px;font-size:13px;font-weight:600}.dash-hero{background:var(--surface);box-shadow:var(--shadow-md);cursor:pointer;transition:box-shadow var(--t-base) var(--ease), border-color var(--t-base) var(--ease), transform var(--t-base) var(--ease);border:1px solid var(--border);border-radius:16px;outline:none;padding:24px 22px 20px}.dash-hero-skeleton{cursor:default;flex-direction:column;gap:12px;display:flex}.dash-hero:hover{box-shadow:var(--shadow-lg);border-color:var(--border-strong);transform:translateY(-1px)}.dash-hero:active{transform:translateY(0)scale(.995)}.dash-hero:focus-visible{box-shadow:var(--shadow-focus)}.dash-hero-label{color:var(--text-muted);text-align:center;margin-bottom:6px;font-size:13px;font-weight:500}.dash-hero-value{color:var(--text-heading);letter-spacing:-.02em;text-align:center;margin-bottom:20px;font-size:38px;font-weight:800;line-height:1.1}.dash-equity-bar{background:var(--bg);border-radius:8px;gap:2px;height:14px;margin-bottom:10px;display:flex;overflow:hidden}.dash-equity-bar-own{background:var(--success);border-radius:8px 0 0 8px;min-width:4px;transition:width .4s}.dash-equity-bar-debt{background:#fca5a5;border-radius:0 8px 8px 0;flex:1;min-width:4px;transition:width .4s}.dash-equity-bar-debt[style*="width: 0"]{display:none}.dash-equity-bar-loan{background:#c4b5fd;min-width:4px;transition:width .4s}.dash-equity-bar-balloon{background:#fcd34d;min-width:4px;transition:width .4s}.dash-equity-legend{color:var(--text-muted);flex-wrap:wrap;justify-content:space-between;gap:8px 12px;font-size:12px;display:flex}.dash-legend-item{align-items:center;gap:5px;display:inline-flex}.dash-legend-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.dash-legend-dot.own{background:var(--success)}.dash-legend-dot.debt{background:#fca5a5}.dash-legend-dot.loan{background:#c4b5fd}.dash-legend-dot.balloon{background:#fcd34d}.dash-hero-metrics{border-top:1px solid var(--border);gap:0;margin-top:14px;padding-top:12px;display:flex}.dash-hero-metric{border-inline-end:1px solid var(--border);flex-direction:column;flex:1;gap:2px;padding:0 8px;display:flex}.dash-hero-metric:first-child{padding-inline-start:0}.dash-hero-metric:last-child{border-inline-end:none}.dash-hero-metric span{color:var(--text-muted);font-size:11px}.dash-hero-metric strong{color:var(--text-primary);font-size:13px;font-weight:600}.dash-view-toggle{justify-content:center;margin-bottom:14px;display:flex}.dash-mini-cards{grid-template-columns:1fr 1fr;gap:12px;margin-top:18px;display:grid}.dash-mini-card{background:var(--surface);border-radius:var(--r-md);box-shadow:var(--shadow-sm);border:1px solid var(--border);flex-direction:column;gap:4px;padding:14px 14px 12px;display:flex}.dash-mini-card-label{color:var(--text-muted);font-size:12px;font-weight:500}.dash-mini-card-value{color:var(--text-heading);margin-bottom:6px;font-size:16px;font-weight:700}.dash-cashflow-rows{border-top:1px solid var(--border);flex-direction:column;gap:0;margin-top:16px;padding-top:14px;display:flex}.dash-upcoming-row{background:var(--surface);border-radius:var(--r-md);box-shadow:var(--shadow-sm);border:1px solid var(--border);cursor:pointer;transition:box-shadow var(--t-fast) var(--ease), transform var(--t-fast) var(--ease);-webkit-tap-highlight-color:transparent;align-items:center;gap:12px;padding:14px 16px;display:flex}.dash-upcoming-row:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.dash-upcoming-row:active{transform:translateY(0)}.dash-upcoming-icon{background:var(--accent-light);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:42px;height:42px;display:flex}.dash-upcoming-info{flex:1;min-width:0}.dash-upcoming-title{color:var(--text);font-size:15px;font-weight:600}.dash-upcoming-subtitle{color:var(--text-muted);margin-top:1px;font-size:12px}.dash-upcoming-amount{flex-shrink:0;font-size:16px;font-weight:700}.prop-stats-grid{grid-template-columns:1fr 1fr;gap:12px;margin-bottom:20px;display:grid}.prop-stat-card{background:var(--surface);border-radius:var(--r-md);box-shadow:var(--shadow-sm);border:1px solid var(--border);flex-direction:column;gap:4px;padding:16px 14px 14px;display:flex}.prop-stat-label{color:var(--text-muted);font-size:12px;font-weight:500}.prop-stat-value{color:var(--text-heading);letter-spacing:-.01em;font-size:19px;font-weight:700;line-height:1.2}.prop-stat-sub{color:var(--text-muted);margin-top:2px;font-size:11.5px}.dash-section-title-row{justify-content:space-between;align-items:center;gap:12px;margin-bottom:-8px;display:flex}.dash-section-title-row .dash-section-title{margin-bottom:0}.dash-card-note{color:var(--text-muted);margin-top:5px;font-size:11px}.dashboard-metrics{background:var(--surface);box-shadow:var(--shadow-sm);border-radius:var(--r-md);border:1px solid var(--border);flex-wrap:wrap;gap:12px;padding:14px 18px;display:flex}.dashboard-metric-item{cursor:default;flex-direction:column;flex:1;gap:4px;min-width:90px;display:flex}.dashboard-metric-item[role=button]{cursor:pointer}.dashboard-metric-item[role=button]:hover .dashboard-metric-value{color:var(--accent);-webkit-text-decoration:underline dotted;text-decoration:underline dotted}.dashboard-metric-label{color:var(--text-muted);white-space:nowrap;font-size:11px;font-weight:500}.dashboard-metric-value{color:var(--text);white-space:nowrap;font-size:16px;font-weight:700;transition:color .15s}.dash-attention-badge{border-radius:var(--r-pill);vertical-align:middle;margin-left:6px;padding:1px 6px;font-size:10px;font-weight:600;display:inline-block}.dash-attention-badge.renewal{color:#9d174d;background:#fce7f3}.dashboard-quick-actions{flex-wrap:wrap;gap:10px;padding-top:4px;display:flex}.dashboard-quick-actions .btn-secondary{text-align:center;flex:1;min-width:90px;font-weight:600}.dashboard-page .dashboard-sections{max-width:700px}@media (width<=480px){.dash-hero-value{font-size:32px}.dashboard-metrics{gap:8px;padding:12px 14px}.dashboard-metric-item{min-width:70px}.dashboard-metric-value{font-size:14px}.dashboard-quick-actions .btn-secondary{padding:8px 10px;font-size:13px}}.chart-card{background:var(--surface);box-shadow:var(--shadow-sm);border-radius:var(--r-md);margin-bottom:16px;padding:16px}.chart-card-title{color:var(--text);margin-bottom:10px;font-size:14px;font-weight:600}.chart-caption{color:var(--text-muted);margin-top:8px;font-size:12px;line-height:1.5}.chart-labels{color:var(--text-muted);justify-content:space-between;margin-top:6px;font-size:12px;display:flex}.mortgage-analytics-section{margin-top:28px}@media (width<=480px){.chart-card{padding:12px}.chart-card-title{font-size:13px}}.dash-hero-value,.login-card h1,.onboarding-title,.sidebar-title,.page-header h1{font-family:var(--font-display);font-weight:700}.amount,.summary-amount,.dash-hero-value,.overview-card-value,.dashboard-metric-value,.data-table td,.mortgage-schedule-table td{font-variant-numeric:tabular-nums}.btn-primary:focus-visible,.btn-secondary:focus-visible,.btn-icon:focus-visible,.nav-link:focus-visible,.hub-tab:focus-visible,.toggle-btn:focus-visible,.btn-onboard-primary:focus-visible,.btn-onboard-skip:focus-visible,a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{box-shadow:var(--shadow-focus);outline:none}button,a,.nav-link,.hub-tab,.toggle-btn,input,select{touch-action:manipulation}.btn-primary,.btn-secondary,.btn-icon,.btn-link,.nav-link,.toggle-btn,.hub-tab{transition:transform var(--t-fast) var(--ease), background var(--t-fast) var(--ease), box-shadow var(--t-fast) var(--ease)}.btn-primary:active,.btn-secondary:active,.btn-icon:active,.btn-link:active,.nav-link:active,.toggle-btn:active,.hub-tab:active{transform:scale(.97)}.loans-section{flex-direction:column;gap:12px;display:flex}.loan-card{flex-direction:column;gap:8px;display:flex}.loan-card-head{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.loan-card-title{flex-direction:column;gap:2px;display:flex}.loan-card-name{font-size:15px;font-weight:600}.loan-card-lender{color:var(--text-muted);font-size:12px}.loan-card-actions{flex-shrink:0;align-items:center;gap:6px;display:flex}.loan-card-numbers{flex-wrap:wrap;gap:16px;font-size:13px;display:flex}.loan-card-meta{color:var(--text-muted);flex-wrap:wrap;gap:6px;font-size:12px;display:flex}.loans-add-btn,.balloon-add-btn{align-self:flex-start}.loan-form-card,.balloon-form-card{flex-direction:column;gap:12px;display:flex}.inv-cost-net{border-top:1px dashed var(--border);color:var(--text-muted);justify-content:space-between;align-items:center;margin-top:6px;padding-top:10px;font-size:13px;font-weight:600;display:flex}.inv-balloon-block{margin-top:20px}.inv-balloon-title{margin:0 0 8px;font-size:15px}.balloon-financing{flex-direction:column;gap:12px;display:flex}.balloon-hint{margin:0}.balloon-row{border-bottom:1px solid var(--border);align-items:center;gap:12px;padding:8px 0;display:flex}.balloon-row:last-child{border-bottom:none}.balloon-row-info{flex-direction:column;flex:1;gap:2px;display:flex}.balloon-row-name{font-size:14px;font-weight:500}.balloon-row-lender{color:var(--text-muted);font-size:12px}.balloon-row-amount{font-size:14px;font-weight:600}.balloon-row-actions{align-items:center;gap:4px;display:flex}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition-duration:.001ms!important;animation-duration:.001ms!important;animation-iteration-count:1!important}}@keyframes skeleton-shimmer{0%{background-position:100% 0}to{background-position:0 0}}.skeleton{background:linear-gradient(90deg, var(--bg-alt) 25%, var(--border) 37%, var(--bg-alt) 63%);border-radius:var(--r-sm);background-size:400% 100%;animation:1.4s infinite skeleton-shimmer;display:block}.skeleton-text{flex-direction:column;gap:8px;display:flex}.skeleton-text-line{height:14px}.skeleton-card{background:var(--surface);box-shadow:var(--shadow-sm);border-radius:var(--r-md);border:1px solid var(--border);flex-direction:column;gap:10px;padding:18px;display:flex}.skeleton-card-label{width:55%;height:13px}.skeleton-card-value{width:70%;height:22px}.skeleton-stats{grid-template-columns:repeat(3,1fr);gap:12px;display:grid}@media (width<=480px){.skeleton-stats{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}}.skeleton-list{background:var(--surface);box-shadow:var(--shadow-sm);border-radius:var(--r-md);border:1px solid var(--border);overflow:hidden}.skeleton-list-row{border-bottom:1px solid var(--border);align-items:center;gap:12px;padding:14px 18px;display:flex}.skeleton-list-row:last-child{border-bottom:none}.skeleton-list-left{flex-direction:column;flex:1;gap:6px;display:flex}.skeleton-list-main{height:14px}.skeleton-list-sub{width:50%;height:11px}.skeleton-list-right{flex-shrink:0;width:64px;height:14px}.empty-state-cta-hint{color:var(--text-muted);margin:0;font-size:.85rem;line-height:1.55}.barchart{flex-direction:column;width:100%;display:flex;overflow:hidden}.barchart-bars{flex-direction:row;align-items:flex-end;gap:8px;width:100%;display:flex}.barchart-col{flex-direction:column;flex:1;justify-content:flex-end;align-items:center;gap:4px;min-width:0;height:100%;display:flex}.barchart-bar{width:100%;min-height:2px;transition:height var(--t-base,.2s) var(--ease,cubic-bezier(.4,0,.2,1));border-radius:4px 4px 0 0}.barchart-bar:hover{opacity:.82}.barchart-value{color:var(--text-muted,#5b6b78);font-size:11px;font-weight:600;font-family:var(--font-body,"Rubik", system-ui, sans-serif);text-align:center;white-space:nowrap;text-overflow:ellipsis;flex-shrink:0;max-width:100%;overflow:hidden}.barchart-labels{flex-direction:row;gap:8px;width:100%;margin-top:6px;display:flex}.barchart-label{color:var(--text-muted,#5b6b78);font-size:12px;font-family:var(--font-body,"Rubik", system-ui, sans-serif);text-align:center;word-break:break-word;flex:1;min-width:0;line-height:1.3}.barchart-empty{text-align:center;color:var(--text-muted);padding:24px 0;font-size:13px}@media (hover:none){.gtask-delete{opacity:1}}.donut-chart-wrap{align-items:center;gap:20px;display:flex}.donut-svg-container{flex-shrink:0;position:relative}.donut-svg-container svg circle{transition:stroke-dasharray var(--t-base,.2s) var(--ease,cubic-bezier(.4,0,.2,1))}.donut-center{text-align:center;pointer-events:none;flex-direction:column;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.donut-center-value{color:var(--text-heading);font-size:17px;font-weight:700;font-family:var(--font-display)}.donut-center-label{color:var(--text-muted);margin-top:2px;font-size:11.5px}.donut-legend{flex-direction:column;flex:1;gap:8px;min-width:0;display:flex}.donut-legend-item{align-items:center;gap:8px;font-size:13px;display:flex}.donut-legend-dot{border-radius:50%;flex-shrink:0;width:9px;height:9px}.donut-legend-label{color:var(--text);text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;overflow:hidden}.donut-legend-pct{color:var(--text-muted);flex-shrink:0;font-size:12px}.donut-legend-value{color:var(--text-muted);flex-shrink:0;font-weight:500}.donut-chart-mini{justify-content:center}@media (width<=480px){.donut-chart-wrap{gap:14px}}.sparkline{width:100%;display:block;overflow:visible}
