:root{--primary: #0ea5e9;--primary-dark: #0284c7;--bg-color: #f0f4f8;--card-radius: 10px;--nav-height: 56px;--nav-bg: #0f172a;--nav-text: #cbd5e1;--nav-hover-bg: rgba(14, 165, 233, .15);--nav-active-bg: #0ea5e9;--nav-dropdown-bg: #1e293b;--border-color: #e2e8f0;--patient-photo-size: 85px}.patient-photo-container{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;margin-bottom:0}.photo-preview-wrapper{position:relative;width:var(--patient-photo-size);height:var(--patient-photo-size);border-radius:50%;border:4px solid #fff;box-shadow:0 4px 12px #00000026;overflow:hidden;background:#f1f5f9;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:transform .2s}.photo-preview-wrapper:hover{transform:scale(1.03)}.photo-preview-wrapper i{font-size:40px;color:#cbd5e1}.photo-preview-wrapper img{width:100%;height:100%;object-fit:cover}.photo-actions{display:flex;gap:4px}.btn-photo{padding:2px 8px!important;font-size:10px!important;border-radius:15px!important}#camera-video{width:100%;max-width:480px;border-radius:12px;background:#000;transform:scaleX(-1)}.profile-header{background:linear-gradient(135deg,#0ea5e9,#6366f1);color:#fff;padding:30px 20px;border-radius:12px 12px 0 0;position:relative}.profile-img-wrapper{width:120px;height:120px;border-radius:50%;border:5px solid rgba(255,255,255,.2);overflow:hidden;background:#f1f5f9;display:flex;align-items:center;justify-content:center;margin:0 auto 15px;box-shadow:0 4px 15px #0000001a}.profile-img-wrapper img{width:100%;height:100%;object-fit:cover}.profile-info-card{border:none;border-radius:12px;box-shadow:0 2px 8px #0000000d;transition:transform .2s}.profile-info-card:hover{transform:translateY(-2px)}.profile-label{font-size:11px;text-transform:uppercase;color:#64748b;font-weight:700;margin-bottom:4px}.profile-value{font-size:14px;font-weight:600;color:#1e293b}*{box-sizing:border-box}body,h1,h2,h3,h4,h5,h6,p,label,input,select,textarea,button{font-family:Noto Sans Lao,sans-serif!important}body{background-color:var(--bg-color);color:#334155;font-size:13px!important;overflow-x:hidden;margin:0;padding-top:var(--nav-height)}.his-topnav{position:fixed;top:0;left:0;right:0;height:var(--nav-height);background:var(--nav-bg);display:flex;align-items:center;z-index:1030;padding:0 16px;gap:4px;box-shadow:0 2px 8px #00000040}.his-brand{display:flex;align-items:center;gap:8px;color:#fff;font-weight:800;font-size:15px;padding:0 12px 0 0;border-right:1px solid rgba(255,255,255,.1);margin-right:8px;white-space:nowrap;flex-shrink:0}.his-brand i{color:#38bdf8;font-size:18px}.his-nav-items{display:flex;align-items:center;flex:1;gap:2px;overflow:visible}.his-nav-link{display:flex;align-items:center;gap:6px;padding:6px 12px;border-radius:6px;color:var(--nav-text)!important;text-decoration:none!important;font-size:12.5px;font-weight:500;white-space:nowrap;transition:all .18s;cursor:pointer}.his-nav-link:hover{background:var(--nav-hover-bg);color:#fff!important}.his-nav-link.active{background:var(--nav-active-bg);color:#fff!important;box-shadow:0 2px 6px #0ea5e966}.his-nav-link i{font-size:13px;width:14px;text-align:center;flex-shrink:0}.his-chevron{font-size:10px!important;transition:transform .2s}.his-dropdown.open>a .his-chevron{transform:rotate(180deg)}.his-nav-right{display:flex;align-items:center;gap:4px;margin-left:auto;flex-shrink:0}.his-bell-btn{position:relative}.his-bell-badge{position:absolute;top:2px;right:4px;background:#ef4444;color:#fff;font-size:9px;font-weight:700;min-width:16px;height:16px;border-radius:8px;display:flex;align-items:center;justify-content:center;padding:0 3px}.his-avatar{width:28px;height:28px;border-radius:50%;background:var(--primary);display:flex;align-items:center;justify-content:center;color:#fff;font-size:12px;flex-shrink:0}.his-dropdown{position:relative}.his-dropdown-menu{display:none;position:absolute;top:100%;right:0;background:#1e293b;border-radius:10px;min-width:220px;padding:8px 0;box-shadow:0 10px 30px #00000080;z-index:10000;border:1px solid rgba(255,255,255,.12);margin-top:5px}.his-dropdown.open .his-dropdown-menu{display:block!important}.his-dropdown-item{display:flex;align-items:center;padding:8px 16px;color:#fff!important;text-decoration:none!important;font-size:13px;transition:all .15s;white-space:nowrap;border-bottom:1px solid rgba(255,255,255,.05)}.his-dropdown-item:hover{background:#0ea5e940;color:#fff!important}.his-dropdown-item i{width:18px;text-align:center;margin-right:10px;font-size:14px}.his-dropdown-item.active{background:var(--nav-active-bg);color:#fff!important;font-weight:600}.his-dropdown-header{padding:12px 16px;font-size:11px;font-weight:800;color:#cbd5e1;background:#0000004d;text-transform:uppercase;letter-spacing:1px;border-bottom:1px solid rgba(255,255,255,.1)}.his-dropdown-footer{border-top:1px solid rgba(255,255,255,.1);background:#00000026;margin-top:0;padding:4px 0}.his-dropdown-footer a{display:block;padding:10px 16px;color:#38bdf8!important;text-decoration:none!important;font-size:12.5px;text-align:center;font-weight:700}.his-dropdown-footer a:hover{background:#0ea5e91a}.his-hamburger{display:none;background:none;border:none;color:#cbd5e1;font-size:18px;padding:6px 10px;cursor:pointer}@media(max-width:768px){.his-hamburger{display:flex;align-items:center}.his-nav-items{display:none;position:absolute;top:var(--nav-height);left:0;right:0;background:var(--nav-bg);flex-direction:column;align-items:stretch;padding:8px;gap:2px;border-top:1px solid rgba(255,255,255,.08);box-shadow:0 8px 16px #0000004d}.his-nav-items.open{display:flex}.his-nav-items .his-dropdown{width:100%}.his-nav-items .his-dropdown-menu{position:static;display:none;box-shadow:none;border:none;background:#ffffff0a;border-radius:6px;margin:2px 0}.his-nav-items .his-dropdown.open .his-dropdown-menu{display:block}.his-nav-link{width:100%}}.his-content-wrapper{padding:16px 18px;min-height:calc(100vh - var(--nav-height))}.card{border-radius:var(--card-radius);border:none;box-shadow:0 1px 4px #00000014;margin-bottom:16px;background:#fff}.card-header{background-color:#fff;border-bottom:1px solid var(--border-color);border-radius:var(--card-radius) var(--card-radius) 0 0!important;padding:10px 16px}.card-body{padding:14px 16px}.table{margin-bottom:0;font-size:12.5px}.table th{background-color:#f1f5f9!important;color:#475569;font-weight:600;text-transform:uppercase;letter-spacing:.5px;padding:10px;border-bottom:2px solid var(--border-color)}.table td{padding:8px 10px;vertical-align:middle;border-bottom:1px solid #f1f5f9}.btn{border-radius:6px;font-weight:500;transition:all .2s;padding:6px 12px;font-size:12.5px}.btn-sm{padding:4px 8px;font-size:11.5px}.btn-primary{background-color:var(--primary);border-color:var(--primary);color:#fff}.btn-primary:hover{background-color:var(--primary-dark);border-color:var(--primary-dark)}.form-control,.form-select{border-radius:6px;border:1px solid #cbd5e1;padding:6px 10px;font-size:13px}.form-control:focus,.form-select:focus{border-color:var(--primary);box-shadow:0 0 0 .2rem #0ea5e940}.form-label{font-weight:600;color:#475569;margin-bottom:4px;font-size:12.5px}.required:after{content:" *";color:#ef4444}h3{font-size:1.15rem!important;font-weight:700!important;color:#1e293b;margin-bottom:0!important}h5{font-size:1.05rem!important;font-weight:600!important}h6{font-size:.95rem!important;font-weight:600!important;margin-bottom:8px!important}.badge{padding:5px 8px;font-weight:600;letter-spacing:.3px;font-size:11px}.small-box{border-radius:10px;overflow:hidden;margin-bottom:15px}.small-box .inner{padding:15px}.select2-container .select2-selection--single{height:36px!important;border:1px solid #cbd5e1!important;border-radius:6px!important}.select2-container--default .select2-selection--single .select2-selection__rendered{line-height:34px!important;font-size:13px;color:#334155!important}.select2-container--default .select2-selection--single .select2-selection__arrow{height:34px!important}.modal-content{border-radius:12px;overflow:hidden;border:none}.modal-header{border-bottom:1px solid var(--border-color);padding:12px 20px}.modal-footer{border-top:1px solid var(--border-color);padding:12px 20px}.login-page{background:linear-gradient(135deg,#f8fafc,#e0f2fe);height:100vh;display:flex;align-items:center;justify-content:center;margin-top:calc(var(--nav-height) * -1);padding-top:0}.login-box{width:400px;max-width:90%}.login-box .card{border-radius:15px;box-shadow:0 10px 25px #0000001a!important}#loading{position:fixed;top:0;left:0;width:100%;height:100%;background:#fffc;z-index:99999;display:flex;justify-content:center;align-items:center;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.print-container{display:none!important}.print-active{display:block!important}@media print{body>*:not(#partial-prints):not(.print-active){display:none!important}#partial-prints{display:block!important}.print-active{display:block!important;position:absolute!important;left:0!important;top:0!important;width:100%!important;height:auto!important;margin:0!important;padding:0!important}.print-active *{visibility:visible!important}.print-container:not(.print-active){display:none!important}body{background-color:#fff!important;margin:0!important;padding:0!important;font-size:14px!important}@page{size:A4 portrait;margin:10mm}.opd2-row{height:8mm}.opd2-row td{height:8mm;padding:0 5px}.opd2-dx-row td{height:8mm;padding:2px 5px;font-size:12px}.opd2-followup-row{height:6.5mm}.opd2-followup-row td{height:6.5mm;padding:0 5px}.opd-table-stretch thead th{background-color:#e0f2fe!important;font-weight:700;padding:3px 5px;-webkit-print-color-adjust:exact!important;print-color-adjust:exact!important}}.opd-page{width:100%;padding:5mm;box-sizing:border-box;page-break-after:always;background:#fff}.opd-page:last-child{page-break-after:avoid}.opd-header-img{width:100%;max-height:35mm;object-fit:contain;display:block!important;visibility:visible!important;margin-bottom:15px}.opd-footer-img{width:100%;max-height:25mm;object-fit:contain;display:block!important;visibility:visible!important;margin-top:auto}.opd-header-title{text-align:center;font-weight:700;font-size:18px;margin:10px 0 5px}.opd-sub-title{text-align:center;font-size:14px;margin-bottom:15px}.opd-section-title{font-weight:700;font-size:15px;border-bottom:1px solid #000;margin:15px 0 8px;padding-bottom:4px}.opd-table-noborder{width:100%;border-collapse:collapse}.opd-table-noborder td,.opd-table-noborder th{border:none!important;padding:6px 4px;font-size:13px;vertical-align:top}.opd-table-stretch th,.opd-table-stretch td{border:1px solid #333;padding:5px;font-size:12px;vertical-align:top}.patient-card{width:85mm;padding:8px 10px;border:2px solid #0ea5e9;border-radius:8px;background:#fff;display:flex!important;align-items:center;gap:10px;margin:10mm auto 0}.patient-card-info{flex:1}.patient-card-qr{flex:0 0 auto;text-align:center}#vac-print-area>div{margin:10mm auto 0!important}.swal2-popup{font-family:Noto Sans Lao,sans-serif!important;border-radius:15px!important}.swal2-title{color:#1e293b!important}.swal2-html-container{color:#334155!important}.swal2-confirm{background-color:var(--primary)!important;box-shadow:0 4px 6px #0ea5e933!important}.swal2-cancel{background-color:#f1f5f9!important;color:#334155!important}.swal2-deny{background-color:#f87171!important}.swal2-shown .swal2-container.swal2-backdrop-show{background:#0f172abf!important}@media(min-width:992px){.his-dropdown-menu{min-width:220px}}.dataTables_length select{padding:2px 25px 2px 8px!important;height:auto!important;font-size:12px!important;border-radius:6px!important;margin:0 5px!important;border:1px solid var(--border-color)!important}.dataTables_filter input{padding:5px 12px!important;border-radius:6px!important;border:1px solid var(--border-color)!important;font-size:13px!important}.dataTables_info,.dataTables_paginate{font-size:12px!important;margin-top:10px!important}.table th,.table td{white-space:nowrap}.table-responsive{overflow-x:auto;max-width:100%}.btn{border-radius:8px!important;font-weight:600!important;transition:all .2s cubic-bezier(.4,0,.2,1)!important;padding:8px 18px!important;font-size:13px!important;border:none!important;box-shadow:0 2px 4px #00000014!important}.btn-primary{background:linear-gradient(135deg,#0ea5e9,#0284c7)!important;color:#fff!important;box-shadow:0 4px 12px #0ea5e94d!important}.btn-primary:hover{transform:translateY(-1px)!important;box-shadow:0 6px 15px #0ea5e973!important;filter:brightness(1.1)}.btn-success{background:linear-gradient(135deg,#10b981,#059669)!important;color:#fff!important;box-shadow:0 4px 12px #10b9814d!important}.btn-success:hover{transform:translateY(-1px)!important;box-shadow:0 6px 15px #10b98173!important;filter:brightness(1.1)}.btn-danger{background:linear-gradient(135deg,#f43f5e,#e11d48)!important;color:#fff!important;box-shadow:0 4px 12px #f43f5e4d!important}.btn-danger:hover{transform:translateY(-1px)!important;box-shadow:0 6px 15px #f43f5e73!important;filter:brightness(1.1)}.btn-sm{padding:5px 12px!important;font-size:12px!important}.timeline-container{position:relative;padding-left:20px}.timeline-container:before{content:"";position:absolute;left:4.5px;top:10px;bottom:10px;width:2px;background:#cbd5e1}.timeline-item{position:relative;padding-bottom:30px}.timeline-item:last-child{padding-bottom:0}.timeline-dot{position:absolute;left:-20px;top:5px;width:11px;height:11px;border-radius:50%;background:#fff;border:2px solid var(--primary);z-index:1}.timeline-date{font-size:11px;font-weight:700;color:#64748b;margin-bottom:5px;text-transform:uppercase}.timeline-card{background:#fff;border-radius:12px;padding:16px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;border-left:4px solid var(--primary);transition:transform .2s}.timeline-card:hover{transform:translate(5px)}.timeline-title{font-weight:700;font-size:14px;color:#1e293b;margin-bottom:8px;display:flex;justify-content:space-between;align-items:center}.timeline-body{font-size:13px;color:#475569}.timeline-tag{display:inline-block;padding:2px 8px;border-radius:12px;font-size:10px;font-weight:700;margin-right:5px;margin-bottom:5px}.timeline-tag-med{background:#dcfce7;color:#166534;border:1px solid #bbf7d0}.timeline-tag-lab{background:#dbeafe;color:#1e40af;border:1px solid #bfdbfe}.timeline-tag-dx{background:#fef2f2;color:#991b1b;border:1px solid #fecaca}.timeline-tag-vitals{background:#fff7ed;color:#9a3412;border:1px solid #ffedd5}.card{transition:transform .2s ease,box-shadow .2s ease;border:1px solid rgba(0,0,0,.05)}.card:hover{transform:translateY(-2px);box-shadow:0 10px 25px -5px #0000001a}.card-header.bg-white{background:#fff!important;border-bottom:1px solid rgba(0,0,0,.03)!important}#dashboardPrintArea canvas{max-width:100%!important}
