/* --- Definición de Fuentes Personalizadas --- */
@font-face {
    font-family: 'CrackerGrotesk';
    src: url('fonts/cracker-grotesk-regular.woff2') format('woff2'),
         url('fonts/cracker-grotesk-regular.otf') format('opentype');
    font-weight: normal;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'TanNimbus';
    src: url('fonts/tan-nimbus.woff2') format('woff2'),
         url('fonts/tan-nimbus.otf') format('opentype');
    font-weight: normal;
    font-style: normal;
    font-display: swap;
}
.t-dots {
    font-family: Arial, Helvetica, sans-serif !important;
    font-weight: bold;
}
.m-0 {
    margin: 0;
}
.font-principal {
    font-family: var(--font-principal) !important;
}
/* --- Paleta de Colores y Variables Globales --- */
:root {
    --color-primario: #024391;
    --color-secundario: #F898D7;
    --color-acento: #FADD44;
    
    --fondo-base: #FDF9F0;
    --fondo-blanco: #ffffff;
    --texto-base: #333;

    /* Variables de fuentes */
    --font-principal: 'CrackerGrotesk', -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
    --font-titulos: 'TanNimbus', serif;

    /* --- VARIABLES DE TIPOGRAFÍA --- */
    --h2-desktop-size: 2.2rem;
    --h3-desktop-size: 2rem;
    --h2-mobile-size: 1.3rem;
    --h3-mobile-size: 1rem;
    --kerning-titulos: 0px; /* <-- VARIABLE PARA AJUSTAR ESPACIO ENTRE LETRAS */


    /* Variables de layout */
    --padding-horizontal: 2rem; /* Padding para móvil y tablet */
    --header-height: 72px; 
    --section-padding-a: 32vw;
    --section-padding-b: 250px;

    /* Variables para el texto grande de dinero */
    --money-desktop-size: 8rem; 
    --money-mobile-size: 10vw; /* CLAVE: Usa 10% del ancho de la pantalla */
    --stroke-desktop-size: 2px;
    --stroke-mobile-size: 1px; /* Reducimos el trazo para móvil */
}

/* Media Query para padding en pantallas grandes */
@media (min-width: 1200px) {
    :root {
    --padding-horizontal: 150px; /* Padding para desktop */
    }
}

/* --- Reset Básico y Estilos Generales --- */
* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

body {
    font-family: var(--font-principal);
    background-color: var(--fondo-base);
    color: var(--texto-base);
    padding-top: var(--header-height); 
        
/* 💥 REGLAS CRÍTICAS ANTI-SCROLL 💥 */
overflow-x: hidden; /* Oculta cualquier desbordamiento que ocurra */
width: 100vw;       /* Asegura que el cuerpo ocupe EXACTAMENTE el ancho de la ventana */
}


/* --- Clases de Utilidad --- */
.container {
    width: 100%;
    padding-left: var(--padding-horizontal);
    padding-right: var(--padding-horizontal);
}

.section-padding-b, .section-padding-a {
    width: 100%;
    padding: 4rem 1rem; /* Padding vertical y padding movil */
}

.bg-azul {
    background-color :var(--color-primario) !important;
    color: #ffffff !important
}
.text-color-accent {
    color: var(--color-acento) !important;
}
.text-color-primary {
    color: var(--color-primario) !important;
}
.text-color-secondary {
    color: var(--color-secundario) !important;
}
.text-center {
    text-align: center !important;
}
.text-left {
    text-align: left !important;
}
.font-normal {
    font-weight: 100;
}
@media (min-width: 1200px) {
    .section-padding-a {
    padding-left: var(--section-padding-a);
    padding-right: var(--section-padding-a);
    }
    .section-padding-b {
    padding-left: var(--section-padding-b);
    padding-right: var(--section-padding-b);
    }
}

/* --- Estilos de Tipografía --- */
h2, h3 {
    font-family: var(--font-titulos);
    color: var(--color-primario);
    letter-spacing: var(--kerning-titulos) !important; /* <-- CAMBIO A VARIABLE */
}

