*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--blue: #2563eb;--blue-dark: #1e40af;--blue-light: #eff6ff;--green: #10b981;--green-bg: #d1fae5;--green-text: #065f46;--red: #ef4444;--red-bg: #fee2e2;--red-text: #991b1b;--orange: #f59e0b;--gray-50: #f8fafc;--gray-100: #f1f5f9;--gray-200: #e2e8f0;--gray-400: #94a3b8;--gray-500: #64748b;--gray-700: #334155;--gray-900: #0f172a;--radius: 10px;--shadow: 0 1px 3px rgba(0,0,0,.1);--shadow-md: 0 4px 12px rgba(0,0,0,.1)}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--gray-100);color:var(--gray-900);font-size:14px}.app{min-height:100vh}.loading{display:flex;align-items:center;justify-content:center;height:100vh;color:var(--gray-500);font-size:1rem}.nav{background:var(--blue-dark);color:#fff;display:flex;align-items:center;justify-content:space-between;padding:0 20px;height:52px;position:sticky;top:0;z-index:200;box-shadow:0 2px 8px #0003}.brand{font-weight:700;font-size:1rem}.nav-title{font-size:.9rem;font-weight:600;opacity:.85}.nav-link{background:#ffffff1f;border:1px solid rgba(255,255,255,.2);color:#fff;padding:5px 12px;border-radius:6px;cursor:pointer;font-size:.8rem;font-weight:500}.nav-link:hover{background:#fff3}.month-nav{display:flex;align-items:center;gap:8px}.month-nav button{background:#ffffff1f;border:none;color:#fff;width:28px;height:28px;border-radius:6px;cursor:pointer;font-size:1.1rem}.month-label{font-weight:600;min-width:100px;text-align:center}.month-select{background:#ffffff1f;border:1px solid rgba(255,255,255,.25);color:#fff;padding:4px 8px;border-radius:6px;font-size:.85rem;font-weight:600;cursor:pointer;min-width:130px}.month-select option{background:#1e3a5f;color:#fff}.empty-month{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;height:60vh}.empty-month-text{font-size:1rem;color:var(--gray-500)}.summary-bar{background:#fff;border-bottom:1px solid var(--gray-200);padding:12px 20px;display:flex;gap:20px;align-items:center;flex-wrap:wrap}.stat{display:flex;flex-direction:column}.s-label{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--gray-500)}.s-value{font-size:1.2rem;font-weight:700;margin-top:2px}.s-value.blue{color:var(--blue)}.s-value.green{color:var(--green)}.s-value.red{color:var(--red)}.s-value.orange{color:var(--orange)}.progress-wrap{flex:1;min-width:160px}.progress-bar{height:8px;background:var(--gray-200);border-radius:99px;overflow:hidden;margin-top:4px}.progress-fill{height:100%;background:var(--green);border-radius:99px;transition:width .3s}.pct{font-size:.78rem;font-weight:600;color:var(--gray-500);margin-top:3px;display:block}.page-body{max-width:1000px;margin:0 auto;padding:20px;display:flex;flex-direction:column;gap:20px}.account-card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}.account-header{display:flex;align-items:center;gap:12px;padding:14px 16px;border-bottom:2px solid var(--gray-100);border-left:4px solid transparent;flex-wrap:wrap;gap:10px}.account-title{display:flex;align-items:center;gap:8px;flex:1;min-width:120px}.account-title h2{font-size:.95rem;font-weight:700}.account-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;display:inline-block}.account-dot.sm{width:8px;height:8px}.account-totals{display:flex;gap:16px}.atotal{font-size:.8rem;color:var(--gray-500)}.atotal strong{color:var(--gray-900)}.atotal .orange{color:var(--orange)}.account-actions{display:flex;gap:6px;margin-left:auto}.btn-ghost-sm{background:none;border:1px solid var(--gray-200);color:var(--gray-700);padding:4px 10px;border-radius:6px;cursor:pointer;font-size:.75rem;font-weight:600}.btn-ghost-sm:hover{background:var(--gray-100);border-color:var(--gray-400)}.payment-table{border-bottom:1px solid var(--gray-100)}.pt-header{display:grid;grid-template-columns:20px 1fr 120px 120px auto auto;gap:8px;padding:6px 16px;background:var(--gray-50);font-size:.7rem;font-weight:700;text-transform:uppercase;color:var(--gray-400)}.pt-row{display:grid;grid-template-columns:20px 1fr 120px 120px auto auto;gap:8px;align-items:center;padding:8px 16px;border-top:1px solid var(--gray-100);transition:background .1s}.pt-row.pt-paid{opacity:.5}.pt-name{font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pt-amount{font-variant-numeric:tabular-nums;font-weight:600;text-align:right}.pt-actual-empty{color:var(--gray-400);font-weight:400}.pt-footer{display:grid;grid-template-columns:20px 1fr 120px 120px auto auto;gap:8px;padding:8px 16px;background:var(--gray-50);border-top:2px solid var(--gray-200);font-size:.82rem;font-weight:700;color:var(--gray-700)}.bal-badge{display:inline-block;font-size:.68rem;font-weight:600;padding:1px 6px;border-radius:99px;margin-left:6px;background:#fef3c7;color:#92400e;white-space:nowrap}.bal-badge.bal-done{background:var(--green-bg);color:var(--green-text)}.drag-handle{cursor:grab;color:var(--gray-300);font-size:1rem;-webkit-user-select:none;user-select:none;line-height:1;padding:0 2px}.drag-handle:active{cursor:grabbing}.group-header{display:flex;align-items:center;gap:8px;padding:5px 16px;background:var(--gray-100);border-top:1px solid var(--gray-200);cursor:pointer;-webkit-user-select:none;user-select:none}.group-header:hover{background:var(--gray-200)}.group-chevron{font-size:.7rem;color:var(--gray-400);width:12px}.group-name{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--gray-500);flex:1}.group-count{font-size:.72rem;color:var(--gray-400)}.group-badge{font-size:.68rem;padding:1px 7px;border-radius:99px;border:1px dashed var(--gray-300);color:var(--gray-400);background:none;cursor:pointer;white-space:nowrap;flex-shrink:0}.group-badge:hover{border-color:var(--blue);color:var(--blue)}.group-badge.has-group{background:var(--blue-light);color:var(--blue);border-color:var(--blue);border-style:solid}.group-input{font-size:.75rem;border:1px solid var(--blue);border-radius:99px;padding:1px 8px;outline:none;width:110px}.payoff-tracker{padding:10px 16px 12px;background:#f8fafc;border-top:1px solid var(--gray-200)}.payoff-row{display:flex;align-items:center;gap:10px;margin-bottom:6px}.payoff-label{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--gray-500);flex-shrink:0}.payoff-current{font-weight:700;font-size:.95rem}.payoff-of{font-size:.78rem;color:var(--gray-400);margin-left:auto}.payoff-bar-wrap{display:flex;align-items:center;gap:10px}.payoff-bar{flex:1;height:8px;background:var(--gray-200);border-radius:99px;overflow:hidden}.payoff-fill{height:100%;border-radius:99px;transition:width .4s}.payoff-pct{font-size:.72rem;color:var(--gray-500);white-space:nowrap}.adhoc-section{padding:10px 16px 14px;background:var(--gray-50);border-top:1px solid var(--gray-200)}.adhoc-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.adhoc-label{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--gray-500)}.adhoc-total{font-size:.82rem;font-weight:700;color:var(--orange)}.adhoc-row{display:grid;grid-template-columns:1fr auto auto;gap:8px;align-items:center;padding:5px 0;border-bottom:1px solid var(--gray-200)}.adhoc-add-row{display:flex;gap:8px;margin-top:10px;align-items:center}.adhoc-add-row input{border:1px solid var(--gray-200);border-radius:6px;padding:5px 10px;font:inherit;font-size:.85rem;flex:1}.adhoc-add-row .amt{flex:0 0 100px;text-align:right}.adhoc-add-row input:focus{outline:none;border-color:var(--blue)}.add-panel{border-top:1px solid var(--gray-200)}.add-mode-toggle{display:flex;align-items:center;gap:4px;padding:8px 16px;background:var(--gray-50);border-bottom:1px solid var(--gray-200)}.mode-btn{padding:4px 12px;border-radius:99px;border:1px solid var(--gray-200);background:#fff;cursor:pointer;font-size:.78rem;font-weight:600;color:var(--gray-500)}.mode-btn.active{background:var(--blue);color:#fff;border-color:var(--blue)}.calc-panel{padding:12px 16px 16px;background:#f0f9ff}.calc-row{display:flex;gap:14px;align-items:flex-end;flex-wrap:wrap}.calc-row label{display:flex;flex-direction:column;gap:3px;font-size:.75rem;font-weight:600;color:var(--gray-500)}.calc-row input{border:1px solid var(--gray-200);border-radius:6px;padding:6px 8px;font:inherit;font-size:.85rem;width:110px;outline:none;background:#fff}.calc-row input:focus{border-color:var(--blue)}.calc-result{display:flex;align-items:center;gap:14px;padding:4px 0;flex-wrap:wrap}.calc-result-value{font-size:1.15rem;font-weight:700;color:var(--blue)}.calc-result-sub{font-size:.75rem;font-weight:400;color:var(--gray-400);margin-left:2px}.bulk-panel{padding:14px 16px;background:#f0f9ff;border-bottom:1px solid #bae6fd}.bulk-hint{font-size:.78rem;color:var(--gray-500);margin-bottom:8px}.bulk-hint code{background:var(--gray-200);padding:1px 5px;border-radius:3px;font-size:.75rem}.bulk-textarea{width:100%;border:1px solid var(--gray-200);border-radius:6px;padding:8px 10px;font:inherit;font-size:.82rem;font-family:monospace;resize:vertical}.bulk-preview{margin-top:10px;background:#fff;border:1px solid var(--gray-200);border-radius:6px;overflow:hidden}.bulk-preview-header{padding:6px 12px;background:var(--gray-50);font-size:.75rem;font-weight:700;color:var(--gray-500);border-bottom:1px solid var(--gray-200)}.bulk-preview-row{display:grid;grid-template-columns:1fr auto auto;gap:8px;padding:5px 12px;border-bottom:1px solid var(--gray-100);font-size:.82rem}.bulk-actions{display:flex;gap:8px;padding:10px 12px}.gray{color:var(--gray-400);font-size:.75rem}.section-heading{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--gray-400);margin-bottom:10px;padding:0 4px}.balances-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px}.balance-card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);padding:14px 16px;border-left:4px solid transparent;display:flex;flex-direction:column;gap:6px}.balance-name{display:flex;align-items:center;gap:6px;font-weight:600;font-size:.88rem}.balance-value{font-size:1.25rem;font-weight:700}.balance-value.green{color:var(--green)}.balance-value.red{color:var(--red)}.balance-rate{font-size:.72rem;color:var(--gray-400)}.balance-input{border:1px solid var(--blue);border-radius:5px;padding:4px 8px;font:inherit;font-size:1.1rem;font-weight:700;width:100%;outline:none}.btn-primary{background:var(--blue);color:#fff;border:none;padding:6px 14px;border-radius:6px;cursor:pointer;font-size:.82rem;font-weight:600}.btn-primary:hover{background:var(--blue-dark)}.btn-sm{padding:4px 10px;font-size:.75rem}.btn-add{background:var(--blue);color:#fff;border:none;border-radius:6px;padding:6px 14px;font:inherit;font-size:.82rem;font-weight:600;cursor:pointer;white-space:nowrap}.btn-cancel{background:none;border:none;color:var(--gray-500);cursor:pointer;font-size:.85rem;padding:6px 8px}.add-row{display:flex;gap:8px;padding:10px 16px;background:var(--blue-light);border-top:1px solid var(--gray-200);align-items:center}.add-row input{border:1px solid var(--gray-200);border-radius:6px;padding:6px 10px;font:inherit;font-size:.85rem;flex:1}.add-row .amt{flex:0 0 100px;text-align:right}.add-row input:focus{outline:none;border-color:var(--blue)}.paid-toggle{padding:3px 10px;border-radius:99px;font-size:.72rem;font-weight:700;cursor:pointer;border:none;white-space:nowrap}.paid-toggle.paid{background:var(--green-bg);color:var(--green-text)}.paid-toggle.unpaid{background:var(--gray-100);color:var(--gray-500)}.bill-delete{color:var(--gray-400);cursor:pointer;font-size:1rem;padding:2px 4px;border:none;background:none;opacity:0;transition:opacity .1s}.pt-row:hover .bill-delete,.adhoc-row:hover .bill-delete,.bill-delete.always-show{opacity:1}.bill-delete:hover{color:var(--red)}.editable-amt{cursor:pointer;border-radius:4px;padding:2px 5px;transition:background .1s}.editable-amt:hover{background:var(--gray-100)}.amt-edit{width:110px;border:1px solid var(--blue);border-radius:5px;padding:3px 6px;text-align:right;font:inherit;font-size:.88rem;font-weight:600;outline:none}.color-dot{width:14px;height:14px;border-radius:50%;border:1.5px solid rgba(0,0,0,.12);cursor:pointer;flex-shrink:0;padding:0}.color-dot.lg{width:22px;height:22px}.color-palette{position:absolute;top:22px;left:0;background:#fff;border:1px solid var(--gray-200);border-radius:8px;box-shadow:var(--shadow-md);padding:8px;display:flex;gap:6px;z-index:50;flex-wrap:wrap;max-width:220px}.color-palette.inline{position:static;box-shadow:none;border:none;background:transparent;padding:0;margin-left:4px;display:inline-flex}.color-swatch{width:20px;height:20px;border-radius:4px;cursor:pointer;padding:0;border:none;transition:transform .1s}.color-swatch.lg{width:26px;height:26px;border-radius:6px}.color-swatch:hover{transform:scale(1.15)}.color-swatch.selected{outline:2px solid var(--blue);outline-offset:2px}.color-row{display:flex;gap:6px;margin-top:6px;flex-wrap:wrap}.container{max-width:960px;margin:0 auto;padding:20px}.card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);margin-bottom:16px;overflow:hidden}.card-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--gray-100)}.card-header h2{font-size:.85rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--gray-500)}.accounts-hint{font-size:.78rem;color:var(--gray-400);padding:8px 16px 4px}.account-row{display:flex;align-items:center;gap:10px;padding:10px 16px;border-top:1px solid var(--gray-100);position:relative}.account-row-info{flex:1;display:flex;flex-direction:column;gap:2px}.account-row-name{font-weight:600}.account-row-type{font-size:.75rem;color:var(--gray-400)}.type-select{font-size:.75rem;color:var(--gray-500);border:none;background:none;cursor:pointer;padding:0;font-family:inherit}.type-select:hover{color:var(--blue)}.type-select:focus{outline:none;color:var(--blue)}.rate-badge{font-size:.78rem;font-weight:700;color:var(--orange);background:#fef3c7;padding:2px 8px;border-radius:99px;cursor:pointer}.rate-badge-empty{color:var(--gray-400);background:var(--gray-100);font-weight:500}.rate-input{width:70px;border:1px solid var(--blue);border-radius:5px;padding:3px 6px;font:inherit;font-size:.85rem;outline:none}.form-row{display:flex;gap:12px;flex-wrap:wrap}.form-row label{display:flex;flex-direction:column;gap:4px;font-size:.78rem;font-weight:600;color:var(--gray-500)}.form-row input,.form-row select{border:1px solid var(--gray-200);border-radius:6px;padding:7px 10px;font:inherit;font-size:.85rem;background:#fff;outline:none}.form-row input:focus,.form-row select:focus{border-color:var(--blue)}.loans-summary{display:flex;gap:16px;padding:0 0 16px;flex-wrap:wrap}.ls-card{flex:1;min-width:160px;background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);padding:16px 20px}.ls-label{font-size:.7rem;font-weight:600;text-transform:uppercase;color:var(--gray-500)}.ls-value{font-size:1.3rem;font-weight:700;margin-top:4px}.ls-value.green{color:var(--green)}.ls-value.red{color:var(--red)}.loan-filters{display:flex;gap:6px;margin-bottom:14px}.loan-filter-btn{padding:5px 14px;border-radius:99px;border:1px solid var(--gray-200);background:#fff;cursor:pointer;font-size:.8rem;font-weight:600;color:var(--gray-500)}.loan-filter-btn.active{background:var(--blue);color:#fff;border-color:var(--blue)}.loan-card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);margin-bottom:14px;overflow:hidden}.loan-top{display:flex;align-items:center;gap:12px;padding:14px 16px}.loan-avatar{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.95rem;color:#fff;flex-shrink:0}.loan-meta{flex:1}.loan-name{font-weight:700}.loan-dir{display:inline-block;font-size:.7rem;font-weight:700;padding:2px 8px;border-radius:99px;margin-top:3px}.loan-dir.owed{background:var(--green-bg);color:var(--green-text)}.loan-dir.iowe{background:var(--red-bg);color:var(--red-text)}.loan-outstanding{text-align:right}.lo-label{font-size:.7rem;color:var(--gray-400);font-weight:600;text-transform:uppercase}.lo-val{font-size:1.2rem;font-weight:700}.lo-val.owed{color:var(--green)}.lo-val.iowe{color:var(--red)}.loan-progress-wrap{padding:0 16px 8px}.loan-progress-bar{height:6px;background:var(--gray-200);border-radius:99px;overflow:hidden;margin-bottom:4px}.loan-progress-fill{height:100%;border-radius:99px;transition:width .3s}.loan-progress-label{font-size:.72rem;color:var(--gray-500);display:flex;justify-content:space-between}.loan-actions{display:flex;gap:6px;padding:10px 16px;border-top:1px solid var(--gray-100);background:var(--gray-50)}.loan-btn{padding:5px 12px;border-radius:6px;font-size:.78rem;font-weight:600;cursor:pointer;border:1px solid var(--gray-200);background:#fff}.loan-btn.primary{background:var(--blue);color:#fff;border-color:var(--blue)}.loan-btn.danger{color:var(--red)}.add-loan-form{padding:12px 16px;border-top:1px solid var(--gray-100);background:var(--blue-light)}.loan-history table{width:100%;border-collapse:collapse;font-size:.82rem}.loan-history th{text-align:left;padding:7px 16px;background:var(--gray-50);font-size:.7rem;font-weight:700;text-transform:uppercase;color:var(--gray-500)}.loan-history td{padding:7px 16px;border-top:1px solid var(--gray-100);font-variant-numeric:tabular-nums}.loan-history tr:hover .bill-delete{opacity:1}.tx-payment{color:var(--green);font-weight:600}.tx-loan{color:var(--red);font-weight:600}.loans-toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.red{color:var(--red)}.green{color:var(--green)}.orange{color:var(--orange)}@media (max-width: 640px){.pt-header,.pt-row,.pt-footer{grid-template-columns:1fr 100px 100px auto auto}.balances-grid{grid-template-columns:1fr 1fr}}
