:root{--navy: #0f172a;--navy-mid: #1e293b;--navy-border: #334155;--navy-text: #94a3b8;--white: #ffffff;--surface: #f8fafc;--surface-hover: #f1f5f9;--border: #e2e8f0;--border-dark: #cbd5e1;--text: #0f172a;--text-mid: #475569;--text-muted: #64748b;--text-light: #94a3b8;--green: #16a34a;--green-bg: #dcfce7;--green-mid: #bbf7d0;--red: #dc2626;--red-bg: #fee2e2;--yellow: #b45309;--yellow-bg: #fef3c7;--blue: #2563eb;--blue-mid: #3b82f6;--blue-bg: #eff6ff;--blue-border: #bfdbfe;--font-ui: "DM Sans", system-ui, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", monospace;--sidebar-w: 264px;--header-h: 76px;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--shadow-sm: 0 1px 3px rgba(0,0,0,.08);--shadow-md: 0 4px 16px rgba(0,0,0,.1);--shadow-lg: 0 16px 48px rgba(0,0,0,.18);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-ui);background:var(--surface);color:var(--text);font-size:14px;line-height:1.5}.app{display:flex;height:100vh;overflow:hidden}.sidebar{width:var(--sidebar-w);min-width:var(--sidebar-w);background:var(--navy);display:flex;flex-direction:column;overflow:hidden}.sidebar-logo{padding:20px 20px 18px;font-size:19px;font-weight:700;letter-spacing:-.6px;color:#fff;border-bottom:1px solid var(--navy-border);flex-shrink:0}.sidebar-logo .logo-accent{color:#60a5fa}.sidebar-logo .logo-sub{font-size:11px;font-weight:400;color:var(--navy-text);display:block;margin-top:1px;letter-spacing:0}.sidebar-nav{padding:10px 10px 0;flex-shrink:0}.nav-btn{width:100%;text-align:left;padding:9px 12px;border:none;background:transparent;color:var(--navy-text);font-family:var(--font-ui);font-size:14px;font-weight:500;border-radius:var(--radius-sm);cursor:pointer;transition:all .15s;margin-bottom:2px;display:flex;align-items:center;gap:9px}.nav-btn:hover{background:var(--navy-mid);color:#cbd5e1}.nav-btn.active{background:var(--navy-mid);color:#fff}.nav-btn svg{opacity:.7}.nav-btn.active svg{opacity:1}.sidebar-month{padding:14px 16px;border-top:1px solid var(--navy-border);border-bottom:1px solid var(--navy-border);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}.month-nav-btn{background:none;border:none;color:var(--navy-text);cursor:pointer;font-size:16px;padding:4px 6px;border-radius:4px;transition:all .15s;line-height:1}.month-nav-btn:hover{background:var(--navy-mid);color:#fff}.month-info{text-align:center}.month-label{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:var(--navy-text);margin-bottom:2px}.month-value{font-size:14px;font-weight:600;color:#fff}.content{flex:1;overflow-y:auto;display:flex;flex-direction:column;background:var(--surface);min-width:0}.budget-header{background:var(--white);border-bottom:1px solid var(--border);padding:0 32px;height:var(--header-h);display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:20;box-shadow:var(--shadow-sm);gap:24px;flex-shrink:0}.header-ready{display:flex;flex-direction:column;min-width:200px}.ready-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1.2px;color:var(--text-muted);margin-bottom:2px}.ready-amount{font-family:var(--font-mono);font-size:30px;font-weight:600;letter-spacing:-1.5px;line-height:1.1;transition:color .2s}.ready-amount.positive{color:var(--green)}.ready-amount.zero{color:var(--text-muted)}.ready-amount.negative{color:var(--red)}.ready-hint{font-size:11px;color:var(--text-muted);margin-top:1px}.ready-hint.good{color:var(--green)}.ready-hint.bad{color:var(--red)}.header-stats{display:flex;gap:28px;flex:1;justify-content:center}.header-stat{text-align:center}.stat-label{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:var(--text-muted);margin-bottom:3px}.stat-value{font-family:var(--font-mono);font-size:17px;font-weight:500;color:var(--text)}.header-actions{display:flex;gap:8px;align-items:center}.header-month{display:flex;align-items:center;gap:2px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:2px 4px}.header-month .month-nav-btn{background:none;border:none;cursor:pointer;color:var(--text-muted);font-size:16px;line-height:1;padding:4px 7px;border-radius:4px;transition:all .12s}.header-month .month-nav-btn:hover{background:white;color:var(--text)}.header-month-value{font-size:13px;font-weight:600;color:var(--text);min-width:104px;text-align:center;white-space:nowrap}.btn{padding:8px 16px;border-radius:var(--radius-sm);font-family:var(--font-ui);font-size:13px;font-weight:600;cursor:pointer;border:none;transition:all .15s;white-space:nowrap;display:inline-flex;align-items:center;gap:6px}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--blue);color:#fff}.btn-primary:hover:not(:disabled){background:var(--blue-mid)}.btn-secondary{background:white;color:var(--text);border:1px solid var(--border)}.btn-secondary:hover:not(:disabled){background:var(--surface);border-color:var(--border-dark)}.btn-ghost{background:transparent;color:var(--text-muted);padding:6px 12px}.btn-ghost:hover:not(:disabled){background:var(--surface);color:var(--text)}.btn-danger{background:var(--red-bg);color:var(--red)}.btn-danger:hover:not(:disabled){background:#fca5a5}.btn-sm{padding:5px 11px;font-size:12px}.quick-budget-bar{background:white;border-bottom:1px solid var(--border);padding:9px 32px;display:flex;align-items:center;gap:8px;flex-shrink:0}.quick-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.8px;color:var(--text-muted);margin-right:4px}.budget-view{padding:20px 32px 40px;flex:1}.budget-table-header{display:grid;grid-template-columns:1fr 130px 130px 130px 32px;padding:6px 12px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1.2px;color:var(--text-muted);border-bottom:2px solid var(--border);margin-bottom:10px}.budget-table-header span:not(:first-child){text-align:right}.category-group{margin-bottom:8px;border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden;background:white;box-shadow:var(--shadow-sm)}.group-header{display:grid;grid-template-columns:1fr 130px 130px 130px 32px;align-items:center;padding:9px 12px;background:var(--surface);cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .12s;border-bottom:1px solid transparent}.group-header:hover{background:var(--surface-hover)}.group-header.open{border-bottom-color:var(--border)}.group-name-wrap{display:flex;align-items:center;gap:7px;min-width:0}.chevron{width:15px;height:15px;color:var(--text-muted);transition:transform .18s ease;flex-shrink:0}.chevron.collapsed{transform:rotate(-90deg)}.group-name-input{border:none;background:transparent;font-family:var(--font-ui);font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:var(--text-mid);width:100%;outline:none;cursor:pointer;padding:2px 4px;border-radius:3px}.group-name-input:focus{cursor:text;background:var(--blue-bg);color:var(--text)}.group-total{font-family:var(--font-mono);font-size:12px;font-weight:500;color:var(--text-muted);text-align:right;padding-right:4px}.group-total.group-available-positive{color:var(--green)}.group-total.group-available-negative{color:var(--red)}.category-row{display:grid;grid-template-columns:1fr 130px 130px 130px 32px;align-items:center;padding:7px 12px;border-top:1px solid #f8fafc;transition:background .1s}.category-row:hover{background:#fafafa}.category-row:hover .row-del-btn{opacity:1}.cat-name-wrap{padding-left:22px;display:flex;align-items:center;min-width:0}.cat-name-input{border:none;background:transparent;font-family:var(--font-ui);font-size:14px;color:var(--text);width:100%;outline:none;padding:2px 4px;border-radius:3px}.cat-name-input:focus{background:var(--surface)}.budgeted-cell{display:flex;justify-content:flex-end;align-items:center}.budget-display{font-family:var(--font-mono);font-size:14px;font-weight:500;color:var(--text);padding:3px 9px;border-radius:var(--radius-sm);cursor:pointer;transition:all .12s}.budget-display:hover{background:var(--blue-bg);color:var(--blue)}.budget-display.zero{color:var(--text-light)}.budget-display.zero:hover{color:var(--blue)}.budget-edit-input{font-family:var(--font-mono);font-size:14px;font-weight:500;width:100px;text-align:right;border:1.5px solid var(--blue-mid);border-radius:var(--radius-sm);padding:2px 8px;outline:none;color:var(--text);background:white;box-shadow:0 0 0 3px var(--blue-bg)}.activity-cell{font-family:var(--font-mono);font-size:13px;color:var(--text-muted);text-align:right;padding-right:4px}.activity-cell.negative{color:var(--text-mid)}.available-cell{font-family:var(--font-mono);font-size:13px;font-weight:600;text-align:right;padding:3px 8px;border-radius:var(--radius-sm)}.available-positive{color:var(--green);background:var(--green-bg)}.available-zero{color:var(--text-muted)}.available-negative{color:var(--red);background:var(--red-bg)}.row-del-btn{opacity:0;background:none;border:none;color:var(--text-light);cursor:pointer;padding:3px;border-radius:4px;font-size:15px;line-height:1;transition:all .12s;display:flex;align-items:center;justify-content:center}.row-del-btn:hover{color:var(--red);background:var(--red-bg)}.group-del-btn{background:none;border:none;color:var(--navy-border);cursor:pointer;padding:3px;border-radius:4px;font-size:15px;line-height:1;transition:all .12s;opacity:0;display:flex;align-items:center;justify-content:center}.group-header:hover .group-del-btn{opacity:1}.group-del-btn:hover{color:var(--red);background:var(--red-bg)}.add-cat-btn{background:none;border:none;color:var(--text-muted);font-size:12px;font-family:var(--font-ui);font-weight:500;cursor:pointer;padding:7px 12px 7px 44px;width:100%;text-align:left;transition:color .12s;display:flex;align-items:center;gap:5px;border-top:1px solid #f8fafc}.add-cat-btn:hover{color:var(--blue)}.add-group-btn{background:none;border:2px dashed var(--border-dark);border-radius:var(--radius-md);color:var(--text-muted);font-size:13px;font-family:var(--font-ui);font-weight:600;cursor:pointer;padding:13px;width:100%;text-align:center;transition:all .15s;margin-top:10px}.add-group-btn:hover{border-color:var(--blue-mid);color:var(--blue);background:var(--blue-bg)}.coa-view{padding:20px 32px 40px;flex:1}.coa-intro{display:flex;align-items:flex-start;justify-content:space-between;gap:24px;margin-bottom:18px}.coa-title{font-size:20px;font-weight:700;letter-spacing:-.4px;color:var(--text)}.coa-desc{font-size:13px;color:var(--text-muted);margin-top:4px;max-width:560px;line-height:1.5}.coa-stats{display:flex;gap:20px;font-size:12px;color:var(--text-muted);white-space:nowrap}.coa-stat-num{font-family:var(--font-mono);font-size:18px;font-weight:600;color:var(--text);margin-right:3px}.coa-group{border:1px solid var(--border);border-radius:var(--radius-md);background:white;box-shadow:var(--shadow-sm);margin-bottom:12px;overflow:hidden}.coa-group-head{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--surface);border-bottom:1px solid var(--border)}.coa-group-name{flex:1;border:1px solid transparent;background:transparent;font-family:var(--font-ui);font-size:14px;font-weight:700;color:var(--text);padding:5px 8px;border-radius:var(--radius-sm);outline:none;min-width:0}.coa-group-name:hover{border-color:var(--border);background:white}.coa-group-name:focus{border-color:var(--blue-mid);background:white;box-shadow:0 0 0 3px var(--blue-bg)}.coa-count{font-size:11px;color:var(--text-muted);white-space:nowrap}.coa-cats{padding:6px 14px 12px}.coa-cat{display:flex;align-items:center;gap:10px;padding:5px 0}.coa-cat-name{flex:1;border:1px solid transparent;background:transparent;font-family:var(--font-ui);font-size:14px;color:var(--text);padding:5px 8px;border-radius:var(--radius-sm);outline:none;min-width:0}.coa-cat-name:hover{border-color:var(--border);background:var(--surface)}.coa-cat-name:focus{border-color:var(--blue-mid);background:white;box-shadow:0 0 0 3px var(--blue-bg)}.coa-code{width:64px;border:1px solid var(--border);border-radius:var(--radius-sm);font-family:var(--font-mono);font-size:12px;color:var(--text-mid);padding:5px 7px;text-align:center;outline:none;background:white}.coa-code:focus{border-color:var(--blue-mid);box-shadow:0 0 0 3px var(--blue-bg)}.coa-code-group{font-weight:600;color:var(--text)}.coa-drag{display:flex;align-items:center;justify-content:center;width:20px;height:24px;color:var(--text-light);cursor:grab;border-radius:4px;flex-shrink:0;transition:all .12s}.coa-drag:hover{color:var(--text-mid);background:var(--surface-hover)}.coa-drag:active{cursor:grabbing}.coa-grip-inline{display:inline-flex;vertical-align:middle;color:var(--text-light);margin:0 2px}.coa-drop-before{box-shadow:inset 0 3px 0 var(--blue-mid)}.coa-drop-area{background:var(--blue-bg);border-radius:var(--radius-sm);outline:2px dashed var(--blue-border);outline-offset:-3px}.coa-move-to{font-size:11px;color:var(--text-muted);display:flex;align-items:center;gap:5px;white-space:nowrap}.coa-group-select{border:1px solid var(--border);border-radius:var(--radius-sm);font-family:var(--font-ui);font-size:12px;color:var(--text);padding:4px 6px;cursor:pointer;outline:none;background:white;max-width:150px}.coa-group-select:focus{border-color:var(--blue-mid)}.coa-del{border:none;background:transparent;color:var(--text-light);font-size:12px;font-weight:600;cursor:pointer;padding:5px 8px;border-radius:var(--radius-sm);transition:all .12s}.coa-del:hover{color:var(--red);background:var(--red-bg)}.coa-del-cat{font-size:17px;line-height:1;padding:2px 8px}.coa-add-cat{background:none;border:none;color:var(--text-muted);font-size:12px;font-family:var(--font-ui);font-weight:600;cursor:pointer;padding:7px 8px;margin-top:2px;border-radius:var(--radius-sm);transition:color .12s}.coa-add-cat:hover{color:var(--blue)}.coa-empty{font-size:13px;color:var(--text-light);padding:6px 8px;font-style:italic}.transactions-view{padding:20px 32px 40px;flex:1}.tx-sticky{position:sticky;top:0;z-index:20;background:var(--surface);padding-bottom:12px}.tx-sticky .bulk-bar{margin:10px 0 0}.tx-toolbar{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px;background:var(--surface);padding:12px 0;border-bottom:1px solid var(--border)}.tx-toolbar-left,.tx-toolbar-right{display:flex;gap:8px;align-items:center}.filter-tabs{display:flex;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:3px}.filter-tab{padding:5px 12px;border:none;background:transparent;font-family:var(--font-ui);font-size:12px;font-weight:600;color:var(--text-muted);border-radius:4px;cursor:pointer;transition:all .12s}.filter-tab.active{background:white;color:var(--text);box-shadow:0 1px 3px #0000001a}.account-filter{width:auto;max-width:240px;padding:6px 10px;font-size:12px;font-weight:600}.account-filter--active{border-color:var(--blue-mid);color:var(--blue);background:var(--blue-bg)}.add-tx-form{background:white;border:1px solid var(--blue-border);border-radius:var(--radius-md);padding:14px 16px;margin-bottom:14px;display:grid;grid-template-columns:150px 130px 1fr 190px 120px auto;gap:10px;align-items:end;box-shadow:0 0 0 3px var(--blue-bg)}.add-tx-form--income{border-color:var(--green-mid);box-shadow:0 0 0 3px var(--green-bg)}.type-toggle{display:flex;border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden;height:35px}.type-tab{flex:1;border:none;background:white;font-family:var(--font-ui);font-size:12px;font-weight:600;color:var(--text-muted);cursor:pointer;transition:all .12s}.type-tab:first-child{border-right:1px solid var(--border)}.type-tab.active.expense{background:var(--text);color:#fff}.type-tab.active.income{background:var(--green);color:#fff}.inflow-pill{display:flex;align-items:center;gap:6px;height:35px;padding:0 12px;border:1px dashed var(--green-mid);border-radius:var(--radius-sm);background:var(--green-bg);color:var(--green);font-size:13px;font-weight:600}.inflow-label{font-size:13px;font-weight:600;color:var(--green)}.detail-income{color:var(--green);font-weight:600}.tx-table{background:white;border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden;box-shadow:var(--shadow-sm)}.tx-grid{display:grid;grid-template-columns:28px 30px 88px 1fr 180px 110px 92px;gap:8px;align-items:center}.tx-row-actions{display:flex;align-items:center;justify-content:flex-end;gap:2px}.tx-action-btn{border:none;background:transparent;cursor:pointer;width:22px;height:22px;border-radius:5px;font-size:13px;line-height:1;color:var(--text-muted);opacity:0;transition:opacity .1s,background .1s,color .1s}.tx-row:hover .tx-action-btn{opacity:1}.tx-action-btn:hover{background:var(--blue-bg);color:var(--blue)}.tx-check-cell{display:flex;align-items:center;justify-content:center}.tx-checkbox{width:15px;height:15px;cursor:pointer;accent-color:var(--blue);margin:0}.tx-row--selected{background:var(--blue-bg)!important}.tx-row--selected:hover{background:#dbeafe!important}.tx-table-header{padding:9px 16px;background:var(--surface);border-bottom:1px solid var(--border);font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1.2px;color:var(--text-muted)}.tx-table-header span:first-child{text-align:center}.tx-row{padding:9px 16px;border-bottom:1px solid #f8fafc;transition:background .1s}.tx-row:last-child{border-bottom:none}.tx-row:hover{background:var(--surface)}.tx-row:hover .row-del-btn{opacity:1}.tx-row--review{box-shadow:inset 3px 0 #f59e0b;background:#fffbeb}.tx-row--review:hover{background:#fef3c7}.tx-row--expanded{background:var(--blue-bg);box-shadow:inset 3px 0 0 var(--blue)}.tx-row--expanded:hover{background:var(--blue-bg)}.tx-detail-panel{border-bottom:1px solid var(--border);background:var(--surface);padding:4px 16px 16px}.tx-detail{position:relative;background:var(--white);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);padding:16px 18px;max-width:640px}.tx-detail .detail-header{padding-right:28px}.tx-detail-close{position:absolute;top:10px;right:12px;border:none;background:transparent;cursor:pointer;font-size:20px;line-height:1;color:var(--text-muted);width:24px;height:24px;border-radius:5px}.tx-detail-close:hover{background:var(--surface);color:var(--text)}.tx-month-divider{display:flex;align-items:baseline;justify-content:space-between;padding:10px 16px 6px;background:var(--surface);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}.tx-month-divider:first-child{border-top:none}.tx-month-label{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-mid)}.tx-month-sub{font-family:var(--font-mono);font-size:12px;color:var(--text-muted)}.tx-row--pending{box-shadow:inset 3px 0 0 var(--slate, #64748b)}.tx-row--voided{opacity:.55}.tx-row--voided .tx-payee-name,.tx-row--voided .tx-amount{text-decoration:line-through}.review-toggle{width:20px;height:20px;border-radius:50%;border:1.5px solid var(--border-dark);background:white;cursor:pointer;font-size:12px;font-weight:700;color:#fff;line-height:1;display:flex;align-items:center;justify-content:center;transition:all .12s;padding:0;margin:0 auto}.review-toggle:hover{border-color:var(--green)}.review-toggle.reviewed{background:var(--green);border-color:var(--green)}.badge-suggest{background:#ede9fe;color:#7c3aed}.cat-select--suggested{color:#7c3aed;font-style:italic}.cat-select--income{color:var(--green);font-weight:600}.suggest-inline{color:#7c3aed;font-weight:600;text-transform:none;letter-spacing:0}.auto-msg{background:var(--blue-bg);border:1px solid var(--blue-border);color:var(--blue);font-size:13px;font-weight:500;padding:9px 14px;border-radius:var(--radius-sm);margin-bottom:12px}.bulk-bar{display:flex;align-items:center;gap:8px;flex-wrap:wrap;background:var(--navy);color:#fff;padding:10px 14px;border-radius:var(--radius-md);margin-bottom:12px;box-shadow:var(--shadow-md);animation:slideUp .15s ease}.bulk-count{font-size:13px;font-weight:700;color:#fff;white-space:nowrap}.bulk-divider{width:1px;height:22px;background:var(--navy-border)}.bulk-field{display:flex;align-items:center;gap:7px;font-size:12px;font-weight:600;color:var(--navy-text);white-space:nowrap}.bulk-select{width:auto;min-width:150px;padding:5px 9px;font-size:13px}.bulk-bar .btn-ghost{color:#cbd5e1}.bulk-bar .btn-ghost:hover:not(:disabled){background:var(--navy-mid);color:#fff}.modal-detail{width:480px}.detail-header{display:flex;align-items:center;gap:12px;padding-bottom:16px;border-bottom:1px solid var(--border);margin-bottom:4px}.detail-logo{width:40px;height:40px;border-radius:8px;object-fit:contain;background:var(--surface);border:1px solid var(--border);flex-shrink:0}.detail-header-text{flex:1;min-width:0}.detail-payee{font-size:18px;font-weight:700;color:var(--text);letter-spacing:-.3px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.detail-sub{display:flex;align-items:center;gap:7px;margin-top:5px;flex-wrap:wrap}.detail-inst{font-size:12px;color:var(--text-muted)}.detail-amount{font-family:var(--font-mono);font-size:22px;font-weight:600;letter-spacing:-.5px;white-space:nowrap}.detail-amount.out{color:var(--text)}.detail-amount.in{color:var(--green)}.detail-grid{display:flex;flex-direction:column;padding:6px 0}.detail-row{display:grid;grid-template-columns:140px 1fr;gap:12px;padding:7px 0;border-bottom:1px solid #f6f8fa;align-items:baseline}.detail-row:last-child{border-bottom:none}.detail-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:var(--text-muted)}.detail-value{font-size:14px;color:var(--text);word-break:break-word}.detail-muted{color:var(--text-light)}.detail-section-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--blue);margin-top:16px;margin-bottom:2px;padding-top:14px;border-top:1px solid var(--border)}.detail-link{color:var(--blue);text-decoration:none}.detail-link:hover{text-decoration:underline}.detail-code{font-family:var(--font-mono);font-size:12px;color:var(--text-muted);background:var(--surface);padding:1px 6px;border-radius:4px}.detail-note-empty{font-size:13px;color:var(--text-muted);background:var(--surface);border-radius:var(--radius-sm);padding:12px 14px;margin-top:14px;line-height:1.5}.detail-bill-linked{display:flex;align-items:center;justify-content:space-between;gap:10px;font-size:13px;color:var(--text)}.detail-bill-open{border:none;background:transparent;padding:0;cursor:pointer;font:inherit;font-weight:700;color:var(--blue)}.detail-bill-open:hover{text-decoration:underline}.detail-bill-actions{display:flex;flex-wrap:wrap;align-items:center;gap:8px}.detail-bill-link{display:flex;align-items:center;gap:8px;flex:1;min-width:200px}.detail-bill-link .form-select{flex:1}.tx-date{font-size:12px;color:var(--text-muted);font-family:var(--font-mono)}.tx-payee{font-size:14px;font-weight:500;display:flex;align-items:center;gap:6px;min-width:0}.tx-payee-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tx-payee-btn{background:none;border:none;padding:0;font:inherit;font-weight:500;color:var(--text);cursor:pointer;text-align:left;max-width:100%;border-radius:3px;transition:color .12s}.tx-payee-btn:hover{color:var(--blue);text-decoration:underline}.badge{font-size:10px;font-weight:700;padding:2px 6px;border-radius:4px;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;flex-shrink:0}.badge-uncat{background:var(--yellow-bg);color:var(--yellow)}.badge-bank{background:var(--navy-mid);color:#94a3b8;font-size:9px}.badge-manual{background:rgba(148,163,184,.18);color:#cbd5e1;font-size:9px}.badge-income{background:var(--green-bg);color:var(--green)}.badge-pending{background:rgba(100,116,139,.15);color:var(--slate, #64748b)}.badge-voided{background:var(--red-bg, #fef2f2);color:var(--red)}.badge-bill{background:#ede9fe;color:#7c3aed;max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tx-category{font-size:13px;color:var(--text-muted)}.cat-select{border:none;background:transparent;font-family:var(--font-ui);font-size:13px;color:var(--text-muted);cursor:pointer;padding:2px 4px;border-radius:4px;width:100%;outline:none;max-width:170px}.cat-select:hover,.cat-select:focus{background:var(--surface);color:var(--text)}.cat-combo{position:relative;width:100%}.cat-combo--row{max-width:170px}.cat-combo-input{font-family:var(--font-ui);width:100%;outline:none}.cat-combo-input--row{border:none;background:transparent;font-size:13px;color:var(--text-muted);padding:2px 4px;border-radius:4px;cursor:pointer;text-overflow:ellipsis}.cat-combo-input--row:hover,.cat-combo-input--row:focus{background:var(--surface);color:var(--text)}.cat-combo-input--row::placeholder{color:var(--text-muted);opacity:1}.cat-combo-input--income{color:var(--green);font-weight:600}.cat-combo-input--suggested{color:#7c3aed;font-style:italic}.cat-combo-input--form{padding:7px 11px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:14px;color:var(--text);background:white;transition:border-color .12s,box-shadow .12s}.cat-combo-input--form:focus{border-color:var(--blue-mid);box-shadow:0 0 0 3px var(--blue-bg)}.cat-combo-menu{z-index:250;overflow-y:auto;background:white;border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:var(--shadow-md);padding:4px}.cat-combo-group-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);padding:6px 8px 3px}.cat-combo-item{font-size:13px;color:var(--text);padding:6px 8px;border-radius:5px;cursor:pointer;display:flex;align-items:baseline;justify-content:space-between;gap:12px}.cat-combo-item-label{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cat-combo-item-hint{font-family:var(--font-mono);font-size:12px;color:var(--text-muted);flex-shrink:0}.cat-combo-item.active{background:var(--blue-bg);color:var(--blue)}.cat-combo-item.active .cat-combo-item-hint{color:var(--blue)}.cat-combo-item.selected .cat-combo-item-label{font-weight:600}.cat-combo-empty{font-size:13px;color:var(--text-muted);padding:8px}.tx-amount{font-family:var(--font-mono);font-size:14px;font-weight:600;text-align:right}.tx-amount.out{color:var(--text)}.tx-amount.in{color:var(--green)}.tx-empty{text-align:center;padding:40px 20px;color:var(--text-muted);font-size:14px}.form-group{display:flex;flex-direction:column;gap:4px}.form-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--text-muted)}.form-input,.form-select{padding:7px 11px;border:1px solid var(--border);border-radius:var(--radius-sm);font-family:var(--font-ui);font-size:14px;color:var(--text);outline:none;transition:border-color .12s,box-shadow .12s;background:white;width:100%}.form-input:focus,.form-select:focus{border-color:var(--blue-mid);box-shadow:0 0 0 3px var(--blue-bg)}.form-select{cursor:pointer}.form-input.mono{font-family:var(--font-mono)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:rgba(15,23,42,.55);-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;z-index:200;animation:fadeIn .15s ease}.modal{background:white;border-radius:var(--radius-lg);padding:28px;width:440px;max-width:calc(100vw - 32px);box-shadow:var(--shadow-lg);animation:slideUp .18s ease}.modal-title{font-size:19px;font-weight:700;color:var(--text);margin-bottom:20px}.modal--wide{width:560px}.bill-form-modal .bills-add{background:transparent;border:none;box-shadow:none;padding:0;margin:0}.modal--wide .modal-title{margin-bottom:6px}.modal-sub{font-size:13px;color:var(--text-muted);margin:0 0 16px;line-height:1.5}.bill-match-search{width:100%;margin-bottom:12px}.bill-match-list{display:flex;flex-direction:column;max-height:340px;overflow-y:auto;border:1px solid var(--border);border-radius:var(--radius-sm)}.bill-match-row{display:grid;grid-template-columns:88px 1fr 1.1fr auto;align-items:center;gap:10px;padding:9px 12px;width:100%;text-align:left;cursor:pointer;font-size:13px;background:white;border:none;border-bottom:1px solid #f6f8fa}.bill-match-row:last-child{border-bottom:none}.bill-match-row:hover{background:var(--surface)}.bill-match-row.exact{background:var(--green-bg)}.bill-match-row.exact:hover{background:var(--green-mid, #bbf7d0)}.bmr-date{color:var(--text-muted)}.bmr-payee{color:var(--text);font-weight:600;display:flex;align-items:center;gap:6px;overflow:hidden}.bmr-cat{color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.bmr-amt{text-align:right;color:var(--text)}.bill-match-empty{padding:16px;text-align:center;color:var(--text-muted);font-size:13px}.modal-form{display:flex;flex-direction:column;gap:14px}.modal-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:6px}.income-list{max-height:160px;overflow-y:auto;margin-top:8px}.income-item{display:flex;align-items:center;justify-content:space-between;padding:8px 10px;background:var(--surface);border-radius:var(--radius-sm);margin-bottom:5px}.income-item-info{font-size:13px;color:var(--text-mid)}.income-item-amount{font-family:var(--font-mono);font-size:14px;font-weight:600;color:var(--green)}.connected-section{border-top:1px solid var(--navy-border);padding:14px 12px;flex:1;overflow-y:auto;display:flex;flex-direction:column}.connected-title{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1.2px;color:#475569;margin-bottom:10px;display:flex;align-items:center;justify-content:space-between}.sync-all-btn{background:var(--navy-border);border:none;color:#cbd5e1;font-family:var(--font-ui);font-size:10px;font-weight:700;letter-spacing:.4px;padding:4px 8px;border-radius:5px;cursor:pointer;display:inline-flex;align-items:center;gap:5px;transition:background .12s}.sync-all-btn:hover:not(:disabled){background:#475569;color:#fff}.sync-all-btn:disabled{opacity:.6;cursor:default}.account-card{background:var(--navy-mid);border-radius:8px;padding:10px 12px;margin-bottom:8px}.account-header{display:flex;align-items:center;gap:7px;margin-bottom:3px}.inst-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.inst-name{font-size:13px;font-weight:600;color:#fff}.acct-sub{font-size:12px;color:var(--navy-text);margin-bottom:5px}.acct-bal{font-family:var(--font-mono);font-size:16px;font-weight:600;color:#fff}.acct-sync{font-size:10px;color:#475569;margin-top:3px}.acct-actions{display:flex;gap:6px;margin-top:8px}.btn-acct{font-size:11px;font-weight:600;padding:4px 10px;border-radius:5px;border:none;cursor:pointer;font-family:var(--font-ui);transition:all .12s}.btn-acct-sync{background:rgba(96,165,250,.18);color:#60a5fa}.btn-acct-sync:hover:not(:disabled){background:rgba(96,165,250,.28)}.btn-acct-sync:disabled{opacity:.5}.btn-acct-disconnect{background:rgba(239,68,68,.18);color:#f87171}.btn-acct-disconnect:hover{background:rgba(239,68,68,.28)}.sync-spinner{display:inline-block;width:12px;height:12px;border:2px solid rgba(96,165,250,.25);border-top-color:#60a5fa;border-radius:50%;animation:spin .7s linear infinite;vertical-align:middle;margin-right:4px}.sync-error{font-size:11px;color:#f87171;background:rgba(239,68,68,.12);border-radius:5px;padding:5px 8px;margin-top:6px;display:flex;align-items:center;justify-content:space-between;gap:6px}.reauth-banner{background:rgba(180,83,9,.15);border:1px solid rgba(180,83,9,.3);border-radius:6px;padding:8px 10px;margin-bottom:8px;font-size:11px;color:#fbbf24;display:flex;align-items:center;justify-content:space-between;gap:8px}.plaid-connect-btn{width:100%;background:rgba(96,165,250,.15);border:1px dashed rgba(96,165,250,.35);border-radius:7px;color:#60a5fa;font-size:12px;font-weight:600;font-family:var(--font-ui);padding:9px;cursor:pointer;transition:all .15s;margin-top:4px;display:flex;align-items:center;justify-content:center;gap:6px}.plaid-connect-btn:hover:not(:disabled){background:rgba(96,165,250,.22);border-color:#60a5fa80}.plaid-connect-btn:disabled{opacity:.5;cursor:not-allowed}.plaid-error{font-size:11px;color:#f87171;margin-top:6px;padding:5px 8px;background:rgba(239,68,68,.1);border-radius:5px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{to{transform:rotate(360deg)}}.category-group,.tx-row{animation:fadeIn .18s ease}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-dark);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#94a3b8}.reports-view{flex:1;display:flex;flex-direction:column;min-height:0;overflow-y:auto}.reports-subnav{display:flex;gap:2px;padding:0 32px;border-bottom:1px solid var(--border);background:white;position:sticky;top:0;z-index:5;overflow-x:auto}.subnav-tab{border:none;background:none;font-family:var(--font-ui);font-size:13px;font-weight:600;color:var(--text-muted);padding:14px;cursor:pointer;border-bottom:2px solid transparent;white-space:nowrap;transition:color .12s}.subnav-tab:hover{color:var(--text)}.subnav-tab.active{color:var(--blue);border-bottom-color:var(--blue)}.reports-controls{display:flex;align-items:center;gap:14px;padding:14px 32px;flex-wrap:wrap;border-bottom:1px solid var(--border);background:var(--surface)}.range-tabs{display:flex;gap:2px;background:var(--surface-2, #eef2f6);border-radius:var(--radius-sm);padding:3px}.range-tab{border:none;background:none;font-family:var(--font-ui);font-size:12px;font-weight:600;color:var(--text-muted);padding:6px 12px;cursor:pointer;border-radius:6px;white-space:nowrap;transition:all .12s}.range-tab:hover{color:var(--text)}.range-tab.active{background:white;color:var(--text);box-shadow:0 1px 3px #0000001a}.range-custom{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text-muted)}.range-custom .form-input{width:auto;padding:6px 10px}.report-body{padding:24px 32px 48px}.metric-row{display:flex;gap:16px;margin-bottom:20px;flex-wrap:wrap}.metric-card{background:white;border:1px solid var(--border);border-radius:var(--radius-md);padding:16px 18px;flex:1;min-width:160px;box-shadow:var(--shadow-sm)}.metric-card--big{flex:1.4}.metric-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.7px;color:var(--text-muted)}.metric-value{font-family:var(--font-mono);font-size:26px;font-weight:600;letter-spacing:-.5px;color:var(--text);margin-top:6px}.metric-card--big .metric-value{font-size:32px}.metric-sub{font-size:12px;color:var(--text-muted);margin-top:4px}.metric-pos{color:var(--green)}.metric-neg{color:var(--red)}.metric-warn{color:#d97706}.metric-goal-card{display:flex;flex-direction:column}.goal-input-row{display:flex;align-items:baseline;margin-top:6px}.goal-input{font-family:var(--font-mono);font-size:26px;font-weight:600;border:none;border-bottom:2px solid var(--blue-mid);width:70px;color:var(--blue);outline:none;padding:0;background:transparent}.goal-pct{font-size:20px;color:var(--blue);font-weight:600}.goal-progress{background:white;border:1px solid var(--border);border-radius:var(--radius-md);padding:12px 16px;margin-bottom:20px;box-shadow:var(--shadow-sm)}.goal-progress-head{display:flex;justify-content:space-between;font-size:13px;color:var(--text-mid);margin-bottom:8px}.goal-progress-bar{height:10px;background:var(--surface);border-radius:999px;overflow:hidden}.goal-progress-fill{height:100%;background:var(--blue);border-radius:999px;transition:width .4s ease}.goal-progress-fill.met{background:var(--green)}.chart-card{background:white;border:1px solid var(--border);border-radius:var(--radius-md);padding:18px 20px;margin-bottom:20px;box-shadow:var(--shadow-sm)}.chart-card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:14px}.chart-card-title{font-size:15px;font-weight:700;color:var(--text);letter-spacing:-.2px}.chart-card-sub{font-size:12px;color:var(--text-muted);margin-top:2px;max-width:600px}.chart-card-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}.report-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:20px}@media (max-width: 1100px){.report-grid-2{grid-template-columns:1fr}}.report-toolbar{display:flex;align-items:center;gap:14px;margin-bottom:18px;flex-wrap:wrap}.report-toolbar .form-input{width:auto}.report-toolbar-spacer{flex:1}.chart-tooltip{background:white;border:1px solid var(--border);border-radius:var(--radius-sm);padding:8px 10px;box-shadow:var(--shadow-md);font-size:12px}.chart-tooltip-label{font-weight:700;margin-bottom:5px;color:var(--text)}.chart-tooltip-row{display:flex;align-items:center;gap:6px;padding:1px 0}.chart-tooltip-dot{width:8px;height:8px;border-radius:2px;flex-shrink:0}.chart-tooltip-name{color:var(--text-muted);margin-right:8px}.chart-tooltip-val{font-family:var(--font-mono);font-weight:600;margin-left:auto;color:var(--text)}.report-empty{text-align:center;padding:50px 20px;color:var(--text-muted)}.report-empty-icon{font-size:40px;margin-bottom:10px}.report-empty-title{font-size:16px;font-weight:700;color:var(--text)}.report-empty-msg{font-size:13px;margin-top:6px;max-width:380px;margin-left:auto;margin-right:auto;line-height:1.5}.mono{font-family:var(--font-mono)}.pos{color:var(--green)}.neg{color:var(--red)}.nw-alloc{display:grid;grid-template-columns:1fr 1fr;gap:16px;align-items:center}@media (max-width: 900px){.nw-alloc{grid-template-columns:1fr}}.nw-alloc-legend{display:flex;flex-direction:column;gap:8px}.nw-alloc-row{display:grid;grid-template-columns:auto 1fr auto auto;align-items:center;gap:10px;font-size:13px}.nw-alloc-dot{width:10px;height:10px;border-radius:3px}.nw-alloc-name{color:var(--text)}.nw-alloc-val{color:var(--text);font-weight:600}.nw-alloc-pct{color:var(--text-muted);min-width:34px;text-align:right}.nw-manage{display:grid;grid-template-columns:1fr 1fr;gap:20px}@media (max-width: 1100px){.nw-manage{grid-template-columns:1fr}}.nw-card{background:white;border:1px solid var(--border);border-radius:var(--radius-md);padding:14px 16px;box-shadow:var(--shadow-sm)}.nw-card-head{display:flex;align-items:center;gap:8px;margin-bottom:10px}.nw-card-head h4{font-size:14px;font-weight:700;color:var(--text)}.nw-dot{width:10px;height:10px;border-radius:50%}.nw-dot-asset{background:var(--asset, #0d9488)}.nw-dot-liability{background:#f43f5e}.nw-total{margin-left:auto;font-weight:600;color:var(--text)}.nw-add-form{display:flex;gap:8px;margin-bottom:10px;flex-wrap:wrap}.nw-add-form .form-input{width:auto;flex:1;min-width:80px}.nw-items{display:flex;flex-direction:column;gap:4px}.nw-empty{font-size:13px;color:var(--text-light);font-style:italic;padding:4px 0}.nw-item{display:flex;align-items:center;gap:8px;padding:4px 0}.nw-item-name{flex:1;border:1px solid transparent;background:transparent;font-size:13px;color:var(--text);padding:4px 6px;border-radius:5px;outline:none;min-width:0}.nw-item-name:hover{border-color:var(--border)}.nw-item-name:focus{border-color:var(--blue-mid)}.nw-item-meta{font-size:11px;color:var(--text-muted);white-space:nowrap}.nw-item-val{width:90px;border:1px solid transparent;background:transparent;font-size:13px;text-align:right;padding:4px 6px;border-radius:5px;outline:none;color:var(--text)}.nw-item-val:hover{border-color:var(--border)}.nw-item-val:focus{border-color:var(--blue-mid)}.nw-item-del{border:none;background:none;color:var(--text-light);cursor:pointer;font-size:16px;padding:0 4px}.nw-item-del:hover{color:var(--red)}.donut-legend{display:flex;flex-direction:column;gap:5px;margin-top:8px}.donut-legend-row{display:flex;align-items:center;gap:8px;font-size:13px}.donut-dot{width:9px;height:9px;border-radius:2px;flex-shrink:0}.donut-name{color:var(--text-mid)}.over-flag{color:var(--red);font-weight:700;font-size:10px;text-transform:uppercase}.donut-val{margin-left:auto;font-weight:600;color:var(--text)}.billbar-list{display:flex;flex-direction:column;gap:9px;margin-top:4px}.billbar-row{display:grid;grid-template-columns:120px 1fr 70px;align-items:center;gap:10px;font-size:13px}.billbar-name{color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.billbar-track{background:var(--surface);border-radius:999px;height:10px;overflow:hidden}.billbar-fill{height:100%;border-radius:999px}.billbar-val{text-align:right;color:var(--text);font-weight:600}.bills-report-list{display:flex;flex-direction:column;margin-top:4px}.bills-report-row{display:grid;grid-template-columns:120px 2fr 1.4fr 1.2fr auto;align-items:center;gap:10px;padding:9px 0;border-bottom:1px solid #f6f8fa;font-size:13px}.bills-report-row:last-child{border-bottom:none}.bills-report-row.soon{background:#fffbeb;margin:0 -10px;padding:9px 10px;border-radius:6px}.brr-due{display:flex;flex-direction:column}.brr-rel{font-size:11px;color:var(--text-muted)}.brr-name{color:var(--text);font-weight:600}.brr-auto{font-size:10px;text-transform:uppercase;letter-spacing:.04em;color:var(--green);background:var(--green-bg);padding:1px 6px;border-radius:999px;margin-left:6px;font-weight:700}.brr-cat,.brr-freq{color:var(--text-muted)}.brr-amt{text-align:right;color:var(--text);font-weight:600}@media (max-width: 700px){.bills-report-row{grid-template-columns:90px 1.5fr auto}.brr-cat,.brr-freq{display:none}}.holdings-table{display:flex;flex-direction:column;margin-top:6px}.holdings-row{display:grid;grid-template-columns:2fr 1.2fr 1fr 1fr 1fr .7fr;align-items:center;gap:10px;padding:9px 0;border-bottom:1px solid #f6f8fa;font-size:13px}.holdings-row:last-child{border-bottom:none}.holdings-head{font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);font-weight:700}.holdings-row .num{text-align:right}.holdings-sub{display:block;font-size:11px;color:var(--text-muted);font-weight:400}.holdings-acct{color:var(--text-mid)}.holdings-row .pos{color:var(--green)}.holdings-row .neg{color:var(--red)}@media (max-width: 700px){.holdings-row{grid-template-columns:1.5fr 1fr 1fr .7fr}.holdings-row span:nth-child(2),.holdings-head span:nth-child(2){display:none}}.merchant-list{display:flex;flex-direction:column}.merchant-row{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid #f6f8fa;font-size:14px}.merchant-row:last-child{border-bottom:none}.merchant-rank{width:22px;height:22px;border-radius:50%;background:var(--surface);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:var(--text-muted)}.merchant-name{flex:1;font-weight:500;color:var(--text)}.merchant-count{font-size:12px;color:var(--text-muted)}.merchant-total{font-weight:600;color:var(--text)}.flag-banner{display:flex;gap:12px;background:#fffbeb;border:1px solid #fde68a;border-radius:var(--radius-md);padding:12px 16px;margin-bottom:18px}.flag-banner-icon{font-size:20px}.flag-banner strong{font-size:13px;color:#92400e}.flag-list{display:flex;gap:6px;flex-wrap:wrap;margin-top:6px}.flag-chip{background:#fef3c7;color:#92400e;font-size:11px;font-weight:600;padding:2px 8px;border-radius:10px}.perf-table{font-size:13px}.perf-head,.perf-row{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr .8fr 100px;gap:10px;align-items:center;padding:9px 8px}.perf-head{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:var(--text-muted);border-bottom:1px solid var(--border)}.perf-row{border-bottom:1px solid #f6f8fa}.perf-row.perf-over{background:#fef2f2}.perf-name{font-weight:500;color:var(--text);display:flex;flex-direction:column}.perf-group{font-size:11px;color:var(--text-muted);font-weight:400}.perf-spark{display:flex;justify-content:flex-end}.cf-summary{font-size:13px}.cf-low-warn{font-size:13px;font-weight:700;color:var(--red);background:var(--red-bg, #fef2f2);padding:4px 10px;border-radius:999px}.cf-weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:5px;margin-bottom:5px}.cf-weekdays span{text-align:center;font-size:10px;font-weight:700;text-transform:uppercase;color:var(--text-muted);letter-spacing:.5px}.cf-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:5px}.cf-cell{aspect-ratio:1;border:1px solid var(--border);border-radius:7px;display:flex;flex-direction:column;align-items:flex-start;justify-content:space-between;padding:5px 6px;cursor:pointer;transition:transform .1s;background:white}.cf-cell:hover{transform:scale(1.05);z-index:2;box-shadow:var(--shadow-md)}.cf-blank{border:none;background:transparent;cursor:default}.cf-daynum{font-size:11px;font-weight:600;color:var(--text-mid)}.cf-daynet{font-size:9px;font-family:var(--font-mono);font-weight:600;opacity:.85}.cf-selected{outline:2px solid var(--blue);outline-offset:1px}.cf-none{background:white}.cf-pos-1{background:#dcfce7}.cf-pos-2{background:#86efac}.cf-neg-1{background:#fee2e2}.cf-neg-2{background:#fca5a5}.cf-legend{display:flex;align-items:center;gap:5px;font-size:11px;color:var(--text-muted);margin-top:12px}.cf-swatch{width:16px;height:16px;border-radius:4px;border:1px solid var(--border)}.cf-daylist-summary{display:flex;gap:14px;font-size:13px;padding-bottom:10px;margin-bottom:8px;border-bottom:1px solid var(--border)}.cf-txn{display:flex;justify-content:space-between;padding:7px 0;font-size:13px;border-bottom:1px solid #f6f8fa}.cf-txn-payee{color:var(--text)}.upcoming-list{display:flex;flex-direction:column}.upcoming-row{display:flex;align-items:center;gap:14px;padding:9px 0;border-bottom:1px solid #f6f8fa;font-size:13px}.upcoming-day{width:42px;font-weight:700;color:var(--blue)}.upcoming-payee{flex:1;color:var(--text);font-weight:500}.upcoming-occ{font-size:11px;color:var(--text-muted)}.extra-slider{display:flex;flex-direction:column;gap:4px;min-width:240px}.extra-slider label{font-size:12px;color:var(--text-muted)}.extra-slider input[type=range]{accent-color:var(--blue)}.debt-table{font-size:13px}.debt-head,.debt-row{display:grid;grid-template-columns:2fr 1fr .7fr 1fr 1fr;gap:10px;align-items:center;padding:10px 8px}.debt-head{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:var(--text-muted);border-bottom:1px solid var(--border)}.debt-row{border-bottom:1px solid #f6f8fa}.debt-name{display:flex;align-items:center;gap:8px;font-weight:500;color:var(--text)}.debt-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0}.debt-focus{font-size:9px;font-weight:700;text-transform:uppercase;background:var(--blue-bg);color:var(--blue);padding:1px 6px;border-radius:8px}.insights-intro{margin-bottom:18px}.insights-cols{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}@media (max-width: 1100px){.insights-cols{grid-template-columns:1fr}}.insight-col{display:flex;flex-direction:column;gap:10px}.insight-col-head{display:flex;align-items:center;gap:7px;font-size:13px;font-weight:700;padding:8px 4px}.insight-count{margin-left:auto;background:var(--surface);color:var(--text-muted);font-size:11px;padding:1px 8px;border-radius:10px}.insight-red{color:var(--red)}.insight-yellow{color:#d97706}.insight-green{color:var(--green)}.insight-card{background:white;border:1px solid var(--border);border-left-width:3px;border-radius:var(--radius-sm);padding:11px 13px;box-shadow:var(--shadow-sm)}.insight-card-red{border-left-color:var(--red)}.insight-card-yellow{border-left-color:#f59e0b}.insight-card-green{border-left-color:var(--green)}.insight-title{font-size:13px;font-weight:600;color:var(--text)}.insight-detail{font-size:12px;color:var(--text-muted);margin-top:3px;line-height:1.4}.insight-empty{font-size:12px;color:var(--text-light);font-style:italic;padding:6px 4px}.auth-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(160deg,var(--navy) 0%,#1a2744 100%);padding:20px}.auth-splash{color:#fff;font-size:15px;opacity:.8}.auth-card{width:100%;max-width:380px;background:white;border-radius:var(--radius-lg);padding:32px 30px;box-shadow:var(--shadow-lg)}.auth-logo{font-size:24px;font-weight:700;letter-spacing:-.8px;color:var(--text)}.auth-tagline{font-size:13px;color:var(--text-muted);margin:4px 0 22px}.auth-form{display:flex;flex-direction:column}.auth-form .form-label{margin-top:12px;margin-bottom:4px}.auth-form .form-label:first-child{margin-top:0}.auth-submit{width:100%;justify-content:center;margin-top:18px;padding:10px}.auth-error{background:var(--red-bg);color:var(--red);font-size:12px;padding:8px 10px;border-radius:var(--radius-sm);margin-top:12px}.auth-notice{background:var(--blue-bg);color:var(--blue);font-size:12px;padding:8px 10px;border-radius:var(--radius-sm);margin-top:12px}.auth-link{background:none;border:none;color:var(--blue);font-size:12px;font-weight:600;cursor:pointer;margin-top:14px;padding:0}.auth-link:hover{text-decoration:underline}.auth-switch{font-size:12px;color:var(--text-muted);margin-top:18px;text-align:center;border-top:1px solid var(--border);padding-top:16px}.auth-switch button{background:none;border:none;color:var(--blue);font-weight:600;cursor:pointer;font-size:12px}.auth-hint{font-size:11px;color:var(--text-light);margin-top:16px;line-height:1.5}.auth-forgot{align-self:flex-end;background:none;border:none;color:var(--blue);font-size:11px;font-weight:600;cursor:pointer;margin-top:6px;padding:0}.auth-forgot:hover{text-decoration:underline}.setup-steps{margin:16px 0 0 18px;font-size:13px;color:var(--text-mid);line-height:1.7}.setup-steps code{font-family:var(--font-mono);font-size:12px;background:var(--surface);padding:1px 5px;border-radius:4px}.cloudbar{border-bottom:1px solid var(--navy-border);padding:10px 12px}.cloudbar-head{width:100%;display:flex;align-items:center;justify-content:space-between;background:none;border:none;cursor:pointer;padding:4px;text-align:left}.cloudbar-title{display:flex;flex-direction:column;min-width:0}.cloudbar-house{font-size:13px;font-weight:700;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cloudbar-status{font-size:10px;margin-top:1px}.cloudbar-ready{color:#4ade80}.cloudbar-saving{color:#fbbf24}.cloudbar-loading{color:var(--navy-text)}.cloudbar-error{color:#f87171}.cloudbar-caret{color:var(--navy-text);font-size:11px}.cloudbar-presence{display:flex;gap:-4px;margin-top:8px;align-items:center;flex-wrap:wrap}.presence-dot{width:24px;height:24px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:9px;font-weight:700;color:#fff;border:2px solid var(--navy);margin-right:-6px;position:relative;opacity:.45}.presence-dot.online{opacity:1;box-shadow:0 0 0 2px #4ade80}.presence-dot.sm{width:20px;height:20px;font-size:8px;margin-right:0;border:none;opacity:1}.cloudbar-soloemail{font-size:11px;color:var(--navy-text)}.cloudbar-menu{margin-top:10px;background:var(--navy-mid);border-radius:var(--radius-sm);padding:10px}.cloudbar-section{margin-bottom:12px}.cloudbar-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:var(--navy-text);margin-bottom:5px}.cloudbar-invite{display:flex;gap:6px}.cloudbar-invite .form-input{flex:1;min-width:0;padding:6px 8px;font-size:12px}.cloudbar-msg{font-size:11px;color:#4ade80;margin-top:6px}.cloudbar-members{display:flex;flex-direction:column;gap:6px}.cloudbar-member{display:flex;align-items:center;gap:7px}.cloudbar-member-email{font-size:11px;color:#cbd5e1;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cloudbar-member-role{font-size:9px;color:var(--navy-text);text-transform:uppercase}.cloudbar-signout{width:100%;background:none;border:1px solid var(--navy-border);color:#cbd5e1;font-size:12px;font-weight:600;padding:7px;border-radius:var(--radius-sm);cursor:pointer;margin-top:4px}.cloudbar-signout:hover{background:var(--navy);color:#fff}.mobile-topbar,.sidebar-backdrop{display:none}.hamburger{display:flex;flex-direction:column;justify-content:center;gap:4px;width:38px;height:38px;background:none;border:none;cursor:pointer;padding:8px}.hamburger span{display:block;height:2px;background:white;border-radius:2px}.mobile-logo{color:#fff;font-weight:700;font-size:16px;letter-spacing:-.4px}.mobile-logo .logo-accent{color:#60a5fa}@media (max-width: 768px){.app{flex-direction:column}.mobile-topbar{display:flex;align-items:center;gap:10px;background:var(--navy);padding:9px 12px;flex-shrink:0;position:sticky;top:0;z-index:40}.sidebar{position:fixed;top:0;left:0;bottom:0;width:82%;max-width:300px;transform:translate(-100%);transition:transform .25s ease;z-index:60;overflow-y:auto}.sidebar.open{transform:translate(0);box-shadow:0 0 40px #00000073}.sidebar-backdrop{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:rgba(0,0,0,.45);z-index:55}.content{flex:1;min-height:0}.budget-view,.report-body,.coa-view,.transactions-view,.quick-budget-bar,.tx-toolbar,.reports-controls{padding-left:14px;padding-right:14px}.reports-subnav{padding:0 8px}.report-body{padding-top:16px;padding-bottom:32px}.budget-header{height:auto;flex-wrap:wrap;padding:12px 14px;gap:10px;position:static}.ready-amount{font-size:24px}.header-ready{min-width:0}.header-stats{width:100%;gap:14px;justify-content:space-between;order:3}.header-actions{flex-wrap:wrap}.budget-view{overflow-x:auto}.budget-table-header,.category-row,.group-header{min-width:520px}.transactions-view{overflow-x:auto}.tx-grid{min-width:680px}.perf-table,.debt-table{overflow-x:auto}.perf-head,.perf-row{min-width:640px}.debt-head,.debt-row{min-width:560px}.add-tx-form{grid-template-columns:1fr 1fr}.modal,.modal-detail{width:calc(100vw - 28px);max-width:460px}.nw-manage{grid-template-columns:1fr}.range-tabs,.filter-tabs{flex-wrap:wrap}}@media (max-width: 480px){.add-tx-form{grid-template-columns:1fr}.metric-card{min-width:100%}.header-stats{gap:10px}.stat-value{font-size:15px}.ready-amount{font-size:22px}.reports-controls{gap:10px}.cf-daynet{display:none}}.inv-view{padding:20px 32px 40px;flex:1}.inv-titlebar{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:18px}.inv-add-form{display:flex;gap:8px;flex-wrap:wrap;background:white;border:1px solid var(--blue-border);border-radius:var(--radius-md);padding:12px 14px;margin-bottom:18px;box-shadow:0 0 0 3px var(--blue-bg)}.inv-add-form .form-input,.inv-add-form .form-select{width:auto;flex:1;min-width:120px}.inv-grid{display:grid;grid-template-columns:340px 1fr;gap:20px;align-items:start}@media (max-width: 900px){.inv-grid{grid-template-columns:1fr}}.inv-left{display:flex;flex-direction:column;gap:16px}.inv-acct-list{display:flex;flex-direction:column;gap:8px}.inv-acct{text-align:left;background:white;border:1px solid var(--border);border-radius:var(--radius-md);padding:12px 14px;cursor:pointer;transition:all .12s;box-shadow:var(--shadow-sm)}.inv-acct:hover{border-color:var(--border-dark)}.inv-acct.active{border-color:var(--blue-mid);box-shadow:0 0 0 3px var(--blue-bg)}.inv-acct-top{display:flex;justify-content:space-between;align-items:baseline}.inv-acct-name{font-weight:700;color:var(--text);font-size:14px}.inv-acct-val{font-weight:600;color:var(--text)}.inv-acct-sub{display:flex;justify-content:space-between;font-size:12px;color:var(--text-muted);margin-top:4px}.inv-right{min-width:0}.inv-detail{background:white;border:1px solid var(--border);border-radius:var(--radius-md);padding:18px 20px;box-shadow:var(--shadow-sm)}.inv-detail-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:12px}.inv-cash-row{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--text-muted);padding:8px 0 12px;border-bottom:1px solid var(--border);margin-bottom:8px}.inv-cash-row .form-input{width:120px}.inv-holdings{overflow-x:auto}.inv-h-head,.inv-h-row{display:grid;grid-template-columns:1.7fr .8fr .9fr 1fr 1fr 1fr 24px;gap:8px;align-items:center;min-width:560px}.inv-h-head{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);padding:6px 4px;border-bottom:1px solid var(--border)}.inv-h-row{padding:7px 4px;border-bottom:1px solid #f6f8fa;font-size:13px}.inv-h-sym{display:flex;flex-direction:column;min-width:0}.inv-h-sym strong{color:var(--text)}.inv-h-name{font-size:11px;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.inv-h-input{width:100%;border:1px solid transparent;background:transparent;font-size:13px;text-align:right;padding:4px 6px;border-radius:5px;outline:none;color:var(--text)}.inv-h-input:hover{border-color:var(--border)}.inv-h-input:focus{border-color:var(--blue-mid);background:white}.inv-add-holding,.inv-add-act{display:flex;gap:8px;flex-wrap:wrap;padding:10px 0}.inv-add-holding .form-input,.inv-add-act .form-input,.inv-add-act .form-select{width:auto;flex:1;min-width:90px}.inv-act-row{display:grid;grid-template-columns:52px 92px 1fr auto 24px;gap:10px;align-items:center;padding:8px 4px;border-bottom:1px solid #f6f8fa;font-size:13px}.inv-act-date{color:var(--text-muted)}.inv-act-sym{color:var(--text-mid);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.inv-act-type{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;padding:2px 7px;border-radius:10px;text-align:center;background:var(--surface);color:var(--text-muted)}.inv-act-buy,.inv-act-contribution{background:var(--green-bg);color:var(--green)}.inv-act-sell,.inv-act-withdrawal,.inv-act-fee{background:var(--red-bg);color:var(--red)}.inv-act-dividend,.inv-act-interest{background:var(--blue-bg);color:var(--blue)}@media (max-width: 768px){.inv-view{padding:16px 14px}}.inv-titlebar-actions{display:flex;gap:8px;align-items:center;flex-shrink:0;flex-wrap:wrap;justify-content:flex-end}.inv-detail-actions{display:flex;gap:8px;align-items:center}.inv-plaid-wrap{display:inline-flex;flex-direction:column;gap:4px}.badge-plaid{background:var(--blue-bg);color:var(--blue)}.transactions-layout{display:grid;grid-template-columns:264px 1fr;align-items:start;flex:1;min-width:0}.accounts-panel{background:white;padding:18px 14px;align-self:stretch}.accounts-panel--filter{border-right:1px solid var(--border)}.accounts-panel--manage{padding:14px 0 0}.accounts-panel .account-card.clickable{cursor:pointer}.acct-empty{font-size:13px;color:var(--text-light);padding:8px 4px;font-style:italic}.accounts-panel .connected-title{color:var(--text-muted);margin-bottom:12px}.acct-group{margin-bottom:14px}.acct-group-head{display:flex;justify-content:space-between;align-items:baseline;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--text-muted);padding:0 2px 6px;margin-bottom:6px;border-bottom:1px solid var(--border)}.acct-group-head .mono{font-size:11px;color:var(--text-mid)}.acct-group .account-card{margin-bottom:8px}.accounts-panel .sync-all-btn{background:var(--surface);color:var(--text-mid)}.accounts-panel .sync-all-btn:hover:not(:disabled){background:var(--surface-hover);color:var(--text)}.acct-all{width:100%;display:flex;justify-content:space-between;align-items:center;padding:10px 12px;background:white;border:1px solid var(--border);border-radius:8px;cursor:pointer;font-size:13px;font-weight:700;color:var(--text);margin-bottom:8px;transition:all .12s}.acct-all:hover{border-color:var(--border-dark)}.acct-all.selected{border-color:var(--blue-mid);box-shadow:0 0 0 2px var(--blue-bg)}.accounts-panel .account-card{background:white;border:1px solid var(--border);cursor:pointer;transition:all .12s}.accounts-panel .account-card:hover{border-color:var(--border-dark)}.accounts-panel .account-card.selected{border-color:var(--blue-mid);box-shadow:0 0 0 2px var(--blue-bg)}.accounts-panel .inst-name{color:var(--text)}.accounts-panel .acct-sub{color:var(--text-muted)}.accounts-panel .acct-bal{color:var(--text)}.accounts-panel .acct-sync{color:var(--text-light)}.accounts-panel .badge-manual{background:var(--surface-hover);color:var(--text-muted)}.accounts-panel .plaid-connect-btn{background:var(--blue);color:#fff;border:none}.accounts-panel .plaid-connect-btn:hover:not(:disabled){background:var(--blue-mid)}.tx-search{display:flex;align-items:center;gap:4px;background:white;border:1px solid var(--border);border-radius:var(--radius-sm);padding:0 8px;height:30px}.tx-search:focus-within{border-color:var(--blue-mid);box-shadow:0 0 0 3px var(--blue-bg)}.tx-search-icon{color:var(--text-light);font-size:15px}.tx-search-input{border:none;outline:none;font-size:13px;font-family:var(--font-ui);width:190px;max-width:40vw;background:transparent}.tx-search-clear{border:none;background:none;cursor:pointer;color:var(--text-light);font-size:15px;line-height:1}.tx-filter-chip{display:inline-flex;align-items:center;gap:6px;background:var(--blue-bg);color:var(--blue);font-size:12px;font-weight:600;padding:4px 8px;border-radius:12px}.tx-filter-chip button{border:none;background:none;color:var(--blue);cursor:pointer;font-size:14px;line-height:1}.logo-mini{display:none;font-size:19px;font-weight:700;letter-spacing:-.6px;color:#fff}.logo-mini .logo-accent{color:#60a5fa}.sidebar-signout{margin-top:auto;display:flex;align-items:center;gap:9px;padding:11px 16px;background:none;border:none;border-top:1px solid var(--navy-border);color:var(--navy-text);cursor:pointer;font-family:var(--font-ui);font-size:13px;font-weight:500}.sidebar-signout:hover{background:rgba(244,63,94,.15);color:#fda4af}.signout-icon{width:16px;flex-shrink:0}.sidebar-collapse{margin-top:0;display:flex;align-items:center;gap:9px;padding:11px 16px;background:none;border:none;border-top:1px solid var(--navy-border);color:var(--navy-text);cursor:pointer;font-family:var(--font-ui);font-size:13px;font-weight:500}.sidebar-collapse:hover{background:var(--navy-mid);color:#cbd5e1}.collapse-icon{font-size:14px;width:16px;text-align:center}@media (min-width: 769px){.sidebar{transition:width .18s ease}.sidebar.collapsed{width:72px;min-width:72px}.sidebar.collapsed .nav-label,.sidebar.collapsed .logo-full{display:none}.sidebar.collapsed .logo-mini{display:inline}.sidebar.collapsed .sidebar-logo{text-align:center;padding:20px 0 18px}.sidebar.collapsed .nav-btn{justify-content:center;padding:9px 0}.sidebar.collapsed .sidebar-month,.sidebar.collapsed .cloudbar{display:none}.sidebar.collapsed .sidebar-collapse,.sidebar.collapsed .sidebar-signout{justify-content:center;padding:11px 0}.sidebar.collapsed .sidebar-signout .nav-label{display:none}}@media (max-width: 768px){.transactions-layout{grid-template-columns:1fr}.accounts-panel{border-right:none;border-bottom:1px solid var(--border)}.sidebar-collapse{display:none}}.undo-fab{position:fixed;left:20px;bottom:20px;z-index:50;display:inline-flex;align-items:center;gap:8px;background:var(--navy);color:#fff;border:none;border-radius:999px;padding:10px 18px;font-family:var(--font-ui);font-size:13px;font-weight:600;cursor:pointer;box-shadow:var(--shadow-md);animation:slideUp .15s ease}.undo-fab:hover{background:var(--navy-mid)}.undo-icon{font-size:16px;line-height:1}.undo-label{color:#94a3b8;font-weight:500}@media (max-width: 768px){.undo-fab{left:12px;bottom:12px;padding:9px 14px}.undo-label{display:none}}.settings-view{padding:20px 32px 48px;flex:1;max-width:760px}.settings-card{background:white;border:1px solid var(--border);border-radius:var(--radius-md);padding:18px 20px;margin-top:16px;box-shadow:var(--shadow-sm)}.settings-card-title{font-size:15px;font-weight:700;color:var(--text)}.settings-card-sub{font-size:12px;color:var(--text-muted);margin:2px 0 12px}.settings-row{display:flex;flex-direction:column;gap:5px;margin-bottom:14px}.settings-row>label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:var(--text-muted)}.settings-row .form-input,.settings-row .form-select{max-width:420px}.settings-inline{display:flex;gap:8px;align-items:center;max-width:420px}.settings-inline .form-input{flex:1}.settings-members{display:flex;flex-direction:column;gap:6px}.settings-member{display:flex;justify-content:space-between;align-items:center;font-size:13px;color:var(--text);background:var(--surface);padding:8px 12px;border-radius:var(--radius-sm);max-width:420px}.settings-role{font-size:10px;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted)}.settings-msg{font-size:12px;color:var(--green);margin-top:4px}.settings-actions{margin-top:8px}.settings-check{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-mid);margin:6px 0 4px;cursor:pointer}.settings-check input{accent-color:var(--blue)}.settings-danger{border-color:#fecaca}.settings-danger .settings-card-title{color:var(--red)}.settings-view .accounts-panel{padding:0}.settings-view .account-card{max-width:480px}@media (max-width: 768px){.settings-view{padding:16px 14px}}.re-section{background:white;border:1px solid var(--border);border-radius:var(--radius-md);padding:18px 20px;margin-top:20px;box-shadow:var(--shadow-sm)}.re-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:12px}.re-add-form{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:14px}.re-add-form .form-input{width:auto;flex:1;min-width:120px}.re-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px}.re-card{border:1px solid var(--border);border-radius:var(--radius-md);padding:14px}.re-card-head{display:flex;justify-content:space-between;align-items:flex-start}.re-name{font-size:14px;font-weight:700;color:var(--text)}.re-del{border:none;background:none;color:var(--text-light);cursor:pointer;font-size:17px;line-height:1}.re-del:hover{color:var(--red)}.re-addr{font-size:12px;color:var(--text-muted);margin:2px 0 10px}.re-fields{display:grid;grid-template-columns:1fr 1fr;gap:8px}.re-fields label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);display:flex;flex-direction:column;gap:3px}.re-fields .form-input{width:100%;padding:5px 8px}.re-equity{display:flex;justify-content:space-between;align-items:center;margin-top:10px;padding-top:8px;border-top:1px solid var(--border);font-size:13px;font-weight:600;color:var(--text-mid)}.re-links{display:flex;gap:12px;margin-top:10px}.re-link{font-size:12px;font-weight:600;color:var(--blue);text-decoration:none}.re-link:hover{text-decoration:underline}.bills-view{padding:20px 32px 48px;flex:1}.bills-autopay{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:var(--text-muted);white-space:nowrap}.bills-autopay input{accent-color:var(--blue)}.bills-table{background:white;border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);margin-top:18px;overflow-x:auto}.bills-head,.bills-row{display:grid;grid-template-columns:1.5fr 1.1fr .8fr 1.2fr .85fr .85fr .7fr 1.1fr;gap:10px;align-items:center;padding:11px 16px;min-width:840px}.bills-due{display:flex;flex-direction:column;line-height:1.25}.bills-due-rel{font-size:10px;color:var(--text-muted)}.bills-head{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:var(--text-muted);border-bottom:1px solid var(--border)}.bills-row{border-bottom:1px solid #f6f8fa;font-size:13px}.bills-row:hover{background:var(--surface)}.bills-row.paid{background:#f6fdf9}.bills-name{font-weight:600;color:var(--text);display:flex;align-items:center;gap:7px}.bills-autopay-tag{font-size:9px;font-weight:700;text-transform:uppercase;background:var(--blue-bg);color:var(--blue);padding:1px 6px;border-radius:8px}.bills-cat{color:var(--text-muted)}.bills-due{color:var(--text-mid)}.bills-monthly{color:var(--text-muted)}.bills-status{font-size:11px;font-weight:700;padding:2px 8px;border-radius:10px}.bills-status.paid{background:var(--green-bg);color:var(--green)}.bills-status.due{background:var(--yellow-bg);color:var(--yellow)}.bills-actions{display:flex;gap:6px;justify-content:flex-end}.bills-footer{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;font-size:13px;font-weight:700;color:var(--text);border-top:2px solid var(--border);min-width:840px}@media (max-width: 768px){.bills-view{padding:16px 14px}}.bills-add{background:white;border:1px solid var(--blue-border);border-radius:var(--radius-md);padding:12px 14px;margin-bottom:18px;box-shadow:0 0 0 3px var(--blue-bg)}.bills-add .re-add-form{margin-bottom:0}.bills-custom{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-top:12px;padding-top:12px;border-top:1px solid var(--border)}.bills-custom-label{font-size:12px;font-weight:600;color:var(--text-muted)}.bills-custom .form-input{width:auto}.bills-chips{display:flex;gap:6px;flex-wrap:wrap}.bills-chip{display:inline-flex;align-items:center;gap:5px;background:var(--blue-bg);color:var(--blue);font-size:12px;font-weight:600;padding:3px 9px;border-radius:12px}.bills-chip button{border:none;background:none;color:var(--blue);cursor:pointer;font-size:14px;line-height:1}.bills-months{display:flex;gap:4px;flex-wrap:wrap}.bills-month{border:1px solid var(--border);background:white;color:var(--text-mid);font-size:11px;font-weight:600;padding:5px 9px;border-radius:6px;cursor:pointer;transition:all .12s}.bills-month:hover{border-color:var(--border-dark)}.bills-month.on{background:var(--blue);color:#fff;border-color:var(--blue)}.bills-row.editing{background:var(--blue-bg)}.bills-edit-panel{border-bottom:1px solid var(--border);background:var(--surface);padding:4px 12px 12px}.bills-edit-panel .bills-add{margin-bottom:0;box-shadow:none;border-color:var(--blue-border)}.bills-searchbar{display:flex;align-items:center;gap:12px;margin-bottom:12px}.bills-searchbar .tx-search{flex:1;max-width:420px}.bills-search-count{font-size:12px;color:var(--text-muted)}.bills-name-btn{border:none;background:transparent;padding:0;cursor:pointer;font:inherit;font-weight:600;color:var(--text);text-align:left}.bills-name-btn:hover{color:var(--blue);text-decoration:underline}.bills-history-panel{border-bottom:1px solid var(--border);background:var(--surface);padding:14px 16px 16px}.bills-history-metrics{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:14px}.bills-history-metrics .metric-card{min-width:120px}.bill-history-grid{display:grid;grid-template-columns:1.5fr 1fr;gap:16px;align-items:start}@media (max-width: 900px){.bill-history-grid{grid-template-columns:1fr}}.bill-pay-list{background:white;border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden}.bill-pay-row{display:grid;grid-template-columns:88px 1fr auto;align-items:center;gap:10px;padding:8px 12px;border-bottom:1px solid #f6f8fa;font-size:13px}.bill-pay-row:last-child{border-bottom:none}.bpr-date{color:var(--text-muted)}.bpr-cat{color:var(--text-mid);display:flex;align-items:center;gap:6px;overflow:hidden}.bpr-amt{text-align:right;color:var(--text);font-weight:600}.bill-viewall{margin-top:10px;border:none;background:transparent;color:var(--blue);font-size:13px;font-weight:600;cursor:pointer;padding:4px 2px}.bill-viewall:hover{text-decoration:underline}.tx-filter-chip--bill{background:#ede9fe;color:#7c3aed}.admin-view{max-width:1100px}.admin-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:18px}.admin-title{font-size:20px;font-weight:700;color:var(--text)}.admin-sub{font-size:13px;color:var(--text-muted);margin-top:4px;max-width:640px}.admin-sub strong{color:var(--text-mid)}.admin-error{background:var(--red-bg, #fef2f2);color:var(--red);border:1px solid #fecaca;padding:10px 14px;border-radius:var(--radius-sm);font-size:13px;margin-bottom:14px}.admin-empty{padding:40px;text-align:center;color:var(--text-muted)}.admin-stats{display:flex;gap:20px;font-size:13px;color:var(--text-muted);margin-bottom:12px}.admin-stats strong{color:var(--text);font-size:15px}.admin-table{background:white;border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden;box-shadow:var(--shadow-sm)}.admin-row{display:grid;grid-template-columns:2fr 1fr 1.7fr 1fr .9fr auto;align-items:center;gap:12px;padding:11px 16px;border-bottom:1px solid #f6f8fa;font-size:13px}.admin-row:last-child{border-bottom:none}.admin-row-head{background:var(--surface);font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--text-muted)}.admin-row--suspended{background:#fff7f7}.admin-acct{display:flex;flex-direction:column;gap:2px}.admin-email{font-weight:600;color:var(--text);display:flex;align-items:center;gap:6px}.admin-name{font-size:11px;color:var(--text-muted)}.admin-you{font-size:9px;text-transform:uppercase;letter-spacing:.04em;background:var(--blue-bg);color:var(--blue);padding:1px 6px;border-radius:999px;font-weight:700}.admin-muted{color:var(--text-mid)}.admin-badge{background:var(--blue-bg);color:var(--blue)}.admin-badge-active{background:var(--green-bg);color:var(--green)}.admin-badge-suspended{background:var(--red-bg, #fef2f2);color:var(--red)}.admin-actions-col{text-align:right}.admin-actions{display:flex;gap:6px;justify-content:flex-end}@media (max-width: 860px){.admin-row{grid-template-columns:1.6fr 1fr auto}.admin-row span:nth-child(2),.admin-row span:nth-child(3),.admin-row span:nth-child(4){display:none}}
