@import"https://fonts.googleapis.com/css2?family=IBM+Plex+Mono:wght@300;400;500;600&family=IBM+Plex+Sans:wght@300;400;500;600&display=swap";:root{--primary: #1a3a6b;--accent: #e8720c;--accent2: #f5a44a;--bg: #f2f4f8;--card: #ffffff;--border: rgba(26,58,107,.1);--border2: rgba(26,58,107,.22);--text: #1a2540;--muted: #6b7a99;--font-sans:"IBM Plex Sans", sans-serif;--font-mono:"IBM Plex Mono", monospace}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-sans);background:var(--bg);color:var(--text);min-height:100vh;font-size:14px;line-height:1.5}.app{max-width:1140px;margin:0 auto;padding:28px 20px 60px}.header{background:var(--primary);border-radius:14px;padding:20px 28px;display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;gap:16px;flex-wrap:wrap}.header-title{font-size:18px;font-weight:600;color:#fff;letter-spacing:-.2px}.header-sub{font-size:12px;color:#ffffffa6;font-family:var(--font-mono);margin-top:3px}.header-right{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.header-total .amount{font-size:26px;font-weight:600;color:#fff;font-family:var(--font-mono);letter-spacing:-.5px}.header-total .label{font-size:11px;color:#ffffffa6;text-align:right}.btn-print{background:var(--accent);color:#fff;border:none;border-radius:8px;padding:9px 18px;font-size:13px;font-weight:500;cursor:pointer;font-family:var(--font-sans);display:flex;align-items:center;gap:7px;transition:background .15s}.btn-print:hover{background:#c45e06}.btn-signout{background:transparent;color:#ffffffb3;border:.5px solid rgba(255,255,255,.3);border-radius:8px;padding:7px 14px;font-size:12px;cursor:pointer;font-family:var(--font-sans);transition:all .15s}.btn-signout:hover{background:#ffffff1a;color:#fff}.summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;margin-bottom:20px}.metric{background:var(--card);border:.5px solid var(--border);border-radius:12px;padding:16px 18px;position:relative;overflow:hidden}.metric:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--primary);border-radius:3px 0 0 3px}.metric.paid:before{background:#28a745}.metric.late:before{background:#dc3545}.metric.soon:before{background:var(--accent)}.metric.debt:before{background:#8b0000}.metric-label{font-size:10px;text-transform:uppercase;letter-spacing:.7px;color:var(--muted);margin-bottom:6px;font-weight:500}.metric-value{font-size:20px;font-weight:600;font-family:var(--font-mono);color:var(--text);line-height:1.1}.metric.paid .metric-value{color:#28a745}.metric.late .metric-value{color:#dc3545}.metric.debt .metric-value{color:#8b0000}.metric-sub{font-size:11px;color:var(--muted);margin-top:4px}.toolbar{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.filter-btn{padding:5px 14px;border:.5px solid var(--border2);background:var(--card);border-radius:20px;font-size:12px;color:var(--muted);cursor:pointer;font-family:var(--font-sans);transition:all .12s}.filter-btn:hover,.filter-btn.active{background:var(--primary);color:#fff;border-color:var(--primary);font-weight:500}.filter-count{margin-left:auto;font-size:12px;color:var(--muted);font-family:var(--font-mono)}.btn-add{background:transparent;color:var(--primary);border:.5px solid var(--primary);border-radius:8px;padding:5px 14px;font-size:12px;cursor:pointer;font-family:var(--font-sans);transition:all .12s}.btn-add:hover{background:var(--primary);color:#fff}.table-wrap{background:var(--card);border:.5px solid var(--border2);border-radius:12px;overflow:hidden;margin-bottom:12px}table{width:100%;border-collapse:collapse}thead th{background:#eef1f8;color:var(--primary);font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.6px;padding:11px 14px;text-align:left;border-bottom:.5px solid var(--border2)}th.r,td.r{text-align:right}th.c,td.c{text-align:center}tbody td{padding:10px 14px;border-bottom:.5px solid var(--border);font-size:13px;vertical-align:middle}tbody tr:last-child td{border-bottom:none}tbody tr.main-row{cursor:pointer}tbody tr.main-row:hover td{background:#f7f9fd}tbody tr.main-row.row-late td{background:#fff6f6}tbody tr.main-row.row-late:hover td{background:#ffefef}tbody tr.main-row.row-soon td{background:#fffaf3}tbody tr.main-row.row-paid td{opacity:.52}tr.expand-row td{padding:0;background:#f8faff;border-bottom:.5px solid var(--border2)}.expand-inner{padding:10px 14px 16px 42px}.expand-title{font-size:10px;text-transform:uppercase;letter-spacing:.6px;color:var(--muted);font-weight:600;margin-bottom:10px}.periods-grid{display:flex;flex-wrap:wrap;gap:8px}.period-card{border:.5px solid var(--border2);border-radius:8px;padding:10px 14px;background:#fff;min-width:150px}.period-card.pc-paid{border-color:#b7dfc3;background:#f0faf3}.period-card.pc-late{border-color:#f0b8bb;background:#fff5f5}.period-card.pc-open{border-color:#f0d8b0;background:#fffaf3}.pc-month{font-size:12px;font-weight:600;color:var(--primary);font-family:var(--font-mono);margin-bottom:4px}.pc-amount{font-size:14px;font-weight:600;font-family:var(--font-mono);color:var(--text)}.pc-date{font-size:10px;color:var(--muted);margin-top:3px}.pc-badge{display:inline-block;margin-top:5px;padding:2px 8px;border-radius:10px;font-size:10px;font-weight:500}.pcb-paid{background:#d4edda;color:#155724}.pcb-late{background:#f8d7da;color:#721c24}.pcb-open{background:#fff3cd;color:#856404}.pc-btn{margin-top:7px;display:block;padding:3px 9px;border-radius:5px;font-size:10px;cursor:pointer;font-family:var(--font-sans);border:.5px solid}.pc-btn.pay{border-color:#28a745;color:#28a745;background:transparent}.pc-btn.pay:hover{background:#28a745;color:#fff}.pc-btn.unpay{border-color:#dc3545;color:#dc3545;background:transparent}.pc-btn.unpay:hover{background:#dc3545;color:#fff}.pc-card-actions{display:flex;gap:5px;margin-top:7px;flex-wrap:wrap}.pc-btn.edit{border-color:#5c73b5;color:#5c73b5;background:transparent}.pc-btn.edit:hover{background:#5c73b5;color:#fff}.pc-btn.del{border-color:#dc354566;color:#dc3545;background:transparent}.pc-btn.del:hover{background:#dc3545;color:#fff;border-color:#dc3545}.pc-edit-form{margin-top:8px;padding-top:8px;border-top:.5px solid var(--border2);flex-direction:column;gap:6px}.pc-edit-form.open{display:flex}.pc-edit-form{display:none}.pc-edit-field{display:flex;flex-direction:column;gap:2px}.pc-edit-field label{font-size:9px;text-transform:uppercase;letter-spacing:.5px;color:var(--muted)}.pc-edit-field input{border:.5px solid var(--border2);border-radius:5px;padding:4px 7px;font-size:12px;font-family:var(--font-mono);color:var(--text);background:#fff;outline:none;width:100%}.pc-edit-field input:focus{border-color:var(--primary)}.pc-edit-btns{display:flex;gap:5px;margin-top:2px}.pc-edit-save{background:var(--primary);color:#fff;border:none;border-radius:5px;padding:4px 10px;font-size:11px;cursor:pointer;font-family:var(--font-sans)}.pc-edit-cancel{background:transparent;color:var(--muted);border:.5px solid var(--border2);border-radius:5px;padding:4px 8px;font-size:11px;cursor:pointer;font-family:var(--font-sans)}.btn-add-period{margin-top:10px;padding:4px 10px;border:.5px dashed var(--border2);border-radius:6px;font-size:11px;color:var(--accent);background:transparent;cursor:pointer;font-family:var(--font-sans)}.btn-add-period:hover{background:#fff8f2}.add-period-form{margin-top:8px;background:#fff;border:.5px solid var(--border2);border-radius:8px;padding:10px 14px;flex-wrap:wrap;gap:10px;align-items:flex-end}.add-period-form.open{display:flex}.add-period-form{display:none}.apf-field{display:flex;flex-direction:column;gap:3px}.apf-field label{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}.apf-field input{border:.5px solid var(--border2);border-radius:5px;padding:5px 8px;font-size:12px;font-family:var(--font-mono);color:var(--text);background:#fff;width:140px;outline:none}.apf-field input:focus{border-color:var(--primary)}.apf-save{background:var(--primary);color:#fff;border:none;border-radius:6px;padding:5px 12px;font-size:12px;cursor:pointer;font-family:var(--font-sans)}.apf-cancel{background:transparent;color:var(--muted);border:.5px solid var(--border2);border-radius:6px;padding:5px 10px;font-size:12px;cursor:pointer;font-family:var(--font-sans);margin-left:4px}.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:20px;font-size:11px;font-weight:500;white-space:nowrap}.b-paid{background:#e8f5ee;color:#15632e}.b-open{background:#fff3e0;color:#7a3800}.b-late{background:#fdecea;color:#8b1c1c}.b-soon{background:#fff8ec;color:#7a4a00}.b-plan{background:#edf0f9;color:#2c3f7a}.days-chip{display:inline-block;padding:2px 7px;border-radius:8px;font-size:11px;font-weight:500;font-family:var(--font-mono)}.dc-neg{background:#fdecea;color:#8b1c1c}.dc-warn{background:#fff8ec;color:#7a4a00}.dc-ok{background:#e8f5ee;color:#15632e}.dc-na{color:var(--muted);font-size:11px}.debt-cell{font-family:var(--font-mono);font-weight:600;font-size:13px;text-align:right;white-space:nowrap}.debt-zero{color:var(--muted);font-weight:400;font-family:var(--font-mono);font-size:13px;text-align:right}.debt-red{color:#8b0000}.debt-periods{font-size:10px;color:#dc3545;display:block;margin-top:1px;font-weight:400}.chevron{display:inline-block;transition:transform .2s;font-size:10px;color:var(--muted);margin-right:4px;user-select:none}.chevron.open{transform:rotate(90deg)}.actions{display:flex;gap:5px;white-space:nowrap}.act-btn{padding:3px 8px;border:.5px solid var(--border2);border-radius:6px;font-size:11px;cursor:pointer;background:transparent;color:var(--muted);font-family:var(--font-sans);transition:all .1s}.act-btn:hover{background:var(--primary);color:#fff;border-color:var(--primary)}.act-btn.del:hover{background:#dc3545;border-color:#dc3545;color:#fff}.add-row-btn{width:100%;border:none;background:transparent;color:var(--accent);font-size:13px;cursor:pointer;padding:11px 14px;text-align:left;border-top:.5px dashed var(--border2);font-family:var(--font-sans);transition:background .12s}.add-row-btn:hover{background:#fff8f2}.input-row{background:#fffaf3}.input-row td{padding:7px 8px}.input-row input{width:100%;border:.5px solid var(--border2);border-radius:6px;padding:5px 8px;font-size:12px;background:#fff;color:var(--text);font-family:var(--font-sans);outline:none}.input-row input:focus{border-color:var(--primary)}.save-btn{background:var(--primary);color:#fff;border:none;border-radius:6px;padding:5px 12px;font-size:12px;cursor:pointer;font-family:var(--font-sans)}.cancel-btn{background:transparent;color:var(--muted);border:.5px solid var(--border2);border-radius:6px;padding:5px 10px;font-size:12px;cursor:pointer;font-family:var(--font-sans);margin-left:4px}.empty-msg{text-align:center;padding:32px;color:var(--muted);font-size:13px}.footer{margin-top:40px;padding-top:16px;border-top:.5px solid var(--border2);display:flex;align-items:flex-end;justify-content:space-between;gap:16px;flex-wrap:wrap}.sig-name{font-size:13px;font-weight:600;color:var(--primary)}.sig-url{font-size:11px;font-family:var(--font-mono);color:var(--accent);text-decoration:none;display:block;margin-top:2px}.sig-url:hover{text-decoration:underline}.footer-meta{text-align:right;font-size:11px;color:var(--muted);font-family:var(--font-mono)}.footer-meta strong{color:var(--text)}.data-bar{display:flex;align-items:center;gap:8px;background:var(--card);border:.5px solid var(--border2);border-radius:10px;padding:9px 14px;margin-top:12px;flex-wrap:wrap}.data-bar-label{font-size:11px;color:var(--muted);margin-right:4px}.btn-data{display:flex;align-items:center;gap:5px;padding:5px 12px;border-radius:7px;font-size:12px;cursor:pointer;font-family:var(--font-sans);font-weight:500;transition:all .12s;border:.5px solid var(--border2);background:transparent;color:var(--text)}.btn-data.export{color:var(--primary);border-color:var(--primary)}.btn-data.export:hover{background:var(--primary);color:#fff}.btn-data.import-btn{color:#5c73b5;border-color:#5c73b5}.btn-data.import-btn:hover{background:#5c73b5;color:#fff}.btn-data.clear{color:#dc3545;border-color:#dc354566}.btn-data.clear:hover{background:#dc3545;color:#fff;border-color:#dc3545}.save-indicator{font-size:11px;font-family:var(--font-mono);color:#28a745;margin-left:auto}.loading-wrap{display:flex;align-items:center;justify-content:center;padding:80px 20px;color:var(--muted);font-family:var(--font-mono);font-size:13px;gap:10px}.spinner{width:18px;height:18px;border:2px solid var(--border2);border-top-color:var(--primary);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.error-msg{background:#fdecea;border:.5px solid #f0b8bb;border-radius:8px;padding:12px 16px;color:#8b1c1c;font-size:13px;margin-bottom:12px}.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg)}.login-card{background:var(--card);border:.5px solid var(--border2);border-radius:16px;padding:40px 36px;width:100%;max-width:380px;box-shadow:0 4px 24px #1a3a6b14}.login-logo{font-size:16px;font-weight:600;color:var(--primary);margin-bottom:4px}.login-sub{font-size:12px;color:var(--muted);font-family:var(--font-mono);margin-bottom:28px}.login-field{display:flex;flex-direction:column;gap:5px;margin-bottom:14px}.login-field label{font-size:11px;text-transform:uppercase;letter-spacing:.6px;color:var(--muted);font-weight:500}.login-field input{border:.5px solid var(--border2);border-radius:8px;padding:9px 12px;font-size:13px;font-family:var(--font-sans);color:var(--text);background:#fff;outline:none;transition:border-color .15s}.login-field input:focus{border-color:var(--primary)}.login-btn{width:100%;background:var(--primary);color:#fff;border:none;border-radius:8px;padding:10px 16px;font-size:14px;font-weight:500;cursor:pointer;font-family:var(--font-sans);margin-top:6px;transition:background .15s}.login-btn:hover{background:#14306b}.login-btn:disabled{opacity:.6;cursor:not-allowed}.login-error{background:#fdecea;border:.5px solid #f0b8bb;border-radius:6px;padding:9px 12px;color:#8b1c1c;font-size:12px;margin-bottom:12px}.print-header{display:none;font-size:11px;color:var(--muted);margin-bottom:8px;font-family:var(--font-mono)}@media print{body{background:#fff;font-size:11px}.app{max-width:100%;padding:12px 14px 20px}.btn-print,.btn-add,.toolbar,.actions,.act-btn,.add-row-btn,.input-row,.expand-row,.btn-add-period,.add-period-form,.data-bar,.btn-signout{display:none!important}.header{border-radius:6px;padding:12px 16px;print-color-adjust:exact;-webkit-print-color-adjust:exact}.table-wrap{border-radius:6px;border:.5px solid #ccc}thead th{background:#eef1f8!important;print-color-adjust:exact;-webkit-print-color-adjust:exact}tbody tr.main-row.row-late td{background:#fff6f6!important;print-color-adjust:exact;-webkit-print-color-adjust:exact}tbody tr.main-row.row-soon td{background:#fffaf3!important;print-color-adjust:exact;-webkit-print-color-adjust:exact}.summary{grid-template-columns:repeat(5,1fr)}.footer{margin-top:20px}.print-header{display:block!important}}@media(max-width:680px){.summary{grid-template-columns:1fr 1fr}}
