/**
 * UAPA Job Board — Estilos del Frontend
 *
 * Complementa Bootstrap 5.3 sin reemplazarlo.
 * Todas las clases propias usan el prefijo .uapa- para evitar colisiones.
 * Estructura mobile-first con variables CSS personalizadas.
 *
 * Secciones:
 *  1. Variables CSS y Reset
 *  2. Tipografía y utilidades generales
 *  3. Buscador en tiempo real
 *  4. Listado de vacantes (tabla)
 *  5. Single vacante — Hero
 *  6. Single vacante — Cards de info rápida
 *  7. Single vacante — Secciones de contenido
 *  8. Single vacante — Tablas de habilidades e idiomas
 *  9. Single vacante — CTA y botón aplicar
 * 10. Formulario de solicitud
 * 11. Animaciones y transiciones
 * 12. Media queries responsivas
 * 13. Modo oscuro (prefers-color-scheme)
 *
 * @package UAPA_Job_Board
 * @since   1.0.0
 */

/* ============================================================
   1. VARIABLES CSS Y RESET
   ============================================================ */

:root {
  /* Paleta principal del plugin */
  --uapa-primary:        #0d6efd;   /* Azul institucional */
  --uapa-primary-dark:   #0a58ca;
  --uapa-primary-light:  #cfe2ff;
  --uapa-secondary:      #041147;   /* Azul marino UAPA */
  --uapa-secondary-light:#e8f0fa;
  --uapa-accent:         #ff8300;   /* Naranja acento */
  --uapa-accent-light:   #fff3cd;

  /* Colores de estado */
  --uapa-success:        #198754;
  --uapa-danger:         #dc3545;
  --uapa-warning:        #ffc107;
  --uapa-info:           #0dcaf0;

  /* Neutrales */
  --uapa-white:          #ffffff;
  --uapa-gray-50:        #f8f9fa;
  --uapa-gray-100:       #f0f4f8;
  --uapa-gray-200:       #e9ecef;
  --uapa-gray-400:       #ced4da;
  --uapa-gray-600:       #6c757d;
  --uapa-gray-800:       #343a40;
  --uapa-gray-900:       #212529;

  /* Tipografía */
  --uapa-font-sans:      -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
  --uapa-font-size-base: 1rem;
  --uapa-line-height:    1.6;

  /* Espaciado */
  --uapa-radius:         0.5rem;
  --uapa-radius-lg:      0.75rem;
  --uapa-radius-pill:    50rem;

  /* Sombras */
  --uapa-shadow-sm:      0 1px 3px rgba(0, 0, 0, 0.08);
  --uapa-shadow:         0 4px 12px rgba(0, 0, 0, 0.10);
  --uapa-shadow-lg:      0 8px 24px rgba(0, 0, 0, 0.14);
  --uapa-shadow-hover:   0 8px 20px rgba(13, 110, 253, 0.20);

  /* Transiciones */
  --uapa-transition:     all 0.22s ease;
  --uapa-transition-slow: all 0.40s ease;
}

/* Reset mínimo para elementos del plugin */
.uapa-wrap *,
.uapa-wrap *::before,
.uapa-wrap *::after {
  box-sizing: border-box;
}

.uapa-wrap {
  font-family: var(--uapa-font-sans);
  font-size: var(--uapa-font-size-base);
  line-height: var(--uapa-line-height);
  color: var(--uapa-gray-900);
}

/* ============================================================
   2. TIPOGRAFÍA Y UTILIDADES GENERALES
   ============================================================ */

.uapa-section-title {
  color: var(--uapa-secondary);
  font-weight: 700;
  font-size: 1.25rem;
  border-left: 4px solid var(--uapa-accent);
  padding-left: 0.75rem;
  margin-bottom: 1.25rem;
}

.uapa-section-title .bi {
  color: var(--uapa-primary);
  margin-right: 0.4rem;
}

.uapa-badge-nuevo {
  font-size: 0.65rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  vertical-align: middle;
  animation: uapa-pulse 2s infinite;
}

.uapa-divider {
  border: none;
  border-top: 2px solid var(--uapa-gray-200);
  margin: 2rem 0;
}

.uapa-error {
  color: var(--uapa-danger);
  background: #fff5f5;
  border: 1px solid #f5c6cb;
  border-radius: var(--uapa-radius);
  padding: 1rem 1.25rem;
}

