/* Animación de gradiente */
@keyframes gradientAnimation {
    0% {
        background-position: 0% 50%;
    }
    50% {
        background-position: 100% 50%;
    }
    100% {
        background-position: 0% 50%;
    }
}

input[type="number"]::-webkit-inner-spin-button,
input[type="number"]::-webkit-outer-spin-button {
    -webkit-appearance: none;
    margin: 0;
}

h3, h1{
    font-family: 'Lato', sans-serif;
    font-weight: bold;
}

.form-label{
    font-family: 'Lato', sans-serif;
    font-size: 18px;
}

.floating-label {
    position: relative;
}

.floating-label .form-control {
    padding-top: 1.5rem;
}

.floating-label label {
    position: absolute;
    top: 12px;
    left: 12px;
    color: #777;
    transition: all 0.2s ease;
    pointer-events: none; /* Para que no bloquee el click en el input */
}

/* Mueve la etiqueta hacia arriba cuando el input tiene contenido o está enfocado */
.floating-label .form-control:not(:placeholder-shown) + label,
.floating-label .form-control:focus + label {
    top: 5px;
    font-size: 0.75rem;
    color: #3498db;
}

.input-with-icon {
    position: relative;
}

.validation-icon {
    position: absolute;
    right: 10px;
    top: 50%;
    transform: translateY(-50%);
    font-size: 1.2em;
    pointer-events: none;
    display: none;
}

.form-control.is-valid + .validation-icon {
    content: '✔'; /* O usa un ícono de una librería */
    color: #27ae60;
    display: block;
}

.form-control.is-invalid + .validation-icon {
    content: '✖'; /* O usa un ícono de una librería */
    color: #e74c3c;
    display: block;
}

/* Estilos para el contenedor de la tarjeta de contacto */
.contact-card {
    background-color: #f8f9fa; /* Un gris muy claro */
    border: 1px solid #e9ecef; /* Un borde sutil */
    border-radius: 12px; /* Bordes redondeados */
    padding: 25px; /* Espaciado interno */
    margin-top: 30px; /* Separación superior para diferenciarlo del campo anterior */
    box-shadow: 0 4px 8px rgba(0,0,0,0.05); /* Una sombra suave para darle profundidad */
}

/* Estilos para el título dentro de la tarjeta */
.contact-card h5 {
    color: #495057; /* Un color de texto más oscuro para el título */
    font-weight: 600; /* Negrita moderada */
    margin-bottom: 10px;
}

/* Estilos para el texto de ayuda */
.contact-card p {
    color: #6c757d; /* Un color de texto secundario */
    font-size: 0.9em;
    margin-bottom: 20px;
}

/* Contenedor principal */
.cupos-container {
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 8px 8px 1px;
    background: linear-gradient(135deg, #f3f3f3, #e0e0e0);
    border-radius: 10px;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);
    max-width: 280px;
    max-height: 90px;
    margin: 20px auto;
    /* display: none; */
}

/* Estilización del texto general */
.cupos-text {
    font-size: 20px;
    font-weight: 600;
    font-family: 'Arial', sans-serif;
    display: flex;
    align-items: center;
    color: #333; /* Texto oscuro */
}

/* Efecto en "Cupos disponibles" */
.cupos-label {
    font-weight: bold;
    color: #335b9b; /* Naranja-rojo vibrante */
    text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.2);
}

/* Estilo del número de cupos disponibles */
.cupos-count {
    font-weight: 700;
    font-size: 22px;
    color: #fff;
    padding: 8px 12px;
    border-radius: 8px;
    box-shadow: 0 3px 6px rgba(0, 0, 0, 0.3);
    border: 1px solid #4CAF50; /* Verde */
    background-color: #0067c4; /* Verde por defecto */
    margin-left: 10px;
    transition: all 0.3s ease-in-out;
}

/* Clase para cambiar el color a rojo cuando los cupos son 0 */
.sin-cupos {
    background-color: rgba(245, 31, 31, 0.82) !important; /* Rojo */
    border-color: #FF5733 !important;
}

