        
/* Estilo para tarjetas verticales */
#overlay {
    display: none; /* Oculto por defecto */
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.5);
    z-index: 999;
}

.card {
    height: 220px; /* Altura estándar para todas las tarjetas */
    transition: transform 0.2s, box-shadow 0.2s; /* Transición suave para el efecto hover */
}
.card:hover {
    transform: scale(1.05);
    cursor: pointer;
    box-shadow: 0 0 10px rgba(77, 163, 255, 0.5);
}
.card-icon img {
    width: 80px; /* Ancho estándar de los íconos */
    height: 80px; /* Altura estándar de los íconos */
    object-fit: cover; /* Ajustar la imagen dentro del contenedor */
}
.card-title {
    color: #ef5196;
}
.card-text {
    color: #212529;
}
/* Espaciado entre columnas y tarjetas */
.row > .col-md-3 {
    padding: 10px;
}

/* Estilo para tarjetas horizontales */
.horizontal-card {
    display: flex;
    align-items: center;
    height: auto;
}
.horizontal-card img {
    width: 120px; /* Ancho de las imágenes en tarjetas horizontales */
    height: 120px; /* Altura uniforme */
    object-fit: cover;
    margin-right: 15px;
}
.horizontal-card .card-body {
    flex-grow: 1;
}
    /* Estilo para el mensaje emergente */
    #popup {
        display: none;
        position: fixed;
        left: 50%;
        top: 50%;
        transform: translate(-50%, -50%);
        padding: 20px;
        background-color: white;
        border: 2px gray; /* Color del borde */
        border-radius: 10px; /* Bordes redondeados */
        box-shadow: 0 0 15px rgba(0, 0, 0, 0.3); /* Sombra */
        z-index: 1000;
        text-align: center; /* Centrar el texto */
    }
    #overlay {
        display: none;
        position: fixed;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        background: rgba(0, 0, 0, 0.5);
        z-index: 999;
    }
    .close-button {
        background-color: #007BFF; /* Color de fondo */
        color: white; /* Color del texto */
        border: none; /* Sin borde */
        padding: 10px 20px; /* Espaciado interno */
        border-radius: 5px; /* Bordes redondeados */
        cursor: pointer; /* Cambia el cursor al pasar el ratón */
        transition: background-color 0.3s; /* Transición suave */
        margin-top: 15px; /* Espacio arriba del botón */
    }

    .close-button:hover {
        background-color: #0056b3; /* Color de fondo al pasar el ratón */
    }
    #backToTop {
    position: fixed;
    bottom: 60px; /* Distancia desde el fondo */
    right: 30px; /* Distancia desde la derecha */
    display: none; /* Ocultar el botón por defecto */
    background-color: #007BFF; /* Color de fondo azul */
    color: white; /* Color del texto */
    border: none; /* Sin borde */
    border-radius: 50%; /* Bordes redondeados */
    width: 50px; /* Ancho del botón */
    height: 50px; /* Altura del botón */
    font-size: 24px; /* Tamaño de la fuente */
    cursor: pointer; /* Cambia el cursor al pasar el ratón */
    transition: background-color 0.3s; /* Transición suave */
    box-shadow: 0 2px 5px rgba(0, 0, 0, 0.3); /* Sombra */
}

#backToTop:hover {
    background-color: #0056b3; /* Color de fondo al pasar el ratón */
}
/* Estilo para el componente de fecha y hora */
#dateTime {
            position: absolute;
            top: 20px; /* Distancia desde la parte superior */
            right: 20px; /* Distancia desde la derecha */
            background-color: rgba(255, 255, 255, 0.9); /* Fondo blanco con opacidad */
            border-radius: 10px; /* Bordes redondeados */
            padding: 10px; /* Espaciado interno */
            box-shadow: 0 2px 5px rgba(0, 0, 0, 0.2); /* Sombra sutil */
            display: flex; /* Usar flexbox para alinear iconos y texto */
            align-items: center; /* Centrar verticalmente */
            font-size: 0.9rem; /* Tamaño de fuente más pequeño */
            color: #0b3b59; /* Color del texto */
            z-index: 1000;
        }
        #dateTime i {
            margin-right: 5px; /* Espacio entre el icono y el texto */
        }

    .banner-container {
        width: 100%;
        max-width: 1200px; /* Limita el tamaño máximo */
        margin: 0 auto; /* Centra el contenedor */
        overflow: hidden; /* Esconde cualquier parte que sobresalga */
        border-radius: 10px; /* Bordes redondeados */
        box-shadow: 0 4px 10px rgba(0, 0, 0, 0.1); /* Sombra sutil */
        transition: transform 0.5s ease; /* Transición suave para el efecto */
    }

    .banner-img {
        width: 100%; /* Hace que la imagen ocupe todo el ancho del contenedor */
        display: block; /* Asegura que no haya espacio debajo de la imagen */
        border-radius: 10px; /* Bordes redondeados en la imagen */
    }

    .banner-container:hover {
        transform: scale(1.05); /* Aumenta el tamaño del contenedor completo al pasar el mouse */
        cursor: pointer; /* Cambia el cursor para indicar interactividad */
    }

    /* Estilos para el mapa */
    .map-container {
        width: 100%;
        max-width: 900px; /* Limita el tamaño máximo en pantallas grandes */
        margin: 0 auto; /* Centra el mapa */
        padding: 20px; /* Espacio alrededor */
    }

    iframe {
        border-radius: 10px; /* Bordes redondeados */
        box-shadow: 0 4px 10px rgba(0, 0, 0, 0.1); /* Sombra suave */
    }

    /* Estilos del botón de chatbot */
    #backToTop {
    margin-bottom: 80px;
    right: 36px;
}