/* ============================================================
   3. BUSCADOR EN TIEMPO REAL
   ============================================================ */

.uapa-buscador-card {
  border-radius: var(--uapa-radius-lg) !important;
  transition: var(--uapa-transition);
}

.uapa-buscador-card:focus-within {
  box-shadow: 0 0 0 3px var(--uapa-primary-light), var(--uapa-shadow) !important;
}

/* Input del buscador */
#uapa-buscador {
  font-size: 0.95rem;
  transition: var(--uapa-transition);
}

#uapa-buscador:focus {
  box-shadow: none;
  border-color: var(--uapa-primary);
}

/* Botón X de limpiar búsqueda */
#uapa-btn-limpiar {
  transition: var(--uapa-transition);
}

#uapa-btn-limpiar:hover {
  background: var(--uapa-danger);
  border-color: var(--uapa-danger);
  color: var(--uapa-white);
}

/* Contador de resultados */
#uapa-contador-resultados {
  font-size: 0.82rem;
  color: var(--uapa-gray-600);
  white-space: nowrap;
}

#uapa-num-resultados {
  font-weight: 700;
  color: var(--uapa-primary);
}

/* ============================================================
   4. LISTADO DE VACANTES — TABLA
   ============================================================ */

.uapa-listado-wrap {
  margin: 1.5rem 0;
}

/* Tabla responsiva */
.uapa-tabla-vacantes {
  font-size: 0.9rem;
  border-radius: var(--uapa-radius-lg);
  overflow: hidden;
  box-shadow: var(--uapa-shadow-sm);
}

.uapa-tabla-vacantes thead th {
  background: var(--uapa-secondary);
  color: var(--uapa-white);
  font-weight: 600;
  font-size: 0.8rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  border: none;
  padding: 0.85rem 1rem;
  white-space: nowrap;
}

.uapa-tabla-vacantes tbody tr {
  transition: var(--uapa-transition);
  border-bottom: 1px solid var(--uapa-gray-200);
}

.uapa-tabla-vacantes tbody tr:hover {
  background-color: var(--uapa-secondary-light) !important;
  transform: translateX(3px);
}

/* Celda de fecha */
.uapa-tabla-vacantes .uapa-col-fecha {
  color: var(--uapa-gray-600);
  font-size: 0.82rem;
  white-space: nowrap;
}

/* Celda del puesto */
.uapa-tabla-vacantes .uapa-col-puesto {
  font-weight: 600;
  color: var(--uapa-secondary);
}

/* Celda de área */
.uapa-tabla-vacantes .uapa-col-area {
  color: var(--uapa-gray-800);
  font-size: 0.88rem;
}

/* Celda de ubicación con ícono */
.uapa-col-ubicacion .bi-geo-alt-fill {
  color: var(--uapa-danger);
  font-size: 0.85rem;
}

/* Botón "Ver Detalles" */
.uapa-btn-detalle {
  border-radius: var(--uapa-radius-pill) !important;
  font-size: 0.78rem !important;
  font-weight: 600 !important;
  padding: 0.3rem 0.85rem !important;
  transition: var(--uapa-transition) !important;
  white-space: nowrap;
}

.uapa-btn-detalle:hover {
  transform: translateY(-1px);
  box-shadow: var(--uapa-shadow-hover) !important;
}

/* Fila oculta cuando el buscador no encuentra resultados */
.uapa-fila-oculta {
  display: none !important;
}

/* Mensaje "sin resultados" */
#uapa-sin-resultados {
  display: none;
  text-align: center;
  padding: 2.5rem 1rem;
  color: var(--uapa-gray-600);
}

#uapa-sin-resultados .bi {
  font-size: 2.5rem;
  display: block;
  margin-bottom: 0.75rem;
  color: var(--uapa-gray-400);
}

/* ============================================================
   5. SINGLE VACANTE — HERO
   ============================================================ */

.uapa-hero {
  position: relative;
  background: #ffffff;
  color: var(--uapa-secondary);
  border-radius: var(--uapa-radius-lg);
  overflow: hidden;
  padding: 2.5rem;
  margin-bottom: 1.75rem;
  border: 1px solid var(--uapa-gray-200);
  border-top: 5px solid var(--uapa-secondary);
  box-shadow: var(--uapa-shadow);
}

