X

Contrato de Desarrollo de Software en México: Qué Debe Incluir y Errores Comunes

9/6/2026

¿Por Qué Necesitas un Contrato de Desarrollo de Software?

Imagina esto: contratas a una empresa de desarrollo para crear tu plataforma digital, inviertes $800,000 MXN, y meses después descubres que el código fuente no es tuyo legalmente, que no hay garantía por bugs, y que cualquier cambio te costará miles adicionales. Este escenario es más común de lo que crees en México, y la razón principal es siempre la misma: la ausencia de un contrato de desarrollo de software bien estructurado.

 

En 2026, el desarrollo de software personalizado se ha convertido en una necesidad para empresas de todos los tamaños. Desde una startup fintech que necesita una app móvil, hasta una distribuidora que busca automatizar su inventario, todos requieren soluciones digitales. Pero sin un contrato adecuado, estás navegando a ciegas. Según datos del Instituto Mexicano de la Propiedad Industrial (IMPI), más del 40% de las disputas entre clientes y proveedores de software se originan por contratos ambiguos o inexistentes.

 

Un contrato de desarrollo de software no es solo un documento legal: es tu póliza de seguro contra malentendidos, incumplimientos y pérdidas económicas. Define quién posee el código, qué sucede si el proyecto se retrasa, cómo se manejan los cambios de alcance, y bajo qué condiciones puedes cancelar. En México, donde la legislación sobre software aún está evolucionando, tener un contrato robusto es la diferencia entre un proyecto exitoso y una pesadilla legal.

 

Este artículo te guiará paso a paso por todo lo que debe incluir un contrato de desarrollo de software en México en 2026. Desde las cláusulas indispensables hasta los errores más comunes que cometen tanto clientes como proveedores. Al final, sabrás exactamente qué buscar, qué negociar, y cómo proteger tu inversión. Si estás considerando contratar desarrollo de software, Magokoro puede ayudarte no solo con el desarrollo, sino también con la estructura contractual adecuada para tu proyecto.

 

Marco Legal del Software en México: Lo Que Dice la Ley

Antes de entrar en cláusulas y términos, es fundamental entender el marco legal que regula el desarrollo de software en México. A diferencia de bienes tangibles, el software tiene una naturaleza dual: es un producto intangible protegido por derechos de autor, pero también puede ser objeto de contratos de servicio.

 

Ley Federal del Derecho de Autor (LFDA)

El software está protegido en México por la Ley Federal del Derecho de Autor, que lo considera una "obra literaria". Esto significa que:

  • El autor original (el desarrollador o empresa de desarrollo) es el titular de los derechos patrimoniales del código fuente por defecto
  • Para que el cliente adquiera estos derechos, debe haber una cesión explícita de derechos patrimoniales en el contrato
  • Sin cesión, el cliente solo tiene una licencia de uso, pero no puede modificar, vender o redistribuir el código
  • Los derechos morales (paternidad de la obra) son irrenunciables en México, aunque rara vez afectan proyectos comerciales

 

Este punto es CRÍTICO y el error número uno en contratos de desarrollo: asumir que porque pagaste, eres dueño del código. La LFDA dice lo contrario. Si tu contrato no especifica una cesión de derechos, técnicamente no puedes contratar a otro desarrollador para modificar tu software sin permiso del creador original.

 

Código Civil Federal y Contratos de Prestación de Servicios

El desarrollo de software se regula principalmente como un contrato de prestación de servicios profesionales (Artículos 2606-2615 del Código Civil Federal). Esto implica:

  • El contrato debe especificar el objeto del servicio (qué se va a desarrollar), el precio, y los plazos de entrega
  • Si no se cumplen los plazos, el cliente puede rescindir el contrato o exigir cumplimiento con indemnización por daños
  • El proveedor tiene derecho a cobrar por el trabajo realizado hasta la fecha de rescisión
  • Las cláusulas penales (multas por incumplimiento) son válidas siempre que no sean excesivas o desproporcionadas

 

Ley Federal de Protección de Datos Personales en Posesión de los Particulares (LFPDPPP)

Si tu software maneja datos personales (usuarios, clientes, empleados), el contrato debe incluir cláusulas de cumplimiento con la LFPDPPP. Esto significa:

  • Especificar quién es el responsable de los datos (generalmente el cliente) y quién es el encargado (el proveedor que los procesa)
  • El proveedor debe implementar medidas de seguridad (cifrado, accesos restringidos) para proteger los datos
  • En caso de brechas de seguridad, el proveedor debe notificar al cliente en un plazo determinado (típicamente 72 horas)
  • El contrato debe prohibir al proveedor usar los datos para fines distintos al proyecto

 

En Magokoro, todos nuestros contratos incluyen cláusulas específicas de protección de datos alineadas con la LFPDPPP, especialmente críticas para proyectos en sectores como salud, finanzas y retail.

 

Normatividad Internacional (cuando aplique)

Si tu proyecto involucra clientes o usuarios en la Unión Europea, debes considerar el GDPR (Reglamento General de Protección de Datos). Si operas en California, el CCPA (California Consumer Privacy Act). Aunque tu empresa esté en México, si procesas datos de residentes de esas regiones, estás sujeto a sus leyes. El contrato debe especificar:

  • Qué regulaciones internacionales aplican
  • Quién es responsable de cumplirlas (generalmente el cliente, pero el proveedor debe implementar funcionalidades de compliance)
  • Costos adicionales por funcionalidades específicas de GDPR/CCPA (por ejemplo, botón de "eliminar mis datos")

 

Elementos Esenciales de un Contrato de Desarrollo de Software

Ahora que conoces el marco legal, pasemos a lo práctico: qué debe incluir tu contrato de desarrollo de software. Voy a desglosar cada sección con ejemplos concretos y cláusulas recomendadas.

 

1. Identificación de las Partes

Parece obvio, pero debe incluir:

  • Cliente: nombre completo o razón social, RFC, domicilio fiscal, representante legal (con poderes para firmar contratos)
  • Proveedor: igual que arriba
  • Fecha de firma y lugar (ciudad en México, importante para jurisdicción)

 

Ejemplo de cláusula:

"Contrato de Prestación de Servicios de Desarrollo de Software que celebran, por una parte, DISTRIBUIDORA EJEMPLO S.A. DE C.V., representada por su Director General, el C. Juan Pérez García, (en adelante 'EL CLIENTE'), y por la otra parte, MAGOKORO S.A. DE C.V., representada por su Director de Operaciones, el C. María López Ruiz, (en adelante 'EL PROVEEDOR'), en la Ciudad de México, a 9 de junio de 2026."

 

2. Objeto del Contrato y Alcance del Proyecto

Esta es la sección más importante y la que genera más disputas. Debe describir qué se va a desarrollar con el mayor detalle posible. Incluye:

  • Descripción funcional: qué hace el software, para qué sirve, qué problemas resuelve
  • Funcionalidades específicas: listado de características (login de usuarios, generación de reportes, integración con API X, etc.)
  • Tecnologías a utilizar: lenguajes de programación, frameworks, bases de datos, infraestructura (AWS, Azure, Google Cloud)
  • Plataformas: ¿Web? ¿App iOS/Android? ¿Desktop?
  • Integraciones: APIs de terceros, sistemas existentes (ERP, CRM, contabilidad)
  • Anexos técnicos: wireframes, mockups, diagramas de flujo, especificaciones de API

 

Ejemplo de cláusula:

Te puede interesar: cuánto cuesta desarrollar una app en México.

"EL PROVEEDOR se obliga a desarrollar un sistema de gestión de inventario y rutas de distribución (en adelante 'EL SOFTWARE') que permita a EL CLIENTE: (i) registrar y dar seguimiento a productos en almacén, (ii) generar órdenes de compra y venta, (iii) optimizar rutas de entrega mediante geolocalización, (iv) emitir facturas electrónicas (CFDI) mediante integración con proveedor PAC, (v) generar reportes de ventas y rotación de inventario. EL SOFTWARE será una aplicación web responsiva desarrollada en React (frontend) y Node.js (backend), con base de datos PostgreSQL alojada en AWS. Se incluye aplicación móvil para choferes (iOS y Android) desarrollada en React Native. El detalle funcional se encuentra en el Anexo A (Especificaciones Funcionales) y el Anexo B (Diseños UX/UI), los cuales forman parte integral de este contrato."

 

Consejo: Entre más específico seas, menos espacio hay para interpretaciones. Si algo no está en el contrato ni en los anexos, NO está incluido en el alcance. Cualquier funcionalidad adicional debe pasar por un proceso de cambio de alcance (ver sección más adelante).

 

3. Cronograma de Entrega y Fases del Proyecto

Define cuándo se entregará el software y en qué etapas. Los proyectos grandes deben dividirse en fases con entregables específicos. Esto facilita el control de calidad y vincula los pagos a avances concretos.

 

Ejemplo de cronograma por fases:

  • Fase 1 - Diseño y Arquitectura (4 semanas): wireframes, mockups de alta fidelidad, diagrama de arquitectura, plan de desarrollo. Entregable: documentación de diseño aprobada por EL CLIENTE.
  • Fase 2 - Desarrollo del MVP (8 semanas): implementación de funcionalidades core (inventario, órdenes, facturación). Entregable: versión funcional en ambiente de pruebas.
  • Fase 3 - Desarrollo de App Móvil (6 semanas): app para choferes con geolocalización y captura de entregas. Entregable: app en TestFlight (iOS) y Google Play Beta.
  • Fase 4 - Integración y Pruebas (4 semanas): integración con sistemas existentes, pruebas de carga, corrección de bugs. Entregable: software completo en producción.
  • Fase 5 - Capacitación y Lanzamiento (2 semanas): capacitación a usuarios, migración de datos, go-live. Entregable: sistema en operación y equipo capacitado.

 

Duración total: 24 semanas (6 meses)

 

Cláusula de cronograma:

"El desarrollo de EL SOFTWARE se realizará en cinco fases según el cronograma del Anexo C. Cada fase concluye con la entrega de los componentes especificados y la aprobación por escrito de EL CLIENTE en un plazo no mayor a 5 días hábiles. La aprobación no podrá ser retenida sin causa justificada. Si EL CLIENTE no responde en el plazo establecido, se considerará aprobación tácita y EL PROVEEDOR podrá continuar con la siguiente fase."

 

Importante: Especifica qué pasa si el cliente no aprueba a tiempo. Muchos proyectos se retrasan porque el cliente tarda semanas en revisar, y luego culpa al proveedor por el retraso.

 

Conoce más sobre nuestra desarrollo de software y aplicaciones.

4. Costo Total, Esquema de Pagos y Forma de Pago

Define cuánto cuesta el proyecto y cómo se pagará. Los esquemas más comunes son:

  • Precio fijo total: se define un monto global que cubre todo el alcance. Ejemplo: $1,200,000 MXN + IVA.
  • Pagos por hitos (milestones): el costo se divide en porcentajes vinculados a entregables. Ejemplo:
    • 30% ($360,000 MXN) al firmar el contrato
    • 20% ($240,000 MXN) al aprobar diseño (Fase 1)
    • 25% ($300,000 MXN) al entregar MVP (Fase 2)
    • 15% ($180,000 MXN) al entregar app móvil (Fase 3)
    • 10% ($120,000 MXN) al lanzamiento exitoso (Fase 5)
  • Tiempo y materiales (T&M): pagas por horas trabajadas. Ejemplo: $1,500 MXN/hora para desarrolladores senior, $1,000 MXN/hora para junior. Se factura mensualmente con reporte de horas detallado.

 

Cláusula de costo y pagos:

"El costo total de EL SOFTWARE es de $1,200,000.00 MXN (Un millón doscientos mil pesos 00/100 M.N.) más IVA. Los pagos se realizarán en cinco exhibiciones vinculadas a los entregables de cada fase, según el siguiente esquema: [detallar como arriba]. Cada pago será exigible al aprobar formalmente el entregable correspondiente. EL CLIENTE realizará los pagos mediante transferencia bancaria a la cuenta de EL PROVEEDOR en un plazo no mayor a 5 días hábiles después de recibir la factura. Los pagos fuera de plazo generarán intereses moratorios del 2% mensual."

 

Consejo: NUNCA pagues el 100% por adelantado. Tampoco esperes hasta el final para pagar todo. Los pagos por hitos protegen a ambas partes y mantienen incentivos alineados.

 

5. Propiedad Intelectual y Cesión de Derechos

Esta es la cláusula que separa un buen contrato de uno mediocre. Define quién es dueño del código fuente, diseños, base de datos y todo material generado.

 