/* --- Estilos de Afiche cuadrado ---
.afiche {
    position: relative;
    width: 100%;
    height: 650px;
    background-color: #d2d2d3;
    overflow: hidden;
    display: flex;
    justify-content: center;
    align-items: center;
}

.afiche-imagen {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
}

.afiche-imagen img {
    box-shadow: 0 0 20px rgba(104, 197, 255, 0.737);
    max-width: 100%;
    max-height: 100%;
    object-fit: contain;
} */

/* estilo afiche horizontal */
.afiche {
    position: relative;
    width: 100%;
    height: auto !important; /* El !important nos asegura de matar cualquier otra altura fija que ande perdida en tu CSS */
    background-color: #d2d2d3;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    padding: 0;
    margin: 0;
}

.afiche-imagen {
    width: 100%;
    line-height: 0; /* 👈 Esto mata el espacio en blanco fantasma debajo de las imágenes */
    font-size: 0;
    display: block;
}

.afiche-imagen img {
    display: block;
    width: 100%;
    height: auto;
    margin: 0;
    padding: 0;
    /* Eliminamos el object-fit y el transform */
}

/* --- Estilos Generales --- */
.barra-color {
    width: 100%;
    height: 15px;
    background: linear-gradient(to right, #E04E1D, #C8006B, #0098DC, #7F5699, #008E37, #0098DC, #2EA29B);
}

/* --- Estilos de Formulario (existente) --- */
.formulario-contenedor {
    background-color: rgba(65, 65, 66, 0.237);
    padding: 0; /* Eliminar padding superior */
    width: 100%;
    display: flex;
    justify-content: center;
    align-items: flex-start; /* Asegurar que el contenido comience desde arriba */
}

.formulario-container { /* Puede ser lo mismo que .formulario-contenedor si solo hay un contenedor */
    width: 100%;
    max-width: 973px;
}

/* Estilo del formulario principal */
.formulario {
    background-color: whitesmoke;
    padding: 5vw;
    box-shadow: 0 0 20px rgba(104, 197, 255, 0.737); /* sombra de contorno */
    width: 100%;
    max-width: 973px;
    margin: 0 auto;
    position: relative;
    top: 0;
}

/* --- Estilos del Filtro de Asistencia (NUEVO) --- */
/* Estilos para alinear los elementos del formulario en línea */
.form-inline {
    display: flex; /* Usa flexbox para alinear elementos */
    flex-wrap: wrap; /* Permite que los elementos se envuelvan en pantallas pequeñas */
    align-items: flex-end; /* Alinea verticalmente los elementos al final (para campos y botón de diferente altura) */
    gap: 0.5rem; /* Espacio entre los elementos del formulario (opción moderna) */
    /* Si usas los estilos de Bootstrap mr-2, mb-3 en el HTML, puede que 'gap' no sea estrictamente necesario, pero ayuda a consistencia */
}

.form-inline .form-group {
    margin-bottom: 0.5rem; /* Espacio inferior entre grupos */
    /* flex: 0 0 auto; */ /* Descomentar si no quieres que los grupos crezcan/se encojan automáticamente */
}

.form-inline label {
    margin-bottom: 0.25rem; /* Pequeño espacio debajo de la etiqueta */
    display: block; /* Asegura que la etiqueta tome su propia línea si es necesario */
}

.form-inline .form-control {
    width: auto; /* Permite que el input tome el ancho necesario según su contenido/tipo */
}

.form-inline .btn {
    margin-bottom: 0.5rem; /* Alinea el botón con los campos de formulario */
}

/* --- Estilos de Botones (existente) --- */
h4.text-primary { /* Aunque es un h4, lo incluyes aquí */
    color: #00407b;
}

h6 {
    font-size: 18px;
}

#enviar { /* Botón por ID */
    background-color: #007bff; /* Azul */
    color: white;
    font-weight: bold;
    border: none;
    padding: 10px 20px;
    font-size: 16px;
    border-radius: 5px;
    cursor: pointer;
}

