/* =========================================================
   Patient List – React Look (SCOPEADO)
   Actívalo poniendo class="npl-patient-list" en #main-container-test-dashboard
   ========================================================= */

#main-container-test-dashboard.npl-patient-list {
  min-height: 100vh;
  /* background-color: #e8eae9; */
  padding: 24px;
  font-family:
    -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen, Ubuntu,
    sans-serif;
  font-size: 14px;
  color: #333;
}

/* Fix select2 "enano" (altura) para que cuadre con los botones */
#main-container-test-dashboard .select2-container .select2-selection--single {
  height: 38px !important;
  display: flex !important;
  align-items: center !important;
}

#main-container-test-dashboard
  .select2-container--default
  .select2-selection--single
  .select2-selection__rendered {
  line-height: 38px !important;
}

#main-container-test-dashboard
  .select2-container--default
  .select2-selection--single
  .select2-selection__arrow {
  height: 38px !important;
}

/* Progreso exportación ZIP (admin) */
.npl-progress {
  height: 10px;
  background: rgba(255, 255, 255, 0.15);
  border-radius: 999px;
  overflow: hidden;
  border: 1px solid #487073 !important;
}

.npl-progress__bar {
  height: 100%;
  background: #66a7acff;
  width: 0%;
  transition: width 0.2s ease;
}

.npl-spinner {
  color: #487073;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  border: 2px solid rgba(255, 255, 255, 0.25);
  border-top-color: rgba(255, 255, 255, 0.85);
  animation: nplspin 0.8s linear infinite;
}

@keyframes nplspin {
  to {
    transform: rotate(360deg);
  }
}

#main-container-test-dashboard.npl-patient-list,
#main-container-test-dashboard.npl-patient-list * {
  box-sizing: border-box;
}

/* Anula tu margen antiguo del content para que quede como React */
#main-container-test-dashboard.npl-patient-list #content-test-dashboard {
  width: 100%;
  margin-top: 0;
}

/* Header superior (tu nombre + admin button) */
#main-container-test-dashboard.npl-patient-list .dashboard-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  margin-bottom: 16px;
}

#main-container-test-dashboard.npl-patient-list .clinico-name {
  font-size: 22px;
  font-weight: 600;
}

#main-container-test-dashboard.npl-patient-list .admin-link {
  text-decoration: none;
}

/* Barra de acciones (fila 1 y fila 2) */
#main-container-test-dashboard.npl-patient-list .actions-bar {
  display: flex;
  gap: 12px;
  margin-bottom: 24px;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
}

.admin-action-bar {
  display: flex;
}

/* Fuerza que la fila 2 sea “otra fila” y no se mezcle visualmente */
#main-container-test-dashboard.npl-patient-list .actions-bar--secondary {
  margin-top: -12px;
  width: 100%;
}

#main-container-test-dashboard.npl-patient-list button[disabled],
#main-container-test-dashboard.npl-patient-list .btn-disabled[disabled] {
  background-color: #d0d3d2 !important;
  color: #999 !important;
  cursor: not-allowed;
  pointer-events: none;
  opacity: 1;
}

/* Botones verdes */
#main-container-test-dashboard.npl-patient-list .btn-primary {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background-color: #5a7d7c;
  color: white;
  border: none;
  padding: 10px 16px;
  border-radius: 4px;
  font-size: 14px;
  cursor: pointer;
  line-height: 1;
}

#main-container-test-dashboard.npl-patient-list .btn-primary:hover {
  background-color: #4a6d6c;
}

#main-container-test-dashboard.npl-patient-list .btn-primary .icon {
  width: 14px;
  height: 14px;
  /* border: 2px solid white; */
  display: inline-block;
  flex: 0 0 auto;
}

/* Botón rojo */
#main-container-test-dashboard.npl-patient-list .btn-danger {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background-color: #e74c3c;
  color: white;
  border: none;
  padding: 10px 16px;
  border-radius: 4px;
  font-size: 14px;
  cursor: pointer;
  line-height: 1;
}

#main-container-test-dashboard.npl-patient-list .btn-danger:hover {
  background-color: #c0392b;
}