Opciones:

  • Cesión total de derechos patrimoniales: el cliente se convierte en propietario absoluto del código. Puede modificarlo, venderlo, licenciarlo a terceros sin restricciones. Esta es la opción más común y recomendada para software a medida.
  • Licencia exclusiva de uso: el cliente puede usar el software, pero no posee el código fuente. No puede modificarlo sin permiso ni venderlo. Usada en software como servicio (SaaS) donde el proveedor retiene control del código.
  • Licencia no exclusiva: el cliente puede usar el software, pero el proveedor puede vender la misma solución a otros clientes. Común en soluciones estándar pre-construidas.

 

Cláusula de cesión de derechos (recomendada para software a medida):

"EL PROVEEDOR cede a favor de EL CLIENTE, de manera total, definitiva e irrevocable, todos los derechos patrimoniales sobre el código fuente, diseños, base de datos, documentación técnica y cualquier material desarrollado en el marco de este contrato. Esta cesión incluye, de manera enunciativa mas no limitativa, los derechos de: (i) reproducción, (ii) distribución, (iii) comunicación pública, (iv) transformación, modificación y creación de obras derivadas, (v) comercialización y licenciamiento a terceros. EL CLIENTE podrá ejercer estos derechos sin limitación alguna y sin obligación de compensación adicional a EL PROVEEDOR. La cesión se perfecciona con el pago total del costo del proyecto. EL PROVEEDOR conserva únicamente los derechos morales de paternidad de la obra, que no afectan el uso comercial de EL SOFTWARE por parte de EL CLIENTE."

 

Excepción - Código Reutilizable:

Muchos proveedores usan librerías, componentes o frameworks propios que aportan al proyecto pero no quieren ceder. Esto es válido si se especifica:

"Se exceptúan de la cesión anterior los componentes reutilizables de EL PROVEEDOR detallados en el Anexo D (ej: sistema de autenticación, librería de reportes), los cuales permanecen como propiedad de EL PROVEEDOR pero se licencian a EL CLIENTE de manera perpetua y sin costo adicional para su uso exclusivo en EL SOFTWARE. EL CLIENTE no podrá extraer estos componentes para usarlos en otros proyectos."

 

Te puede interesar: las mejores empresas de desarrollo de software en México.

En Magokoro, siempre cedemos los derechos completos del código desarrollado específicamente para el cliente, reteniendo únicamente nuestras librerías internas que aceleran el desarrollo y reducen costos.

 

6. Confidencialidad y Protección de Información

Durante el desarrollo, el proveedor accederá a información sensible: datos de clientes, estrategias de negocio, APIs privadas, etc. El contrato debe incluir cláusulas de confidencialidad robustas.

 

Cláusula de confidencialidad:

"Ambas partes acuerdan mantener en estricta confidencialidad toda información sensible intercambiada durante la vigencia de este contrato, incluyendo pero no limitándose a: (i) datos de clientes y usuarios, (ii) estrategias comerciales, (iii) credenciales de acceso a sistemas, (iv) APIs y documentación técnica propietaria, (v) información financiera. Esta obligación permanece vigente por un plazo de 5 años después de la terminación del contrato. Se exceptúa de esta obligación la información que: (a) sea de dominio público, (b) haya sido legalmente obtenida de terceros sin restricción de confidencialidad, (c) deba revelarse por mandato de autoridad competente. En caso de incumplimiento, la parte infractora indemnizará a la otra por daños y perjuicios, con mínimo equivalente al 50% del valor del contrato."

 

NDA Adicional: Para proyectos particularmente sensibles, es recomendable firmar un NDA (Non-Disclosure Agreement) separado ANTES de compartir información detallada y firmar el contrato de desarrollo.

 

7. Garantías, Mantenimiento y Soporte Post-Entrega

¿Qué pasa si después del lanzamiento aparecen bugs? ¿Quién los arregla y quién paga? Esta sección define:

  • Período de garantía: tiempo durante el cual el proveedor corrige errores sin costo adicional. Típicamente 3-6 meses.
  • Qué está cubierto: errores funcionales (bugs), problemas de rendimiento, fallos de seguridad. NO incluye cambios de funcionalidad ni nuevas features.
  • Tiempo de respuesta: SLA (Service Level Agreement) para atender reportes. Ejemplo: bugs críticos (sistema caído) en 4 horas, bugs menores en 48 horas.
  • Mantenimiento continuo: después de la garantía, costo anual de mantenimiento (actualizaciones, parches de seguridad, soporte). Típicamente 15-20% del costo de desarrollo anual.

 

Cláusula de garantía:

"EL PROVEEDOR garantiza que EL SOFTWARE funcionará conforme a las especificaciones del Anexo A por un período de 6 meses a partir del lanzamiento en producción. Durante este período, EL PROVEEDOR corregirá sin costo adicional cualquier error funcional reportado por EL CLIENTE, con los siguientes tiempos de respuesta: (i) bugs críticos (sistema inoperante): solución en máximo 4 horas hábiles, (ii) bugs mayores (funcionalidad clave afectada): solución en 24 horas hábiles, (iii) bugs menores (afectan UX pero no operación): solución en 72 horas hábiles. Después del período de garantía, EL CLIENTE podrá contratar un plan de mantenimiento anual por $180,000 MXN + IVA, que incluye: actualizaciones de seguridad, parches de compatibilidad, soporte técnico vía email/chat, y hasta 20 horas de desarrollo de mejoras menores."

 

Importante: Define claramente qué es un "bug" vs una "mejora". Muchas disputas surgen porque el cliente reporta como bug algo que en realidad es una funcionalidad nueva no incluida en el alcance original.

 

8. Penalizaciones por Incumplimiento (de Ambas Partes)

Un buen contrato protege a ambas partes. Las penalizaciones deben ser equilibradas:

  • Por retraso del proveedor: descuento de 2-5% del costo total por cada semana de retraso, con tope máximo de 20%. Después de ese tope, el cliente puede rescindir.
  • Por retraso del cliente: si el cliente no aprueba entregables a tiempo, no proporciona información necesaria, o no paga en plazo, el cronograma se extiende sin penalización para el proveedor.
  • Por incumplimiento de especificaciones: si el software no cumple con las funcionalidades acordadas, el proveedor debe corregirlo sin costo. Si persiste, el cliente puede retener el pago correspondiente a esa fase.

 