.uapa-hero::before {
  content: '';
  position: absolute;
  top: 0;
  right: 0;
  width: 220px;
  height: 100%;
  background: linear-gradient(135deg, transparent 60%, rgba(4, 17, 71, 0.04) 100%);
  pointer-events: none;
}

.uapa-hero::after {
  display: none;
}

.uapa-hero-content {
  position: relative;
  z-index: 1;
  display: flex;
  align-items: center;
  gap: 1.75rem;
  flex-wrap: wrap;
}

/* Imagen de la vacante */
.uapa-hero-imagen {
  flex-shrink: 0;
}

.uapa-hero-imagen img,
.uapa-hero-img-square {
  width: 120px;
  height: 120px;
  aspect-ratio: 1 / 1;
  object-fit: cover;
  border-radius: var(--uapa-radius);
  border: 3px solid var(--uapa-gray-200);
  box-shadow: var(--uapa-shadow);
}

/* Texto del hero */
.uapa-hero-info {
  flex: 1;
  min-width: 0;
}

.uapa-hero-empresa {
  font-size: 0.88rem;
  font-weight: 700;
  color: var(--uapa-accent);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  margin-bottom: 0.4rem;
}

.uapa-hero-titulo {
  font-size: 1.8rem;
  font-weight: 800;
  line-height: 1.2;
  margin-bottom: 0.75rem;
  word-break: break-word;
  color: var(--uapa-secondary);
}

.uapa-hero-badges {
  display: flex;
  gap: 0.5rem;
  flex-wrap: wrap;
  align-items: center;
}

/* ============================================================
   6. SINGLE VACANTE — CARDS DE INFO RÁPIDA
   ============================================================ */

.uapa-info-cards {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1rem;
  margin-bottom: 1.75rem;
}

.uapa-info-card {
  background: var(--uapa-white);
  border: 1px solid var(--uapa-gray-200);
  border-radius: var(--uapa-radius);
  padding: 1.1rem 1.25rem;
  display: flex;
  align-items: flex-start;
  gap: 0.85rem;
  transition: var(--uapa-transition);
  box-shadow: var(--uapa-shadow-sm);
}

.uapa-info-card:hover {
  border-color: var(--uapa-primary);
  box-shadow: var(--uapa-shadow);
  transform: translateY(-2px);
}

.uapa-info-card-icon {
  width: 40px;
  height: 40px;
  border-radius: var(--uapa-radius);
  background: var(--uapa-primary-light);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.uapa-info-card-icon .bi {
  font-size: 1.2rem;
  color: var(--uapa-primary);
}

.uapa-info-card-body {
  flex: 1;
  min-width: 0;
}

.uapa-info-card-label {
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--uapa-gray-600);
  margin-bottom: 0.2rem;
}

.uapa-info-card-value {
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--uapa-secondary);
  word-break: break-word;
}

/* ============================================================
   7. SINGLE VACANTE — SECCIONES DE CONTENIDO
   ============================================================ */

.uapa-seccion {
  background: var(--uapa-white);
  border: 1px solid var(--uapa-gray-200);
  border-radius: var(--uapa-radius-lg);
  padding: 1.75rem;
  margin-bottom: 1.5rem;
  box-shadow: var(--uapa-shadow-sm);
}

/* Lista de funciones y requisitos */
.uapa-lista-puesto {
  list-style: none;
  padding: 0;
  margin: 0;
}

.uapa-lista-puesto li {
  padding: 0.45rem 0 0.45rem 1.6rem;
  position: relative;
  color: var(--uapa-gray-800);
  border-bottom: 1px dashed var(--uapa-gray-200);
  font-size: 0.95rem;
}

.uapa-lista-puesto li:last-child {
  border-bottom: none;
}

.uapa-lista-puesto li::before {
  content: '\F26D';                /* Bootstrap Icons: check-circle-fill */
  font-family: 'bootstrap-icons';
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  color: var(--uapa-success);
  font-size: 0.85rem;
}

/* Texto de experiencia */
.uapa-experiencia-texto {
  background: var(--uapa-gray-50);
  border-left: 3px solid var(--uapa-accent);
  border-radius: 0 var(--uapa-radius) var(--uapa-radius) 0;
  padding: 1rem 1.25rem;
  color: var(--uapa-gray-800);
  font-style: italic;
  font-size: 0.95rem;
  margin: 0;
}

