:root {
  --azul: #185fa5;
  --azul-claro: #e6f1fb;
  --verde: #0f6e56;
  --verde-claro: #e1f5ee;
  --rojo: #993c1d;
  --rojo-claro: #faece7;
  --gris-texto: #444441;
  --gris-claro: #888780;
  --gris-fondo: #f1efe8;
  --borde: #d3d1c7;
  --blanco: #ffffff;
  --radio: 10px;
}

* { box-sizing: border-box; }

body {
  margin: 0;
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  background: var(--gris-fondo);
  color: var(--gris-texto);
  line-height: 1.6;
}

.contenedor {
  max-width: 480px;
  margin: 0 auto;
  padding: 24px 16px 60px;
}

.contenedor-ancho {
  max-width: 900px;
  margin: 0 auto;
  padding: 24px 16px 60px;
}

.tarjeta {
  background: var(--blanco);
  border: 1px solid var(--borde);
  border-radius: var(--radio);
  padding: 20px;
  margin-bottom: 16px;
}

h1, h2, h3 { font-weight: 600; }
h1 { font-size: 22px; margin: 0 0 4px; }
h2 { font-size: 18px; margin: 0 0 12px; }
h3 { font-size: 15px; margin: 0 0 8px; }

.subtitulo { color: var(--gris-claro); font-size: 14px; margin: 0 0 20px; }

label { display: block; font-size: 13px; color: var(--gris-claro); margin-bottom: 4px; }

input[type="text"], input[type="email"], input[type="password"], textarea {
  width: 100%;
  padding: 10px 12px;
  border: 1px solid var(--borde);
  border-radius: 8px;
  font-size: 15px;
  margin-bottom: 14px;
  background: var(--blanco);
  color: var(--gris-texto);
}

textarea { min-height: 80px; resize: vertical; }

button, .boton {
  display: inline-block;
  width: 100%;
  padding: 12px 16px;
  border: none;
  border-radius: 8px;
  background: var(--azul);
  color: #fff;
  font-size: 15px;
  font-weight: 600;
  cursor: pointer;
  text-align: center;
  text-decoration: none;
}

button.secundario, .boton.secundario {
  background: transparent;
  color: var(--azul);
  border: 1px solid var(--borde);
}

button:disabled { opacity: 0.5; cursor: not-allowed; }

.enlace-simple {
  background: none;
  border: none;
  color: var(--azul);
  font-size: 14px;
  font-weight: 500;
  width: auto;
  padding: 0;
  text-decoration: underline;
}

.error { color: var(--rojo); font-size: 14px; margin: -4px 0 12px; }
.exito { color: var(--verde); font-size: 14px; margin: -4px 0 12px; }

.fila-superior {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 20px;
  gap: 12px;
}

.barra-progreso {
  height: 8px;
  background: var(--gris-fondo);
  border-radius: 99px;
  overflow: hidden;
  margin-bottom: 8px;
}
.barra-progreso-relleno {
  height: 100%;
  background: var(--verde);
}

.fila-modulo {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 0;
  border-bottom: 1px solid var(--gris-fondo);
  text-decoration: none;
  color: inherit;
}
.fila-modulo:last-child { border-bottom: none; }
.fila-modulo.bloqueado { opacity: 0.55; pointer-events: none; }

.icono-estado {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  font-size: 16px;
  font-weight: 700;
}
.icono-estado.completado { background: var(--verde-claro); color: var(--verde); }
.icono-estado.disponible { background: var(--azul-claro); color: var(--azul); }
.icono-estado.bloqueado { background: var(--gris-fondo); color: var(--gris-claro); }

.etiqueta-estado { font-size: 12px; }
.etiqueta-estado.completado { color: var(--verde); }
.etiqueta-estado.disponible { color: var(--azul); }
.etiqueta-estado.bloqueado { color: var(--gris-claro); }

.opcion-quiz {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 10px 12px;
  border: 1px solid var(--borde);
  border-radius: 8px;
  margin-bottom: 8px;
  cursor: pointer;
}
.opcion-quiz input { margin-top: 3px; }

.pregunta-quiz { margin-bottom: 20px; }
.pregunta-quiz p.texto-pregunta { font-weight: 600; margin-bottom: 10px; }

.resultado-quiz {
  padding: 14px;
  border-radius: 8px;
  margin-top: 16px;
  font-weight: 600;
}
.resultado-quiz.aprobado { background: var(--verde-claro); color: var(--verde); }
.resultado-quiz.reprobado { background: var(--rojo-claro); color: var(--rojo); }

table { width: 100%; border-collapse: collapse; font-size: 14px; }
th, td { text-align: left; padding: 10px 8px; border-bottom: 1px solid var(--gris-fondo); }
th { color: var(--gris-claro); font-weight: 500; font-size: 13px; }

.badge {
  display: inline-block;
  padding: 3px 10px;
  border-radius: 99px;
  font-size: 12px;
  font-weight: 600;
}
.badge.completado { background: var(--verde-claro); color: var(--verde); }
.badge.disponible { background: var(--azul-claro); color: var(--azul); }
.badge.sin-iniciar { background: var(--gris-fondo); color: var(--gris-claro); }

.metricas {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
  gap: 12px;
  margin-bottom: 20px;
}
.metrica {
  background: var(--blanco);
  border: 1px solid var(--borde);
  border-radius: var(--radio);
  padding: 14px;
}
.metrica .numero { font-size: 22px; font-weight: 700; }
.metrica .etiqueta { font-size: 12px; color: var(--gris-claro); }

.fila-respuesta { padding: 12px 0; border-bottom: 1px solid var(--gris-fondo); }
.fila-respuesta .pregunta { font-size: 13px; color: var(--gris-claro); margin-bottom: 4px; }
.fila-respuesta .respuesta { font-size: 15px; }

.tabs { display: flex; gap: 8px; margin-bottom: 16px; }
.tabs button { width: auto; flex: 1; }

@media (min-width: 700px) {
  .fila-modulo { padding: 14px 0; }
}