Cláusula de penalizaciones:

"Si EL PROVEEDOR no entrega en los plazos establecidos por causas imputables a él, se aplicará una penalización de 3% del costo total del proyecto por cada semana de retraso, con un tope máximo de 15%. Después de 5 semanas de retraso acumulado, EL CLIENTE podrá rescindir el contrato y EL PROVEEDOR deberá reintegrar todos los pagos recibidos, menos el valor del trabajo efectivamente entregado y aprobado. No se aplicarán penalizaciones si el retraso se debe a: (i) falta de aprobación oportuna de EL CLIENTE, (ii) cambios de alcance solicitados por EL CLIENTE, (iii) eventos de fuerza mayor (desastres naturales, pandemias, cambios regulatorios). En caso de retraso en pagos por parte de EL CLIENTE superior a 10 días hábiles, EL PROVEEDOR podrá suspender el desarrollo hasta recibir el pago correspondiente, sin que esto constituya incumplimiento."

 

9. Gestión de Cambios de Alcance (Change Orders)

En el 90% de los proyectos de software, el alcance cambia durante el desarrollo. El cliente tiene nuevas ideas, descubre requisitos no contemplados, o el mercado evoluciona. Esto es normal, pero debe gestionarse formalmente para evitar "scope creep" (expansión incontrolada del alcance).

 

Cláusula de cambios de alcance:

"Cualquier modificación al alcance definido en el Anexo A deberá solicitarse mediante un Change Order (Orden de Cambio) por escrito. EL PROVEEDOR evaluará el impacto en costo y cronograma, y enviará una cotización en máximo 3 días hábiles. Si EL CLIENTE aprueba, se firmará un addendum al contrato actualizando el alcance, costo y fechas de entrega. Los cambios menores que no afecten cronograma ni requieran más de 4 horas de desarrollo se absorberán sin costo adicional, con límite de 20 horas acumuladas durante el proyecto. Los cambios no aprobados formalmente no se implementarán."

 

 

💡 ¿Necesitas ayuda con contratos de desarrollo de software? En Magokoro tenemos experiencia implementando asesoría legal y técnica para proyectos de software para empresas en México. Agenda una consultoría gratuita →

 

Consejo: Documenta TODO cambio por escrito. Nunca aceptes "cambios rápidos" de palabra que luego se vuelven grandes modificaciones no facturadas.

 

10. Causas de Rescisión y Terminación Anticipada

Define bajo qué condiciones cualquiera de las partes puede terminar el contrato antes de completar el proyecto.

 

Cláusula de rescisión:

"EL CLIENTE podrá rescindir este contrato en cualquier momento mediante notificación por escrito con 15 días de anticipación, pagando: (i) el valor del trabajo completado y aprobado hasta la fecha, (ii) una penalización del 10% del saldo pendiente del proyecto. EL PROVEEDOR deberá entregar todo el código fuente, diseños y documentación desarrollados hasta ese momento. EL PROVEEDOR podrá rescindir si: (i) EL CLIENTE acumula más de 30 días de retraso en pagos, (ii) EL CLIENTE no cumple con sus obligaciones de aprobación y provisión de información por más de 4 semanas, (iii) EL CLIENTE solicita funcionalidades ilegales o que infringen derechos de terceros. Cualquiera de las partes podrá rescindir sin penalización en caso de fuerza mayor que imposibilite la continuación del proyecto por más de 60 días."

 

Errores Comunes en Contratos de Desarrollo de Software

Ahora que sabes qué debe incluir un contrato, veamos los errores más frecuentes que cometen empresas mexicanas (tanto clientes como proveedores) y cómo evitarlos.

Te puede interesar: outsourcing de desarrollo de software.

 

Error #1: Alcance Ambiguo o Demasiado General

Problema: El contrato dice "desarrollar una app móvil para gestión de ventas" sin especificar funcionalidades exactas. Resultado: el cliente espera 50 features, el proveedor entrega 20, y ambos tienen razón según el contrato.

 

Solución: Anexa especificaciones funcionales detalladas. Incluye wireframes, diagramas de flujo, listas de funcionalidades numeradas. Si algo no está en el anexo, no está en el alcance. Magokoro siempre genera un documento de especificaciones de 20-40 páginas que firma el cliente ANTES de empezar a codear.

 

Error #2: No Definir Quién Posee el Código Fuente

Problema: El contrato no menciona propiedad intelectual. El cliente asume que por pagar es dueño. El proveedor asume que retiene el código. Seis meses después, el cliente quiere contratar a otro equipo para agregar funcionalidades y descubre que legalmente no puede.

 

Solución: Incluye una cláusula explícita de cesión de derechos patrimoniales (como la que vimos arriba). Si el proveedor retiene el código, que sea claro y el cliente reciba una licencia perpetua de uso sin costo adicional.

 

Error #3: Pagar 100% por Adelantado o 100% al Final

Problema (100% adelantado): El cliente paga todo antes de ver resultado alguno. Si el proveedor resulta ser incompetente o desaparece, el dinero está perdido.

 

Problema (100% al final): El proveedor trabaja durante meses sin recibir un solo peso. Si el proyecto toma más tiempo del estimado, puede quedarse sin flujo de efectivo y abandonar.

 

Solución: Pagos por hitos vinculados a entregables. Típicamente: 30% al inicio, 40-50% distribuido en fases intermedias, 10-20% al lanzamiento exitoso. Esto alinea incentivos y reduce riesgos para ambos.

 

Error #4: No Especificar Tiempos de Respuesta para Aprobaciones

Problema: El proveedor entrega la Fase 1 (diseño) y espera aprobación del cliente. El cliente tarda 3 semanas en revisar. Luego reclama que el proyecto va retrasado. El proveedor dice que la culpa es del cliente.

 

Solución: Define en el contrato que el cliente tiene, por ejemplo, 5 días hábiles para revisar y aprobar cada entregable. Si no responde en ese plazo, se considera aprobación tácita y el cronograma continúa. También define que el cronograma se extiende proporcionalmente a cualquier retraso del cliente.

 

Error #5: Confundir "Bug" con "Nueva Funcionalidad"

Problema: El cliente reporta: "El sistema no envía notificaciones por WhatsApp". El proveedor responde: "Porque no estaba en el alcance, solo incluimos email". El cliente insiste: "Es un bug, deben arreglarlo sin costo".

 