#chatbotButton {
    position: fixed;
    bottom: 30px;
    right: 30px;
    background-color: #007BFF;
    color: white;
    border: none;
    border-radius: 50%;
    width: 60px;
    height: 60px;
    font-size: 24px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);
    transition: background-color 0.3s;
    z-index: 1000;

}

#chatbotButton:hover {
    background-color: #0056b3;
}

/* Estilos de la ventana de chatbot */
.chat-window {
    display: none;
    position: fixed;
    bottom: 100px;
    right: 30px;
    width: 300px;
    background-color: white;
    border-radius: 8px;
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.2);
    overflow: hidden;
    z-index: 1001;
}

.chat-header {
    background-color: #007BFF;
    color: white;
    padding: 10px;
    font-weight: bold;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.close-chat-button {
    background: none;
    border: none;
    color: white;
    font-size: 18px;
    cursor: pointer;
}

.chat-content {
    padding: 15px;
    height: 200px;
    overflow-y: auto;
    font-size: 14px;
}

.chat-input {
    display: flex;
    padding: 10px;
    border-top: 1px solid #eee;
}

.chat-input input {
    flex: 1;
    padding: 8px;
    border: 1px solid #ddd;
    border-radius: 4px;
    margin-right: 5px;
}

.chat-input button {
    background-color: #007BFF;
    color: white;
    border: none;
    padding: 8px 12px;
    border-radius: 4px;
    cursor: pointer;
    transition: background-color 0.3s;
}

.chat-input button:hover {
    background-color: #0056b3;
}

.chatbot-indicator {
    position: fixed;
    bottom: 100px; /* Ajuste para que no interfiera con el botón del chatbot */
    right: 30px;
    background-color: #007BFF;
    padding: 10px 15px;
    border-radius: 8px;
    box-shadow: 0px 4px 8px rgba(0, 0, 0, 0.2);
    font-size: 14px;
    color: #333;
    display: flex;
    align-items: center;
    z-index: 1000;
    transition: opacity 0.5s ease-out;
}

/* Estilo del texto "Asistente Paloma" */
.chatbot-text {
    font-size: 1rem;
    font-weight: bold;
    color: #ffffff; /* Color amarillo */
    margin-bottom: 5px;
}

/* Estilo de la flecha */
#arrow-indicator {
    position: relative;
    width: 0; 
    height: 0; 
    border-left: 15px solid transparent;
    border-right: 15px solid transparent;
    border-top: 20px solid #ffffff; /* Color amarillo */
    margin: 5px auto 0;
    animation: bounce 1s infinite alternate;
}

/* Animación de rebote */
@keyframes bounce {
    from {
        transform: translateY(0);
    }
    to {
        transform: translateY(-10px);
    }
}


.contenedor-banner {
    display: flex;
    justify-content: space-between;
    padding: 20px;
    background-color: #0b3b59;
    color: white;
    border-radius: 10px;

    width: 82%; /* Ocupar 80% del ancho de la página */
    margin: 0 auto; /* Centramos el contenedor */
    position: relative; /* Necesario para el icono */
}


.contenido-banner {
    flex: 1;
    margin-right: 20px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: flex-start; /* Ajuste para que el texto no se estire demasiado */
    text-align: left; /* Alineamos el texto a la izquierda para pantallas pequeñas */
    letter-spacing: 1px; /* Espacio entre las letras */
}

.contenido-banner h1 {
    margin: 0;
    font-size: 1.8rem; /* Ajustamos el tamaño de la fuente */
}

