*,*: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-900: #0f172a;--radius: 10px;--shadow: 0 1px 3px 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)}.nav{background:#1e40af;color:#fff;display:flex;align-items:center;justify-content:space-between;padding:0 20px;height:52px;position:sticky;top:0;z-index:100}.brand{font-weight:700;font-size:1rem}.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}.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}.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)}.progress-wrap{flex:1;min-width:140px}.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:.8rem;font-weight:600;color:var(--gray-500);margin-top:2px;display:block}.tabs{display:flex;gap:2px;padding:16px 20px 0;background:#fff;border-bottom:1px solid var(--gray-200)}.tab{padding:8px 16px;border-radius:8px 8px 0 0;cursor:pointer;font-weight:500;color:var(--gray-500);border:1px solid transparent;border-bottom:none;position:relative;top:1px;background:none}.tab.active{color:var(--blue);background:#fff;border-color:var(--gray-200);font-weight:600}.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)}.hright{display:flex;gap:8px;align-items:center}.btn-primary{background:var(--blue);color:#fff;border:none;padding:6px 12px;border-radius:6px;cursor:pointer;font-size:.8rem;font-weight:600}.btn-sm{padding:4px 10px;font-size:.75rem}.toggle-btn{padding:4px 10px;border-radius:6px;border:1px solid var(--gray-200);background:#fff;cursor:pointer;font-size:.75rem;font-weight:600;color:var(--gray-500)}.toggle-btn.active{background:var(--gray-100);border-color:var(--gray-300)}.bill-row{display:grid;grid-template-columns:1fr auto auto auto;align-items:center;padding:9px 16px;border-bottom:1px solid var(--gray-100);gap:8px}.bill-row.paid-row{opacity:.55}.bill-name{font-weight:500}.bill-amount{font-weight:600;font-variant-numeric:tabular-nums;min-width:90px;text-align:right}.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(--red-bg);color:var(--red-text)}.bill-delete{color:var(--gray-400);cursor:pointer;font-size:1rem;padding:2px 4px;border:none;background:none;opacity:0}.bill-row:hover .bill-delete{opacity:1}.add-row{display:grid;grid-template-columns:1fr auto auto auto;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}.add-row .amt{width:100px;text-align:right}.btn-add{background:var(--blue);color:#fff;border:none;border-radius:6px;padding:7px 14px;font-size:.85rem;font-weight:600;cursor:pointer}.btn-cancel{background:none;border:none;color:var(--gray-500);cursor:pointer;font-size:.85rem;padding:7px 8px}.section-total{display:flex;justify-content:flex-end;gap:20px;padding:10px 16px;background:var(--gray-50);border-top:2px solid var(--gray-200);font-size:.85rem;color:var(--gray-500)}.facility-header{display:grid;grid-template-columns:1fr 110px 130px auto;gap:8px;padding:8px 16px;font-size:.7rem;font-weight:700;text-transform:uppercase;color:var(--gray-400);border-bottom:1px solid var(--gray-200)}.facility-row{display:grid;grid-template-columns:1fr 110px 130px auto;gap:8px;align-items:center;padding:9px 16px;border-bottom:1px solid var(--gray-100)}.fval{text-align:right;font-weight:500;font-variant-numeric:tabular-nums}.fbal-input{border:1px solid var(--gray-200);border-radius:5px;padding:3px 7px;text-align:right;width:110px;font:inherit;font-size:.85rem;font-weight:600}.adhoc-row{display:grid;grid-template-columns:1fr 110px auto;gap:8px;align-items:center;padding:9px 16px;border-bottom:1px solid var(--gray-100)}.debt-row{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;border-bottom:1px solid var(--gray-100)}.dlabel{font-weight:500;display:flex;align-items:center;gap:8px}.dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.drate{font-size:.75rem;color:var(--gray-400)}.dval-input{border:1px solid var(--gray-200);border-radius:5px;padding:3px 8px;text-align:right;width:110px;font:inherit;font-weight:700}.loans-summary{display:flex;gap:16px;padding:16px 20px;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)}.form-row{display:flex;gap:8px;flex-wrap:wrap;align-items:flex-end}.form-row label{font-size:.75rem;font-weight:600;color:var(--gray-500);display:flex;flex-direction:column;gap:4px}.form-row input,.form-row select{border:1px solid var(--gray-200);border-radius:6px;padding:6px 10px;font:inherit;font-size:.85rem;background:#fff}.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}.tx-payment{color:var(--green);font-weight:600}.tx-loan{color:var(--red);font-weight:600}.grid2{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:0}@media (max-width: 640px){.grid2{grid-template-columns:1fr}}.debt-row-right{display:flex;align-items:center;gap:6px}.debt-row .bill-delete{opacity:0}.debt-row:hover .bill-delete{opacity:1}.debt-add-row{display:flex;gap:8px;padding:10px 16px;background:var(--gray-50);border-top:1px solid var(--gray-200);align-items:center}.debt-add-row input{border:1px solid var(--gray-200);border-radius:6px;padding:5px 8px;font:inherit;font-size:.85rem;background:#fff;outline:none}.debt-add-row input:focus{border-color:var(--blue)}.net-position{display:flex;align-items:center;gap:32px;padding:20px 16px;flex-wrap:wrap}.net-op{font-size:1.5rem;color:var(--gray-300)}.chart-card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);margin-bottom:16px;overflow:hidden}.chart-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px 0}.chart-header h2{font-size:.85rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--gray-500)}.chart-legend{display:flex;flex-wrap:wrap;gap:12px;padding:8px 16px}.legend-item{display:flex;align-items:center;gap:5px;font-size:.75rem;font-weight:500;color:var(--gray-700)}.legend-dot{width:10px;height:10px;border-radius:2px;flex-shrink:0}.chart-body{padding:12px 16px 16px;height:320px}.payoff-badges{display:flex;flex-wrap:wrap;gap:8px;padding:12px 16px 14px;border-top:1px solid var(--gray-100)}.payoff-badge{font-size:.75rem;font-weight:600;padding:3px 10px;border-radius:99px;white-space:nowrap}.payoff-badge.badge-short{background:var(--green-bg);color:var(--green-text)}.payoff-badge.badge-mid{background:#fef3c7;color:#92400e}.payoff-badge.badge-long{background:#dbeafe;color:#1e40af}.payoff-badge.badge-over{background:var(--red-bg);color:var(--red-text)}.loans-toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
