body {
    font-family: 'Roboto', sans-serif;
    margin: 0;
    padding: 0;
    color: #333;
    background-color: #f8f9fa;
    display: flex;
    flex-direction: column;
    min-height: 100vh; /* Full height of the viewport */
}
/* Estilos del header */
/* Estilos del header */
header {
    background-color: #ff0000; /* Rojo */
    color: #ffffff; /* Blanco puro */
    padding: 10px 0; /* Espaciado arriba y abajo */
    box-shadow: none; /* Elimina cualquier sombra aplicada */
}

/* Contenedor del header */
.header-container {
    display: flex;
    justify-content: center; /* Centra el contenedor dentro del header */
    padding: 0 20px; /* Espaciado interno del contenedor */
}

/* Estilo del contenedor del logo y el botón de alternancia */
.container-fluid {
    display: flex;
    justify-content: space-between; /* Espacio entre el escudo y el botón */
    align-items: center; /* Alineación vertical centrada */
}

.navbar {
    width: 100%;
}

/* Logo */
.navbar-brand {
    display: flex;
    align-items: center; /* Alinea verticalmente el escudo */
    margin-right: auto; /* Empuja el escudo hacia la izquierda */
}

/* Botón de alternancia */
.navbar-toggler {
    border: none; /* Sin borde para el botón */
    background-color: transparent; /* Fondo transparente */
    position: relative; /* Posicionamiento relativo dentro del contenedor */
    outline: none; /* Elimina el contorno del botón */
}

/* Icono del botón de alternancia */
.navbar-toggler-icon {
    background-image: url('data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMzAiIGhlaWdodD0iMjQiIHZpZXdCb3g9IjAgMCAzMCAyNCIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KICAgIDxsaW5lIHgxPSIwIiB5MT0iMyIgeDI9IjMwIiB5Mj0iMyIgc3Ryb2tlPSJ3aGl0ZSIgc3Ryb2tlLXdpZHRoPSI0IiBzdHJva2UtbGluZWNhcD0icm91bmQiIC8+CiAgICA8bGluZSB4MT0iMCIgeTE9IjEyIiB4Mj0iMzAiIHkyPSIxMiIgc3Ryb2tlPSJ3aGl0ZSIgc3Ryb2tlLXdpZHRoPSI0IiBzdHJva2UtbGluZWNhcD0icm91bmQiIC8+CiAgICA8bGluZSB4MT0iMCIgeTE9IjIxIiB4Mj0iMzAiIHkyPSIyMSIgc3Ryb2tlPSJ3aGl0ZSIgc3Ryb2tlLXdpZHRoPSI0IiBzdHJva2UtbGluZWNhcD0icm91bmQiIC8+Cjwvc3ZnPg==');
    background-size: cover; /* Ajusta el tamaño del icono */
    width: 30px;
    height: 24px;
}

/* Mostrar el botón de alternancia en todas las pantallas */
.navbar-toggler {
    display: block; /* Asegura que el botón sea visible en todas las pantallas */
}

/* Estilos del menú desplegable */
.collapse {
    background-color: #ff0000; /* Color de fondo del menú desplegable */
    max-width: 100%;
}

/* Asegúrate de que el menú de navegación esté alineado correctamente en dispositivos móviles */
@media (max-width: 991px) {
    .navbar-nav {
        text-align: center; /* Centra el menú en dispositivos móviles */
        background-color: #ff0000;
    }
    
    .navbar-nav .nav-item {
        margin: 0; /* Espaciado entre los elementos del menú en dispositivos móviles */
        background-color: #ff0000;
    }
}

/* Color blanco para los enlaces del menú */
.nav-link {
    color: #ffffff !important; /* Blanco puro para los enlaces */
}

/* Hover y enfoque en los enlaces del menú */
.nav-link:hover, .nav-link:focus {
    color: #e6e6e6 !important; /* Color gris claro para hover y enfoque */
}

.hero {
    text-align: center;
    padding: 50px 20px;
}

.hero h1 {
    font-size: 3em;
    color: red;
    margin: 0;
}

.hero p {
    color: red;
    font-size: 1.2em;
    margin: 10px 0 0;
}

.next-match {
    text-align: center;
    padding: 0px 20px;
}

.next-match h2 {
    font-size: 2em;
    margin: 0 0 20px;
}

.match-info {
    display: flex;
    justify-content: center;
    align-items: center;
}

.team {
    text-align: center;
    margin: 0 20px;
}

.team img {
    width: 100px;
    height: 100px;
}

.vs {
    font-size: 2em;
    font-weight: bold;
    margin: 0 20px;
}

.match-details {
    margin-top: 20px;
}

.carousel-container {
    margin-top: 50px;
}

.equipo_p {
    margin-top: 30px;
    margin-left: 40px;
    color: red;
}