#main-container-test-dashboard.npl-patient-list .btn-danger .icon {
  width: 14px;
  height: 14px;
  /* border: 2px solid white; */
  display: inline-block;
  flex: 0 0 auto;
}

/* Botón deshabilitado */
#main-container-test-dashboard.npl-patient-list .btn-disabled {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background-color: #d0d3d2;
  color: #999;
  border: none;
  padding: 10px 16px;
  border-radius: 4px;
  font-size: 14px;
  cursor: not-allowed;
  line-height: 1;
}

.patient-actions button{
  width: 180px;
}

.filters-patient-list-container {
  display: flex;
}

#main-container-test-dashboard.npl-patient-list .btn-disabled .icon {
  width: 14px;
  height: 14px;
  border: 2px solid #999;
  display: inline-block;
  flex: 0 0 auto;
}

/* Input de búsqueda */
#main-container-test-dashboard.npl-patient-list .search-input {
  padding: 10px 16px;
  border: 1px solid #c0c3c2;
  border-radius: 4px;
  font-size: 14px;
  background-color: white;
  outline: none;
  min-width: 200px;
}

#main-container-test-dashboard.npl-patient-list .search-input::placeholder {
  color: #999;
}

#main-container-test-dashboard.npl-patient-list .search-input:focus {
  border-color: #5a7d7c;
  box-shadow: 0 0 0 2px rgba(90, 125, 124, 0.1);
}

/* Select de filtro */
#main-container-test-dashboard.npl-patient-list .filter-select {
  padding: 10px 16px;
  border: 1px solid #c0c3c2;
  border-radius: 4px;
  font-size: 14px;
  background-color: white;
  outline: none;
  cursor: pointer;
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23666' d='M6 8L1 3h10z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 12px center;
  padding-right: 36px;
  min-width: 180px;
}

#main-container-test-dashboard.npl-patient-list .filter-select:focus {
  border-color: #5a7d7c;
  box-shadow: 0 0 0 2px rgba(90, 125, 124, 0.1);
}

/* Card del paciente */
#main-container-test-dashboard.npl-patient-list .patient-card {
  background-color: white;
  border: 1px solid #d0d3d2;
  border-radius: 4px;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.05);
  margin-bottom: 16px;
  overflow: hidden;
}

#main-container-test-dashboard.npl-patient-list .patient-card-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 12px 20px;
  background-color: #c8d6c8;
}

#main-container-test-dashboard.npl-patient-list .patient-card-header:focus {
  outline: 2px solid rgba(90, 125, 124, 0.25);
  outline-offset: 2px;
}

#main-container-test-dashboard.npl-patient-list .patient-card-title {
  font-size: 14px;
  font-weight: 400;
  color: #333;
}

#main-container-test-dashboard.npl-patient-list .toggle-btn {
  width: 24px;
  height: 24px;
  background: none;
  border: none;
  cursor: pointer;
  font-size: 18px;
  color: #666;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0;
}

#main-container-test-dashboard.npl-patient-list .toggle-btn:hover {
  color: #333;
}

#main-container-test-dashboard.npl-patient-list .patient-card-content {
  padding: 24px 20px;
}

#main-container-test-dashboard.npl-patient-list
  .patient-card-content.is-collapsed {
  display: none;
}

/* Grid de datos (4 columnas) */
#main-container-test-dashboard.npl-patient-list .data-row {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
  margin-bottom: 20px;
}

@media (max-width: 900px) {
  #main-container-test-dashboard.npl-patient-list .data-row {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 500px) {
  #main-container-test-dashboard.npl-patient-list .data-row {
    grid-template-columns: 1fr;
  }
}

#main-container-test-dashboard.npl-patient-list .data-item {
  font-size: 14px;
  color: #333;
}

#main-container-test-dashboard.npl-patient-list .data-label {
  color: #333;
}

#main-container-test-dashboard.npl-patient-list .data-value {
  font-weight: 600;
}

