/* En tu archivo CSS principal (o en la vista) */

.improtec-hero {
    /* 🔴 Reemplaza 'path/to/your/image.jpg' con la ruta real de tu imagen de fondo */
    background-image: url('/assets/img/slider/IMPROTEC-COTIZACION.png');
    background-repeat: no-repeat;
    background-position: center center;
    background-size: cover;
    position: relative;
    padding-top: 100px; /* Ajusta el padding para centrar el texto */
    padding-bottom: 100px;
}

.improtec-hero::before {
    /* Overlay semi-transparente oscuro */
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    /* 🔴 Tono de azul oscuro para el overlay: ajusta el color y la opacidad (0.7) */
    background-color: rgba(18, 30, 52, 0.75);
    z-index: 1;
}

.improtec-hero .container {
    position: relative;
    z-index: 2; /* Asegura que el contenido esté sobre el overlay */
}

/* Estilo para las tarjetas de estadísticas */
.improtec-stats .card {
    border-radius: 12px;
    border: none;
}

/* Colores de referencia de la imagen */
:root {
    --improtec-blue: #14305c; /* Color oscuro del ícono y texto */
    --improtec-light-blue: #e6f0f6; /* Color de fondo del círculo del ícono */
}

/* Estilo para los iconos */
.improtec-icon-circle {
    font-size: 2rem;
    color: var(--improtec-blue);
    background-color: var(--improtec-light-blue);
    padding: 8px;
    border-radius: 50%;
    margin-right: 1rem;
    /* Asegura que el icono esté centrado en el círculo si usas una fuente de iconos */
    display: flex;
    align-items: center;
    justify-content: center;
    width: 3.5rem;
    height: 3.5rem;
}

/* Estilo para las tarjetas */
.card.shadow-sm {
    border-radius: 12px;
}
.card h3 {
    color: var(--improtec-blue) !important;
}

.card{
    box-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.3) !important;
}

/* Añade esta clase a tu CSS */
.card-animated {
    opacity: 0;
    transform: translateY(20px); /* Ligeramente desplazada hacia abajo */
    transition: opacity 0.5s ease-out, transform 0.5s ease-out; /* Transición para la animación */
}

/* Estado final al mostrar */
.card-animated.is-visible {
    opacity: 1;
    transform: translateY(0);
}