/* Descripción de la empresa */
.uapa-empresa-desc {
  color: var(--uapa-gray-800);
  font-size: 0.97rem;
  line-height: 1.7;
}

/* ============================================================
   8. SINGLE VACANTE — TABLAS DE HABILIDADES E IDIOMAS
   ============================================================ */

.uapa-tabla-habilidades {
  font-size: 0.9rem;
  border-radius: var(--uapa-radius);
  overflow: hidden;
}

.uapa-tabla-habilidades thead th {
  background: var(--uapa-gray-100);
  color: var(--uapa-secondary);
  font-weight: 700;
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  border-bottom: 2px solid var(--uapa-gray-200);
  padding: 0.65rem 1rem;
}

.uapa-tabla-habilidades tbody td {
  padding: 0.6rem 1rem;
  vertical-align: middle;
  border-color: var(--uapa-gray-200);
}

.uapa-tabla-habilidades tbody tr:hover {
  background-color: var(--uapa-gray-50);
}

/* Icono de habilidad */
.uapa-skill-icon {
  color: var(--uapa-primary);
  margin-right: 0.4rem;
  font-size: 0.85rem;
}

/* ============================================================
   9. SINGLE VACANTE — CTA Y BOTÓN APLICAR
   ============================================================ */

/* Sección CTA al final de la vacante */
.uapa-cta-section {
  background: var(--uapa-secondary);
  border-radius: var(--uapa-radius-lg);
  padding: 2.25rem;
  text-align: center;
  margin: 2rem 0;
  color: var(--uapa-white);
}

.uapa-cta-section h3 {
  font-size: 1.35rem;
  font-weight: 700;
  margin-bottom: 0.5rem;
}

.uapa-cta-section p {
  opacity: 0.85;
  margin-bottom: 1.5rem;
  font-size: 0.95rem;
}

/* Badge de detalles en el hero (área, ubicación) — fondo claro */
.uapa-badge-detalle {
  background: rgba(4, 17, 71, 0.08);
  color: var(--uapa-secondary);
  font-weight: 600;
  font-size: 0.78rem;
  border: 1px solid rgba(4, 17, 71, 0.15);
}

/* Botón principal de aplicar */
.uapa-btn-aplicar {
  background: var(--uapa-accent) !important;
  color: #ffffff !important;
  border: 2px solid var(--uapa-accent) !important;
  border-radius: var(--uapa-radius-pill) !important;
  font-weight: 700 !important;
  font-size: 1rem !important;
  padding: 0.75rem 2.25rem !important;
  transition: var(--uapa-transition) !important;
  text-decoration: none !important;
  display: inline-block;
  cursor: pointer;
}

.uapa-btn-aplicar:hover {
  background: #e67600 !important;
  border-color: #e67600 !important;
  color: #ffffff !important;
  transform: translateY(-2px);
  box-shadow: 0 8px 20px rgba(255, 131, 0, 0.40) !important;
}

/* Botón aplicar alternativo (verde, para usar en la vacante inline) */
.uapa-btn-aplicar-inline {
  border-radius: var(--uapa-radius-pill) !important;
  font-weight: 700 !important;
  padding: 0.7rem 2rem !important;
  transition: var(--uapa-transition) !important;
  box-shadow: var(--uapa-shadow) !important;
}

.uapa-btn-aplicar-inline:hover {
  transform: translateY(-2px);
  box-shadow: var(--uapa-shadow-lg) !important;
}

/* Ancla al formulario desde el hero */
.uapa-anchor-aplicar {
  scroll-behavior: smooth;
}

/* ============================================================
   10. FORMULARIO DE SOLICITUD
   ============================================================ */

/* Card contenedora del formulario */
.uapa-form-card {
  border-radius: var(--uapa-radius-lg) !important;
  border: none !important;
  box-shadow: var(--uapa-shadow-lg) !important;
  overflow: hidden;
}

/* Encabezado del formulario */
.uapa-form-header {
  background: var(--uapa-secondary);
  color: var(--uapa-white);
  padding: 1.75rem 2rem;
}

.uapa-form-header h3 {
  font-size: 1.3rem;
  font-weight: 700;
  margin: 0 0 0.3rem;
}

.uapa-form-header p {
  opacity: 0.80;
  font-size: 0.9rem;
  margin: 0;
}