Solución: Define claramente en el contrato que un "bug" es cualquier desviación de las especificaciones del Anexo A. Si una funcionalidad no estaba en el Anexo A, no es un bug, es un cambio de alcance que requiere un Change Order y cotización adicional.

 

Error #6: No Incluir Cláusula de Fuerza Mayor

Problema: Después de la pandemia COVID-19, muchas empresas aprendieron esto de la manera difícil. Un contrato sin cláusula de fuerza mayor obliga al proveedor a cumplir incluso si un desastre natural, pandemia o cambio regulatorio hace imposible el desarrollo.

 

Solución: Incluye una cláusula que suspenda obligaciones en caso de eventos fuera del control de las partes. Después de 60-90 días de suspensión, cualquiera puede rescindir sin penalización, pagando solo por el trabajo completado.

 

Error #7: Olvidar la Infraestructura y Hosting

Problema: El contrato especifica el desarrollo del software, pero no aclara quién contrata y paga los servidores, dominios, SSL, servicios de terceros (email, SMS, pagos). Al lanzar, descubren que nadie presupuestó $15,000 MXN/mes de AWS.

 

Solución: Especifica si el costo de desarrollo incluye infraestructura o si el cliente la contratará por separado. En Magokoro, ofrecemos dos modalidades: (1) cliente contrata su propia infraestructura (tenemos guías de configuración), o (2) incluimos 6 meses de hosting en el precio del proyecto y después el cliente asume el costo mensual.

 

Error #8: No Definir el Proceso de Aceptación Final

Problema: El proveedor dice "está listo, paguen el saldo final". El cliente dice "aún hay detalles, no pagamos hasta que esté perfecto". Ninguno tiene razón clara porque el contrato no define qué significa "listo".

 

Solución: Define un proceso formal de aceptación: (1) el proveedor notifica que el software está completo, (2) el cliente tiene 10 días para hacer pruebas exhaustivas (User Acceptance Testing - UAT), (3) cualquier problema detectado en ese período se clasifica como bug (si desviación de especificaciones) o mejora (si nueva funcionalidad), (4) el cliente firma un Acta de Aceptación al aprobar, disparando el pago final. Si el cliente rechaza, debe listar específicamente qué no cumple las especificaciones.

 

Aspectos Legales Específicos de México que Debes Conocer

México tiene particularidades legales que afectan contratos de software:

Te puede interesar: metodologías ágiles en desarrollo de software.

 

Retención de IVA en Servicios Profesionales

Si contratas a una persona física (freelancer) para desarrollo de software, por ley debes retenerle el IVA y enterarlo al SAT. Esto NO aplica si contratas a una persona moral (empresa con S.A. de C.V. o S. de R.L. de C.V.). El contrato debe especificar si hay retención.

 

Facturación Electrónica (CFDI)

Todos los pagos deben respaldarse con CFDI (Comprobante Fiscal Digital por Internet). El contrato debe especificar que el proveedor emitirá factura electrónica al recibir cada pago, con clave de producto/servicio 81112000 (Consultoría en programas de informática).

 

Registro de Contratos en INDAUTOR (Opcional pero Recomendable)

Puedes registrar tu contrato y la cesión de derechos en el Instituto Nacional del Derecho de Autor (INDAUTOR). No es obligatorio, pero otorga certeza jurídica y facilita demostrar titularidad del código ante disputas. Costo: ~$2,500 MXN, plazo: 4-6 semanas.

 

Jurisdicción y Legislación Aplicable

El contrato debe especificar bajo qué leyes se rige y qué tribunales tienen jurisdicción en caso de disputa.

 

Cláusula de jurisdicción:

"Para la interpretación y cumplimiento de este contrato, las partes se someten a las leyes de los Estados Unidos Mexicanos y a la jurisdicción de los tribunales de la Ciudad de México, renunciando expresamente a cualquier otro fuero que pudiera corresponderles por razón de su domicilio presente o futuro."

 

Contratos de Precio Fijo vs Tiempo y Materiales: ¿Cuál Conviene?

Hay dos modelos principales de contratación para desarrollo de software. Cada uno tiene ventajas y desventajas según el tipo de proyecto.

 

Precio Fijo (Fixed Price)

Qué es: Se define un alcance específico, un costo total y un cronograma de entrega. El proveedor se compromete a entregar todo lo acordado por ese precio, sin importar cuántas horas tome.

 

Conoce más sobre nuestra agenda una consultoría gratuita.

Ventajas para el cliente:

  • Presupuesto predecible, no hay sorpresas
  • Riesgo del proyecto transferido al proveedor (si toma más tiempo, el proveedor pierde, no el cliente)
  • Facilita aprobaciones internas y contabilidad

 

Desventajas para el cliente:

  • Menos flexibilidad para cambios (cualquier modificación requiere renegociación)
  • Puede ser más caro si el alcance es incierto (el proveedor agrega "colchón" de seguridad al precio)
  • Si el cliente no define bien el alcance, puede acabar con un producto que "cumple el contrato" pero no satisface necesidades reales

 

Cuándo usar precio fijo:

  • Proyectos con requisitos claros y estables (ej: migración de sistema existente, app con especificaciones bien definidas)
  • Cliente tiene presupuesto fijo y no puede excederlo
  • Proyecto tiene deadline estricto (ej: lanzamiento antes de temporada alta)

 

Tiempo y Materiales (Time & Materials - T&M)

Qué es: El cliente paga por las horas efectivamente trabajadas. Se define una tarifa por hora (ej: $1,200 MXN/hora) y se factura mensualmente con reporte detallado de actividades.

 

Ventajas para el cliente:

  • Máxima flexibilidad para cambiar prioridades y alcance durante el desarrollo
  • Solo pagas por lo que realmente se trabaja, no por estimaciones infladas
  • Ideal para proyectos exploratorios o de innovación donde los requisitos evolucionan

 

Desventajas para el cliente:

  • Presupuesto incierto, puede exceder lo planeado
  • Requiere supervisión constante para asegurar que las horas se usan eficientemente
  • Dificulta aprobaciones internas ("no sabemos cuánto costará al final")

 

Cuándo usar T&M:

  • Proyectos de investigación y desarrollo (R&D) donde el alcance final es desconocido
  • Startups en etapa temprana que pivotean frecuentemente
  • Mantenimiento continuo y evolutivo de software existente
  • Cliente tiene equipo técnico que puede supervisar y priorizar el trabajo

 