/* Botones de acción del paciente */
#main-container-test-dashboard.npl-patient-list .patient-actions {
  display: flex;
  gap: 12px;
  margin-top: 24px;
  flex-wrap: wrap;
  align-items: center;
}

#main-container-test-dashboard.npl-patient-list .patient-actions form {
  margin: 0;
}

@media (max-width: 600px) {
  #main-container-test-dashboard.npl-patient-list .patient-actions {
    flex-direction: column;
    align-items: stretch;
  }

  #main-container-test-dashboard.npl-patient-list .patient-actions button {
    width: 100%;
    justify-content: center;
  }

  #main-container-test-dashboard.npl-patient-list .patient-actions form {
    width: 100%;
  }
}

/* Loader */
.loader-container {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.5);
  z-index: 9999;

  display: flex; /* base */
  justify-content: center;
  align-items: center;
}

/* 🔥 Esto pisa el display:block de jQuery.show() */
.loader-container[style*="display: block"] {
  display: flex !important;
}

.loader {
  border: 5px solid #f3f3f3;
  border-top: 5px solid #3498db;
  border-radius: 50%;
  width: 40px;
  height: 40px;
  animation: spin 2s linear infinite;
}

@keyframes spin {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}

/* Select2 (que no rompa) */
#main-container-test-dashboard.npl-patient-list .select2-container {
  min-width: 180px;
}

/* Evita que estilos viejos (hover con transform) te fastidien el look */
#main-container-test-dashboard.npl-patient-list button:hover {
  transform: none !important;
  box-shadow: none !important;
}

/* =========================================================
   Patient Form – React Look (MAQUETADO "PACIENTE INFANTIL")
   Actívalo poniendo class="npl-patient-form" en #main-container-test-dashboard
   ========================================================= */

/* Reset local (sin liarla fuera del contenedor) */
#main-container-test-dashboard.npl-patient-form,
#main-container-test-dashboard.npl-patient-form * {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

/* Base */
#main-container-test-dashboard.npl-patient-form {
  min-height: 100vh;
  /* background-color: #e8ecef; */
  padding: 20px;
  font-family:
    -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen, Ubuntu,
    sans-serif;
  font-size: 14px;
  color: #333;
}

#main-container-test-dashboard.npl-patient-form #content-test-dashboard {
  width: 100%;
  margin-top: 0;
}

/* Container */
#main-container-test-dashboard.npl-patient-form .container {
  max-width: 1100px;
  margin: 0 auto;
}

/* =========================================================
   Botón volver
   ========================================================= */
#main-container-test-dashboard.npl-patient-form .btn-back {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background-color: #5b8a8a;
  color: #fff;
  border: none;
  padding: 10px 20px;
  border-radius: 4px;
  font-size: 14px;
  cursor: pointer;
  margin-bottom: 20px;
}

#main-container-test-dashboard.npl-patient-form .btn-back:hover {
  background-color: #4a7575;
}

#main-container-test-dashboard.npl-patient-form .btn-back-icon {
  width: 16px;
  height: 16px;
  background-color: #fff;
  border-radius: 2px;
  flex: 0 0 auto;
}

/* =========================================================
   Card
   ========================================================= */
#main-container-test-dashboard.npl-patient-form .card {
  background-color: #fff;
  border-radius: 8px;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
  overflow: hidden;
  border: 0;
}

#main-container-test-dashboard.npl-patient-form .card-header {
  background-color: #f5f7f8;
  padding: 15px 20px;
  border-bottom: 1px solid #e0e0e0;
}

#main-container-test-dashboard.npl-patient-form .card-title {
  font-size: 14px;
  font-weight: 400;
  color: #333;
}

#main-container-test-dashboard.npl-patient-form .card-body {
  padding: 25px;
}

/* Neutraliza fieldset/legend antiguos */
#main-container-test-dashboard.npl-patient-form .npl-fieldset {
  border: 0;
  padding: 0;
  margin: 0;
  min-width: 0;
}

#main-container-test-dashboard.npl-patient-form .npl-legend {
  display: none;
}

/* =========================================================
   Grid del formulario
   ========================================================= */
#main-container-test-dashboard.npl-patient-form .form-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
}

