@media screen and (min-width: 1920px){
    html, body{
        font-size: 28px;
    }
}
@media screen and (min-width: 1180px){
    .item_m:hover{
        border-color: currentColor;
    }
    /* .item_m_d:hover span{
        border-bottom: 1px solid currentColor;
    } */
    .red:hover span{
        border-bottom:1px solid currentColor;
    }
    .fs_item:hover span{
        cursor: pointer;
        border-bottom:1px solid currentColor;
    }
    .footer_col p a:hover{
        text-decoration: underline;
    }
     .header_int p a:hover{
        text-decoration: underline;
    }
    .texto a:hover{
        text-decoration: underline;
    }
    .btn:hover{
        background-color: #17333A;
        color: #E5E8EA;
    }
    .lSSlideOuter .lSPager.lSpg > li:hover a{
        background-color: currentColor;
    }
    .banner_nav_a:hover {
        text-decoration: underline;
        text-decoration-skip-ink: none;
    }
}


@media screen and (max-width: 950px){
    html, body{
        font-size: 14px;
    }
    .header_int,
    .contenido,
    .footer_int{
        width: calc(100% - 60px);
    }
    .banner_informacion .banner_info{
        width: calc(100% - 30px - 2.65rem);
    }
    .ss_title{
        padding-left: 30px;
    }
    .sb_title{
        padding: 0 30px 0 4rem;
    }
    .s_parrafo{
        padding: 2rem 30px 2rem 4rem;
    }
    .lSAction{
        left: 30px;
        transform: translateX(0);
    }
    .lSSlideOuter .lSPager.lSpg{
        right: 30px;
    }
    .header_int{
        grid-template-columns: 1fr 13.63rem;
    }

    .logo{
        padding: 1rem 0;
    }

    .texto,
    .info_extra_info{
        width: 100%;
        max-width: 550px;
    }
    .btn.btn_cotiza{
        right: 30px;
    }
    .over_form{
        position: fixed;
        top: 0;
        left: 0;
        z-index: 10;
        background-color: rgb(0 0 0 / 20%);
    }
    .contenido.contenido_mitad{
        grid-template-columns: 1fr;
    }
    .contenido.contenido_mitad .texto{
        width: 100%;
        max-width: initial;
        border-right: 1px solid currentColor;
        box-sizing: border-box;
    }
    .texto_page{
        min-height: initial;
    }
    .imagen_back{    
        width: 100%;
        height: 56vw;
        top: 0;
        position: relative;border-right: 1px solid currentColor;
        border-left: 1px solid currentColor;
        border-top: 1px solid currentColor;
    }
    .banner_nav_a{
        font-size: 1.2rem;
    }
    
}


@media screen and (max-width: 840px){
    .texto_page_bloque .contenido{
        grid-template-columns: 10rem 1fr;
    }
}

@media screen and (max-width: 700px){
    .menu{
        display: none;
    }
    .header_desplegar{
        display: none!important;
    }
    .btn_responsive{
        display: flex;
        width: 3rem;
        align-items: center;
        justify-content: center;
        cursor: pointer;
    }
    .btn_responsive span{
    width: 2rem;
    height: 1px;
    background-color: currentColor;
    position: relative;
}
    .btn_responsive span::after{
        content: '';
        position: absolute;
        bottom: -10px;
        width: 100%;
        height: 1px;
        background-color: currentColor;
    }
    .btn_responsive span::before{
        content: '';
        position: absolute;
        top: -10px;
        width: 100%;
        height: 1px;
        background-color: currentColor;
    }
    .f_menu{
        display: none;
    }
    .footer_int{
        display: flex;
        align-items: center;
        text-align: center;
        justify-content: flex-start;
        flex-direction: column-reverse;
    }
    .footer_col {
        padding: 0;
    }
    footer {
        padding: 3rem;
    }
    .footer_col:nth-child(2) .footer_sub .fs_item{
        margin: 0 1rem;
    }
    .fs_item{
        margin: 0 1rem;
        padding: 0;
    }
    .banner_informacion .banner_int{
        display: flex;
        flex-direction: column;
    }
    .banner_informacion .banner_img{
        border-right: 0;
        border-bottom: 1px solid currentColor;
        margin-bottom: 2rem;
    }
    .frase_slide .contenido{
        display: flex;
        padding-bottom: 5rem;
    }
    .lSAction {
        bottom: 20px;
        left: 50%;
        transform: translateX(-50%);
    }
    .fraccion{
        bottom: 20px;
    }
    .frase_image{
        justify-content: flex-end;
    }
    .frase {
        padding: 0;
        width: 100%;
    }
    .servicios_slide{
        display: flex;
        flex-direction: column;
    }
    .sb_title{
        min-height: 6.3rem;
        padding: 0 30px;
        border-bottom: 1px solid currentColor;
        border-left:none;
    }
    .s_parrafo{
        padding: 2rem  30px 4rem;border: none;
    }
    .btn{
        padding: 1em 2.2rem;    border-radius: 1.6em;
    }
    .banner_informacion .banner_info h2{
        font-size: 1.8rem;
    }
    .banner_imagen .banner_info h2{
        font-size: 1.1rem;
        margin: 0 0 2rem;
    }


    .menu_responsive{
    display: none;
    position: absolute;
    top: calc(100% + 1px);
    left: 0;
    width: 100%;
    height: calc(100vh - 59px);
}
    .mr_menu{
    display: block;
    background-color: #e5e8ea;
    padding: 0;
    box-sizing: border-box;
    width: 100%;
    height: 100%;
    overflow: auto;
}
    .item_mr{
    display: block;
    padding: 1.2rem 30px;
    border-bottom: 1px solid currentColor;
}
    .mr_menu_responsive{
    display: none;
    background-color: #e5e8ea;
    width: 100%;
    height: 100%;
    z-index: 2;
    position: absolute;
    top: 0;
    right: 0;
}
.item_mr.servicio_responsive{
    display: flex;
    align-items: center;
    justify-content: space-between;
}
.ss_title{
    position: relative;
    top: initial;
}
.frase_s_int{
    max-width: 100%;
}
.banner_nav{
    display: none;
}
.galeria_scroll-info .btn{margin: 0;}
.banner_imagen .banner_img{
    padding-bottom: 60%;
}
.galeria_scroll-info nav{
    justify-content: flex-start;
}
.btn_fixed{
    top: 0;
}

}

@media screen and (max-width: 640px){
    .texto_page_bloque .contenido{
        grid-template-columns: 1fr;
    }
    .texto_page_bloque ul{
        padding-left: 1rem;
    }
    .galeria_scroll-info{
        flex-direction: column;
    align-items: flex-start;
    }
    .info-scroll{
        width: 100%;
    }
    .galeria_scroll-info nav{
        width: 100%;
    }
    .galeria_scroll-item:first-child{
        height: auto;
        padding-top: 2rem;
    }
    .frases_contenido{
        height: auto;
        display: block;
    }
}

@media screen and (max-width: 500px){
    .form_cube{
        box-sizing: border-box;
        width: calc(100% - 40px);
    }
    .cerrar{
        right: 0;
        top: -3rem;
    }
    .doble_label{
        flex-direction: column;
    }
    .contenido.contenido_mitad{
        width: 100%;
    }
    .contenido.contenido_mitad .texto,
    .imagen_back{
        border:none;
    }
    .imagen_back{
        border-top: 1px solid currentColor;
        border-bottom: 1px solid currentColor;
    }
}