body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f5f5f5;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}*{box-sizing:border-box;margin:0;padding:0}body{background-color:#f8fafc;color:#1e293b;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.app{display:flex;flex-direction:column;min-height:100vh}.navbar{background-color:#fff;border-bottom:1px solid #e2e8f0;height:64px;justify-content:space-between;padding:0 2rem;position:-webkit-sticky;position:sticky;top:0;z-index:100}.navbar,.navbar-brand{align-items:center;display:flex}.navbar-brand{gap:.75rem}.navbar-logo{align-items:center;background:linear-gradient(135deg,#6366f1,#4f46e5);border-radius:8px;color:#fff;display:flex;font-size:1rem;height:36px;justify-content:center;width:36px}.navbar-brand h1{color:#1e293b;font-size:1.25rem;font-weight:700}.navbar-links{display:flex;gap:.5rem}.navbar-links a{border-radius:6px;color:#64748b;font-size:.95rem;font-weight:500;padding:.5rem 1rem;text-decoration:none;transition:all .2s}.navbar-links a.active,.navbar-links a:hover{background-color:#f1f5f9;color:#1e293b}.navbar-right{gap:1rem}.navbar-right,.navbar-user{align-items:center;display:flex}.navbar-user{gap:.75rem}.user-email{color:#64748b;font-size:.875rem}.notification-btn{background:none;border:none;border-radius:8px;color:#64748b;cursor:pointer;font-size:1.25rem;padding:.5rem;transition:all .2s}.notification-btn:hover{background-color:#f1f5f9;color:#1e293b}.btn-signout{background-color:#f1f5f9;border:none;border-radius:6px;color:#64748b;cursor:pointer;font-size:.875rem;font-weight:500;padding:.5rem 1rem;transition:all .2s}.btn-signout:hover{background-color:#e2e8f0;color:#1e293b}.main-content{flex:1 1;margin:0 auto;max-width:1400px;padding:2rem;width:100%}.demo-banner{background:linear-gradient(135deg,#6366f1,#4f46e5);border-radius:8px;color:#fff;font-size:.875rem;font-weight:500;margin-bottom:1.5rem;padding:.75rem 1.5rem;text-align:center}.page-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:2rem}.page-title h1{color:#1e293b;font-size:1.75rem;font-weight:700;margin-bottom:.5rem}.page-title p{color:#64748b;font-size:.95rem}.page-actions{display:flex;gap:.75rem}.btn-date{align-items:center;background-color:#fff;border:1px solid #e2e8f0;border-radius:8px;color:#1e293b;cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:.5rem;padding:.625rem 1rem;transition:all .2s}.btn-date:hover{background-color:#f8fafc;border-color:#cbd5e1}.btn-configure{align-items:center;background:linear-gradient(135deg,#6366f1,#4f46e5);border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:.5rem;padding:.625rem 1.25rem;transition:all .2s}.btn-configure:hover{opacity:.9;transform:translateY(-1px)}.stats-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(4,1fr);margin-bottom:2rem}@media (max-width:1200px){.stats-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:600px){.stats-grid{grid-template-columns:1fr}}.stat-card{background:#fff;border:1px solid #f1f5f9;border-radius:12px;box-shadow:0 1px 3px #0000000d;padding:1.5rem;transition:all .2s}.stat-card:hover{box-shadow:0 4px 12px #00000014;transform:translateY(-2px)}.stat-card-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:1rem}.stat-icon{align-items:center;border-radius:10px;display:flex;font-size:1.25rem;height:44px;justify-content:center;width:44px}.stat-icon.blue{background-color:#eff6ff;color:#3b82f6}.stat-icon.green{background-color:#f0fdf4;color:#22c55e}.stat-icon.purple{background-color:#f5f3ff;color:#8b5cf6}.stat-icon.orange{background-color:#fff7ed;color:#f97316}.stat-change{align-items:center;display:flex;font-size:.875rem;font-weight:600;gap:.25rem}.stat-change.positive{color:#22c55e}.stat-change.negative{color:#ef4444}.stat-label{color:#64748b;font-size:.875rem;font-weight:500;margin-bottom:.5rem}.stat-value{color:#1e293b;font-size:2rem;font-weight:700;margin-bottom:.25rem}.stat-subtitle{color:#94a3b8;font-size:.8rem}.card{background:#fff;border:1px solid #f1f5f9;border-radius:12px;box-shadow:0 1px 3px #0000000d;padding:1.5rem}.card,.card-header{margin-bottom:1.5rem}.card-header{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between}.card h2{color:#1e293b;font-size:1.125rem;font-weight:600;margin:0}.payment-grid-card{border:1px solid #e2e8f0}.filter-controls{align-items:center;display:flex;gap:.75rem}.month-filter{appearance:none;-webkit-appearance:none;-moz-appearance:none;background-color:#fff;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-position:right .75rem center;background-repeat:no-repeat;background-size:1rem;border:1px solid #e2e8f0;border-radius:8px;color:#1e293b;cursor:pointer;font-size:.875rem;min-width:180px;padding:.5rem 2.5rem .5rem 1rem}.month-filter:hover{border-color:#cbd5e1}.month-filter:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a;outline:none}.year-selector{align-items:center;display:flex;gap:.5rem}.btn-year{background-color:#f1f5f9;border:none;border-radius:6px;color:#64748b;cursor:pointer;font-size:.875rem;height:32px;transition:all .2s;width:32px}.btn-year:hover{background-color:#e2e8f0;color:#1e293b}.current-year{color:#1e293b;font-size:1rem;font-weight:600;min-width:50px;text-align:center}.payment-legend{background-color:#f8fafc;border-radius:8px;display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:1rem;padding:.75rem 1rem}.legend-item{align-items:center;color:#64748b;display:flex;font-size:.8rem;gap:.4rem}.legend-dot{border-radius:3px;height:12px;width:12px}.legend-dot.paid{background-color:#22c55e}.legend-dot.partial{background:linear-gradient(135deg,#f59e0b 50%,#22c55e 0)}.legend-dot.pending{background-color:#f59e0b}.legend-dot.overdue{background-color:#ef4444}.legend-dot.advance{background-color:#8b5cf6}.legend-dot.not-due{background-color:#e2e8f0}.legend-dot.future{background-color:#f1f5f9}.grid-hint{color:#94a3b8;font-size:.8rem;margin-bottom:1rem}.payment-grid-container{overflow-x:auto}.payment-grid{border-collapse:collapse;min-width:800px;width:100%}.payment-grid td,.payment-grid th{border-bottom:1px solid #f1f5f9;padding:.75rem .5rem;text-align:center}.payment-grid th{background-color:#f8fafc;color:#64748b;font-size:.8rem;font-weight:600;letter-spacing:.025em;text-transform:uppercase}.payment-grid th.current-month{background-color:#6366f1;color:#fff}.payment-grid .hospital-col{min-width:200px;padding:.75rem 1rem;text-align:left}.payment-grid .hospital-col strong{color:#1e293b;font-weight:600}.payment-grid .hospital-col small{color:#94a3b8;font-size:.75rem}.payment-grid .total-col{background-color:#f8fafc;min-width:100px}.payment-grid tbody tr:hover{background-color:#f8fafc}.payment-cell{border-radius:4px;font-size:.875rem;font-weight:600;height:36px;margin:2px;transition:all .2s;width:40px}.payment-cell.clickable{cursor:pointer}.payment-cell.clickable:hover{box-shadow:0 2px 8px #00000026;transform:scale(1.15)}.cell-paid{background-color:#dcfce7;color:#166534}.cell-partial{background:linear-gradient(135deg,#fef3c7 50%,#dcfce7 0);color:#92400e}.cell-pending{background-color:#fef3c7;color:#92400e}.cell-overdue{animation:pulse-cell 2s infinite;background-color:#fee2e2;color:#991b1b}.cell-not-due{background-color:#f8fafc;color:#cbd5e1}.cell-future{background-color:#fff;border:1px dashed #e2e8f0;color:#e2e8f0}.cell-advance{background-color:#f3e8ff;color:#7c3aed}@keyframes pulse-cell{0%,to{opacity:1}50%{opacity:.7}}.cell-icon{display:block}.cell-percent{display:block;font-size:.6rem;font-weight:700;margin-top:-2px}.total-amount{color:#22c55e;font-size:.75rem}.total-amount.partial{color:#f59e0b}.expected{color:#94a3b8;font-size:.7rem}table{border-collapse:collapse;width:100%}table td,table th{border-bottom:1px solid #f1f5f9;padding:.875rem 1rem;text-align:left}table th{color:#64748b;font-size:.8rem;font-weight:600;letter-spacing:.025em;text-transform:uppercase}table tbody tr:hover,table th{background-color:#f8fafc}table td strong{color:#1e293b}.status-badge{border-radius:9999px;font-size:.75rem;font-weight:600;padding:.25rem .75rem}.status-active{background-color:#dcfce7;color:#166534}.status-inactive{background-color:#fee2e2;color:#991b1b}.btn{align-items:center;border:none;border-radius:8px;cursor:pointer;display:inline-flex;font-size:.875rem;font-weight:600;gap:.5rem;justify-content:center;padding:.75rem 1.5rem;transition:all .2s ease}.btn-primary{background:linear-gradient(135deg,#6366f1,#4f46e5);box-shadow:0 4px 14px #6366f159;color:#fff}.btn-primary:hover{box-shadow:0 6px 20px #6366f173;transform:translateY(-2px)}.btn-primary:active{transform:translateY(0)}.btn-secondary{background-color:#f8fafc;border:1px solid #e2e8f0;color:#475569}.btn-secondary:hover{background-color:#f1f5f9;border-color:#cbd5e1;color:#1e293b}.btn-success{background:linear-gradient(135deg,#22c55e,#16a34a);box-shadow:0 4px 14px #22c55e59;color:#fff}.btn-success:hover{box-shadow:0 6px 20px #22c55e73;transform:translateY(-2px)}.btn-danger{background:linear-gradient(135deg,#ef4444,#dc2626);box-shadow:0 4px 14px #ef444459;color:#fff}.btn-danger:hover{box-shadow:0 6px 20px #ef444473;transform:translateY(-2px)}.btn-outline{background:#0000;border:2px solid #6366f1;color:#6366f1}.btn-outline:hover{background:#6366f1;color:#fff}.btn-ghost{background:#0000;border:none;color:#64748b}.btn-ghost:hover{background:#f1f5f9;color:#1e293b}.btn-small{font-size:.8rem;padding:.5rem 1rem}.btn-icon{border-radius:8px;height:36px;padding:0;width:36px}.action-btn{align-items:center;background:#0000;border:none;border-radius:6px;color:#94a3b8;cursor:pointer;display:flex;height:32px;justify-content:center;transition:all .2s;width:32px}.action-btn:hover{background:#f1f5f9;color:#475569}.btn-add{align-items:center;background:linear-gradient(135deg,#6366f1,#4f46e5);border-radius:10px;box-shadow:0 4px 14px #6366f159;color:#fff;display:inline-flex;font-weight:600;gap:.5rem;padding:.75rem 1.5rem}.btn-add:hover{box-shadow:0 6px 20px #6366f173;transform:translateY(-2px)}.btn-add .icon{font-size:1.1rem;font-weight:700}.modal-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background-color:#0f172a80;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.modal{background:#fff;border-radius:16px;box-shadow:0 20px 40px #00000026;max-height:90vh;max-width:480px;overflow-y:auto;padding:1.5rem;width:90%}.modal h2{color:#1e293b;font-size:1.25rem;font-weight:700;margin-bottom:1.25rem}.payment-modal-info{background-color:#f8fafc;border-radius:8px;margin-bottom:1.5rem;padding:1rem}.payment-modal-info p{color:#475569;font-size:.9rem;margin:.375rem 0}.overdue-warning{background-color:#fee2e2;border-radius:6px;color:#991b1b;font-size:.85rem;font-weight:600;margin-top:.75rem;padding:.5rem .75rem}.partial-warning{background-color:#fef3c7;color:#92400e}.advance-info,.partial-warning{border-radius:6px;font-size:.85rem;font-weight:500;margin-top:.75rem;padding:.5rem .75rem}.advance-info{background-color:#f3e8ff;color:#7c3aed}.form-group{margin-bottom:1.25rem}.form-group label{color:#475569;display:block;font-size:.875rem;font-weight:500;margin-bottom:.5rem}.form-group input,.form-group select{border:1px solid #e2e8f0;border-radius:8px;font-size:.95rem;padding:.75rem;transition:all .2s;width:100%}.form-group input:focus,.form-group select:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a;outline:none}.form-hint{color:#94a3b8;display:block;font-size:.8rem;margin-top:.5rem}.partial-hint{color:#f59e0b;font-weight:600}.status-dropdown{border:1px solid #e2e8f0;border-radius:8px;cursor:pointer;font-size:.95rem;padding:.75rem;width:100%}.modal-actions{display:flex;gap:.75rem;justify-content:flex-end;margin-top:1.5rem}.loading{color:#64748b;padding:3rem;text-align:center}.spinner{animation:spin 1s linear infinite;border:3px solid #f1f5f9;border-radius:50%;border-top-color:#6366f1;height:40px;margin:0 auto 1rem;width:40px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.text-green{color:#22c55e}.text-red{color:#ef4444}.text-gray{color:#64748b}.font-semibold{font-weight:600}@media (max-width:768px){.navbar{padding:0 1rem}.navbar-links{display:none}.main-content{padding:1rem}.page-header{flex-direction:column;gap:1rem}.page-actions{justify-content:flex-start;width:100%}}
/*# sourceMappingURL=main.40639075.css.map*/