Modelo Híbrido: Precio Fijo con "Capping" de Horas

Muchas empresas usan un modelo híbrido: precio fijo para el alcance mínimo (MVP), pero con flexibilidad para cambios menores dentro de un "banco de horas". Ejemplo:

  • Costo base: $900,000 MXN por alcance definido en Anexo A
  • Banco de 100 horas a $1,200 MXN/hora para cambios menores (total: $120,000 MXN)
  • Cambios que excedan el banco se cotizan y aprueban por separado

 

Esto combina predictibilidad de precio fijo con la flexibilidad de T&M para ajustes.

 

Checklist: Qué Revisar Antes de Firmar

Antes de firmar cualquier contrato de desarrollo de software, revisa esta checklist:

 

  • ☑ Identificación completa de ambas partes (razón social, RFC, representante legal con poderes)
  • ☑ Objeto del contrato claro y alcance detallado (con anexos técnicos: especificaciones, wireframes, diagrams)
  • ☑ Cronograma de entrega por fases con entregables específicos y fechas
  • ☑ Costo total y esquema de pagos por hitos (NUNCA 100% adelantado ni 100% al final)
  • ☑ Cláusula de cesión de derechos de autor o licencia de uso (según lo que necesites)
  • ☑ Cláusulas de confidencialidad para proteger información sensible
  • ☑ Garantías y soporte post-entrega (período, qué cubre, SLA)
  • ☑ Penalizaciones por incumplimiento (de ambas partes, no solo del proveedor)
  • ☑ Proceso de gestión de cambios de alcance (Change Orders)
  • ☑ Causas de rescisión y terminación anticipada
  • ☑ Cláusula de fuerza mayor
  • ☑ Aclaración sobre infraestructura y hosting (quién contrata, quién paga)
  • ☑ Proceso de aceptación final y criterios (UAT, Acta de Aceptación)
  • ☑ Tiempos de respuesta para aprobaciones del cliente
  • ☑ Jurisdicción y legislación aplicable
  • ☑ Cumplimiento con LFPDPPP si maneja datos personales
  • ☑ Especificación de tecnologías, plataformas y estándares
  • ☑ Plan de capacitación y transferencia de conocimiento (si aplica)

 

Si el contrato que te presentaron NO incluye al menos 12 de estos puntos, pide que lo revisen y completen ANTES de firmar. Un contrato incompleto es una bomba de tiempo.

 

Casos de Éxito: Cómo un Buen Contrato Salvó Proyectos

Para ilustrar la importancia de contratos bien estructurados, veamos casos reales (anónimos) de empresas mexicanas:

 

Caso 1: Distribuidora de Alimentos en CDMX

Situación: Una distribuidora contrató a un proveedor para desarrollar un sistema de gestión de rutas y entregas. El contrato especificaba 4 meses de desarrollo, precio fijo de $850,000 MXN, y cesión completa de derechos del código.

Te puede interesar: QA y testing de software.

 

Problema: A los 3 meses, el proveedor entregó una versión que no cumplía con el 40% de las funcionalidades especificadas en el Anexo A. El cliente rechazó la entrega.

 

Resolución: Gracias a que el contrato incluía: (1) especificaciones funcionales detalladas en anexo, (2) proceso de aceptación formal con criterios claros, (3) penalización del 4% por semana de retraso, el cliente pudo:

  • Demostrar que el software no cumplía lo acordado (lista de funcionalidades faltantes vs Anexo A)
  • Retener el pago final de $200,000 MXN hasta recibir las funcionalidades faltantes
  • Aplicar penalización de 12% ($102,000 MXN) por 3 semanas de retraso

 

El proveedor completó las funcionalidades en 3 semanas adicionales, el cliente pagó el saldo menos la penalización, y ambos quedaron conformes. Sin un contrato detallado, esto habría terminado en tribunal.

 

Caso 2: Fintech en Monterrey

Situación: Una startup fintech contrató desarrollo de una app de inversiones. El contrato NO incluía cláusula de cesión de derechos, solo mencionaba "prestación de servicios de desarrollo".

 

Problema: Después de lanzar, la startup levantó capital de inversionistas. Durante el due diligence, los inversionistas descubrieron que la startup NO era dueña del código fuente, técnicamente solo tenía una licencia de uso. El proveedor (un freelancer) podía legalmente negarse a ceder los derechos o pedir una compensación adicional.

 

Resolución: La startup tuvo que renegociar con el desarrollador, pagando $300,000 MXN adicionales para obtener la cesión de derechos retroactiva. Esto retrasó la inversión 2 meses.

 

Lección: Si tu startup planea levantar capital, asegúrate de POSEER el código fuente desde el día uno. Los inversionistas SIEMPRE revisan esto.

 

Caso 3: E-commerce en Guadalajara

Situación: Un comercio electrónico contrató rediseño de su plataforma con un proveedor bajo esquema de precio fijo ($1,100,000 MXN). El contrato incluía cláusula de cambios de alcance con Change Orders.

 

Problema: A mitad del proyecto, el cliente solicitó agregar: (1) integración con 3 marketplaces adicionales (Mercado Libre, Amazon, Walmart), (2) sistema de puntos de lealtad, (3) módulo de suscripciones recurrentes. Nada de esto estaba en el alcance original.

 

Resolución: Gracias a la cláusula de Change Orders, el proveedor cotizó los cambios ($420,000 MXN adicionales + 6 semanas), el cliente aprobó por escrito, y se firmó un addendum al contrato. El proyecto se completó sin disputas, ambos sabían qué esperar.

 

Lección: Los cambios son normales. Lo que NO es normal es no documentarlos y cobrarlos formalmente.

 

¿Cuánto Cuesta Desarrollar Software Personalizado en México en 2026?

Los costos varían enormemente según complejidad, tecnologías y proveedor. Aquí un desglose realista de precios en el mercado mexicano:

 

Software Básico (CRM, Inventario Simple, Landing Pages Dinámicas)

  • Alcance: 10-20 pantallas, funcionalidades CRUD, integraciones básicas (email, pagos)
  • Costo: $250,000 - $600,000 MXN
  • Plazo: 2-4 meses
  • Ejemplo: Sistema de gestión de clientes para un despacho contable, con facturación electrónica y reportes

 