/* Responsive */
@media (max-width: 900px) {
  #main-container-test-dashboard.npl-patient-form .form-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 500px) {
  #main-container-test-dashboard.npl-patient-form .form-grid {
    grid-template-columns: 1fr;
  }
}

/* =========================================================
   Form group + labels
   ========================================================= */
#main-container-test-dashboard.npl-patient-form .form-group {
  display: flex;
  flex-direction: column;
}

#main-container-test-dashboard.npl-patient-form .form-label {
  font-size: 14px;
  color: #333;
  margin-bottom: 8px;
  font-weight: 600;
}

#main-container-test-dashboard.npl-patient-form .form-label span {
  color: #888;
}

/* =========================================================
   Inputs
   ========================================================= */
#main-container-test-dashboard.npl-patient-form .form-input {
  padding: 10px 12px;
  border: 1px solid #ddd;
  border-radius: 4px;
  font-size: 14px;
  color: #333;
  background-color: #fff;
  outline: none;
}

#main-container-test-dashboard.npl-patient-form .form-input:focus {
  border-color: #5b8a8a;
}

/* =========================================================
   Select
   ========================================================= */
#main-container-test-dashboard.npl-patient-form .form-select {
  padding: 10px 12px;
  border: 1px solid #ddd;
  border-radius: 4px;
  font-size: 14px;
  color: #888;
  background-color: #fff;
  cursor: pointer;
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23888' d='M6 8L1 3h10z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 12px center;
  padding-right: 36px;
  outline: none;
}

#main-container-test-dashboard.npl-patient-form .form-select:focus {
  border-color: #5b8a8a;
}

/* Si hay selects con valor ya elegido, que no parezcan placeholder */
#main-container-test-dashboard.npl-patient-form .form-select:not([value=""]) {
  color: #333;
}



button.selected{
  background-color:#E4C46A!important;
  font-size: 14px!important;
}

button.deselected{
  background-color:#F7F7F7!important;
  font-size: 14px!important;
  color: black!important;
}

.test-title{
  text-align: center;
  font-size: 14px!important;
}

/* =========================================================
   Radios
   ========================================================= */
#main-container-test-dashboard.npl-patient-form .radio-group {
  display: flex;
  align-items: center;
  gap: 20px;
  padding-top: 8px;
  flex-wrap: wrap;
}

#main-container-test-dashboard.npl-patient-form .radio-label {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 14px;
  color: #333;
  cursor: pointer;
}

#main-container-test-dashboard.npl-patient-form .radio-input {
  width: 16px;
  height: 16px;
  accent-color: #5b8a8a;
  cursor: pointer;
  margin: 0;
}

/* =========================================================
   Botón guardar
   ========================================================= */
#main-container-test-dashboard.npl-patient-form .btn-submit {
  background-color: #5b8a8a;
  color: #fff;
  border: none;
  padding: 12px 24px;
  border-radius: 4px;
  font-size: 14px;
  cursor: pointer;
  margin-top: 25px;
}

#main-container-test-dashboard.npl-patient-form .btn-submit:hover {
  background-color: #4a7575;
}

/* =========================================================
   Footer note
   ========================================================= */
#main-container-test-dashboard.npl-patient-form .footer-note {
  margin-top: 40px;
  font-size: 13px;
  color: #666;
}

/* Disabled */
#main-container-test-dashboard.npl-patient-form button[disabled],
#main-container-test-dashboard.npl-patient-form input[disabled],
#main-container-test-dashboard.npl-patient-form select[disabled] {
  opacity: 0.65;
  cursor: not-allowed;
  pointer-events: none;
}

/* =========================================================
   Patient Results (Ventas) – React Look (SCOPEADO)
   - Solo afecta a la pantalla de resultados (id="npl-ventas-results-page")
   - NO toca estilos de Highcharts (solo contenedor/tabla)
   ========================================================= */

#npl-ventas-results-page,
#npl-ventas-results-page * {
  box-sizing: border-box;
}