/* Labels del formulario */
.uapa-form-label {
  font-weight: 600;
  font-size: 0.88rem;
  color: var(--uapa-secondary);
  margin-bottom: 0.35rem;
}

.uapa-form-label .uapa-required {
  color: var(--uapa-danger);
  margin-left: 0.2rem;
}

/* Inputs, selects y textareas */
.uapa-form-control,
.uapa-form-select {
  border-radius: var(--uapa-radius) !important;
  border-color: var(--uapa-gray-400) !important;
  font-size: 0.93rem !important;
  padding: 0.55rem 0.85rem !important;
  transition: var(--uapa-transition) !important;
}

.uapa-form-control:focus,
.uapa-form-select:focus {
  border-color: var(--uapa-primary) !important;
  box-shadow: 0 0 0 0.2rem var(--uapa-primary-light) !important;
}

/* Estados de validación de Bootstrap (complemento visual) */
.uapa-form-control.is-valid,
.uapa-form-select.is-valid {
  background-image: none !important; /* Quitar ícono de check de Bootstrap */
  border-color: var(--uapa-success) !important;
  padding-right: 0.85rem !important;
}

.uapa-form-control.is-invalid,
.uapa-form-select.is-invalid {
  background-image: none !important;
  border-color: var(--uapa-danger) !important;
  padding-right: 0.85rem !important;
}

/* Feedback de validación */
.uapa-invalid-feedback {
  font-size: 0.8rem;
  color: var(--uapa-danger);
  margin-top: 0.25rem;
  display: none;
}

.uapa-form-control.is-invalid ~ .uapa-invalid-feedback,
.uapa-form-select.is-invalid ~ .uapa-invalid-feedback {
  display: block;
}

/* Input de archivo CV */
.uapa-file-input-wrap {
  position: relative;
}

.uapa-file-drop-zone {
  border: 2px dashed var(--uapa-gray-400);
  border-radius: var(--uapa-radius);
  padding: 1.5rem 1rem;
  text-align: center;
  cursor: pointer;
  transition: var(--uapa-transition);
  background: var(--uapa-gray-50);
}

.uapa-file-drop-zone:hover,
.uapa-file-drop-zone.uapa-dragover {
  border-color: var(--uapa-primary);
  background: var(--uapa-primary-light);
}

.uapa-file-drop-zone .bi {
  font-size: 2rem;
  color: var(--uapa-gray-400);
  display: block;
  margin-bottom: 0.5rem;
  transition: var(--uapa-transition);
}

.uapa-file-drop-zone:hover .bi,
.uapa-file-drop-zone.uapa-dragover .bi {
  color: var(--uapa-primary);
}

.uapa-file-drop-zone p {
  margin: 0;
  font-size: 0.88rem;
  color: var(--uapa-gray-600);
}

.uapa-file-drop-zone strong {
  color: var(--uapa-primary);
}

/* Vista previa del archivo seleccionado */
.uapa-file-preview {
  display: none;
  background: var(--uapa-primary-light);
  border: 1px solid var(--uapa-primary);
  border-radius: var(--uapa-radius);
  padding: 0.65rem 1rem;
  font-size: 0.88rem;
  align-items: center;
  gap: 0.75rem;
}

.uapa-file-preview.uapa-visible {
  display: flex;
}

.uapa-file-preview .bi {
  font-size: 1.4rem;
  color: var(--uapa-danger);
  flex-shrink: 0;
}

.uapa-file-preview-info {
  flex: 1;
  min-width: 0;
}

