body,
html {
    margin: 0;
    padding: 0;
    overflow-x: hidden;
    font-family: Helvetica, sans-serif;
}

* {
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

/*COLORS*/
:root {
    /*PRINCIPALES*/
    --blue-intense: #031c4b !important;
    --blue: #02256b !important;
    --btn-blue: #09509d !important;
    --purple: #3c3c84 !important;
    --purple-light: #464ab3 !important;
    --gray: #6c6b6b !important;
    --beige: #b4b6b1 !important;
    --white: #fff !important;
    --black: #000 !important;
}

.gray {
    color: var(--gray);
}

.blue {
    color: var(--blue);
}

.blue-light {
    color: var(--btn-blue);
}

.white {
    color: var(--white);
}

.blue-intense {
    color: var(--blue-intense) !important;
}

.purple {
    color: var(--purple);
}

.purple-light {
    color: var(--purple-light);
}

.text-justify {
    text-align: justify;
}

/*SECTIONS*/
.section-blue-intense {
    background-color: var(--blue-intense);
    position: relative;
}

.section-blue {
    background-color: var(--blue);
    position: relative;
}

.section-purple {
    background-color: var(--purple);
    color: var(--white);
    position: relative;
}

.section-white {
    background-color: var(--white);
    position: relative;
}

.section-beige {
    background-color: var(--beige);
    position: relative;
}

.pb-10 {
    padding-bottom: 10rem;
}

.pt-10 {
    padding-top: 10rem;
}

.pt-16 {
    padding-top: 16rem;
}

.pt-20 {
    padding-top: 20rem;
}

.img-center {
    z-index: 1;
    top: 105rem;
    position: absolute;
}

/*BUTTONS*/

.btn-blue {
    border-radius: 30px;
    border: 2px solid var(--btn-blue) !important;
    background-color: var(--btn-blue);
    color: var(--white);
    text-decoration: none;
    font-weight: bold;
}

.btn-white {
    border-radius: 30px;
    border: 2px solid var(--white) !important;
    background-color: var(--white);
    color: var(--gray);
    text-decoration: none;
    font-weight: bold;
    padding: .5rem 2.5rem;
}

.btn-bw {
    border-radius: 30px;
    border: 2px solid var(--blue) !important;
    background-color: var(--white);
    color: var(--blue);
    text-decoration: none;
    font-weight: bold;
    padding: 0rem 1.5rem;
}

.imagen-intermedia {
    position: absolute;
    top: calc(100% - 125px);
    /* Coloca la imagen en el límite de la primera sección */
    left: 50%;
    transform: translateX(-50%);
    z-index: 5;
}

.imagen-intermedia img {
    display: block;
    max-width: 80vw;
    height: auto;
}

.logo-c {
    width: 11vw;
    height: auto;
}

.obras {
    width: 30vw;
    height: auto;
}

.gal {
    border: 2px solid var(--white);
    padding: 0 1rem;
    color: var(--white);
}

.td-none {
    text-decoration: none !important;
    color: var(--white);
}

.card-img-overlay:hover {
    background: #031c4b96;
    transition: background .5s ease-out;
}

.card-img-overlay .fa-circle-plus {
    opacity: 0;
}

.card-img-overlay:hover .fa-circle-plus {
    opacity: 1;
    transition: background .5s ease-out;
}

.img-mc {
    width: 100%;
    max-height: 60vh;
    object-fit: contain;
}

/*estilos galeria*/

.card img {
    object-fit: cover;
}


.thumb {
    width: 80px;
    height: 60px;
    object-fit: cover;
    cursor: pointer;
    transition: transform 0.2s;
    border: 2px solid transparent;
}

.thumb:hover,
.thumb.active-thumb {
    transform: scale(1.05);
    border-color: var(--btn-blue);
    /* color bootstrap primary */
}

.thumb-container {
    overflow-x: auto;
    white-space: nowrap;
    padding: 0.5rem 1rem;
    background: var(--white);
}


.gal-img {
    object-fit: cover;
    height: 30vh;
    width: 30vw;
}

.card.shadow-sm {
    height: 360px;
}


.carousel-control-prev,
.carousel-control-next {
    background-color: rgba(0, 0, 0, 0.3);
    /* fondo negro semitransparente */
    border-radius: 50%;
    /* botones redondos */
    width: 50px;
    /* tamaño del botón */
    height: 50px;
    top: 50%;
    transform: translateY(-50%);
}

/*HEADER*/
/* Transición suave del fondo */
.navbar {
    transition: background-color 0.4s ease, box-shadow 0.4s ease;
    background-color: #02256b81;
    min-height: 6rem;
    position: fixed;
    top: 0;
    right: 0;
    left: 0;
    z-index: 1030;
}

/* Estilo cuando se aplica el scroll */
.navbar.scrolled {
    background-color: var(--blue-intense) !important;
    /* O el color que desees */
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
}

/* Cambia el color de los links si es necesario */
.navbar-collapse .nav-link {
    color: var(--white) !important;
}

.offcanvas-body .nav-link {
    color: var(--gray) !important;
}

.logo {
    max-width: 10vw;
    position: absolute;
    top: 1rem;
    left: 13rem;
}

.navbar.scrolled .container .navbar-brand .logo {
    max-width: 6vw;
}

.cursor-default {
    cursor: default !important;
}

.offcanvas {
    position: fixed;
    background-color: var(--black);
    max-width: 60%;
}

/*FOOTER*/

footer {
    background-color: var(--blue);
    color: var(--white);
}

footer ul {
    list-style-type: none;
    padding: 0;
}

footer li::before {
    content: "\203A";
    font-size: 1.5rem;
    padding-right: .8rem;
}

footer div div p .m-0 {
    line-height: 1.5rem;
}

footer p {
    font-size: 1rem;
}

.footer-info {
    line-height: 1.5rem;
}

.copy-text {
    font-size: .8rem;
    letter-spacing: 2px;
}

/*MEDIA QUERIES*/

@media only screen and (max-width: 576px) {
    .imagen-intermedia {
        top: calc(100% - 30px);
    }

    .pb-10 {
        padding-bottom: 5rem;
    }

    .pt-10 {
        padding-top: 5rem;
    }

    .pt-16 {
        padding-top: 5rem;
    }

    .logo-c {
        width: 35vw;
    }

    .obras {
        width: 80vw;
    }

    .logo {
        max-width: 15vw;
        left: 3rem;
    }

    .navbar {
        position: relative;
        background-color: var(--blue-intense);
    }
}

@media (min-width: 576px) and (max-width: 1024px) {
    .col-md-7 {
        width: 66.66666667%;
    }

    .imagen-intermedia {
        top: calc(100% - 45px);
    }

    .logo-c {
        width: 15vw;
    }

    .obras {
        width: 40vw;
    }

    .logo {
        left: 2rem;
    }

    .pt-20 {
        padding-top: 13rem;
    }
}