#npl-ventas-results-page {
  max-width: 1200px;
  margin: 0 auto;
  padding: 24px;
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen, Ubuntu, sans-serif;
  font-size: 14px;
  color: #333;
  --npl-ventas-col-raw: 120px;
  --npl-ventas-col-z: 120px;
  --npl-ventas-col-pctl: 100px;
  --npl-ventas-col-collapse: 40px;
  --npl-ventas-col-gap: 12px;
  --npl-ventas-grid: 1fr var(--npl-ventas-col-raw) var(--npl-ventas-col-z) var(--npl-ventas-col-pctl) var(--npl-ventas-col-collapse);
}

/* Barra superior */
#npl-ventas-results-page .top-actions {
  display: flex;
  gap: 16px;
  margin-bottom: 24px;
  align-items: center;
  flex-wrap: wrap;
}

#npl-ventas-results-page .btn {
  padding: 10px 20px;
  border-radius: 6px;
  font-size: 14px;
  font-weight: 500;
  cursor: pointer;
  transition: background-color 0.2s ease, border-color 0.2s ease, color 0.2s ease;
  border: none;
  line-height: 1;
}

#npl-ventas-results-page .btn-primary {
  background-color: #5a7d7c;
  color: #fff;
}

#npl-ventas-results-page .btn-primary:hover {
  background-color: #4a6d6c;
}

#npl-ventas-results-page .btn-secondary {
  background-color: #b8c5b8;
  color: #333;
}

#npl-ventas-results-page .btn-secondary:hover {
  background-color: #a8b5a8;
}

#npl-ventas-results-page .btn-outline {
  background-color: #fff;
  color: #666;
  border: 1px solid #ddd;
}

#npl-ventas-results-page .btn-outline:hover {
  background-color: #f9f9f9;
}

/* Select */
#npl-ventas-results-page .select-wrapper {
  position: relative;
}

#npl-ventas-results-page .select {
  padding: 10px 40px 10px 16px;
  border: 1px solid #ddd;
  border-radius: 6px;
  background-color: #fff;
  font-size: 14px;
  color: #666;
  cursor: pointer;
  appearance: none;
  min-width: 260px;
  outline: none;
}

#npl-ventas-results-page .select:focus {
  border-color: #5a7d7c;
  box-shadow: 0 0 0 2px rgba(90, 125, 124, 0.10);
}

#npl-ventas-results-page .select-wrapper::after {
  content: "";
  position: absolute;
  right: 16px;
  top: 50%;
  transform: translateY(-50%);
  width: 0;
  height: 0;
  border-left: 5px solid transparent;
  border-right: 5px solid transparent;
  border-top: 5px solid #666;
  pointer-events: none;
}

/* Card */
#npl-ventas-results-page .results-card {
  background-color: #fff;
  border-radius: 8px;
  overflow: hidden;
  margin-bottom: 24px;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.10);
  border: 1px solid rgba(0, 0, 0, 0.06);
}

/* Header estilo captura (verde suave) */
#npl-ventas-results-page .card-header {
  display: grid;
  grid-template-columns: var(--npl-ventas-grid); /* último: botón colapsar */
  padding: 14px 20px;
  background-color: #c8d6c8;
  font-size: 14px;
  align-items: center;
  column-gap: var(--npl-ventas-col-gap);
}

#npl-ventas-results-page .card-header-title {
  font-weight: 400;
  color: #333;
}

#npl-ventas-results-page .card-header-title strong {
  font-weight: 700;
}

#npl-ventas-results-page .card-header-col {
  text-align: center;
  color: #333;
  font-weight: 400;
}

#npl-ventas-results-page .card-collapse {
  display: flex;
  align-items: center;
  justify-content: flex-end;
}

#npl-ventas-results-page .card-collapse-btn {
  width: 28px;
  height: 28px;
  border-radius: 6px;
  border: 1px solid rgba(0, 0, 0, 0.10);
  background: rgba(255, 255, 255, 0.35);
  color: #4a6d6c;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  line-height: 1;
}

#npl-ventas-results-page .card-collapse-btn:hover {
  background: rgba(255, 255, 255, 0.55);
}