.contenido-banner p {
    margin: 5px 0; /* Reducimos el margen */
    font-size: 1rem; /* Reducimos el tamaño del texto para hacerlo más comprimido */
}

.contenedor-slider {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 500px; /* Reducimos el tamaño del contenedor al de la imagen */
    background-color: white;
    padding: 10px;
    border-radius: 10px;
    position: relative; /* Necesario para posicionar los botones dentro del contenedor */
}

.slider {
    display: flex;
    overflow: hidden;
    width: 100%; /* Ajustamos para que ocupe solo el ancho de la imagen */
}

.slider img {
    width: 100%; /* La imagen ahora ocupa todo el ancho del contenedor */
    cursor: pointer;
    border-radius: 10px;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
}

.anterior, .siguiente {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    background-color: rgba(0, 0, 0, 0.5);
    color: white;
    border: none;
    padding: 10px;
    cursor: pointer;
    border-radius: 50%;
    z-index: 10; /* Asegura que los botones estén por encima de la imagen */
}

.anterior {
    left: 10px; /* Ajusta la posición del botón anterior */
}

.siguiente {
    right: 10px; /* Ajusta la posición del botón siguiente */
}

/* Modal */
.modal {
    display: none; /* Oculto por defecto */
    position: fixed;
    z-index: 1100; /* Asegúrate de que se superponga sobre otros elementos */
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    overflow: auto; /* Permite el scroll si el contenido es muy grande */
    background-color: rgba(0, 0, 0, 0.8); /* Fondo semitransparente oscuro */
}

.imagen-modal {
    margin: auto;
    display: block;
    max-width: 90%; /* Ajusta el tamaño de la imagen en proporción a la pantalla */
    max-height: 90%; /* Ajusta la altura máxima de la imagen */
}

.cerrar {
    position: absolute;
    top: 10px;
    right: 25px;
    color: #fff;
    font-size: 35px;
    font-weight: bold;
    cursor: pointer;
}

.cerrar:hover,
.cerrar:focus {
    color: #ccc;
    text-decoration: none;
    cursor: pointer;
}

/* Icono en la esquina inferior izquierda */
.icono {
    position: absolute;
    bottom: 20px;
    left: 20px;
    font-size: 30px;
    color: white; /* Color del icono */
    cursor: pointer;
    z-index: 20;
}
body {
    /*font-family: Arial, sans-serif;*/
    background-color: #f9f9f9; /* Color de fondo suave */
}

.banner-container {
    display: flex;
    align-items: center; /* Centra verticalmente el contenido */
    background-color: #ffffff; /* Color de fondo del contenedor */
    border-radius: 10px; /* Bordes redondeados */
    box-shadow: 0 4px 8px rgba(58, 147, 248, 0.1); /* Sombra sutil */
    padding: 20px; /* Espaciado interno */
    margin: 20px auto; /* Espaciado externo, centrado horizontalmente */
    max-width: 1105px; /* Ancho máximo del contenedor */
    cursor: default;
}
.banner-image {
    width: 600px; /* Ancho de la imagen */
    height: auto; /* Mantiene la proporción de la imagen */
    border-radius: 10px; /* Bordes redondeados para la imagen */
    margin-right: 20px; /* Espacio entre la imagen y el texto */
}

.banner-text {
    max-width: 400px; /* Ancho máximo del texto */
}

.banner-text h2 {
    font-size: 1.5em; /* Tamaño de la fuente del título */
    color: #333; /* Color del texto */
}

.banner-text p {
    font-size: 1em; /* Tamaño de la fuente del párrafo */
    color: #666; /* Color del texto del párrafo */
}

@media (max-width: 768px) {
    .banner-container {
        flex-direction: column; /* Cambia a columna en pantallas más pequeñas */
        align-items: flex-start; /* Alinea el contenido a la izquierda */
    }

    .banner-image {
        width: 100%; /* La imagen ocupa el 100% del ancho del contenedor */
        max-width: none; /* Elimina el ancho máximo para que se ajuste */
        margin-right: 0; /* Elimina el margen derecho */
        margin-bottom: 20px; /* Agrega margen inferior para separación */
    }

    .banner-text {
        max-width: 100%; /* Permite que el texto ocupe el 100% del ancho */
    }

    .banner-text h2 {
        font-size: 1.25em; /* Tamaño de la fuente del título más pequeño */
    }

    .banner-text p {
        font-size: 0.9em; /* Tamaño de la fuente del párrafo más pequeño */
    }
}