.player {
    display: flex;
    align-items: center;
    padding: 20px;
    border-bottom: 1px solid #ddd;
}

.player-image {
    width: 150px;
    height: auto;
    margin-right: 20px;
    margin-left: 10px;
}


.player-details {
    display: flex;
    justify-content: space-between;
    align-items: center;
    width: 100%;
}

.player-info {
    flex: 1;
}

.player-info h3 {
    margin: 0;
    font-size: 1.5em;
}

.player-info p {
    margin: 10px 0 0;
}

.player-stats {
    text-align: left;
    margin: 10px;
}

.player-stats h4 {
    margin-right: 10px;
    font-size: 1.2em;
}

.player-stats ul {
    list-style-type: none;
    padding: 0;
    margin-right: 10px;
}

.player-stats ul li {
    margin: 10px;
}
/* Media Queries */

/* Media Queries */
@media (max-width: 768px) {
    .player {
        flex-direction: column;
        align-items: center;
        position: relative; /* Asegura que las estadísticas se posicionen correctamente */
    }

    .player-image {
        width: 150px; /* Tamaño ajustado para pantallas más pequeñas */
        height: auto;
    }

    .player-info {
        font-size: 1em; /* Tamaño ajustado para el nombre en pantallas más pequeñas */
    }

    .player-stats {
        position: static; /* Cambio a posición estática para móviles */
        font-size: 0.7em; /* Tamaño aún más pequeño para las estadísticas en móviles */
        margin-top: 10px; /* Separar las estadísticas de la foto */
    }
}

@media (max-width: 576px) {
    .player-image {
        width: 120px; /* Tamaño aún más pequeño para pantallas muy pequeñas */
        height: auto;
    }

    .player-info {
        font-size: 0.9em; /* Tamaño más pequeño del nombre en pantallas muy pequeñas */
    }

    .player-stats {
        font-size: 0.6em; /* Tamaño más pequeño para estadísticas en pantallas muy pequeñas */
    }
}
footer {
    background-color: #343a40;
    color: white;
    text-align: center;
    padding: 20px 0;
}


/* Carnet de Socio Section */
.carnet-socio {
    text-align: center; /* Centra la imagen horizontalmente */
    padding: 0 40px;
    margin-bottom: 30px;
}

.carnet-img {
    max-width: 100%; /* Asegura que la imagen no se desborde del contenedor */
    height: auto; /* Mantiene la proporción de la imagen */
    border-radius: 15px; /* Esquinas redondeadas */
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2); /* Sombra */
    opacity: 0; /* Inicialmente invisible */
    animation: fadeInUp 1s forwards; /* Animación */
    max-width: 600px;
}

/* Estilos para la sección Hazte Socio */
.membership-form-container {
    padding: 20px;
    background-color: white;
    box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
    border-radius: 8px;
    max-width: 600px;
    margin: 0px auto 50px; /* Ajusta el margen superior aquí */
    position: relative; /* Necesario para el posicionamiento absoluto de la imagen */
}

.membership-form .form-label {
    font-weight: bold;
    color: #ff0000; /* Rojo */
}

.membership-form .form-control {
    border: 1px solid #ddd;
    border-radius: 4px;
    padding: 10px;
}

.membership-form .btn-primary {
    background-color: #ff0000; /* Rojo */
    border-color: #ff0000; /* Rojo */
    padding: 10px 20px;
    font-size: 1.1em;
    font-weight: bold;
}

.membership-form .btn-primary:hover {
    background-color: #e60000; /* Rojo más oscuro */
    border-color: #e60000; /* Rojo más oscuro */
}

/* Animaciones */
@keyframes fadeIn {
    from { opacity: 0; }
    to { opacity: 1; }
}

.wrapper {
    display: flex;
    flex-direction: column;
    min-height: 100vh;
}

.contact {
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
}

.contact-info {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    gap: 20px;
    margin: 50px 20px;
}