/* Content */
#npl-ventas-results-page .card-content {
  padding: 0; /* la tabla ya tiene padding interno */
}

/* Tabla */
#npl-ventas-results-page .data-table {
  width: 100%;
}

/* “Subtítulo” de cada test (gris) */
#npl-ventas-results-page .table-section {
  margin: 0;
}

#npl-ventas-results-page .table-section-header {
  padding: 10px 20px;
  font-size: 14px;
  color: #333;
  background: #e1e3e2;
  border-top: 1px solid rgba(0,0,0,0.06);
  border-bottom: 1px solid rgba(0,0,0,0.06);
}

/* Filas */
#npl-ventas-results-page .table-row {
  display: grid;
  grid-template-columns: var(--npl-ventas-grid);
  padding: 8px 20px;
  font-size: 14px;
  align-items: center;
  column-gap: var(--npl-ventas-col-gap);
  border-bottom: 0;
}

/* Empuja las columnas numéricas para que coincidan con la cabecera (reserva hueco del botón de colapsar) */
#npl-ventas-results-page .table-row::after {
  content: "";
  display: block;
}

/* Zebra suave como en tu captura */
#npl-ventas-results-page .table-section .table-row:nth-of-type(even) {
  background: #fafafa;
}

#npl-ventas-results-page .table-section .table-row:nth-of-type(odd) {
  background: #ffffff;
}

#npl-ventas-results-page .table-cell {
  text-align: center;
  color: #333;
}

#npl-ventas-results-page .table-cell:first-child {
  text-align: left;
}

#npl-ventas-results-page .table-cell.label {
  display: flex;
  align-items: center;
  gap: 8px;
}

#npl-ventas-results-page .table-cell.label.bold {
  font-weight: 700;
}

/* Badge "Gráfico" en la fila Total correctas */
#npl-ventas-results-page .npl-chart-badge {
  display: inline-flex;
  align-items: center;
  gap: 3px;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.03em;
  color: #5a7d7c;
  background: #eaf3f3;
  border: 1px solid #b8d5d4;
  border-radius: 10px;
  padding: 1px 7px 1px 5px;
  margin-left: 6px;
  vertical-align: middle;
  white-space: nowrap;
}

#npl-ventas-results-page .npl-chart-badge svg {
  color: #5a7d7c;
  flex-shrink: 0;
}

/* Footer botones */
#npl-ventas-results-page .card-footer {
  display: flex;
  gap: 12px;
  padding: 18px 20px;
  flex-wrap: wrap;
  border-top: 1px solid rgba(0,0,0,0.06);
}

#npl-ventas-results-page .tab-btn {
  padding: 10px 20px;
  border-radius: 6px;
  font-size: 14px;
  font-weight: 500;
  cursor: pointer;
  transition: background-color 0.2s ease, border-color 0.2s ease, color 0.2s ease;
}

#npl-ventas-results-page .tab-btn.active {
  background-color: #5a7d7c;
  color: #fff;
  border: none;
}

#npl-ventas-results-page .tab-btn:not(.active) {
  background-color: #fff;
  color: #666;
  border: 1px solid #ddd;
}

#npl-ventas-results-page .tab-btn:not(.active):hover {
  background-color: #f9f9f9;
}

/* Toggle chart (se mantiene, pero sin tocar Highcharts) */
#npl-ventas-results-page .chart-toggle {
  display: flex;
  gap: 8px;
  padding: 16px 20px 0;
}

#npl-ventas-results-page .toggle-btn {
  width: 36px;
  height: 36px;
  border: 1px solid #ddd;
  border-radius: 6px;
  background-color: #bdbaba;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background-color 0.2s ease, border-color 0.2s ease;
}

#npl-ventas-results-page .toggle-btn:hover {
  background-color: rgb(165, 162, 162);
}

#npl-ventas-results-page .toggle-btn.active {
  background-color: #5a7d7c;
  border-color: #5a7d7c;
}

#npl-ventas-results-page .toggle-btn.active svg {
  stroke: #fff;
}

#npl-ventas-results-page .toggle-btn svg {
  width: 18px;
  height: 18px;
  stroke: #666;
}