#enviar:hover {
    background-color: #0056b3; /* Azul más oscuro al pasar el mouse */
}

.btn-primary { /* Botón por clase Bootstrap, si la estás personalizando */
    background-color: #00407b;
    color: white;
    padding: 10px 20px;
    font-size: 16px;
    border: none;
    border-radius: 4px;
    cursor: pointer;
}

/* --- Estilos de Validación (existente) --- */
/* Validaciones */
.valido {
    color: green;
    font-weight: bold;
}

.invalido {
    color: red;
    font-weight: bold;
}

/* --- Estilos de Componentes Específicos (NUEVO) --- */
/* Estilos para los Badges de estado de asistencia */
.badge-success { /* Para estado "Presente" */
    background-color: #28a745; /* Verde de Bootstrap */
    color: white;
    padding: .25em .5em; /* Espaciado interno */
    border-radius: .25rem; /* Bordes redondeados */
    /* Puedes añadir font-size, font-weight si quieres que destaquen */
}

.badge-danger { /* Para estado "Ausente" */
    background-color: #dc3545; /* Rojo de Bootstrap */
    color: white;
    padding: .25em .5em;
    border-radius: .25rem;
}

/* --- Ajustes Responsivos (existente) ---*/
@media (max-width: 768px) {
    /*
}
    .afiche {
        height: 350px;
    }

    .afiche-imagen img {
        object-fit: contain;
    }

    .formulario {
        padding: 4vw;
        width: 100%;
    }

 */
    /* --- CSS PARA RESPONSIVE (MÓVIL) afiche horizontal --- */

.afiche {
    /* Reemplazamos los 350px por auto para que crezca/se encoja con la imagen */
    height: auto;
    width: 100%;
    position: relative;
    overflow: hidden;
    background-color: #d2d2d3;
    display: flex;
    flex-direction: column;
}

.afiche-imagen {
    width: 100%;
    display: flex;
    justify-content: center;
}

.afiche-imagen img {
    width: 100%;
    height: auto; /* Esto garantiza que no se deforme al achicarse la pantalla */
    display: block;
    object-fit: contain;

    /* Si quieres que en el celular también tenga ese pequeño estiramiento
       vertical que le pusiste a la web, descomenta la siguiente línea: */
    /* transform: scaleY(1.10); */
    /* transform-origin: center; */
}

.formulario {
    padding: 5vw; /* Subí un poquito a 5vw, en móviles 4vw a veces queda muy pegado al borde */
    width: 100%;
    box-sizing: border-box; /* Vital para que el padding no te genere un molesto scroll horizontal en el celular */
}

    /* Si tienes estilos de formulario en línea que necesitan ajuste en tabletas */
    .form-inline {
        /* Ajustes específicos para 768px si es necesario */
    }

@media (max-width: 480px) {
    .afiche {
        height: auto; /* Dejamos que la imagen controle la altura */
        display: flex;
        flex-direction: column;
    }

    .afiche-imagen img {
        width: 100%;
        height: auto; /* Mantiene la proporción perfecta sin estirarse */
        display: block; /* Elimina el pequeño margen invisible que dejan las imágenes por defecto */
        object-fit: contain;
    }

    .formulario {
        padding: 4vw; /* Te sugiero 4vw para que los campos no queden tan pegados al borde del celular */
        width: 95%;
        margin: 0 auto; /* Como le diste 95% de ancho, esto asegura que quede perfectamente centrado */
        box-sizing: border-box; /* Fundamental para que el padding no sume al 95% y rompa la pantalla */
    }

    .btn-primary { /* Botón principal si necesita ajuste en móviles */
        font-size: 14px;
        padding: 8px 16px;
    }

    /* Si tienes estilos de formulario en línea que necesitan ajuste en móviles */
    .form-inline {
        /* Ajustes específicos para 480px si es necesario */
    }
}
}