h2 {
    font-size: var(--h2-desktop-size);
    margin-bottom: 1.5rem;
}

h3 {
    font-size: var(--h3-desktop-size);
    margin-top: 1.5rem;
    margin-bottom: 0.5rem;
}

.convocatoria-section h3 {
font-family: var(--font-principal);
margin: 0px !important;
margin-top: px !important;
font-weight: 100;
}
.convocatoria-section p{ 
font-size: 1.5rem;
margin-bottom: 5px;
line-height: 1.6; /* <-- AUMENTO DE INTERLINEADO */
}

/* --- Estilos del Encabezado (Header) --- */
.main-header {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    z-index: 1000;
    background-color: transparent;
    padding-top: 1rem;
    padding-bottom: 1rem;
    display: flex;
    justify-content: space-between;
    align-items: center;
    transition: background-color 0.4s ease, box-shadow 0.4s ease;
}

.main-header.scrolled {
    background-color: var(--fondo-base); /* <-- CAMBIO DE COLOR DE FONDO */
}

.brand-container {
    display: flex;
    align-items: center;
    gap: 15px;
}

.logo { width: 50px; height: auto; }
.logo img { width: 100%; height: auto; display: block; }

.brand-name {
    font-family: var(--font-titulos);
    font-size: 1rem;
    font-weight: normal;
    color: var(--color-primario);
    transition: opacity 0.3s ease;
    margin-left: 25px;
}
        
.brand-name .domain-extension { color: var(--color-secundario); }

.main-nav ul { list-style: none; display: flex; gap: 20px; }
.main-nav a {
    text-decoration: none;
    color: var(--color-primario);
    font-weight: 500;
    padding: 8px 16px;
    border-radius: 5px;
    transition: background-color 0.3s ease, color 0.3s ease;
}
.main-nav a:hover { background-color: var(--color-primario); color: var(--fondo-blanco); }

.menu-toggle { display: none; background: none; border: none; cursor: pointer; padding: 10px; z-index: 1001; }
.menu-toggle .bar { display: block; width: 25px; height: 3px; background-color: var(--color-primario); margin: 5px auto; transition: all 0.3s ease-in-out; }
.menu-toggle.is-active .bar:nth-child(1) { transform: translateY(8px) rotate(45deg); }
.menu-toggle.is-active .bar:nth-child(2) { opacity: 0; }
.menu-toggle.is-active .bar:nth-child(3) { transform: translateY(-8px) rotate(-45deg); }

/* --- Sección Héroe --- */
.hero {
    height: calc(100vh - var(--header-height));
    width: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
    margin-bottom: -15vh;
    position: relative;
    z-index: 1;
    overflow: hidden; /* Añadido para evitar desbordamiento y deformación */
}
.hero-logo { max-width: 100%; max-height: 100%; width: auto; height: auto; }
        
.hero-brand-name {
    display: none; /* Oculto en desktop por defecto */
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 2;
    font-family: var(--font-titulos);
    font-weight: normal;
    font-size: 1rem !important;
    color: var(--color-primario);
}
.hero-brand-name .domain-extension {
    color: var(--color-secundario);
}

/* --- Sección Presentado Por --- */
.sponsors-section {
    padding-top: 20vh;
    text-align: center;
    background-color: var(--color-secundario);
    position: relative;
    z-index: 0;
}
.sponsors-logos {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 2rem;
    flex-wrap: wrap;
}
.sponsor-logo img {
    max-width: 160px;
    height: auto;
}

/* --- Sección Convocatoria --- */
.convocatoria-section {
    background-color: var(--fondo-base);
}
.convocatoria-layout {
    display: flex;
    gap: 3rem;
    flex-direction: column;
}
.convocatoria-main, .convocatoria-aside {
    flex: 1;
}
.prize-table {
    border: 2px solid var(--color-primario);
    padding: 1.5rem;
    text-align: center;
}
.prize-table h3 {
    font-size: 2rem;
    margin-top: 0;
}
.prize-table .amount {
    font-family: var(--font-titulos);
    color: var(--color-primario);
    font-size: 3rem;
    display: block;
    margin-bottom: 0.5rem;
}
.prize-table .usd-amount {
    font-family: var(--font-titulos);
    color: var(--color-primario);
    font-size: 1.5rem;
    display: block;
}

    .sponsor-logo:last-of-type img{
    max-width: 210px !important;
    }
        