#npl-ventas-results-page .chart-title {
  text-align: center;
  font-size: 16px;
  font-weight: 700;
  color: #333;
  margin: 10px 0 8px;
}

#npl-ventas-results-page .chart-container,
#npl-ventas-results-page .chart-area {
  width: 100%;
  min-height: 350px;
  padding: 0 20px 16px;
  border: none;
  box-shadow: none;
}

#npl-ventas-results-page .npl-view-p,
#npl-ventas-results-page .npl-chart-mode,
#npl-ventas-results-page .npl-chart-line,
#npl-ventas-results-page .npl-chart-bar {
  border: none;
  box-shadow: none;
  outline: none;
}

#npl-ventas-results-page .chart-with-legend {
  display: flex;
  gap: 24px;
  align-items: flex-start;
  padding: 0 20px 16px;
}

#npl-ventas-results-page .legend {
  background-color: #fff;
  border: 1px solid #ddd;
  border-radius: 6px;
  padding: 12px 16px;
  font-size: 12px;
  width: 270px;
}

#npl-ventas-results-page .legend-item {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 4px 0;
}

#npl-ventas-results-page .legend-color {
  width: 12px;
  height: 12px;
  border-radius: 50%;
  flex-shrink: 0;
}

#npl-ventas-results-page .legend-text {
  color: #333;
}

/* Legend Colors (idéntico a tu maquetación) */
#npl-ventas-results-page .color-muy-superior { background-color: #4a7c59; }
#npl-ventas-results-page .color-superior { background-color: #7cb342; }
#npl-ventas-results-page .color-promedio-alto { background-color: #9ccc65; }
#npl-ventas-results-page .color-promedio { background-color: #81d4a8; }
#npl-ventas-results-page .color-promedio-bajo { background-color: #dce775; }
#npl-ventas-results-page .color-limite { background-color: #ffb74d; }
#npl-ventas-results-page .color-muy-bajo { background-color: #e57373; }

/* Estado colapsado */
#npl-ventas-results-page .results-card.is-collapsed .card-content,
#npl-ventas-results-page .results-card.is-collapsed .card-footer {
  display: none;
}

/* Responsive */
@media (max-width: 768px) {
  #npl-ventas-results-page .card-header {
    grid-template-columns: var(--npl-ventas-grid);
    row-gap: 8px;
  }

  #npl-ventas-results-page .card-header-col {
    display: none;
  }

  #npl-ventas-results-page .table-row {
    grid-template-columns: var(--npl-ventas-grid);
  }

  #npl-ventas-results-page .chart-with-legend {
    flex-direction: column;
  }

  #npl-ventas-results-page .legend {
    width: 100%;
    min-width: 0;
  }
}

/* ── Avisos generales de resultados ─────────────────────────────── */
.npl-notice {
  max-width: 540px;
  margin: 40px auto;
  padding: 28px 32px;
  background: #f8f9fa;
  border: 1px solid #dee2e6;
  border-radius: 10px;
  text-align: center;
  font-size: 15px;
  color: #495057;
  line-height: 1.6;
}

/* Variante: acceso denegado por token ya consumido */
.npl-notice--denied {
  background: #fff5f5;
  border-color: #f5c2c7;
  color: #842029;
}
.npl-notice--denied strong {
  display: block;
  font-size: 17px;
  margin-bottom: 8px;
}

/* ── Botón "Ver resultados una vez" ─────────────────────────────── */
#main-container-test-dashboard.npl-patient-list .btn-view-once-ventas {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background-color: #7a5ccc;
  color: white;
  border: none;
  padding: 10px 16px;
  border-radius: 4px;
  font-size: 14px;
  cursor: pointer;
  line-height: 1;
  width: 180px;
}
#main-container-test-dashboard.npl-patient-list .btn-view-once-ventas:hover {
  background-color: #6648b5;
}
#main-container-test-dashboard.npl-patient-list .btn-view-once-ventas:disabled {
  background-color: #d0d3d2;
  color: #999;
  cursor: not-allowed;
}