Aplicaciones Móviles (iOS + Android)

  • Alcance: App nativa o híbrida (React Native, Flutter), 15-30 pantallas, backend con API, integraciones de terceros
  • Costo: $400,000 - $1,200,000 MXN
  • Plazo: 3-6 meses
  • Ejemplo: App de delivery para restaurante, con geolocalización, pagos, notificaciones push

 

Plataformas Web Complejas (Marketplaces, SaaS, ERPs)

  • Alcance: 50+ pantallas, múltiples roles de usuario, dashboards, integraciones complejas (contabilidad, logística, pagos), panel de administración robusto
  • Costo: $800,000 - $3,000,000 MXN
  • Plazo: 6-12 meses
  • Ejemplo: Plataforma de marketplace B2B para distribuidoras, con catálogo de 10,000+ productos, cotizaciones automatizadas, integración con SAP

 

Soluciones Enterprise con IA

  • Alcance: Sistemas complejos con machine learning, procesamiento de lenguaje natural, visión por computadora, arquitectura escalable para millones de usuarios
  • Costo: $2,500,000 - $10,000,000+ MXN
  • Plazo: 9-24 meses
  • Ejemplo: Plataforma de análisis de crédito para banco, con modelos de IA para scoring, detección de fraude, y recomendaciones personalizadas

 

Factores que Afectan el Costo

  • Diseño UX/UI: Un diseño custom profesional puede agregar 15-25% al costo vs usar templates
  • Integraciones: Cada integración con API de terceros (facturación, pagos, ERP, CRM) suma $30,000-$100,000 MXN dependiendo complejidad
  • Seguridad y compliance: Cumplir con LFPDPPP, PCI-DSS (pagos con tarjeta), HIPAA (salud) agrega 10-20% al costo
  • Infraestructura: Hosting básico (hasta 10,000 usuarios): $5,000-$15,000 MXN/mes. Escalable (100,000+ usuarios): $50,000-$200,000 MXN/mes
  • Mantenimiento anual: Típicamente 15-20% del costo de desarrollo inicial

 

En Magokoro, ofrecemos cotizaciones transparentes con desglose por fase, y siempre incluimos en el contrato los supuestos sobre los que se basa el precio. Si surge algo inesperado, lo discutimos abiertamente antes de continuar.

 

Diferencias Entre Contratar Freelancers vs Empresas de Desarrollo

Otra decisión importante es con quién contratar. Cada opción tiene pros y contras:

 

Freelancers o Desarrolladores Independientes

Ventajas:

  • Costo generalmente más bajo (tarifas de $500-$1,500 MXN/hora vs $1,200-$2,500 MXN/hora de empresas)
  • Comunicación directa con quien hace el trabajo
  • Flexibilidad de horarios y esquemas de pago

 

Te puede interesar: mantenimiento de software y costos ocultos.

Desventajas:

  • Riesgo de abandono (si se enferma, consigue otro proyecto mejor pagado, o simplemente desaparece)
  • Sin respaldo legal robusto (personas físicas tienen menos activos que embargar en caso de incumplimiento)
  • Limitación de capacidad (un freelancer no puede escalar a 10 desarrolladores si el proyecto crece)
  • Menor estructura: no hay PM, no hay QA, no hay diseñador... todo depende de una persona

 

Cuándo contratar freelancer:

  • Proyectos pequeños (<$300,000 MXN)
  • Tienes experiencia técnica y puedes supervisar el trabajo
  • No tienes deadline crítico

 

Empresas de Desarrollo (Software Houses)

Ventajas:

  • Equipo completo: desarrolladores, diseñadores, QA, project managers
  • Respaldo legal (empresa constituida con activos)
  • Procesos estructurados y metodologías (Agile, Scrum)
  • Capacidad de escalar recursos según necesidad del proyecto
  • Mayor probabilidad de continuidad (si un desarrollador renuncia, la empresa asigna otro)

 

Desventajas:

  • Costo más alto (incluye overhead de la empresa: oficinas, administración, impuestos)
  • Menos flexibilidad (horarios de oficina, procesos formales)
  • Comunicación mediada (hablas con PM, no directamente con desarrollador)

 

Cuándo contratar empresa:

  • Proyectos medianos a grandes (>$500,000 MXN)
  • Necesitas garantías y respaldo legal
  • Deadline estricto y alto riesgo de negocio si falla
  • No tienes expertise técnica para supervisar desarrollo

 

Magokoro es una empresa de desarrollo con presencia en México, lo que combina: (1) respaldo legal de una S.A. de C.V., (2) equipo multidisciplinario completo, (3) procesos estructurados con visibilidad total para el cliente, y (4) precios competitivos gracias a eficiencia operativa y herramientas de IA.

 

Red Flags: Señales de Alerta en Contratos de Software

Termino con una lista de señales de alerta que deberían hacerte reconsiderar firmar un contrato:

 

  • 🚩 El proveedor se niega a firmar NDA antes de discutir tu proyecto — señal de que no respeta confidencialidad
  • 🚩 El contrato no especifica plazos de entrega — "lo terminamos cuando lo terminamos" no es aceptable
  • 🚩 Solicitan 100% del pago por adelantado — riesgo altísimo de fraude o abandono
  • 🚩 No hay cláusula de cesión de derechos y el proveedor se niega a agregarla — quiere quedarse con tu código
  • 🚩 El "contrato" es un email o un PDF de 2 páginas — proyectos serios requieren contratos serios
  • 🚩 No hay especificaciones técnicas, solo descripciones vagas — "haremos una app bonita y funcional"
  • 🚩 El proveedor no hace preguntas durante la cotización — señal de que no entiende tu negocio o está usando plantillas genéricas
  • 🚩 No ofrecen garantía post-entrega — "una vez entregado, ya no es nuestro problema"
  • 🚩 Portafolio inexistente o con proyectos que no pueden demostrar — puede ser una empresa fantasma
  • 🚩 Presión para firmar rápido "porque la oferta expira" — táctica de venta, no de partner profesional

 

Si ves 3 o más de estas red flags, busca otro proveedor.

 

Conclusión: Un Buen Contrato es una Inversión, No un Gasto

Desarrollar software personalizado es una inversión significativa, tanto en dinero como en tiempo. Un contrato de desarrollo de software bien estructurado no es un trámite burocrático, es la columna vertebral de un proyecto exitoso. Protege tu inversión, define expectativas claras, previene malentendidos, y te da herramientas legales para exigir cumplimiento.

 