.uapa-file-preview-name {
  font-weight: 600;
  color: var(--uapa-secondary);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.uapa-file-preview-size {
  color: var(--uapa-gray-600);
  font-size: 0.78rem;
}

.uapa-btn-quitar-archivo {
  color: var(--uapa-danger);
  background: none;
  border: none;
  cursor: pointer;
  font-size: 1.2rem;
  padding: 0;
  line-height: 1;
  flex-shrink: 0;
  transition: var(--uapa-transition);
}

.uapa-btn-quitar-archivo:hover {
  opacity: 0.7;
}

/* Radios de "¿Eres colaborador?" */
.uapa-radio-group {
  display: flex;
  gap: 1rem;
  flex-wrap: wrap;
}

.uapa-radio-option {
  flex: 1;
  min-width: 120px;
  position: relative;
}

/* Ocultar el input nativo sin romper el click del label (1px, no 0) */
.uapa-radio-option .form-check-input[type="radio"] {
  position: absolute;
  opacity: 0;
  width: 1px;
  height: 1px;
  margin: 0;
  pointer-events: none;
}

/* Estilizar el label como botón seleccionable */
.uapa-radio-option .form-check-label {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  width: 100%;
  padding: 0.65rem 1rem;
  border: 2px solid var(--uapa-gray-400);
  border-radius: var(--uapa-radius);
  cursor: pointer;
  font-weight: 600;
  font-size: 0.9rem;
  color: var(--uapa-gray-600);
  transition: var(--uapa-transition);
  text-align: center;
  user-select: none;
  margin: 0;
}

.uapa-radio-option .form-check-label:hover {
  border-color: var(--uapa-secondary);
  color: var(--uapa-secondary);
  background: var(--uapa-secondary-light);
}

/* Estado seleccionado */
.uapa-radio-option .form-check-input[type="radio"]:checked + .form-check-label {
  border-color: var(--uapa-secondary);
  background: var(--uapa-secondary);
  color: #ffffff;
}

.uapa-radio-option .form-check-input[type="radio"]:checked + .form-check-label .bi {
  color: #ffffff;
}

/* Focus accesible con teclado */
.uapa-radio-option .form-check-input[type="radio"]:focus-visible + .form-check-label {
  outline: 2px solid var(--uapa-accent);
  outline-offset: 2px;
}

/* Botón de submit */
.uapa-btn-submit {
  border-radius: var(--uapa-radius-pill) !important;
  font-size: 1.05rem !important;
  font-weight: 700 !important;
  padding: 0.8rem 2rem !important;
  letter-spacing: 0.02em !important;
  transition: var(--uapa-transition) !important;
  position: relative;
  overflow: hidden;
}

.uapa-btn-submit::after {
  content: '';
  position: absolute;
  inset: 0;
  background: rgba(255, 255, 255, 0);
  transition: background 0.2s ease;
}

.uapa-btn-submit:hover::after {
  background: rgba(255, 255, 255, 0.08);
}

.uapa-btn-submit:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 18px rgba(25, 135, 84, 0.35) !important;
}

.uapa-btn-submit:active {
  transform: translateY(0);
}

.uapa-btn-submit:disabled {
  transform: none !important;
  box-shadow: none !important;
  opacity: 0.75;
  cursor: not-allowed;
}

/* Separador de secciones del formulario */
.uapa-form-section-title {
  font-size: 0.78rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--uapa-gray-600);
  padding-bottom: 0.5rem;
  border-bottom: 1px solid var(--uapa-gray-200);
  margin-bottom: 1.25rem;
  margin-top: 0.5rem;
}

/* Aviso de privacidad bajo el botón */
.uapa-privacy-note {
  font-size: 0.78rem;
  color: var(--uapa-gray-600);
  text-align: center;
  margin-top: 0.75rem;
}

.uapa-privacy-note .bi {
  color: var(--uapa-success);
  margin-right: 0.25rem;
}

/* ============================================================
   11. ANIMACIONES Y TRANSICIONES
   ============================================================ */

/* Pulso para el badge NUEVO */
@keyframes uapa-pulse {
  0%, 100% { opacity: 1; }
  50%       { opacity: 0.65; }
}