/* Media Queries para pantallas más pequeñas */
@media (max-width: 768px) {
    .contenedor-banner {
        flex-direction: column; /* Apilamos los elementos */
        width: 95%; /* Hacemos que el contenedor ocupe más ancho en pantallas pequeñas */
        padding: 10px;
    }

    .contenedor-slider {
        width: 100%; /* La imagen ocupará el 100% de la pantalla en pantallas pequeñas */
    }

    .contenido-banner h1 {
        font-size: 1.5rem; /* Reducimos el tamaño del título */
    }

    .contenido-banner p {
        font-size: 0.9rem; /* Reducimos el tamaño del texto del párrafo */
    }
}

@media (max-width: 480px) {
    .contenedor-banner {
        width: 100%; /* Aseguramos que ocupe el 100% en pantallas muy pequeñas */
    }

    .contenido-banner h1 {
        font-size: 1.2rem; /* Reducimos aún más el tamaño del título */
    }

    .contenido-banner p {
        font-size: 0.8rem; /* Reducimos aún más el tamaño del párrafo */
    }
}


     .clave-unica-component-wrapper {
            padding: 20px 0; /* Espacio exterior opcional */
        }

        .clave-unica-component {
            background-color: #fff;
            background-image: url("data:image/svg+xml,%3Csvg width='10' height='10' viewBox='0 0 10 10' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle cx='1' cy='1' r='0.5' fill='%23cccccc'/%3E%3C/svg%3E");
            border: 1px solid #e0e0e0;
            border-radius: 8px;
            overflow: hidden;
        }

        .clave-unica-left-col-content {
            padding: 25px;
            display: flex;
            flex-direction: column;
            align-items: center;
            justify-content: center;
            text-align: center;
            height: 100%; /* Para que se estire con align-items-stretch */
        }

        .clave-unica-graphic-link {
            display: inline-block;
            text-decoration: none;
        }

        .clave-unica-graphic {
            max-width: 450px; /* Límite superior para la imagen */
            width: 100%;      /* Asegura que sea responsiva dentro de su max-width */
            height: auto;
            display: block;
        }

        .clave-unica-separator-col {
            /* Estilos para la columna del divisor manejados por clases de Bootstrap (d-none d-lg-flex) */
        }
        .clave-unica-divider {
            width: 2px;
            background-color: #0B3B59;
            height: 70%; /* Altura relativa al contenedor del divisor */
        }

        .clave-unica-right-col-content {
            padding: 0;
            display: flex;
            align-items: stretch; /* Asegura que el wrapper del iframe se estire */
            height: 100%; /* Para que se estire con align-items-stretch */
        }

        .iframe-video-wrapper {
            position: relative;
            width: 100%;
            height: 100%; /* Se estira para igualar altura en layouts lado a lado */
            min-height: 280px; /* Altura mínima para tablet y escritorio */
            background-color: #000;
            overflow: hidden;
        }

        .iframe-video-wrapper iframe {
            position: absolute;
            top: 0;
            left: 0;
            width: 100%;
            height: 100%;
            border: 0;
        }

        /* --- ESTILOS RESPONSIVOS --- */

        /* Tablet (md): 768px a 991.98px */
        /* En este punto, las columnas .col-md-6 ya están lado a lado. */
        /* El divisor vertical (.clave-unica-separator-col) está oculto por d-none y solo aparece en d-lg-flex. */
        /* No se necesita un separador horizontal. El min-height del iframe se aplica. */
        @media (min-width: 768px) and (max-width: 991.98px) {
            /* No se necesitan estilos específicos aquí si el comportamiento por defecto es el deseado. */
            /* El .iframe-video-wrapper usará su min-height: 280px o height:100% si la otra columna es más alta. */
        }


        /* Móvil (xs, sm): hasta 767.98px */
        /* Las columnas .col-md-6 se apilan automáticamente. */
        @media (max-width: 767.98px) {
            .clave-unica-left-col-content {
                border-bottom: 2px solid #0B3B59; /* Separador horizontal */
                margin-bottom: 20px; /* Espacio después del separador */
                padding-bottom: 25px; /* Espacio interno antes del separador */
            }

            .iframe-video-wrapper {
                padding-top: 56.25%; /* Proporción 16:9 para el video */
                height: 0;           /* Anula la altura explícita para usar padding-top */
                min-height: 0;       /* Anula la altura mínima para que padding-top funcione */
            }
             .clave-unica-graphic {
                max-width: 300px; /* Opcional: reducir un poco más la imagen en móviles muy pequeños */
                                  /* Si el padding de 25px es suficiente, esto puede no ser necesario */
            }
        }