@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";.notification-bell-container{position:relative}.notification-bell-btn{background:none;border:none;color:var(--text-dark);font-size:1.2rem;cursor:pointer;position:relative;padding:.5rem;transition:color .2s}.notification-bell-btn:hover,.notification-bell-btn.active{color:var(--primary-color)}.notification-badge{position:absolute;top:0;right:0;background-color:var(--accent-color);color:#fff;font-size:.7rem;padding:2px 5px;border-radius:10px;min-width:18px;text-align:center;border:2px solid var(--card-bg)}.notification-badge.pulse{animation:pulse-red 2s infinite}@keyframes pulse-red{0%{transform:scale(.95);box-shadow:0 0 #ef4444b3}70%{transform:scale(1);box-shadow:0 0 0 6px #ef444400}to{transform:scale(.95);box-shadow:0 0 #ef444400}}.notification-dropdown{position:absolute;top:100%;right:0;width:350px;background-color:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--border-radius);box-shadow:var(--shadow);z-index:1000;display:flex;flex-direction:column;max-height:500px;margin-top:10px}.notification-header{padding:1rem;border-bottom:1px solid var(--border-color)}.header-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.header-top h4{margin:0;color:var(--text-dark);font-size:1rem}.header-actions{display:flex;gap:10px}.header-action-btn{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:.8rem;padding:0}.header-action-btn:hover{color:var(--primary-color)}.notification-filters{display:flex;gap:5px}.filter-btn{background:none;border:1px solid var(--border-color);border-radius:12px;padding:2px 8px;font-size:.75rem;color:var(--text-muted);cursor:pointer;transition:all .2s}.filter-btn:hover{background-color:var(--body-bg)}.filter-btn.active{background-color:var(--primary-color);color:#fff;border-color:var(--primary-color)}.notification-list{overflow-y:auto;flex:1}.no-notifications{padding:2rem;text-align:center;color:var(--text-muted)}.no-notifications i{font-size:2rem;margin-bottom:.5rem;opacity:.5}.notification-item{padding:1rem;border-bottom:1px solid var(--border-color);display:flex;gap:1rem;position:relative;cursor:pointer;transition:background-color .2s}.notification-item:last-child{border-bottom:none}.notification-item:hover{background-color:var(--body-bg)}.notification-item.unread{background-color:#3b82f60d}:root[data-theme=dark] .notification-item.unread{background-color:#3b82f626}.notification-icon{font-size:1.2rem;margin-top:2px}.notification-item.critical .notification-icon{color:var(--accent-color)}.notification-item.warning .notification-icon{color:var(--warning-color)}.notification-item.success .notification-icon{color:var(--success-color)}.notification-item.info .notification-icon{color:var(--info-color)}.notification-item.error .notification-icon{color:var(--accent-color)}.notification-content{flex:1}.notification-title{font-weight:600;font-size:.9rem;color:var(--text-dark);margin-bottom:2px}.notification-message{font-size:.85rem;color:var(--text-muted);margin-bottom:4px}.notification-time{font-size:.75rem;color:var(--text-muted);opacity:.8}.notification-dismiss{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:1.2rem;line-height:1;padding:0;opacity:0;transition:opacity .2s;position:absolute;top:5px;right:5px}.notification-item:hover .notification-dismiss{opacity:1}.notification-dismiss:hover{color:var(--accent-color)}@media (max-width: 480px){.notification-dropdown{position:fixed;top:60px;left:0;right:0;width:100%;margin-top:0;border-radius:0;border-left:none;border-right:none;max-height:calc(100vh - 60px)}}.sidebar{background-color:var(--sidebar-bg);color:var(--text-light);display:flex;flex-direction:column;width:100%;height:100%;position:relative;transition:width var(--transition-speed) ease-in-out;box-shadow:0 0 20px #0003}.sidebar-header{display:flex;align-items:center;gap:.75rem;padding:1rem;height:var(--header-height);border-bottom:1px solid rgba(255,255,255,.1)}.sidebar-logo{height:36px;width:36px;min-width:36px;object-fit:contain;flex-shrink:0;transition:transform .3s ease}.sidebar-title{margin:0;font-size:1.25rem;color:var(--text-light);font-weight:600;white-space:nowrap;opacity:1;transition:opacity .3s ease}.sidebar-menu{padding:1rem;flex-grow:1;overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--primary-color) transparent}.menu-separator{height:1px;background-color:#ffffff1a;margin:1rem 0}.menu-item{display:flex;align-items:center;padding:.9rem 1rem;margin-bottom:.5rem;border-radius:8px;color:var(--text-light);text-decoration:none;transition:background-color .2s ease,color .2s ease;white-space:nowrap}.menu-item i{margin-right:1rem;width:24px;text-align:center;font-size:1.2rem;transition:margin .3s ease}.menu-item:hover{background-color:#ffffff1a}.menu-item.active{background-color:var(--primary-color);color:var(--text-light);font-weight:500}.logout-item{cursor:pointer;margin-top:auto}.lock-btn{position:absolute;top:50%;right:-18px;transform:translateY(-50%);background:var(--primary-color);border:2px solid var(--background-color);color:var(--text-light);width:36px;height:36px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:1100;opacity:0;transition:opacity .3s ease,transform .3s ease,background-color .3s ease}.sidebar-container:hover .lock-btn{opacity:1}.lock-btn:hover{background-color:var(--primary-hover);transform:translateY(-50%) scale(1.1)}.sidebar.collapsed .sidebar-title,.sidebar.collapsed .menu-item span,.sidebar.collapsed .menu-separator{opacity:0;width:0;visibility:hidden;margin:0;transition:opacity .2s ease,visibility .2s ease,width .2s ease,margin .2s ease}.sidebar.collapsed .sidebar-header{justify-content:center}.sidebar.collapsed .sidebar-logo{transform:scale(1.1)}.sidebar.collapsed .menu-item i{margin-right:0}@media (max-width: 992px){.lock-btn{display:none}}:root{--sidebar-width: 260px;--sidebar-collapsed-width: 80px;--header-height: 60px;--transition-speed: .3s}.app-layout{display:grid;grid-template-rows:var(--header-height) 1fr;height:100vh;overflow:hidden}.app-header{grid-area:header;display:flex;align-items:center;justify-content:space-between;padding:0 2rem;background-color:var(--card-bg);box-shadow:var(--shadow);border-bottom:1px solid var(--border-color);z-index:500;position:relative}.user-profile{display:none;align-items:center;gap:.75rem}.user-info{display:flex;flex-direction:column}.user-name{font-weight:600;color:var(--text-dark)}.user-role{font-size:.8rem;color:var(--text-muted)}.header-content{display:flex;justify-content:flex-end;align-items:center;width:100%}.sidebar-container{grid-area:sidebar;height:100%;z-index:10;position:relative}.main-content{grid-area:content;overflow-y:auto;padding:2rem;background-color:var(--body-bg);z-index:5;position:relative}@media (min-width: 993px){.app-layout{grid-template-columns:var(--sidebar-width) 1fr;grid-template-rows:var(--header-height) 1fr;grid-template-areas:"sidebar header" "sidebar content";transition:grid-template-columns var(--transition-speed) ease-in-out}.user-profile{display:flex}.header-content{width:auto}.sidebar-container{overflow:visible}.menu-toggle{display:none}.app-layout.sidebar-collapsed{grid-template-columns:var(--sidebar-collapsed-width) 1fr}.sidebar-overlay{display:none}}@media (max-width: 992px){.app-layout{grid-template-columns:1fr;grid-template-areas:"header" "content"}.app-header{padding:0 1rem;justify-content:space-between}.menu-toggle{display:block;background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--text-dark);padding:0}.sidebar-container{overflow:hidden;position:fixed;top:0;left:0;height:100vh;width:var(--sidebar-width);transform:translate(-100%);transition:transform var(--transition-speed) ease;z-index:1000}.sidebar-container.open{transform:translate(0)}.sidebar-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#00000080;z-index:999;opacity:0;visibility:hidden;transition:opacity var(--transition-speed) ease}.sidebar-overlay.active{opacity:1;visibility:visible}}.page-container{display:flex;justify-content:center;align-items:center;min-height:100vh;width:100%;padding:1rem;background-color:#31363f}.content-wrapper{display:flex;width:100%;max-width:1100px;z-index:1}.form-panel{display:flex;justify-content:center;align-items:center;width:100%}.background-panel{display:none}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.login-card{background-color:var(--card-bg);border-radius:var(--border-radius);box-shadow:var(--shadow);padding:2.5rem 2rem;width:100%;max-width:400px;text-align:center;color:var(--text-dark);animation:fadeIn .8s ease-out forwards}.login-header{margin-bottom:2rem}.login-logo{max-width:100px;height:auto;margin-bottom:1rem}.login-header h2{font-size:1rem;margin-bottom:.5rem;color:var(--primary-color)}.login-header p{color:var(--text-muted);font-size:.9rem}.login-body{padding:0 .5rem}@media (min-width: 1024px){.content-wrapper{height:90vh;max-height:700px;border-radius:1rem;box-shadow:0 10px 40px #0006;overflow:hidden}.form-panel{width:50%;background-color:var(--card-bg)}.background-panel{display:block;width:50%;background-image:url(/assets/photo-1579165466949-518dd72a9c14-BGpFa5ld.png);background-size:cover;background-position:center}.login-card{box-shadow:none;background-color:transparent;color:var(--text-dark)}}@media (max-width: 1023px){.page-container{background-image:url(/assets/photo-1579165466949-518dd72a9c14-BGpFa5ld.png);background-size:cover;background-position:center;position:relative}.page-container:before{content:"";position:absolute;inset:0;background-color:#0009;z-index:0}.login-card{background-color:#222831e6;color:#eee;max-width:90%}.login-header h2,.login-header p{color:#eee}}:root{--primary-color: #3b82f6;--primary-hover: #2563eb;--secondary-color: #6c7580;--accent-color: #ef4444;--success-color: #10b981;--warning-color: #f59e0b;--info-color: #0ea5e9;--body-bg: #f4f7f6;--card-bg: #ffffff;--sidebar-bg: #2c3e50;--text-dark: #1f2937;--text-light: #f9fafb;--text-muted: #6b7280;--border-color: #e5e7eb;--border-radius: .5rem;--shadow: 0 2px 4px rgba(0, 0, 0, .1);--transition: all .2s ease-in-out;--sidebar-width: 260px;--sidebar-collapsed-width: 80px;--header-height: 60px}select option{background-color:var(--card-bg);color:var(--text-dark)}.charts-grid{display:grid;grid-template-columns:1fr;gap:1.5rem;margin-bottom:2rem}.chart-card{background:var(--card-bg);padding:1.5rem;border-radius:8px;border:1px solid var(--border-color)}.chart-card h3{text-align:center;margin-top:0;margin-bottom:1.5rem;font-size:1.25rem;color:var(--text-dark)}@media (min-width: 992px){.charts-grid{grid-template-columns:1fr 1fr}}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;color:var(--text-color-secondary, #4a5568)}.loading-spinner{width:50px;height:50px;border-radius:50%;display:inline-block;border-top:3px solid var(--primary-color, #4299e1);border-right:3px solid transparent;box-sizing:border-box;animation:spin 1s linear infinite;margin-bottom:1rem}.loading-spinner:after{content:"";box-sizing:border-box;position:absolute;left:0;top:0;width:50px;height:50px;border-radius:50%;border-bottom:3px solid #e53e3e;border-left:3px solid #38a169;animation:spin-alt .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@keyframes spin-alt{to{transform:rotate(-360deg)}}.loading-text{font-size:1rem;font-weight:500}.loading-overlay{position:absolute;inset:0;background-color:var(--overlay-bg, rgba(255, 255, 255, .85));z-index:10;display:flex;align-items:center;justify-content:center;border-radius:8px}.page-title{margin-bottom:2rem}.page-title h2{font-size:2rem;margin:0 0 5px;color:var(--text-dark);font-weight:600}.page-title span{font-size:1rem;color:var(--text-muted)}.stats-container{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-bottom:2rem}.stat-card{background:var(--card-bg);padding:1.5rem;border-radius:var(--border-radius);border:1px solid var(--border-color);display:flex;align-items:center;transition:all .2s ease-in-out;border-left:4px solid transparent}.stat-card:hover{transform:translateY(-3px);box-shadow:var(--shadow)}.stat-icon{margin-right:1rem;font-size:1.75rem}.stat-card:has(.icon-patients){border-left-color:#3b82f6}.stat-card .icon-patients{color:#3b82f6}.stat-card:has(.icon-tests){border-left-color:#10b981}.stat-card .icon-tests{color:#10b981}.stat-card:has(.icon-pending){border-left-color:#f59e0b}.stat-card .icon-pending{color:#f59e0b}.stat-card:has(.icon-critical){border-left-color:#ef4444}.stat-card .icon-critical{color:#ef4444}.stat-card.status-online{border-left-color:#10b981}.stat-card.status-online .icon-status{color:#10b981}.stat-card.status-offline{border-left-color:#6c757d}.stat-card.status-offline .icon-status{color:#6c757d}.stat-text h3{font-size:1.75rem;color:var(--text-dark);margin:0;font-weight:600}.stat-text p{color:var(--text-muted);margin:0;font-size:.9rem}.card h3{margin-top:0;margin-bottom:1rem;font-size:1.25rem}.table-responsive{width:100%;overflow-x:auto}table{width:100%;border-collapse:collapse}th,td{text-align:left;padding:1rem;border-bottom:1px solid var(--border-color);vertical-align:middle}thead th{font-weight:600;color:var(--text-muted);text-transform:uppercase;font-size:.75rem;letter-spacing:.5px}tbody tr:last-child td{border-bottom:none}tbody tr:hover{background-color:#f9fafb}td.patient-avatar-cell{width:1%;padding-right:0}td.patient-name-cell small{display:block;font-weight:400;color:var(--text-muted);font-size:.8rem}.status{padding:.25rem .6rem;border-radius:999px;font-size:.75rem;font-weight:600;text-transform:capitalize;display:inline-block}.status.pending{background-color:#fffbeb;color:#b45309}.status.completed{background-color:#f0fdf4;color:#15803d}.status.critical{background-color:#fef2f2;color:#b91c1c}@media (max-width: 992px){.card table,.modal table{display:none}.patients-cards{display:flex;flex-direction:column;gap:1rem}.patient-card{background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--border-radius);padding:1rem;display:grid;grid-template-columns:auto 1fr;grid-template-rows:auto auto auto;gap:.5rem 1rem;grid-template-areas:"avatar name" "avatar details" "actions actions"}.patient-card:hover{box-shadow:var(--shadow)}.patient-card-avatar{grid-area:avatar;align-self:start}.patient-card-name{grid-area:name;font-weight:600;color:var(--text-dark);margin:0}.patient-card-name small{display:block;font-weight:400;color:var(--text-muted);font-size:.8rem;margin-top:2px}.patient-card-details{grid-area:details;display:flex;flex-direction:column;gap:.5rem}.patient-card-detail{display:flex;justify-content:space-between;font-size:.9rem}.patient-card-detail .label{color:var(--text-muted);font-weight:500}.patient-card-detail .value{color:var(--text-dark)}.patient-card-actions{grid-area:actions;margin-top:.5rem;padding-top:.5rem;border-top:1px solid var(--border-color);text-align:right}.table-responsive .patients-cards{display:flex}}.modal-backdrop{position:fixed;inset:0;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000;padding:20px;animation:fadeIn .3s ease}.modal{background:var(--card-bg);border-radius:var(--border-radius);width:100%;max-width:800px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow);display:flex;flex-direction:column;animation:slideIn .3s ease}@keyframes slideIn{0%{transform:translateY(-20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal.large-modal{max-width:900px}.modal.extra-large-modal{max-width:95%;width:900px}.modal-header{padding:20px 24px;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;align-items:center}.modal-header h3{margin:0;font-size:1.5rem;font-weight:600}.modal-body{padding:24px}.modal-footer{padding:20px 24px;border-top:1px solid var(--border-color);display:flex;justify-content:flex-end;gap:12px;background:#f8f9fa}.close-btn{background:none;border:none;font-size:24px;cursor:pointer;color:var(--text-muted)}.form-section{padding:20px 0;border-bottom:1px solid var(--border-color);margin-bottom:20px}.form-section:last-of-type{border-bottom:none}.form-section h4{margin:0 0 16px;color:var(--text-dark);font-size:1.1rem;display:flex;align-items:center;gap:8px}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:16px}.form-group label{font-weight:500;margin-bottom:6px;font-size:.9rem}.form-group label.required:after{content:" *";color:var(--accent-color)}.form-group input,.form-group select,.form-group textarea{width:100%;padding:12px;border:1px solid var(--border-color);border-radius:6px;font-size:1rem;transition:all .2s ease;background-color:var(--card-bg);color:var(--text-dark)}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #3b82f633}.status{padding:4px 12px;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:capitalize;display:inline-block}.status.completed{background-color:#dcfce7;color:#166534}.status.pending{background-color:#fef3c7;color:#92400e}.status.cancelled{background-color:#fee2e2;color:#991b1b}.action-buttons{display:flex;flex-wrap:wrap;gap:8px}.footer-buttons{display:flex;flex-direction:row;justify-content:center;align-items:flex-start;gap:.25rem}.alert-modal-backdrop{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:2000;animation:fadeIn .3s ease}.alert-modal-content{background:var(--card-bg);border-radius:var(--border-radius);box-shadow:0 10px 30px #0003;width:90%;max-width:450px;text-align:center;padding-top:2rem;border-top:5px solid;animation:popIn .3s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes popIn{0%{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}.alert-modal-content.alert-info{border-top-color:var(--primary-color)}.alert-modal-content.alert-error{border-top-color:var(--accent-color)}.alert-modal-icon{font-size:4rem;margin-bottom:1rem}.alert-modal-content.alert-info .alert-modal-icon{color:var(--primary-color)}.alert-modal-content.alert-error .alert-modal-icon{color:var(--accent-color)}.alert-modal-text{padding:0 1.5rem}.alert-modal-text h3{font-size:1.5rem;font-weight:600;margin-bottom:.5rem;color:var(--text-dark)}.alert-modal-text p{font-size:1rem;color:var(--text-muted);line-height:1.5;margin-bottom:1.5rem}.alert-modal-footer{padding:1.5rem;background-color:var(--body-bg);border-bottom-left-radius:var(--border-radius);border-bottom-right-radius:var(--border-radius);display:flex;justify-content:flex-end;gap:10px}.flex{display:flex}.justify-between{justify-content:space-between}.items-center{align-items:center}.flex-grow{flex-grow:1}.self-end{align-self:flex-end}.mb-4{margin-bottom:1rem}.mr-4{margin-right:1rem}@media (max-width: 992px){.table-responsive table{display:none}.lab-tests-cards{display:flex;flex-direction:column;gap:1rem}.lab-test-card{background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--border-radius);padding:1rem;display:flex;flex-direction:column;gap:1rem}.lab-test-card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem}.lab-test-card-title{font-weight:600;margin:0;font-size:1.1rem}.lab-test-card-date{color:var(--text-muted);font-size:.9rem;white-space:nowrap}.lab-test-card-details{display:flex;flex-direction:column;gap:.5rem}.lab-test-card-detail{display:flex;justify-content:space-between;font-size:.9rem;padding:.25rem 0}.lab-test-card-detail .label{color:var(--text-muted);font-weight:500}.lab-test-card-actions{display:flex;gap:.5rem;flex-wrap:wrap}.no-data{text-align:center;padding:2rem;color:var(--text-muted)}}@media (min-width: 993px){.lab-tests-cards{display:none}}.advanced-search{margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border-color)}.search-row{display:flex;flex-wrap:wrap;align-items:flex-end;gap:1.5rem}.search-group{flex:1}.name-search-group{flex-basis:100%}.date-range-group{display:flex;gap:1.5rem;flex-direction:row;align-items:flex-end;flex-grow:2}.search-actions{display:flex;gap:.5rem;padding-bottom:.75rem;flex-grow:1;justify-content:flex-end}.patients-page .page-title{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.patient-link{font-weight:600;color:var(--primary-color);transition:color .2s ease}.patient-link:hover{color:var(--primary-hover);text-decoration:underline}.no-data{text-align:center;padding:2rem;color:var(--text-muted)}@media (max-width: 992px){.search-row{flex-direction:column;align-items:stretch;gap:.5rem}.date-range-group{flex-direction:row;gap:.5rem}.search-actions{padding-bottom:0;margin-top:1rem;justify-content:stretch}.search-actions .btn{flex:1}.patients-page .card table{display:none}.patients-cards{display:flex;flex-direction:column;gap:1rem}.patient-card{background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--border-radius);padding:1rem;display:flex;flex-direction:column;gap:1rem;box-shadow:0 1px 3px #0000000d;transition:box-shadow .2s ease}.patient-card:hover{box-shadow:var(--shadow)}.patient-card-header{display:flex;align-items:center;gap:1rem}}@media (min-width: 993px){.patients-cards{display:none}}.skeleton{background-color:#e9ecef;border-radius:4px;animation:pulse 1.5s cubic-bezier(.4,0,.6,1) infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.skeleton-text{width:100%;height:1em;margin-bottom:.5em}.skeleton-text:last-child{margin-bottom:0}.skeleton-title{width:50%;height:1.5em;margin-bottom:1em}.skeleton-button{width:120px;height:38px}.patient-profile-container{max-width:1400px;margin:30px auto;padding:30px;font-family:Inter,sans-serif;background-color:var(--body-bg)}.profile-header{display:flex;justify-content:space-between;align-items:center;background-color:var(--card-bg);padding:25px 30px;border-radius:var(--border-radius);box-shadow:var(--shadow);margin-bottom:30px}.header-info{display:flex;align-items:center;gap:20px}.patient-avatar{width:80px;height:80px;border-radius:50%;object-fit:cover;border:4px solid var(--primary-color)}.header-info h1{font-size:2.2rem;font-weight:700;margin:0;color:var(--text-dark)}.patient-id{font-size:1rem;color:var(--text-muted);margin:5px 0 0}.header-actions{display:flex;gap:15px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:25px;margin-bottom:30px}.stat-card{display:flex;align-items:center;background:var(--card-bg);padding:20px;border-radius:var(--border-radius);box-shadow:var(--shadow);transition:transform .2s ease,box-shadow .2s ease}.stat-card:hover{transform:translateY(-4px);box-shadow:0 8px 20px #0000001a}.stat-icon{width:50px;height:50px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.5rem;margin-right:20px;background-color:var(--body-bg);color:var(--primary-color)}.stat-card.warning .stat-icon{background-color:#ffc10733;color:var(--accent-color)}.stat-info p{margin:0;color:var(--text-muted);font-size:.9rem}.stat-info h3{margin:5px 0 0;font-size:1.5rem;font-weight:600;color:var(--text-dark)}.profile-tabs{display:flex;gap:10px;border-bottom:2px solid var(--border-color);margin-bottom:30px}.tab-btn{display:flex;align-items:center;gap:10px;padding:12px 20px;font-size:1rem;font-weight:500;border:none;background:transparent;cursor:pointer;color:var(--text-muted);border-bottom:3px solid transparent;transition:color .2s,border-color .2s}.tab-btn:hover{color:var(--primary-color)}.tab-btn.active{color:var(--primary-color);border-bottom-color:var(--primary-color)}.tab-btn.critical{color:var(--accent-color)}.tab-btn.critical.active{border-bottom-color:var(--accent-color)}.tab-badge{background-color:var(--border-color);color:var(--text-muted);font-size:.8rem;padding:3px 8px;border-radius:12px}.tab-btn.active .tab-badge{background-color:var(--primary-color);color:#fff}.tab-btn.critical.active .tab-badge{background-color:var(--accent-color)}.tab-content{animation:fadeIn .5s ease-in-out}.overview-grid,.details-tab-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:25px}.info-card{background:var(--card-bg);border-radius:var(--border-radius);box-shadow:var(--shadow);padding:25px}.info-card.full-width{grid-column:1 / -1}.info-card.critical-card{background:#ffc1071a;border-left:5px solid var(--accent-color)}.info-card-title{display:flex;align-items:center;gap:12px;font-size:1.25rem;font-weight:600;margin:-25px -25px 20px;padding:20px 25px;border-bottom:1px solid var(--medium-gray)}.detail-item{display:flex;justify-content:space-between;padding:10px 0;border-bottom:1px solid var(--light-gray)}.detail-item.block{flex-direction:column;align-items:flex-start;gap:5px}.detail-item:last-child{border-bottom:none}.detail-item label{font-weight:500;color:var(--text-muted)}.detail-item span{color:var(--text-dark);text-align:right;font-weight:500}.detail-item.block span{text-align:left;padding-top:5px;color:var(--text-dark)}.critical-list-summary{list-style:none;padding-left:10px;margin-bottom:20px}.critical-list-summary li{padding:5px 0}.recent-activity-list{list-style:none;padding:0;margin:0}.recent-activity-list li{display:flex;align-items:center;padding:12px 0;border-bottom:1px solid var(--border-color)}.recent-activity-list li:last-child{border:none}.recent-activity-list .test-icon{margin-right:15px;font-size:1.2rem;color:var(--secondary-color)}.recent-activity-list li div{flex-grow:1}.recent-activity-list li strong{display:block}.recent-activity-list li small{color:var(--text-muted)}.link-btn{background:none;border:none;color:var(--primary-color);cursor:pointer;font-weight:600;margin-top:15px;padding:0}.test-history-item{display:flex;align-items:center;justify-content:space-between;padding:20px;border-bottom:1px solid var(--border-color);background:var(--card-bg);border-radius:var(--border-radius);margin-bottom:15px;box-shadow:0 2px 5px #0000000d}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 1200px){.profile-header{flex-direction:column;align-items:flex-start;gap:20px}}@media (max-width: 768px){.stats-grid,.overview-grid,.details-tab-grid{grid-template-columns:1fr}.profile-tabs{overflow-x:auto}}.user-management-page .action-buttons{white-space:nowrap}.user-management-page .action-buttons button{margin:0 2px;padding:6px 10px;font-size:12px}.role-badge{padding:.25rem .6rem;border-radius:999px;font-size:.75rem;font-weight:600;text-transform:capitalize;display:inline-block}.role-admin{background-color:#fef2f2;color:#b91c1c}.role-manager{background-color:#fffbeb;color:#b45309}.role-technician{background-color:#f0fdf4;color:#15803d}@media (max-width: 992px){.user-management-page .card table{display:none}.users-cards{display:flex;flex-direction:column;gap:1rem}.user-card{background:var(--card-bg, #ffffff);border:1px solid var(--border-color, #e5e7eb);border-radius:var(--border-radius, 8px);padding:1rem;display:flex;flex-direction:column;gap:1rem}.user-card:hover{box-shadow:var(--shadow, 0 2px 8px rgba(0,0,0,.1))}.user-card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem}.user-card-info{flex:1}.user-card-name{font-weight:600;color:var(--dark-text);margin:0 0 .25rem;font-size:1.1rem}.user-card-username{color:var(--gray);font-size:.9rem}.user-card-details{display:flex;flex-direction:column;gap:.5rem}.user-card-detail{display:flex;justify-content:space-between;font-size:.9rem;padding:.25rem 0}.user-card-detail .label{color:var(--gray);font-weight:500}.user-card-detail .value{color:var(--dark-text);text-align:right}.user-card-actions{display:flex;gap:.5rem;flex-wrap:wrap}.user-card-actions .btn{flex:1;min-width:80px;text-align:center;padding:.5rem .75rem;font-size:.85rem}.table-responsive .users-cards{display:flex}}@media (min-width: 769px){.users-cards{display:none}}.file-upload-row{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}.file-input-group{display:flex;flex-direction:column}.file-input-group input[type=file]{border:2px dashed var(--border-color);padding:1rem;background-color:var(--body-bg);cursor:pointer;transition:var(--transition)}.file-input-group input[type=file]:hover{border-color:var(--primary-color);background-color:#e9f2ff}.file-preview{margin-top:1rem;max-width:150px;max-height:100px;border-radius:var(--border-radius);border:1px solid var(--border-color);object-fit:contain}@media (max-width: 768px){.file-upload-row{grid-template-columns:1fr}}.personnel-stats-container{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1.5rem;margin-bottom:2rem}.personnel-stats-container .stat-card{background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--border-radius-lg);padding:1.5rem;display:flex;align-items:center;gap:1.5rem;transition:var(--transition)}.personnel-stats-container .stat-card:hover{transform:translateY(-5px);box-shadow:var(--shadow)}.personnel-stats-container .stat-icon{font-size:2.2rem;padding:1rem;border-radius:50%;color:#fff;display:flex;align-items:center;justify-content:center;width:60px;height:60px}.personnel-stats-container .stat-text h3{margin:0;font-size:2rem;font-weight:700;color:var(--text-dark)}.personnel-stats-container .stat-text p{margin:0;color:var(--text-muted)}.personnel-stats-container .stat-icon.fa-users{background-color:#007bff}.personnel-stats-container .stat-icon.icon-active{background-color:#28a745}.personnel-stats-container .stat-icon.icon-temporary{background-color:#ffc107}.personnel-stats-container .stat-icon.icon-inactive{background-color:#6c757d}.personnel-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem}.personnel-card{background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--border-radius);padding:1.5rem;text-align:center;transition:var(--transition);display:flex;flex-direction:column;align-items:center}.personnel-card:hover{transform:translateY(-5px);box-shadow:var(--shadow)}.personnel-avatar{margin-bottom:1rem}.personnel-card h4{margin:0 0 .25rem;font-size:1.2rem;font-weight:600;color:var(--text-dark)}.personnel-card .position{color:var(--primary-color);font-weight:500;margin-bottom:.75rem}.personnel-card .email{color:var(--text-muted);font-size:.9rem;margin-bottom:1rem}.profile-link{margin-top:auto;padding-top:1rem;border-top:1px solid var(--border-color);width:100%}.personnel-table{width:100%;border-collapse:collapse}.personnel-table tbody tr{cursor:pointer;transition:background-color .2s ease}.personnel-table th,.personnel-table td{padding:1rem;text-align:left;border-bottom:1px solid var(--border-color);vertical-align:middle}.personnel-table th{background-color:#f9fafb;font-weight:600;color:var(--text-muted);font-size:.8rem;text-transform:uppercase}.personnel-table tbody tr:hover{background-color:#f0f5ff}.license-status{padding:.25em .6em;font-size:.75rem;font-weight:600;border-radius:999px;text-transform:uppercase;letter-spacing:.5px;display:inline-block}.license-status-valid{color:#15803d;background-color:#f0fdf4}.license-status-expired{color:#b91c1c;background-color:#fef2f2}.license-status-mobile{margin-bottom:.75rem;font-size:.9rem}.personnel-info-cell{display:flex;align-items:center;gap:1rem}.personnel-info-cell .name{font-weight:600}.personnel-info-cell .email{font-size:.85rem;color:var(--text-muted);display:block}@media (min-width: 993px){.personnel-grid{display:none}}@media (max-width: 992px){.personnel-table{display:none}}.personnel-profile{max-width:1100px;margin:2rem auto;padding:2rem;background-color:var(--card-bg);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-lg)}.profile-header{display:flex;justify-content:space-between;align-items:center;gap:1.5rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border-color);margin-bottom:1.5rem}.profile-header .header-info{display:flex;align-items:center;gap:1.5rem}.profile-header h1{margin:0 0 .25rem;font-size:2rem;font-weight:600;color:var(--text-dark)}.profile-header .personnel-id{font-size:1rem;color:var(--text-muted);margin:0}.profile-tabs{display:flex;border-bottom:1px solid var(--border-color);margin-bottom:2rem}.tab-btn{padding:1rem 1.5rem;border:none;background:transparent;cursor:pointer;font-size:1rem;font-weight:500;color:var(--text-muted);position:relative;transition:all .3s ease}.tab-btn.active{color:var(--primary-color)}.tab-btn.active:after{content:"";position:absolute;bottom:-1px;left:0;width:100%;height:3px;background-color:var(--primary-color);border-radius:2px}.tab-content .info-card{background-color:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--border-radius);padding:2rem}.info-card-title{font-size:1.25rem;font-weight:600;margin-bottom:1.5rem;display:flex;align-items:center;gap:.75rem;color:var(--text-dark)}.details-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem}.detail-item{display:flex;text-align:left;flex-direction:column}.detail-item.full-width{grid-column:1 / -1}.detail-item label{font-size:.8rem;color:var(--text-muted);text-transform:uppercase;margin-bottom:.5rem}.detail-item .detail-item-value{font-size:1rem;font-weight:500;padding:.75rem 1rem;background-color:var(--body-bg);border-radius:4px;border:1px solid var(--border-color);white-space:pre-wrap}.status-badge{display:inline-block;padding:.4rem .8rem;border-radius:var(--border-radius);font-size:.9rem;font-weight:600;line-height:1;text-align:center;white-space:nowrap;vertical-align:middle;color:#fff}.status-badge.status-active{background-color:#28a745}.status-badge.status-not-active,.status-badge.status-others{background-color:#6c757d}.status-badge.status-temporary{background-color:#ffc107;color:#212529}.emergency-contacts-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem}.contact-card{background-color:var(--body-bg);border:1px solid var(--border-color);border-radius:var(--border-radius);padding:1rem;display:flex;flex-direction:column;gap:.25rem}.contact-card strong{font-size:1.1rem;color:var(--text-dark)}.contact-card small{color:var(--text-muted);font-style:italic}.contact-card p{margin:.5rem 0 0;display:flex;align-items:center;gap:.5rem}.back-link-container{margin-top:2rem;text-align:center}.offline-indicator{position:fixed;bottom:20px;left:50%;transform:translate(-50%);padding:.75rem 1.5rem;border-radius:8px;color:#fff;z-index:2000;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #0003;max-width:90vw;width:fit-content}.offline-indicator.offline{background-color:#ef4444}.offline-indicator.online{background-color:#10b981}.indicator-content{display:flex;align-items:center;gap:.75rem}.indicator-content i{margin-right:0;flex-shrink:0}.toast-container{position:fixed;top:20px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:10px;pointer-events:none}.toast{background:var(--card-bg, #ffffff);border-radius:8px;box-shadow:0 4px 12px #00000026;padding:12px 16px;min-width:300px;max-width:400px;display:flex;align-items:flex-start;gap:12px;pointer-events:auto;animation:slideInRight .3s ease-out forwards;border-left:4px solid #ccc;color:var(--text-color, #333)}@keyframes slideInRight{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.toast-success{border-left-color:#10b981}.toast-success .toast-icon{color:#10b981}.toast-error{border-left-color:#ef4444}.toast-error .toast-icon{color:#ef4444}.toast-warning{border-left-color:#f59e0b}.toast-warning .toast-icon{color:#f59e0b}.toast-info{border-left-color:#3b82f6}.toast-info .toast-icon{color:#3b82f6}.toast-critical{border-left-color:#dc2626;background-color:#fef2f2}.toast-critical .toast-icon,.toast-critical .toast-title{color:#dc2626}.toast-icon{font-size:1.2rem;margin-top:2px;flex-shrink:0}.toast-content{flex:1}.toast-title{font-weight:600;margin-bottom:4px;font-size:.95rem}.toast-message{font-size:.9rem;opacity:.9;line-height:1.4}.toast-close{background:none;border:none;font-size:1.2rem;color:#9ca3af;cursor:pointer;padding:0;line-height:1}.toast-close:hover{color:#4b5563}:root{--primary-color: #3b82f6;--primary-hover: #2563eb;--secondary-color: #6c7580;--accent-color: #ef4444;--success-color: #10b981;--warning-color: #f59e0b;--info-color: #0ea5e9;--body-bg: #f4f7f6;--card-bg: #ffffff;--sidebar-bg: #2c3e50;--text-dark: #1f2937;--text-light: #f9fafb;--text-muted: #6b7280;--border-color: #e5e7eb;--border-radius: .5rem;--shadow: 0 2px 4px rgba(0, 0, 0, .1);--transition: all .2s ease-in-out;--sidebar-width: 260px;--sidebar-collapsed-width: 80px;--header-height: 60px;--text-color: var(--text-dark);--text-color-secondary: var(--text-muted);--background-color: var(--body-bg);--overlay-bg: rgba(255, 255, 255, .85)}.dark-mode{--primary-color: #60a5fa;--primary-hover: #3b82f6;--body-bg: #111827;--card-bg: #1f2937;--sidebar-bg: #0f172a;--text-dark: #f9fafb;--text-muted: #9ca3af;--border-color: #374151;--shadow: 0 4px 6px -1px rgba(0, 0, 0, .5), 0 2px 4px -1px rgba(0, 0, 0, .3);--overlay-bg: rgba(17, 24, 39, .85)}*{margin:0;padding:0;box-sizing:border-box;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}body{background-color:var(--body-bg);color:var(--text-dark);line-height:1.6}a{text-decoration:none;color:var(--primary-color)}a:hover{color:var(--primary-hover)}.btn{padding:10px 18px;border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:var(--transition);display:inline-flex;align-items:center;justify-content:center;gap:8px}.btn-primary{background:var(--primary-color);color:#fff}.btn-primary:hover{background:var(--primary-hover);transform:translateY(-1px)}.btn-secondary{background:var(--secondary-color);color:#fff}.btn-secondary:hover{background:#5a6268}.btn-success{background:var(--success-color);color:#fff}.btn-success:hover{background:#059669}.btn-danger{background:var(--accent-color);color:#fff}.btn-danger:hover{background:#dc2626}.card{background:var(--card-bg);border-radius:var(--border-radius);border:1px solid var(--border-color);padding:1.5rem;margin-bottom:1.5rem}.floating-label-group{position:relative;margin-bottom:1.5rem}.floating-input,.floating-label-group select,.floating-label-group textarea{width:100%;padding:.75rem;border:1px solid var(--border-color);border-radius:var(--border-radius);background-color:var(--card-bg);font-size:1rem;transition:border-color .2s;color:var(--text-dark)}.floating-input:focus,.floating-label-group select:focus,.floating-label-group textarea:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 2px #3b82f633}.floating-label{position:absolute;top:.75rem;left:.75rem;background-color:var(--card-bg);padding:0 .25rem;color:var(--text-muted);font-size:1rem;transition:all .2s;pointer-events:none}.floating-input:focus+.floating-label,.floating-input:not(:placeholder-shown)+.floating-label,.floating-label-group select:focus+.floating-label,.floating-label-group select:not([value=""])+.floating-label,.floating-label-group textarea:focus+.floating-label,.floating-label-group textarea:not(:placeholder-shown)+.floating-label{top:-.65rem;font-size:.75rem;color:var(--primary-color)}.error-message{background-color:#fef2f2;color:#b91c1c;padding:.75rem 1rem;border-radius:6px;margin:1rem 0;display:flex;align-items:center;gap:.5rem;font-size:.9rem}.loading{text-align:center;padding:3rem;font-size:1.2rem;color:var(--text-muted)}.abnormality-indicator{margin-left:5px;font-size:1rem;color:var(--accent-color);font-weight:700}.online-indicator{display:inline-flex;align-items:center;gap:6px;font-size:.8rem;padding:3px 8px;border-radius:12px;font-weight:500}.online-indicator:before{content:"";display:block;width:8px;height:8px;border-radius:50%}.online-indicator.online{color:#065f46;background-color:#d1fae5}.online-indicator.online:before{background-color:var(--success-color)}.online-indicator.offline{color:var(--text-muted);background-color:#f3f4f6}.online-indicator.offline:before{background-color:var(--secondary-color)}