/* Entrada suave para el formulario */
@keyframes uapa-fade-in-up {
  from {
    opacity: 0;
    transform: translateY(20px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.uapa-form-card {
  animation: uapa-fade-in-up 0.4s ease both;
}

/* Shimmer de carga (skeleton) */
@keyframes uapa-shimmer {
  0%   { background-position: -400px 0; }
  100% { background-position: 400px 0; }
}

.uapa-skeleton {
  background: linear-gradient(90deg, #f0f0f0 25%, #e0e0e0 50%, #f0f0f0 75%);
  background-size: 400px 100%;
  animation: uapa-shimmer 1.4s ease infinite;
  border-radius: var(--uapa-radius);
  height: 1rem;
}

/* Spin para carga */
@keyframes uapa-spin {
  to { transform: rotate(360deg); }
}

.uapa-spin {
  display: inline-block;
  animation: uapa-spin 0.75s linear infinite;
}

/* ============================================================
   12. MEDIA QUERIES RESPONSIVAS
   ============================================================ */

/* ── xs: < 576px ── */
@media (max-width: 575.98px) {

  .uapa-hero {
    padding: 1.5rem;
  }

  .uapa-hero-titulo {
    font-size: 1.35rem;
  }

  .uapa-hero-imagen img,
  .uapa-hero-img-square {
    width: 80px;
    height: 80px;
  }

  .uapa-info-cards {
    grid-template-columns: 1fr;
    gap: 0.75rem;
  }

  .uapa-seccion {
    padding: 1.25rem;
  }

  .uapa-form-header {
    padding: 1.25rem 1.25rem;
  }

  .uapa-radio-group {
    flex-direction: column;
    gap: 0.5rem;
  }

  .uapa-cta-section {
    padding: 1.5rem 1rem;
  }

  .uapa-tabla-vacantes {
    font-size: 0.82rem;
  }

  /* En móvil ocultar columna de área */
  .uapa-tabla-vacantes .uapa-col-area {
    display: none;
  }
}

/* ── sm: 576px – 767px ── */
@media (min-width: 576px) and (max-width: 767.98px) {

  .uapa-info-cards {
    grid-template-columns: repeat(2, 1fr);
  }

  .uapa-hero-titulo {
    font-size: 1.55rem;
  }
}

/* ── md: 768px – 991px ── */
@media (min-width: 768px) and (max-width: 991.98px) {

  .uapa-info-cards {
    grid-template-columns: repeat(2, 1fr);
  }

  .uapa-hero-titulo {
    font-size: 1.65rem;
  }
}

/* ── lg: 992px+ ── */
@media (min-width: 992px) {

  .uapa-info-cards {
    grid-template-columns: repeat(4, 1fr);
  }

  .uapa-hero-titulo {
    font-size: 1.9rem;
  }

  .uapa-form-card {
    max-width: 860px;
    margin-left: auto;
    margin-right: auto;
  }
}

/* ── xl: 1200px+ ── */
@media (min-width: 1200px) {

  .uapa-hero {
    padding: 3rem 3.5rem;
  }

  .uapa-hero-imagen img,
  .uapa-hero-img-square {
    width: 140px;
    height: 140px;
  }
}

/* ============================================================
   13. MODAL DE SOLICITUD DE EMPLEO
   ============================================================ */

/* Cabecera del modal con color institucional */
.uapa-modal-header {
  background: var(--uapa-secondary);
  color: #ffffff;
  padding: 1.1rem 1.5rem;
  border-bottom: 3px solid var(--uapa-accent);
}

.uapa-modal-header .modal-title {
  font-weight: 700;
  font-size: 1rem;
}

/* Invertir color del botón de cierre (X blanca) */
.uapa-modal-header .btn-close {
  filter: brightness(0) invert(1);
  opacity: 0.8;
}

.uapa-modal-header .btn-close:hover {
  opacity: 1;
}

/* Sin padding en el body (el formulario tiene el suyo) */
#uapa-modal-solicitud .modal-body {
  padding: 0;
}

/* Quitar card-shadow y rounded del formulario dentro del modal */
#uapa-modal-solicitud .uapa-form-card {
  border-radius: 0 !important;
  box-shadow: none !important;
  animation: none !important;
  border: none !important;
}

/* Ocultar encabezado de la card dentro del modal (el modal ya tiene header) */
#uapa-modal-solicitud .uapa-form-header {
  display: none !important;
}

/* Scroll interno del modal en móvil */
@media (max-width: 575.98px) {
  #uapa-modal-solicitud .modal-dialog {
    margin: 0.5rem;
  }
}

/* ============================================================
   14. RESPONSIVE EXTRAS SINGLE VACANTE
   ============================================================ */

/* Sticky bar móvil — se muestra siempre (no hay scroll-target en modal) */
.uapa-sticky-mobile {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 1030;
  background: rgba(255, 255, 255, 0.97);
  backdrop-filter: blur(8px);
  padding: 0.75rem 1rem;
  border-top: 1px solid var(--uapa-gray-200);
  box-shadow: 0 -4px 12px rgba(0, 0, 0, 0.10);
}

/* Botón sticky en móvil usa color accent */
.uapa-sticky-mobile .btn-success {
  background: var(--uapa-accent) !important;
  border-color: var(--uapa-accent) !important;
  font-weight: 700;
}

.uapa-sticky-mobile .btn-success:hover {
  background: #e67600 !important;
  border-color: #e67600 !important;
}
