
MUVi (Museo Universitario Virtual) — Plataforma para la venta de recorridos virtuales 360° de los museos de la Universidad de Colima: compra, acreditación de horas universitarias y CMS completo.
La Dirección General de Patrimonio Cultural de la UDC tiene museos con colecciones valiosas, pero sin presencia digital para mostrarlas ni venderlas.
La apuesta fue: recorridos virtuales inmersivos en 360° que cualquier persona pueda comprar desde casa, y que los estudiantes puedan acreditar como horas universitarias. Un museo que no cierra.

Obtén información de los museos de la Universidad de Colima.

Explora los diversos recorridos que ofrece cada museo.

Selecciona y compra vía MercadoPago, el de tu mayor interés.


Disfruta de la experiencia virtual con Kuula.


Obtén información de los museos de la Universidad de Colima.

Explora los diversos recorridos que ofrece cada museo.

Selecciona y compra vía MercadoPago, el de tu mayor interés.


Disfruta de la experiencia virtual con Kuula.

Entré como Frontend Developer pero el proyecto requería más. Cuando los endpoints del backend no estaban listos, los resolví para no bloquear la entrega.
El CMS se construyó como un sistema de gestión completo con edición de contenido, subida de imágenes y configuración de los tours Kuula.
Página de presentación de MUVi, los museos y sus colecciones. Catálogo de recorridos disponibles con precio y descripción.
Integración de pagos para comprar recorridos. Estudiantes pueden canjear su acceso por horas universitarias acreditables.
Integración con Kuula para incrustar los tours virtuales inmersivos dentro de la plataforma, una vez completada la compra.
Panel de administración para gestionar museos, exposiciones, recorridos y contenido sin intervención técnica. Construido sobre Prisma + PostgreSQL.

El proyecto tuvo cambios de requerimientos constantes desde la product owner.
Aprendí a no enamorarme de mis diseños: separar lo que cambia (contenido, estructura de secciones) de lo que no puede cambiar (arquitectura del CMS, flujo de pagos).