En México, donde la regulación de software está en constante evolución y muchas empresas aún operan con acuerdos informales, tener un contrato profesional te distingue y te protege. No importa si contratas a un freelancer de $200,000 MXN o a una empresa para un proyecto de $3,000,000 MXN: siempre, SIEMPRE firma un contrato detallado.

 

Si después de leer este artículo sientes que necesitas asesoría para estructurar tu proyecto o revisar un contrato que te presentaron, en Magokoro no solo desarrollamos software de clase mundial, también ayudamos a nuestros clientes a navegar el proceso contractual con transparencia total. Nuestros contratos incluyen todas las cláusulas mencionadas aquí, especificaciones técnicas detalladas, y un proceso de desarrollo con visibilidad en tiempo real.

 

Contáctanos para una consultoría inicial sin costo. Revisaremos tu proyecto, te daremos un estimado realista de costos y tiempos, y te explicaremos exactamente qué debe incluir tu contrato para proteger tu inversión.

 

Recuerda: un proyecto de software sin contrato es como construir una casa sin planos. Puede que salga bien... o puede que no. ¿Para qué arriesgarse?

 

 

¿Listo para dar el siguiente paso?

En Magokoro ayudamos a empresas mexicanas con asesoría legal y técnica para proyectos de software. Desde la estrategia hasta la implementación, nuestro equipo te acompaña en cada paso.

👉 Agenda tu consultoría gratuita aquí — sin compromiso, 100% enfocada en tu caso.

 

Preguntas Frecuentes (FAQ)

¿Qué debe incluir un contrato de desarrollo de software en México?

Un contrato de desarrollo de software debe incluir: alcance del proyecto detallado, cronograma de entrega por fases, costo total y esquema de pagos, cláusulas de propiedad intelectual, acuerdos de confidencialidad, garantías y mantenimiento post-entrega, términos de cancelación, y penalizaciones por incumplimiento. En México, debe cumplir con la Ley Federal del Derecho de Autor y el Código Civil.

 

¿Cuánto cuesta desarrollar un software personalizado en México en 2026?

Los costos varían según complejidad. Software básico (CRM, inventario): $250,000-$600,000 MXN. Apps móviles (iOS/Android): $400,000-$1,200,000 MXN. Plataformas web complejas: $800,000-$3,000,000 MXN. Soluciones enterprise con IA: $2,500,000+ MXN. El precio depende de funcionalidades, integraciones, diseño UX/UI y tecnologías usadas.

 

¿De quién es la propiedad del código fuente desarrollado?

Por defecto en México, el código fuente pertenece al desarrollador (Ley Federal del Derecho de Autor). Sin embargo, mediante cláusulas de "cesión de derechos patrimoniales" o "work for hire" en el contrato, puedes adquirir la propiedad completa del código. Es CRÍTICO especificar esto explícitamente en el contrato para evitar disputas legales futuras.

 

¿Qué son los hitos de pago y por qué son importantes?

Los hitos (milestones) dividen el proyecto en fases con entregables específicos. Ejemplo: 30% al firmar, 30% en diseño aprobado, 20% en desarrollo MVP, 20% en entrega final. Esto protege ambas partes: el cliente paga conforme recibe valor, y el proveedor recibe flujo continuo. Evita el riesgo de pagar 100% por adelantado o recibir el producto completo sin haber pagado nada.

 

¿Necesito un abogado para firmar un contrato de desarrollo de software?

Para proyectos mayores a $500,000 MXN o con cláusulas de propiedad intelectual complejas, SÍ es recomendable. Un abogado especializado en TI puede revisar: cesión de derechos, cláusulas de confidencialidad, penalizaciones, términos de rescisión, y cumplimiento con leyes mexicanas (LFDA, LFPDPPP). Para proyectos pequeños, una plantilla bien estructurada puede ser suficiente.

 

¿Qué pasa si el proveedor no entrega a tiempo?

El contrato debe incluir cláusulas de penalización por retraso. Ejemplo: descuento de 2-5% del costo total por cada semana de retraso, hasta un máximo de 20%. También debe especificar causas de "fuerza mayor" (desastres naturales, pandemias) que extienden plazos sin penalización. Si el retraso es grave, puedes invocar cláusulas de rescisión y recuperar pagos realizados.

 

¿Cómo proteger mi idea de negocio al contratar un desarrollador?

Mediante un NDA (Acuerdo de Confidencialidad) firmado ANTES de compartir información sensible. El contrato también debe incluir cláusulas de confidencialidad que prohíban al desarrollador usar tu idea para competidores o proyectos propios. En México, el NDA es vinculante legalmente y puedes demandar por daños si se incumple. Magokoro siempre firma NDAs con clientes antes de iniciar proyectos.

 

¿Qué incluye el mantenimiento post-entrega?

El contrato debe especificar: duración de garantía (típicamente 3-6 meses), qué bugs están cubiertos (errores funcionales vs mejoras nuevas), tiempo de respuesta (24-48h para bugs críticos), y costo de mantenimiento continuo después de la garantía (10-20% del costo de desarrollo anual). Sin esto, puedes enfrentar costos inesperados al reportar errores.

 

¿Puedo cancelar el contrato a mitad del proyecto?

Sí, pero debe estar definido en el contrato. Típicamente: el cliente puede cancelar pagando el trabajo completado hasta la fecha + una penalización (10-20% del saldo pendiente). El proveedor debe entregar todo el código y diseños producidos hasta ese momento. Sin una cláusula clara, la cancelación puede llevar a disputas legales costosas.

 

¿Qué diferencia hay entre un contrato de desarrollo fijo vs tiempo y materiales?

Precio fijo: alcance, costo y cronograma definidos desde el inicio. Ideal para proyectos con requisitos claros. Riesgo: cambios cuestan extra. Tiempo y materiales (T&M): pagas por horas trabajadas, mayor flexibilidad para cambios. Ideal para proyectos exploratorios o con requisitos que evolucionan. Riesgo: costo final puede exceder presupuesto. En México, el precio fijo es más común para evitar sorpresas.

Heading 1

Heading 2

Heading 3

Heading 4

Heading 5
Heading 6

Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur.

Block quote

Ordered list

  1. Item 1
  2. Item 2
  3. Item 3

Unordered list

  • Item A
  • Item B
  • Item C

Text link

Bold text

Emphasis

Superscript

Subscript