/* --- Diseño Responsivo (Responsive Design) --- */
@media (max-width: 992px) {
    .brand-name { display: none; } /* <-- CAMBIO: SE VUELVE A OCULTAR EN MÓVIL */
    .convocatoria-layout { flex-direction: column; }
}

@media (max-width: 768px) {
    h2 {
    font-size: var(--h2-mobile-size);
    }
    h3 {
    font-size: var(--h3-mobile-size);
    }
    .prize-table h3 {
        font-size: 1.5rem; /* Tamaño específico para esta tabla en móvil */
    }
.convocatoria-section p{ 
    font-size: var(--h2-mobile-size);
    margin-bottom: 25px !important;
}
.convocatoria-section h3{ 
    font-size: var(--h2-mobile-size) !important;
}

    .menu-toggle { display: block; margin-right: 0 rem; }
    .main-nav ul {
    flex-direction: column;
    position: absolute;
    top: 100%; left: 0; width: 100%;
    background-color: var(--fondo-base); /* <-- COLOR DE FONDO MENÚ */
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
    max-height: 0; opacity: 0;
    overflow: hidden;
    transition: max-height 0.4s ease-out, opacity 0.4s ease-out;
    }
    .main-nav ul.is-active { max-height: 50vh; opacity: 1; }
    .main-nav li { width: 100%; text-align: center; }
    .main-nav a { display: block; padding: 1rem; border-top: 1px solid #f0f0f0; }

    .hero {
    height: 60vh;
    margin-bottom: -10vh;
    flex-direction: column; /* Apila el texto y el logo verticalmente */
    gap: 1rem; /* Añade espacio entre el texto y el logo */
    }
    .hero-logo { 
    max-width: 100%; 
    max-height: 100%; /* Se reduce para dar espacio al texto */
    }
    .hero-brand-name {
    display: block;
    font-size: 2.2rem;
    position: static; /* Quita el posicionamiento absoluto */
    transform: none; /* Resetea la transformación */
    }
    .sponsors-section { 
    padding-top: 10vh; 
    }
    
}
@media (min-width: 768px) {
    .sponsor-logo:last-of-type {
    padding-left: 10px;
    border-left: 2px solid #024391 !important;
    height: auto !important;
    width: auto !important;
    }

}

/* --- CLASE GENÉRICA DE LAYOUT Y TIPOGRAFÍA (Reemplaza estilos de Convocatoria) --- */
.generic-section {
width: 100%;
/* Padding vertical (4rem) y horizontal (1rem) para móvil/tablet */
padding: 4rem 1rem; 
}

@media (min-width: 1200px) {
.generic-section {
    /* Requiere --padding-horizontal en :root */
    padding-left: var(--padding-horizontal);
    padding-right: var(--padding-horizontal);
}
}

/* --- ESTILOS DE h3 dentro de .generic-section (Tomados de .convocatoria-section h3) --- */
.generic-section h3 {
/* Toma font-family de convocatoria */
font-family: var(--font-principal); /* Requiere --font-principal en :root */
margin: 0px !important;
margin-top: px !important; /* NOTA: Se conserva el valor inválido de tu original */
}

/* --- ESTILOS de p dentro de .generic-section (Tomados de .convocatoria-section p) --- */
.generic-section p { 
font-size: 1.5rem;
}

/* --- MEDIA QUERY DE .generic-section h3 y p (Tomados de .convocatoria-section) --- */
@media (max-width: 768px) {
.generic-section p { 
    /* Requiere --h2-mobile-size en :root */
    font-size: var(--h2-mobile-size); 
}
.generic-section h3 { 
    /* Requiere --h2-mobile-size en :root */
    font-size: var(--h2-mobile-size) !important;
}
}

/* 1. CONTENEDOR CENTRAL: Centra ambas capas y establece el contexto */
.centered-text-wrapper {
position: relative; 
text-align: center !important; /* Centra el texto y los elementos inline/inline-block */
width: 100%; 
height: 10rem; /* Ajustar según la altura de tu fuente de 8rem */
margin: 0 auto; 

}

/* 2. CAPA DE SOMBRA (DIV de color sólido) */
.text-shadow-layer {
/* CLAVE DE POSICIONAMIENTO */
position: absolute;
top: 0;
left: 0; 
z-index: 1; 

/* FORZAMOS EL CENTRADO DENTRO DE LA CAPA */
width: 100%; /* CLAVE: Ocupa todo el ancho del wrapper */
text-align: center; /* CLAVE: Centra el texto internamente */

/* El desplazamiento de 2px 3px de tu sombra original */
transform: translate(2px, 3px); 

/* Estilos de fuente */
font-family: var(--font-principal);
font-size: 8rem !important;
color: #024391; /* Color de la sombra nítida */

/* SIN TRAZO */
-webkit-text-stroke: 0; 
text-shadow: none;

}

/* 3. CAPA FRONTAL (El texto con gradiente) */
.text-gradient-money {
/* CLAVE DE POSICIONAMIENTO */
position: absolute;
top: 0;
left: 0;
z-index: 2; /* Siempre encima de la sombra */

/* FORZAMOS EL CENTRADO DENTRO DE LA CAPA */
width: 100%; /* CLAVE: Ocupa todo el ancho del wrapper */
text-align: center; /* CLAVE: Centra el texto internamente */

/* Estilos de fuente y TRAZO ORIGINAL (VUELVE AQUÍ) */
font-family: var(--font-principal);
font-size: 8rem !important;
-webkit-text-stroke: 2px rgba(2,67,145,1); /* Trazo nítido original */
text-shadow: none; 

/* Propiedades del gradiente */
color: #F898D7;
background-image: linear-gradient(0deg, #F898D7 35%, #FADD44 80%);
background-clip: text;
-webkit-background-clip: text;
-webkit-text-fill-color: transparent;


}

@media (max-width: 820px) { 
.text-shadow-layer,.text-gradient-money  {
    font-size: 5rem !important; /* Ajustar según la altura de tu fuente de 8rem */
}
.centered-text-wrapper {
    height: 5rem;
}
}

/* ---------------------------------------------------------------------------------- */
/* --- MEDIA QUERY: AJUSTES RESPONSIVOS PARA MÓVILES (Max-Width 768px) --- */
/* ---------------------------------------------------------------------------------- */
@media (max-width: 768px) {

/* --- VARIABLES TEMPORALES PARA MÓVIL (Basado en el bloque responsive anterior) --- */
/* Estas variables deben coincidir con las que definiste globalmente,
    pero las declaramos aquí para hacer el código independiente: */
/* Asumiendo que 10vw es el tamaño de la fuente móvil y 1px es el trazo móvil. */
:root {
    --money-mobile-size: 10vw; 
    --stroke-mobile-size: 1px;
}


/* 1. CONTENEDOR CENTRAL (Móvil) */
.centered-text-wrapper {
    /* Altura proporcional a la fuente de 10vw */
    height: 1.1em; 
    line-height: 1.1;
}

/* 2. CAPA DE SOMBRA (Móvil) */
.text-shadow-layer {
    /* SOBRESCRIBE el font-size de 8rem */
    font-size: var(--money-mobile-size) !important; /* Ahora 10vw */
    
    /* Reducimos el desplazamiento de 2px 3px a 1px 1.5px */
    transform: translate(1px, 1.5px); 
}

/* 3. CAPA FRONTAL (Móvil) */
.text-gradient-money {
    /* SOBRESCRIBE el font-size de 8rem */
    font-size: var(--money-mobile-size) !important; /* Ahora 10vw */
    
    /* Reducimos el trazo de 2px a 1px */
    -webkit-text-stroke: var(--stroke-mobile-size) rgba(2,67,145,1); 
    line-height: 1.1;
}

}

/* --- CONFIGURACIÓN DE CENTRADO DEL CONTENEDOR PRINCIPAL --- */


.responsive-prize-table {
/* PC Ancho y centrado */
max-width: 700px; 
width: 90%; 
table-layout: fixed; 
border-collapse: collapse; 
margin: 10px auto; 

font-family: var(--font-principal);
font-size: 1.7rem; 
color: white; 
}

/* ---------------------------------------------------------------------- */
/* --- AJUSTES DE FILA Y CELDA --- */
/* ---------------------------------------------------------------------- */

/* Estilo para todas las celdas */
.responsive-prize-table td {
vertical-align: middle; 
padding: 10px 5px; /* Padding reducido */
white-space: normal; 
border-bottom: 1px dashed rgba(255, 255, 255, 0.5); 
}


/* 1. La Celda del Puesto (TD) ahora es invisible y actúa como un marcador */
.responsive-prize-table .col-puesto {
width: 200px; /* Mínimo ancho para que la celda exista */
padding: 0;
text-align: center;
}

/* 2. El Puesto (span.puesto-label) se posiciona absolutamente */
.prize-row .puesto-label {
position: absolute;
transform: translateY(-50%);

/* Estilos estéticos */
font-size: 1em; 
font-weight: bold;
color: var(--color-secundario);
text-align: center;
}
.text-center-col-mxn {
    text-align: center;
    padding: 12px;
    
}

/* 3. Nueva Distribución de Anchos (Solo 2 Columnas) */
.responsive-prize-table .col-mxn {
width: 60%; /* CLAVE: Damos 60% del ancho para que quepa el texto de 1.7rem */
text-align: left; 
}

.responsive-prize-table .col-usd {
width: 40%; /* El 40% restante */
text-align: left; 
padding-right: 0;
font-size: 1em; 
}

/* 4. Estilo de Bloque MXN (Ahora tiene más espacio para NO romperse) */
.responsive-prize-table .monto-mxn {
color: #ffffff; 
min-height: 2.5em; /* Altura mínima ajustada para 1 línea con buen padding */
margin-right: 0; 
padding: 5px 12px; 
font-size: 1em;
}

/* ---------------------------------------------------------------------- */
/* --- MEDIA QUERY: AJUSTES RESPONSIVOS (PARA MÓVIL: max-width 768px) --- */
/* ---------------------------------------------------------------------- */
@media (max-width: 768px) {
.text-center-col-mxn {
    padding-left: 20px !important;
}
/* 1. Contenedor de la Tabla para Habilitar Scroll Horizontal (CRUCIAL) */
.convocatoria-main {
    overflow-x: auto; /* Habilita el scroll horizontal cuando el contenido es más ancho */
    -webkit-overflow-scrolling: touch; /* Mejora el rendimiento del scroll en iOS */
    padding: 0 15px; /* Asegura un padding lateral si el contenedor principal no lo tiene */
}

/* 2. La Tabla debe ser más ancha que el contenedor para forzar el scroll */
.responsive-prize-table {
    /* Se requiere un ancho mínimo fijo (en px) para forzar el scroll,
        ya que el ancho 100% haría que la tabla se comprima. */
    max-width: auto; 
    width: auto; 
    font-size: 1.1em; /* Reducimos la fuente para ahorrar espacio */
}

/* 3. Reducción de Padding en Celdas y Encabezados */
.responsive-prize-table th,
.responsive-prize-table td {
    padding: 10px; /* Reducción de padding para maximizar espacio */
    white-space: nowrap; /* Impedimos la rotura de línea en los montos (MXN/USD) */
}

/* 4. Aseguramos que la etiqueta del Puesto no cause overflow */
.prize-row .puesto-label {
    position: static; /* El posicionamiento absoluto es la causa de muchos problemas en diseño responsive */
    transform: none;
    left: auto;
    font-size: 1em; /* El tamaño de fuente será el que hereda de la tabla (1.1em) */
}

/* Eliminamos la altura mínima que fue forzada anteriormente */
.responsive-prize-table .monto-mxn {
    min-height: auto;
    white-space: nowrap; /* Mantenemos en una línea */
    font-size: 1em;
}
}


/**********************************/
/**********************************/
/**********************************/

/* --- Estilos del Contenedor Principal --- */
.ubicacion-grid-layout {
display: flex; /* Habilitamos Flexbox */
flex-wrap: wrap; /* Permite que los elementos salten de línea en pantallas pequeñas */
align-items: center; /* Centra verticalmente los elementos */
gap: 30px; /* Espacio entre las columnas */
}

/* --- Estilos de la Columna de Texto --- */
.ubicacion-text-content {
flex: 2; /* Ocupa 2 partes de las 3 disponibles (2/3) */
min-width: 300px; /* Mínimo ancho para evitar compresión excesiva en pantallas medianas */
font-family: var(--font-principal);
color: var(--color-primario);

@media (min-width: 820px) {
    font-size: 1.2rem !important;
}

@media (max-width: 768px) {
    font-size: 1.2rem !important;
}
}
/* --- Estilos de la Columna de Imagen --- */
.ubicacion-image-content {
flex: 1; /* Ocupa 1 parte de las 3 disponibles (1/3) */
text-align: center; /* Centra la imagen si hay espacio extra */
min-width: 250px; /* Mínimo ancho para la imagen */
}

/* --- Imagen Responsiva --- */
.ubicacion-image-content .responsive-image {
max-width: 100%; /* Asegura que la imagen no exceda su contenedor */
height: auto; /* Mantiene la proporción de la imagen */
display: block; /* Elimina espacio extra debajo de la imagen */
margin: 0 auto; /* Centra la imagen si el contenedor es más grande */
}

/* --- Estilo del Botón (ejemplo, ajusta a tus clases existentes) --- */
.button-primary {
display: inline-block;
padding: 15px 30px; /* <-- PADDING SIMÉTRICO */
background-color: var(--color-primario); /* Un color de ejemplo, usa el tuyo */
color: var(--color-acento);
text-decoration: none;
border-radius: 50px;
transition: background-color 0.3s ease;
text-align: center; /* <-- ALINEACIÓN DE TEXTO */

@media (max-width: 768px) {
    font-size: 1.2rem !important;
    padding: 20px 35px;
}
}
.button-primary:hover {
background-color: #0055aa; /* Color al pasar el ratón */
}


/* ---------------------------------------------------------------------- */
/* --- MEDIA QUERY: AJUSTES RESPONSIVOS PARA PANTALLAS PEQUEÑAS (MÓVIL) --- */
/* ---------------------------------------------------------------------- */
@media (max-width: 768px) {
.ubicacion-grid-layout {
    flex-direction: column; /* Apila las columnas una encima de la otra */
    gap: 20px; /* Reduce el espacio entre elementos apilados */
    padding: 0 15px; /* Añade un poco de padding lateral en móvil */
}

/* En móvil, ambos elementos ocupan todo el ancho disponible */
.ubicacion-text-content,
.ubicacion-image-content {
    flex: auto; /* Restablece el crecimiento para ocupar el ancho completo */
    width: 100%; /* Ocupan el 100% del ancho */
    min-width: auto; /* Elimina el min-width para adaptarse mejor */
}

.ubicacion-text-content {
    text-align: left; /* <-- ALINEACIÓN A LA DERECHA EN MÓVIL */
}

/* Puedes ajustar el tamaño de fuente si es necesario */
.ubicacion-text-content p {
    font-size: 1em;
}
}

.ubicacion-text-content { flex: 1; }
.ubicacion-image-content { flex: 1; }

/*******************************/
/*******************************/
/*******************************/
/* --- Estilos Generales de la Sección --- */
.contacto-section {
padding: 60px 0;
}

/* El fondo amarillo (bg-yellow) ya debería estar definido en tu CSS global */
.bg-yellow {
background-color: #f7e658; /* Color de ejemplo basado en la imagen */
}

.text-color-dark {
color: #444444; /* Color de texto para el párrafo de descripción */
}

/* --- Estilos del Formulario de Suscripción --- */
.suscripcion-form {
display: flex; /* Alinea los elementos del formulario en fila */
justify-content: center; /* Centra el formulario completo */
align-items: stretch; /* Hace que el input y el botón tengan la misma altura */
max-width: 500px; /* Limita el ancho del formulario para no ser demasiado grande en desktop */
margin: 0 auto; /* Centra el bloque del formulario */
box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
}

.input-email {
flex-grow: 1; /* Permite que el input ocupe el espacio restante */
padding: 10px 15px;
font-size: 1em;
border: 3px solid #01315e; /* Borde oscuro para el recuadro */
outline: none;
}

.button-enviar {
padding: 10px 25px;
background-color: #01315e; /* Color de fondo oscuro (Azul/Gris) */
color: #ffffff;
font-size: 1em;
font-weight: bold;
border: 3px solid #01315e; /* Borde que coincide con el fondo para un look sólido */
cursor: pointer;
white-space: nowrap; /* Evita que el botón se rompa */
transition: background-color 0.3s;
}

.button-enviar:hover {
background-color: #00569a; /* Un color más claro al pasar el ratón */
}

/* --- Estilos de Redes Sociales --- */
.redes-sociales {
text-align: center; /* Centra los iconos */
}

.social-icon {
display: inline-block;
margin: 0 10px; /* Espacio entre los iconos */
font-size: 2.5em; /* Tamaño grande de los iconos */
color: #01315e; /* Color oscuro para los iconos */
text-decoration: none;
transition: color 0.2s;
}

.social-icon:hover {
color: #00569a; /* Color de hover */
}

/* ---------------------------------------------------------------------- */
/* --- MEDIA QUERY: AJUSTES RESPONSIVOS PARA MÓVIL (max-width 550px) --- */
/* ---------------------------------------------------------------------- */
@media (max-width: 550px) {
.suscripcion-form {
    flex-direction: column; /* Apila el input y el botón */
    max-width: 90%; /* Ocupa más ancho en móvil */
}

.input-email {
    border-bottom: none; /* Elimina el borde inferior cuando se apilan */
}

.button-enviar {
    margin-top: 5px; /* Pequeño espacio entre el input y el botón */
    border-radius: 0; /* Opcional: para que se vea como un bloque sólido apilado */
}

.social-icon {
    font-size: 2em; /* Iconos un poco más pequeños en móvil */
}
}


/* --- Estilos de Redes Sociales (Aseguran que estén centrados) --- */
.redes-sociales {
text-align: center; /* Centra los iconos */
}

/* --- Estilos del Icono Individual --- */
.social-icon {
display: inline-block;
margin: 0 15px; /* Espacio entre los iconos, ligeramente aumentado */
font-size: 3.5em; /* Tamaño grande de los iconos (puedes ajustar este valor) */
color: var(--color-primario); /* Color oscuro que usaste en el botón */
text-decoration: none;
transition: color 0.2s;
}

.social-icon:hover {
color: var(--color-primario); /* Color de hover */
}

/* ---------------------------------------------------------------------- */
/* --- Ajuste para Móviles (Los hace un poco más pequeños) --- */
/* ---------------------------------------------------------------------- */
@media (max-width: 550px) {
.social-icon {
    font-size: 2.8em; /* Iconos un poco más pequeños en móvil para mejor ajuste */
    margin: 0 10px;
}
}


/* --- Estilo para PC/Tablet: Ancho Máximo para el icono de WhatsApp --- */
.whatsapp-icon {
/* Aquí definimos el ancho máximo, simulando tus 400px de PC */
max-width: 400px;
width: 100%; /* Asegura que la imagen siempre ocupe el ancho disponible */
height: auto;
display: block; /* Ayuda con el centrado y el flujo */
margin: 0 auto;
}

/* --- MEDIA QUERY: Ajuste para Móviles --- */
@media (max-width: 550px) {
.whatsapp-icon {
    /* Reducimos el tamaño máximo para que se vea bien y no desborde.
        80vw significa el 80% del ancho de la ventana del móvil. */
    max-width: 80vw;
    width: 80vw; 
}
}