/* ==========================================================================
   Convocatorias - Detalle, inscripciones
   ========================================================================== */

/* Badges de estado de convocatoria */
.badge-borrador {
  background: var(--color-white, #fff);
  color: var(--color-primary);
  border: 1px solid var(--color-primary);
  position: relative;
  overflow: hidden;
  transition: transform 0.3s ease;
}

.badge-borrador::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(
    120deg,
    transparent 0%,
    transparent 30%,
    rgba(var(--color-primary-rgb), 0.15) 50%,
    transparent 70%,
    transparent 100%
  );
  transform: translateX(-100%);
  transition: transform 0.5s ease;
  pointer-events: none;
}

.badge-borrador:hover {
  transform: translate(2px, -2px);
}

.badge-borrador:hover::after {
  transform: translateX(100%);
}

/* Botón volver en detalle convocatoria */
.convocatoria-detalle__title .btn-ghost {
  background: var(--color-white, #fff);
  color: var(--color-primary);
  border: 1px solid var(--color-primary);
  position: relative;
  overflow: hidden;
  transition: transform 0.3s ease;
}

.convocatoria-detalle__title .btn-ghost::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(
    120deg,
    transparent 0%,
    transparent 30%,
    rgba(var(--color-primary-rgb), 0.15) 50%,
    transparent 70%,
    transparent 100%
  );
  transform: translateX(-100%);
  transition: transform 0.5s ease;
  pointer-events: none;
}

.convocatoria-detalle__title .btn-ghost:hover {
  transform: translate(2px, -2px);
}

.convocatoria-detalle__title .btn-ghost:hover::after {
  transform: translateX(100%);
}

.badge-abierta {
  background: var(--color-success-light);
  color: var(--color-success);
  border-color: var(--color-success-border);
}

.badge-en_curso {
  background: var(--color-info-light);
  color: var(--color-info);
  border-color: var(--color-info-border);
}

.badge-finalizada {
  background: var(--role-admin-light);
  color: var(--role-admin);
  border-color: var(--role-admin-border);
}

.badge-cancelada {
  background: #fee2e2;
  color: #dc2626;
  border-color: #fecaca;
}

/* Contenedor glass-card que envuelve las convocatoria-cards: quitar padding */
.glass-card:has(.convocatoria-card) {
  padding: 0;
  background: transparent;
  border: none;
  box-shadow: none;
  backdrop-filter: none;
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

/* Convocatoria cards en tab */
.convocatoria-card {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-4) var(--space-5);
  border: 2px solid rgba(36, 100, 96, 0.12);
  border-radius: var(--radius-md);
  background: rgba(var(--color-primary-rgb), 0.04);
  cursor: pointer;
  transition:
    box-shadow var(--transition-base),
    border-color var(--transition-base);
}

.convocatoria-card:hover {
  box-shadow: var(--glass-shadow);
  border-color: rgba(36, 100, 96, 0.35);
}

.convocatoria-card__info {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
}

.convocatoria-card__nombre {
  font-size: var(--text-sm);
  font-weight: var(--font-semibold);
  background: linear-gradient(90deg, var(--color-primary-dark), var(--color-primary-light));
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}

.convocatoria-card__meta {
  display: flex;
  gap: var(--space-3);
  font-size: var(--text-xs);
  color: var(--color-gray-500);
}

.convocatoria-card__right {
  display: flex;
  align-items: center;
  gap: var(--space-3);
}

.convocatoria-card__right svg {
  color: var(--color-gray-400);
  transition: color var(--transition-fast);
}

.convocatoria-card:hover .convocatoria-card__right svg {
  color: var(--color-primary);
}

/* Detalle convocatoria */
.convocatoria-detalle__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  margin-bottom: var(--space-6);
  flex-wrap: wrap;
}

.convocatoria-detalle__title {
  display: flex;
  align-items: center;
  gap: var(--space-3);
}

.convocatoria-detalle__acciones {
  display: flex;
  gap: var(--space-2);
  flex-wrap: wrap;
}

/* Inscripciones - contador */
.inscripciones-counter {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-4);
  background: var(--color-gray-50);
  border-radius: var(--radius-lg);
  margin-bottom: var(--space-4);
}

.inscripciones-counter__value {
  font-size: var(--text-2xl);
  font-weight: var(--font-bold);
  color: var(--color-primary);
}

.inscripciones-counter__label {
  font-size: var(--text-sm);
  color: var(--color-gray-500);
}