.contact-item {
    background-color: white;
    border: 2px solid #ff0000; /* Red border */
    border-radius: 10px;
    padding: 20px;
    text-align: center;
    width: 300px;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.contact-item:hover {
    transform: translateY(-5px);
    box-shadow: 0 8px 16px rgba(0, 0, 0, 0.2);
}

.contact-item .icon {
    font-size: 3em;
    color: #ff0000; /* Red */
    margin-bottom: 10px;
}

.contact-item h2 {
    font-size: 1.5em;
    color: #ff0000; /* Red */
    margin-bottom: 10px;
}

.contact-item p {
    font-size: 1.2em;
    color: green;
}

/* Media Queries para Responsive Design */
@media (max-width: 768px) {
    .hero h1 {
        font-size: 1.5rem;
    }

    .hero p {
        font-size: 1rem;
    }

    .membership-form-container {
        padding: 1rem;
    }

    .carnet-img {
        width: 80%; /* Tamaño reducido en pantallas más pequeñas */
    }

    .membership-form {
        padding: 1rem;
    }
}

@media (max-width: 576px) {
    .hero h1 {
        font-size: 1.25rem;
    }

    .hero p {
        font-size: 0.875rem;
    }

    .carnet-img {
        width: 100%; /* Ajusta el tamaño de la imagen para pantallas muy pequeñas */
    }

    .membership-form {
        padding: 0.5rem;
    }
}

/* Estilo para el formulario de predicción */
.prediction-form-container {
    padding: 30px;
    border-radius: 8px;
    margin-top: 20px;
    position: relative;
    overflow: hidden;
    animation: fadeIn 1s ease-out;
}

.prediction-form-container h2 {
    margin-bottom: 20px;
    font-size: 1.5rem;
    font-weight: bold;
    padding: 20px;
    text-align: center;
}
/* Estilo predeterminado para pantallas grandes */
.prediction-form {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    margin-top: 20px; /* Espacio arriba del formulario */
}

.team-image {
    text-align: center;
    margin: 0 20px; /* Ajusta el margen para que los escudos estén más pegados a la izquierda */
}

.team-image img {
    width: 120px; /* Tamaño en pantallas grandes */
    height: auto;
    border-radius: 8px;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);
    transition: transform 0.3s ease;
}

.team-image img:hover {
    transform: scale(1.05);
}

/* Ajustes para pantallas pequeñas */
@media (max-width: 767.98px) {
    .prediction-form {
        flex-direction: column; /* Apilar elementos verticalmente en pantallas pequeñas */
        align-items: center; /* Centrar los elementos en pantallas pequeñas */
        margin-top: 30px; /* Espacio arriba del formulario en móviles */
    }

    .prediction-form .team-image {
        margin: 10px 0; /* Espacio vertical entre los escudos en pantallas pequeñas */
        width: 100%; /* Asegurar que las imágenes no sobrepasen el ancho del contenedor */
        text-align: center; /* Centrar el contenido de la imagen */
    }

    .prediction-form .team-image img {
        width: 80px; /* Tamaño en pantallas pequeñas */
        margin: 0 10px; /* Espacio horizontal entre los escudos */
    }

    .membership-form {
        display: flex;
        flex-direction: column; /* Apilar elementos verticalmente */
        align-items: center; /* Centrar los elementos */
        width: 100%; /* Asegurar que el formulario no sobrepase el contenedor */
    }

    .result-container {
        display: flex;
        align-items: center;
        justify-content: center; /* Centrar los selects */
        margin-bottom: 15px; /* Espaciado inferior */
        width: 100%; /* Asegurar que el contenedor no sobrepase el ancho del formulario */
    }

    .result-select {
        width: 60px; /* Ajustar el tamaño de los selects */
        margin: 0 5px; /* Espacio horizontal entre los selects */
        font-size: 14px; /* Tamaño de texto ajustado */
        text-align: center; /* Centrar el texto dentro del select */
    }

    .form-control {
        width: 100%; /* Asegurar que el campo de código de socio no sobrepase el contenedor */
        max-width: 300px; /* Limitar el ancho máximo del campo de código de socio */
    }

    .btn-primary {
        width: 100%; /* Asegurar que el botón no sobrepase el contenedor */
        max-width: 300px; /* Limitar el ancho máximo del botón */
        font-size: 14px; /* Tamaño de texto ajustado */
        padding: 10px; /* Ajustar el padding para móviles */
    }
}

/* Ajustes adicionales para pantallas grandes */
@media (min-width: 768px) {
    .prediction-form {
        flex-direction: row; /* Apilar elementos en fila en pantallas grandes */
        align-items: center;
        margin-top: 40px; /* Espacio adicional arriba del formulario */
    }

    .team-image {
        margin: 0 30px; /* Aumenta el margen para que los escudos estén más pegados a la izquierda */
        flex: 1; /* Permite que las imágenes ocupen más espacio si es necesario */
    }

    .membership-form {
        width: 70%; /* Aumenta el ancho del formulario */
        max-width: 800px; /* Establece un ancho máximo mayor para pantallas grandes */
    }
}

/* Estilo para el formulario */
.prediction-form .form-control {
    margin-bottom: 15px;
}

.prediction-form .btn {
    display: block;
    width: 100%;
}

