*,:after,:before{box-sizing:border-box;margin:0;padding:0}:root{--navy:#0f172a;--slate-800:#1e293b;--slate-700:#334155;--slate-600:#475569;--slate-500:#64748b;--slate-400:#94a3b8;--slate-200:#e2e8f0;--slate-100:#f1f5f9;--slate-50:#f8fafc;--white:#fff;--primary:#4f46e5;--primary-l:#eef2ff;--green:#16a34a;--green-l:#dcfce7;--red:#dc2626;--red-l:#fee2e2;--amber:#d97706;--amber-l:#fef3c7;--blue:#2563eb;--blue-l:#dbeafe;--teal:#0d9488;--teal-l:#ccfbf1;--purple:#7c3aed;--purple-l:#f5f3ff;--sidebar-w:220px;--topbar-h:52px;--radius:8px;--radius-lg:12px;--shadow-sm:0 1px 3px #0f172a0f,0 1px 2px #0f172a0a;--shadow:0 4px 16px #0f172a14,0 1px 3px #0f172a0f;--shadow-lg:0 8px 32px #0f172a1f,0 2px 8px #0f172a14;background:#f8fafc;background:var(--slate-50);color:#0f172a;color:var(--navy);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Inter,sans-serif;font-size:14px;line-height:1.5}body{-webkit-font-smoothing:antialiased}.app-shell{background:#f8fafc;background:var(--slate-50);display:flex;min-height:100vh}.main-content{flex:1 1;margin-left:220px;margin-left:var(--sidebar-w);min-width:0}.main-content,.sidebar{display:flex;flex-direction:column}.sidebar{background:#fff;background:var(--white);border-right:1px solid #e2e8f0;border-right:1px solid var(--slate-200);bottom:0;left:0;overflow:hidden;position:fixed;top:0;width:220px;width:var(--sidebar-w);z-index:100}.sidebar-logo{align-items:center;border-bottom:1px solid #f1f5f9;border-bottom:1px solid var(--slate-100);display:flex;flex-shrink:0;gap:10px;padding:16px 14px 12px}.sidebar-nav{flex:1 1;overflow-y:auto;padding:10px 8px}.nav-item{align-items:center;background:#0000;border:none;border-radius:8px;border-radius:var(--radius);color:#475569;color:var(--slate-600);cursor:pointer;display:flex;font-size:13px;font-weight:500;gap:9px;margin-bottom:2px;padding:9px 10px;text-align:left;transition:all .15s;width:100%}.nav-item svg{flex-shrink:0;height:16px;width:16px}.nav-item:hover{background:#f1f5f9;background:var(--slate-100);color:#0f172a;color:var(--navy)}.nav-item.active{background:#eef2ff;background:var(--primary-l);color:#4f46e5;color:var(--primary);font-weight:700}.sidebar-footer{border-top:1px solid #f1f5f9;border-top:1px solid var(--slate-100);flex-shrink:0;padding:12px 10px}.role-badge{align-items:center;display:flex;gap:8px}.role-info{flex:1 1;min-width:0;overflow:hidden}.topbar{align-items:center;background:#fff;background:var(--white);border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--slate-200);display:flex;flex-shrink:0;gap:16px;height:52px;height:var(--topbar-h);padding:0 24px;position:-webkit-sticky;position:sticky;top:0;z-index:50}.page-body{flex:1 1;overflow-y:auto;padding:24px}.card{background:#fff;background:var(--white);border:1px solid #e2e8f0;border:1px solid var(--slate-200);border-radius:12px;border-radius:var(--radius-lg);box-shadow:0 1px 3px #0f172a0f,0 1px 2px #0f172a0a;box-shadow:var(--shadow-sm);margin-bottom:16px}.card-header{align-items:center;border-bottom:1px solid #f1f5f9;border-bottom:1px solid var(--slate-100);display:flex;flex-wrap:wrap;gap:10px;justify-content:space-between;padding:14px 20px}.card-body{padding:16px 20px}.stat-grid{grid-gap:14px;display:grid;gap:14px;grid-template-columns:repeat(4,1fr);margin-bottom:20px}@media (max-width:900px){.stat-grid{grid-template-columns:repeat(2,1fr)}}.stat-card{background:#fff;background:var(--white);border:1px solid #e2e8f0;border:1px solid var(--slate-200);border-radius:12px;border-radius:var(--radius-lg);box-shadow:0 1px 3px #0f172a0f,0 1px 2px #0f172a0a;box-shadow:var(--shadow-sm);padding:18px 20px}.stat-label{color:#64748b;color:var(--slate-500);font-size:11px;font-weight:700;letter-spacing:.5px;margin-bottom:6px;text-transform:uppercase}.stat-value{font-size:28px;font-weight:800;line-height:1;margin-bottom:4px}.stat-sub{color:#94a3b8;color:var(--slate-400);font-size:12px}.btn{align-items:center;border:none;border-radius:8px;border-radius:var(--radius);cursor:pointer;display:inline-flex;font-size:13px;font-weight:600;gap:6px;padding:8px 16px;transition:all .15s;white-space:nowrap}.btn:disabled{cursor:not-allowed;opacity:.55}.btn-primary{background:#4f46e5;background:var(--primary);color:#fff}.btn-primary:hover:not(:disabled){background:#3730a3}.btn-secondary{background:#f1f5f9;background:var(--slate-100);border:1px solid #e2e8f0;border:1px solid var(--slate-200);color:#334155;color:var(--slate-700)}.btn-secondary:hover:not(:disabled){background:#e2e8f0;background:var(--slate-200)}.btn-danger{background:#fef2f2;border:1px solid #fecaca;color:#dc2626}.btn-danger:hover:not(:disabled){background:#dc2626;border-color:#dc2626;color:#fff}.btn-ghost{background:#0000;color:#475569;color:var(--slate-600)}.btn-ghost:hover:not(:disabled){background:#f1f5f9;background:var(--slate-100)}.btn-sm{font-size:12px;padding:5px 11px}.btn-xs{font-size:11px;padding:3px 8px}.input{background:#fff;background:var(--white);border:1px solid #e2e8f0;border:1px solid var(--slate-200);border-radius:8px;border-radius:var(--radius);color:#0f172a;color:var(--navy);font-size:13px;outline:none;padding:8px 12px;transition:border-color .15s,box-shadow .15s;width:100%}.input:focus{border-color:#4f46e5;border-color:var(--primary);box-shadow:0 0 0 3px #4f46e51a}.input::placeholder{color:#94a3b8;color:var(--slate-400)}select.input{cursor:pointer}.form-group{margin-bottom:14px}.form-label{color:#475569;color:var(--slate-600);display:block;font-size:12px;font-weight:600;margin-bottom:5px}.badge{align-items:center;border-radius:99px;display:inline-flex;font-size:11px;font-weight:700;padding:2px 8px;white-space:nowrap}.badge-green{background:#dcfce7;background:var(--green-l);color:#16a34a;color:var(--green)}.badge-red{background:#fee2e2;background:var(--red-l);color:#dc2626;color:var(--red)}.badge-blue{background:#dbeafe;background:var(--blue-l);color:#2563eb;color:var(--blue)}.badge-purple{background:#f5f3ff;background:var(--purple-l);color:#7c3aed;color:var(--purple)}.badge-teal{background:#ccfbf1;background:var(--teal-l);color:#0d9488;color:var(--teal)}.badge-amber{background:#fef3c7;background:var(--amber-l);color:#d97706;color:var(--amber)}.badge-gray{background:#f1f5f9;background:var(--slate-100);color:#64748b;color:var(--slate-500)}.alert{align-items:center;border-radius:8px;border-radius:var(--radius);display:flex;font-size:13px;gap:8px;margin-bottom:12px;padding:10px 14px}.alert-red{background:#fee2e2;background:var(--red-l);border-left:3px solid #dc2626;border-left:3px solid var(--red);color:#991b1b}.alert-green{background:#dcfce7;background:var(--green-l);border-left:3px solid #16a34a;border-left:3px solid var(--green);color:#166534}.alert-amber{background:#fef3c7;background:var(--amber-l);border-left:3px solid #d97706;border-left:3px solid var(--amber);color:#92400e}.alert-blue{background:#dbeafe;background:var(--blue-l);border-left:3px solid #2563eb;border-left:3px solid var(--blue);color:#1d4ed8}.patient-row{align-items:center;border-bottom:1px solid #f1f5f9;border-bottom:1px solid var(--slate-100);cursor:pointer;display:flex;gap:12px;padding:12px 20px;transition:background .12s}.patient-row:last-child{border-bottom:none}.patient-row:hover{background:#f8fafc;background:var(--slate-50)}.patient-avatar{background:#eef2ff;background:var(--primary-l);border-radius:10px;color:#4f46e5;color:var(--primary);flex-shrink:0;font-size:14px;font-weight:800;height:36px;justify-content:center;width:36px}.patient-avatar,.value-row{align-items:center;display:flex}.value-row{border-bottom:1px solid #f1f5f9;border-bottom:1px solid var(--slate-100);gap:10px;padding:9px 0}.value-row:last-child{border-bottom:none}.value-name{color:#334155;color:var(--slate-700);flex:1 1;font-size:13px;font-weight:600;min-width:0}.value-result{font-size:14px;font-weight:800;min-width:72px;text-align:center}.value-normal{color:#16a34a;color:var(--green)}.value-abnormal{color:#dc2626;color:var(--red)}.value-unit{font-size:12px;min-width:48px}.value-ref,.value-unit{color:#94a3b8;color:var(--slate-400)}.value-ref{font-size:11px;min-width:70px;white-space:nowrap}.pdf-mock{background:#fff;border:1px solid #e0e0e0;color:#222;font-family:Courier New,monospace;font-size:10px;padding:20px 18px}.pdf-header{border-bottom:2px solid #1a237e;margin-bottom:12px;padding-bottom:10px}.pdf-title{color:#1a237e;font-size:14px;font-weight:900;letter-spacing:1.5px}.pdf-subtitle{color:#555;font-size:9px;margin-top:2px}.pdf-table{border-collapse:collapse;margin-top:10px;width:100%}.pdf-table th{background:#f0f0f0;border:1px solid #ddd;font-size:9px;font-weight:700;padding:5px 7px;text-align:left}.pdf-table td{border:1px solid #eee;padding:5px 7px}.pdf-normal{color:#16a34a;font-weight:700}.pdf-abnormal{color:#dc2626;font-weight:700}.search-wrap{align-items:center;display:flex;position:relative}.search-wrap svg{color:#94a3b8;color:var(--slate-400);height:15px;left:12px;pointer-events:none;position:absolute;width:15px}.search-wrap .input{padding-left:38px}.tabs{border-bottom:2px solid #e2e8f0;border-bottom:2px solid var(--slate-200);display:flex;gap:2px;margin-bottom:20px}.tab{background:#0000;border:none;border-bottom:2px solid #0000;color:#64748b;color:var(--slate-500);cursor:pointer;font-size:13px;font-weight:600;margin-bottom:-2px;padding:9px 18px;transition:all .15s}.tab.active,.tab:hover{color:#4f46e5;color:var(--primary)}.tab.active{border-bottom-color:#4f46e5;border-bottom-color:var(--primary)}.modal-overlay{align-items:center;background:#0f172a73;display:flex;inset:0;justify-content:center;padding:20px;position:fixed;z-index:1000}.modal{background:#fff;background:var(--white);border-radius:12px;border-radius:var(--radius-lg);box-shadow:0 8px 32px #0f172a1f,0 2px 8px #0f172a14;box-shadow:var(--shadow-lg);display:flex;flex-direction:column;max-height:90vh;max-width:560px;overflow:hidden;width:100%}.modal-header{align-items:center;border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--slate-200);display:flex;flex-shrink:0;justify-content:space-between;padding:16px 20px}.modal-body{flex:1 1;overflow-y:auto;padding:20px}.modal-footer{border-top:1px solid #e2e8f0;border-top:1px solid var(--slate-200);display:flex;flex-shrink:0;gap:8px;justify-content:flex-end;padding:14px 20px}.empty-state{align-items:center;color:#94a3b8;color:var(--slate-400);display:flex;flex-direction:column;justify-content:center;padding:48px 24px;text-align:center}.empty-state svg{height:40px;margin-bottom:14px;opacity:.4;width:40px}.empty-state h3{color:#475569;color:var(--slate-600);font-size:15px;font-weight:700;margin-bottom:6px}.empty-state p{font-size:13px;max-width:320px}.login-page{align-items:center;background:linear-gradient(135deg,#0f172a,#1e293b);display:flex;justify-content:center;min-height:100vh;padding:20px}.login-card{background:#fff;background:var(--white);border-radius:16px;box-shadow:0 24px 64px #0000004d;max-width:400px;padding:36px 40px;width:100%}.trend-summary-bar{background:#f8fafc;background:var(--slate-50);border:1px solid #e2e8f0;border:1px solid var(--slate-200);border-radius:10px;display:flex;flex-wrap:wrap;gap:20px;margin-bottom:16px;padding:14px 18px}.trend-summary-item{display:flex;flex-direction:column}.trend-summary-label{color:#94a3b8;color:var(--slate-400);font-size:10px;font-weight:700;letter-spacing:.5px;margin-bottom:3px;text-transform:uppercase}.trend-summary-value{font-size:20px;font-weight:800;line-height:1.1}.trend-summary-sub{color:#94a3b8;color:var(--slate-400);font-size:11px;margin-top:2px}.trend-divider{align-self:stretch;background:#e2e8f0;background:var(--slate-200);margin:0 4px;width:1px}.history-item{background:#f8fafc;background:var(--slate-50);border:1px solid #e2e8f0;border:1px solid var(--slate-200);border-radius:8px;margin:4px 8px;padding:10px 12px;position:relative}.history-item.is-latest{background:#f0f4ff;border-color:#4f46e540}.back-btn{align-items:center;background:#0000;border:none;color:#475569;color:var(--slate-600);cursor:pointer;display:inline-flex;font-size:13px;font-weight:600;gap:6px;padding:4px 0}.back-btn:hover{color:#4f46e5;color:var(--primary)}.type-strip{align-items:center;border-radius:99px;display:inline-flex;font-size:11px;font-weight:700;gap:5px;padding:3px 10px}.type-hematology{background:#dbeafe;background:var(--blue-l);color:#2563eb;color:var(--blue)}.type-hormone{background:#f5f3ff;background:var(--purple-l);color:#7c3aed;color:var(--purple)}.type-immunology{background:#ccfbf1;background:var(--teal-l);color:#0d9488;color:var(--teal)}.type-biochemical{background:#dcfce7;background:var(--green-l);color:#16a34a;color:var(--green)}.type-other{background:#f1f5f9;background:var(--slate-100);color:#64748b;color:var(--slate-500)}.imaging-viewer{align-items:center;background:#0f172a;border-radius:12px;border-radius:var(--radius-lg);display:flex;justify-content:center;min-height:360px;overflow:hidden;position:relative}.imaging-viewer img{cursor:zoom-in;display:block;max-height:520px;max-width:100%;object-fit:contain}::-webkit-scrollbar{height:5px;width:5px}::-webkit-scrollbar-track{background:#0000}::-webkit-scrollbar-thumb{background:#e2e8f0;background:var(--slate-200);border-radius:99px}::-webkit-scrollbar-thumb:hover{background:#cbd5e1;background:var(--slate-300,#cbd5e1)}.text-muted{color:#94a3b8;color:var(--slate-400)}.text-sm{font-size:12px}.text-xs{font-size:11px}.fw-700{font-weight:700}.fw-800{font-weight:800}.mt-auto{margin-top:auto}.divider{border:none;border-top:1px solid #f1f5f9;border-top:1px solid var(--slate-100);margin:12px 0}.upload-area{background:#fafbfc;border:2px dashed #cbd5e1;border-radius:12px;cursor:pointer;padding:32px 20px;text-align:center;transition:all .2s;-webkit-user-select:none;user-select:none}.upload-area:hover{background:#f5f3ff;border-color:#4f46e5}.upload-area.dragging{background:#eef2ff;border-color:#4f46e5}.upload-area *{cursor:pointer}.flowsheet-table{border:2px solid #94a3b8;border-collapse:collapse;width:100%}.flowsheet-table thead tr{background:#e2e8f0}.flowsheet-table th{color:#334155;font-size:11px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;white-space:nowrap}.flowsheet-table td,.flowsheet-table th{border:1px solid #94a3b8;padding:10px 18px}.flowsheet-table td{font-size:13px}.flowsheet-table tbody tr:nth-child(2n){background:#f1f5f9}.flowsheet-table tbody tr:nth-child(odd){background:#fff}.flowsheet-table tbody tr:hover{background:#eff6ff}.flowsheet-table tbody tr.highlighted{background:#dbeafe;outline:2px solid #2563eb}
/*# sourceMappingURL=main.16eac8a0.css.map*/