/* Buscador alumnos autocomplete */
.alumno-search {
  position: relative;
  margin-bottom: var(--space-4);
}

.alumno-search__results {
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  z-index: var(--z-dropdown);
  background: var(--color-white);
  border: 1px solid var(--color-gray-200);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lg);
  max-height: 240px;
  overflow-y: auto;
  margin-top: var(--space-1);
}

.alumno-search__item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-3) var(--space-4);
  cursor: pointer;
  transition: background var(--transition-fast);
}

.alumno-search__item:hover {
  background: var(--color-gray-50);
}

.alumno-search__item-info {
  display: flex;
  flex-direction: column;
}

.alumno-search__item-nombre {
  font-size: var(--text-sm);
  font-weight: var(--font-medium);
  color: var(--color-gray-900);
}

.alumno-search__item-email {
  font-size: var(--text-xs);
  color: var(--color-gray-500);
}

/* Sesiones presenciales */
.sesion-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-3) var(--space-4);
  border-bottom: 1px solid var(--color-gray-100);
}

.sesion-item:last-child {
  border-bottom: none;
}

.sesion-item__info {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.sesion-item__fecha {
  font-size: var(--text-sm);
  font-weight: var(--font-semibold);
  color: var(--color-gray-900);
}

.sesion-item__horario {
  font-size: var(--text-xs);
  color: var(--color-gray-500);
}

.sesion-item__lugar {
  font-size: var(--text-xs);
  color: var(--color-gray-400);
}

/* Estado de inscripcion badge */
.badge-activa {
  background: var(--color-success-light);
  color: var(--color-success);
  border-color: var(--color-success-border);
}

.badge-completada {
  background: var(--color-info-light);
  color: var(--color-info);
  border-color: var(--color-info-border);
}

.badge-suspendida {
  background: var(--color-warning-light);
  color: var(--color-warning);
  border-color: var(--color-warning-border);
}

.badge-baja {
  background: var(--color-gray-100);
  color: var(--color-gray-500);
  border-color: var(--color-gray-200);
}

/* --------------------------------------------------------------------------
   Apertura progresiva de contenidos
   -------------------------------------------------------------------------- */
.apertura-contenidos {
  max-width: 960px;
}

.apertura-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: var(--space-4);
}

.apertura-estado {
  display: inline-flex;
  align-items: center;
  padding: 2px 8px;
  border-radius: var(--radius-sm);
  font-size: var(--text-xs);
  font-weight: 500;
}

.apertura-estado--abierto {
  background: rgba(34, 197, 94, 0.1);
  color: var(--color-success, #22c55e);
}

.apertura-estado--cerrado {
  background: rgba(240, 173, 78, 0.1);
  color: var(--color-warning, #f0ad4e);
}

.apertura-modulo .input-field,
.apertura-leccion .input-field {
  min-width: 0;
}

/* Barra de acciones batch */
.apertura-barra-acciones {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-2) var(--space-3);
  margin-bottom: var(--space-3);
  background: var(--color-gray-100);
  border: 1px solid var(--color-gray-200);
  border-radius: var(--radius-md);
  position: sticky;
  top: 0;
  z-index: 10;
}

.apertura-barra-acciones__count {
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--color-primary, #3b82f6);
  white-space: nowrap;
}

.apertura-barra-acciones__btns {
  display: flex;
  align-items: center;
  gap: var(--space-1);
  flex-wrap: wrap;
}

.apertura-barra-acciones__sep {
  width: 1px;
  height: 20px;
  background: var(--color-gray-300);
  margin: 0 var(--space-1);
}

/* Checkboxes */
.apertura-check {
  width: 16px;
  height: 16px;
  accent-color: var(--color-primary, #3b82f6);
  cursor: pointer;
  flex-shrink: 0;
}

/* Layout de header del módulo con checkbox */
.apertura-modulo__header {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  margin-bottom: var(--space-3);
}

.apertura-modulo__controles {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

/* Layout de lección con checkbox */
.apertura-leccion {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-2) 0;
  border-top: 1px solid var(--color-gray-700);
}

.apertura-modulo__lecciones {
  padding-left: var(--space-6);
}

/* Highlight seleccionados */
.apertura-check:checked ~ * {
  opacity: 1;
}

.btn-success {
  background: var(--color-success, #22c55e);
  color: #fff;
  border: none;
}

.btn-success:hover {
  background: #16a34a;
}

.btn-danger {
  background: var(--color-error, #ef4444);
  color: #fff;
  border: none;
}

.btn-danger:hover {
  background: #dc2626;
}