/* Animación de aparición */
@keyframes fadeIn {
    from {
        opacity: 0;
        transform: translateY(20px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* Definir la animación */
@keyframes fadeInUp {
    from {
        opacity: 0;
        transform: translateY(20px);
    }
    to {
        opacity: 1;
        transform:  translateY(0);
    }
}

/* Animaciones */
@keyframes fadeIn {
    from { opacity: 0; }
    to { opacity: 1; }
}

/* Contenedor para los campos de resultado */
.result-container {
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 10px; /* Espaciado inferior */
}

/* Estilo para los campos de resultado */
.result-input {
    width: 60px; /* Ajusta el ancho de los campos de resultado */
    margin: 0 3px; /* Espaciado horizontal entre los campos */
    font-size: 10px; /* Tamaño de texto más pequeño */
    text-align: center; /* Centra el texto dentro del campo */
}

/* Estilo para los campos de selección de resultado */
.result-select {
    width: 40px; /* Ajusta el ancho del select */
    margin: 0 2px; /* Espaciado horizontal entre los campos */
    font-size: 12px; /* Tamaño de texto más pequeño */
    text-align: center; /* Centra el texto dentro del select */
    padding: 3px; /* Relleno reducido para hacer el campo más pequeño */
}

/* Estilo para el separador entre campos de resultado */
.result-separator {
    font-size: 50px; /* Tamaño del guión */
    color: red; /* Color rojo */
    margin: 0px 8px; /* Espaciado horizontal alrededor del guión */
}

/* Estilo para el campo de código de socio */
.form-label {
    font-weight: bold;
    color: red; /* Rojo */
}

.form-control {
    border: 2px solid #ff0000;
    border-radius: 4px;
    padding: 6px;
    font-size: 12px; /* Tamaño de texto más pequeño */
}
 
.mb-30 {
    padding: 15px 0px;
}

/* Estilos para el botón primario */
.btn-primary {
    background-color: #ff0000 !important; /* Color rojo */
    border: none;
    color: white;
    padding: 3px 8px; /* Ajusta el padding para hacer el botón más pequeño */
    border-radius: 4px;
    font-size: 10px; /* Tamaño de texto más pequeño */
    width: auto; /* Ajusta el ancho automáticamente al contenido */
}

.btn-primary:hover {
    background-color: #cc0000 !important; /* Color rojo oscuro al pasar el ratón */
}

/* Incluye el CSS aquí */
.membership-form-container {
    position: relative; /* Necesario para el posicionamiento absoluto de la alerta */
}

@media (max-width: 767.98px) {
   
    .hero {
        padding: 30px 15px;
    }
    
    .hero h1 {
        font-size: 2em;
    }
    
    .hero p {
        font-size: 1em;
    }
    
    .carousel-container {
        margin-top: 30px;
    }
    
    .carousel-item img {
        width: 100%;
        height: 100px;
    }
}

.footer-links a {
    color: white;
    text-decoration: underline;
    margin: 0 10px;
}

.footer-links a:hover {
    color: white;
    text-decoration: underline;
}

.table-container {
    margin: 30px auto;
    max-width: 100%; /* Cambia max-width a 100% para móviles */
    background-color: #ffffff;
    border-radius: 8px;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
    overflow: hidden;
    padding: 20px;
}

.table-container h2 {
    text-align: center;
    color: #ff0000; /* Rojo */
    margin-bottom: 20px;
}

.table {
    width: 100%; /* Asegúrate de que la tabla ocupe todo el contenedor */
    border-collapse: collapse; /* Mejora la apariencia de la tabla */
}

.table thead th {
    background-color: #ff0000; /* Rojo */
    color: white;
    text-align: center;
    font-weight: bold;
}

.table tbody tr:nth-child(even) {
    background-color: #f2f2f2;
}

.table tbody tr:hover {
    background-color: #e6e6e6;
}

.table td, .table th {
    padding: 10px;
    text-align: center;
    font-size: 0.9em; /* Ajusta el tamaño de fuente para que se ajuste mejor en móviles */
}

.table .team-name {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    overflow: hidden; /* Evitar desbordamiento */
}

.table .team-name img {
    width: 30px; /* Reduce el tamaño de las imágenes para dispositivos móviles */
    height: 30px; /* Cambia también la altura */
    border-radius: 4px;
    margin-right: 5px; /* Menos espacio entre el escudo y el nombre del equipo */
}

.table td {
    font-size: 0.9em; /* Tamaño de fuente más pequeño en móviles */
}

.table .position {
    font-weight: bold;
}

.table .team-name {
    font-weight: bold;
    padding-left: 5px; /* Reduce el espacio adicional para alinear el nombre del equipo */
}

/* Estilos específicos para móviles */
@media (max-width: 768px) {
    .table td {
        padding: 5px; /* Menos relleno en móviles */
    }

    .table th {
        padding: 8px; /* Menos relleno en móviles */
    }
}


footer a {
    color: white;            /* Cambia el color del enlace a blanco */
    text-decoration: underline; /* Asegura que el enlace esté subrayado */
}
    
footer a:hover {
    color: white;            /* Mantiene el color blanco incluso al pasar el cursor por encima */
    text-decoration: underline; /* Mantiene el subrayado al pasar el cursor por encima */
}