/*SLIDER*/
.sect_slider_main{
    position: relative;
}
.sect_slider_main:after {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 28px;
    background-image: url(../../../../public/img/fondo/nubes2.png);
    background-size: cover;
    background-repeat: repeat;
    transform: rotate(180deg);
}
.carousel-item {
    height: 100vh;
    min-height: 300px;
    background: no-repeat center center scroll;
    -webkit-background-size: cover;
    -moz-background-size: cover;
    -o-background-size: cover;
    background-size: cover;
}

.carousel-item:before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: #000;
    opacity: 0.5;
}

.sect_slider_main .carousel-control-prev-icon,
.sect_slider_main .carousel-control-next-icon {
    left: 0;
    position: absolute;
    width: 100%;
    z-index: 2;
    height: auto;
    display: block !important;
    -o-transform: translate(0, -50%);
    -webkit-transform: translate(0, -50%);
    -ms-transform: translate(0, -50%);
    transform: translate(0, -50%);
    margin: 0 !important;
}


/*CAPTION SLIDER*/

.slide_caption {
    position: absolute;
    overflow: hidden;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    /* right: 0; */
    display: flex;
    display: -moz-flex;
    flex-flow: row wrap;
    align-items: center;
    justify-content: center;
}
.slide_caption .slide_right{
    width: 40%;
    max-width: 500px;
    margin: 0 10px;
}
.slide_head {
    text-align: left;
    overflow: hidden;
    margin-left: 50px;
}
/**/
.slide_caption .slide_head h2 {
    color: #fff;
    font-weight: 700;
    font-size: 50px;
}

.slide_caption .slide_head h5 {
    color: #ffc815;
    font-size: 40px;
}

.delay-1 {
    animation-delay: 1s;
}

.delay-2 {
    animation-delay: 2s;
}

.delay-3 {
    animation-delay: 3s;
}

.delay-4 {
    animation-delay: 4s;
}

.delay-5 {
    animation-delay: 5s;
}

.delay-6 {
    animation-delay: 6s;
}

.list_redes{
    list-style: none;
    padding-left: 0;
    margin-bottom: 0;
    margin-bottom: 0;
    margin-top: 25px;
}
.list_redes>li{
    display: inline-block;
    margin-right: 20px;
}
.list_redes>li>a{
    color: #ffffff;
    font-size: 25px;
    -webkit-transition: all ease 500ms;
    -o-transition: all ease 500ms;
    transition: all ease 500ms;
}
.list_redes>li>a:hover{
    color: #ffc815;
    -webkit-transition: all ease 500ms;
    -o-transition: all ease 500ms;
    transition: all ease 500ms;
}
/**/
.slide_caption .slide_left{
    width: 50%;
    margin: 0 10px;
}
.frm_slider{
    width: 100%;
    max-width: 500px;
    background: rgba(255, 255, 255, 0.63);
    padding: 25px;
}
.input_text{
    width: 100%;
    display: block;
    padding: 15px;
    border-radius: 5px;
    border: 0;
    margin-bottom: 15px;
}
.input_text:focus{
    outline: none;
}
.txt_area{
    width: 100%;
    border: 0;
    border-radius: 5px;
    padding: 15px;
    min-height: 150px;
}
.input_select{
    width: 100%;
    display: block;
    padding: 15px;
    border-radius: 5px;
    border: 0;
    margin-bottom: 15px;
    min-height: 54px;
}
.txt_area:focus{
    outline: none;
}
.btn_enviar{
    display: block;
    padding: 20px;
    background: #ffc815;
    width: 100%;
    border: 0;
    margin-top: 10px;
    border-radius: 5px;
    cursor: pointer;
    -webkit-transition: all ease 500ms;
    -o-transition: all ease 500ms;
    transition: all ease 500ms;
}
.btn_enviar:hover{
    background: #04172a;
    color: #ffffff;
    -webkit-transition: all ease 500ms;
    -o-transition: all ease 500ms;
    transition: all ease 500ms;
}
.btn_enviar:focus{
    outline: none;
}
@media(max-width: 991px){
    .slide_caption .slide_head h2 {
        font-size: 30px;
    }
    .list_redes>li>a {
        font-size: 15px;
    }
}
/**/
.carousel-control-prev {
    left: 0;
    background: transparent;
    height: 80px;
    width: 75px;
    align-items: normal;
    top: 50%;
    transform: matrix(1, 0, 0, 1, 0, -55);
}

.carousel-control-prev-icon {
    position: relative;
}

.carousel-control-prev .carousel-control-prev-icon:before {
    content: "\f104";
    font-family: "FontAwesome";
    display: block;
    background: #ffc815;
    color: #ffffff;
    width: 47px;
    height: 80px;
    text-align: center;
    line-height: 80px;
    top: -1px;
    position: absolute;
    font-size: 30px;
    transition: all ease 500ms;
}

.carousel-control-prev .sr-only {
    width: 30px;
    height: 80px;
    position: absolute;
    top: 0px;
    right: 0;
    clip: unset;
    background: #ffffff;
}

.carousel-control-prev .sr-only:before {
    content: "Anterior";
    right: 0;
    color: #afafaf;
    display: block;
    text-align: center;
    width: 80px;
    position: absolute;
    bottom: 21%;
    width: 100%;
    height: 30px;
    font-weight: 700;
    transform: rotate(-90deg);
}

.carousel-control-prev:hover .carousel-control-prev-icon:before {
    width: 102%;
    transition: all ease 500ms;
}


/*NEXT*/

.carousel-control-next {
    right: 0;
    background: transparent;
    height: 80px;
    width: 75px;
    align-items: normal;
    top: 50%;
    transform: matrix(1, 0, 0, 1, 0, -55);
}

.carousel-control-next .carousel-control-next-icon:before {
    content: "\f105";
    font-family: "FontAwesome";
    display: block;
    background: #ffc815;
    color: #ffffff;
    width: 47px;
    height: 80px;
    text-align: center;
    line-height: 80px;
    top: -1px;
    position: absolute;
    right: 0;
    font-size: 30px;
    transition: all ease 500ms;
}

.carousel-control-next .sr-only {
    width: 30px;
    height: 80px;
    position: absolute;
    top: 0px;
    left: 0;
    clip: unset;
    background: #ffffff;
}

.carousel-control-next .sr-only:before {
    content: "Siguiente";
    left: 0;
    color: #afafaf;
    display: block;
    text-align: center;
    width: 80px;
    position: absolute;
    top: 21%;
    width: 100%;
    height: 30px;
    font-weight: 700;
    transform: rotate(90deg);
}

.carousel-control-next:hover .carousel-control-next-icon:before {
    width: 102%;
    transition: all ease 500ms;
}

@media(max-width: 991px) {
    .slide_caption .slide_head h1 {
        font-size: 30px;
    }
    .slide_caption .slide_head h5 {
        font-size: 20px;
    }
}

@media(max-width: 767px) {
    .carousel-control-prev,
    .carousel-control-next {
        width: 50px;
    }
    .carousel-control-prev .carousel-control-prev-icon:before,
    .carousel-control-next .carousel-control-next-icon:before {
        width: 25px;
    }

}

@media(max-width: 550px) {
    .slide_caption .slide_head h1 {
        font-size: 20px;
    }
    .slide_caption .slide_head h5 {
        font-size: 15px;
    }
    .slide_caption>div {
        width: 70%;
        margin: 0 auto;
    }
}

@media(max-width: 767px){
    .slide_right{
        display: none;
    }
    .slide_caption .slide_left {
        width: 90%;
        margin: 0 10px;
    }
    .slide_head {
        text-align: center;
        margin-left: 0;
    }
}
/******************** SECTION WELCOME ***********************/
.sect_welcome{
    padding: 80px 0;
}
.box_welcome{
    margin-top: 30px;
}
.box_welcome p, .box_welcome ul{
    /*text-align: center;*/
    color: #989898;
}
.m_welcome{
    margin: 60px 0;
    text-align: center;
}
.box_down{
    width: 100%;
    max-width: 300px;
    margin: 0 auto;
    background: #ffc815;
    padding: 20px;
    color: #04172a;
    border-radius: 10px;    
    animation: 1s down infinite alternate;
    -webkit-transition: all ease 500ms;
    -o-transition: all ease 500ms;
    transition: all ease 500ms;
}
.box_down:hover{
    background: #04172a;
    color: #ffc815;
    -webkit-transition: all ease 500ms;
    -o-transition: all ease 500ms;
    transition: all ease 500ms;
}
@keyframes down{
    from{
        transform: translate(0,-10px);
    }
    to{
        transform: translate(0,10px);
    }
}
@media(max-width: 767px){
    .box_down {
        max-width: 230px;
        padding: 10px;
        font-size: 15px;
    }
    .box_down h5{
        font-size: 15px;
    }
}

/****************** SECTION NOSOTROS ***********************/
.sect_nosotros{
    background-image: url(../../../../public/img/fondo/fondo-nosotros.jpg);
    background-size: cover;
    background-position: center;
    background-attachment: fixed;
    position: relative;
}
.sect_nosotros:before{
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 28px;
    background-image: url(../../../../public/img/fondo/nubes2.png);
    background-size: cover;
    background-repeat: repeat;
}
.sect_nosotros:after{
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 28px;
    background-image: url(../../../../public/img/fondo/nubes2.png);
    background-size: cover;
    background-repeat: repeat;
    transform: rotate(180deg);
}
.sect_nosotros .flex_nosotros{
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: flex;
    -webkit-flex-flow: row wrap;
    -moz-flex-flow: row wrap;
    -ms-flex-flow: row wrap;
    -o-flex-flow: row wrap;
    flex-flow: row wrap;
    justify-content: flex-end;
}
.sect_nosotros .flex_nosotros .flex_right{
    width: 50%;
    padding: 90px 50px;
    background: rgba(255, 255, 255, 0.87);
}
.sect_nosotros .flex_nosotros .descripcion p{
    color: #6d6d6d;
        text-align: justify;
}
.sect_nosotros .flex_nosotros .btn_contactanos{
    text-decoration: none;
    color: #000000;
    font-weight: 700;
    background: #ffc815;
    padding: 20px 10px;
    display: block;
    width: 250px;
    margin: 0 auto;
    text-align: center;
    border-radius: 10px;
    margin-top: 40px;
    -webkit-transition: all ease 500ms;
    -o-transition: all ease 500ms;
    transition: all ease 500ms;
}
.sect_nosotros .flex_nosotros .btn_contactanos:hover{
    background: #01408c;
    color: #fff;
    -webkit-transition: all ease 500ms;
    -o-transition: all ease 500ms;
    transition: all ease 500ms;
}
@media(max-width: 768px){
    .sect_nosotros .flex_nosotros .flex_right {
        width: 100%;
        background: rgba(255, 255, 255, 0.81);
    }
    .sect_nosotros .flex_nosotros .btn_contactanos {
        width: 200px;
    }
}
/**/


/************************************** SECTION SERVICIOS *******************************************/
.sect_servicios{
    padding: 80px 0;
    position: relative;
}
.sect_servicios .title_general{
    margin-bottom: 60px;    
}
/**/
.box_servicios{
    overflow: hidden;
    display: block;
    position: relative;
}
.box_servicios svg {
    position: absolute;
    opacity: 0.8;
    top: -1px;
    z-index: 10;
    width: 100%;
    height: 100%;
}
.box_servicios svg path {
    fill: #fff;
}
.sect_servicios:before {
        content: "";
    position: absolute;
    bottom: -25px;
    left: 0;
    width: 100%;
    height: 28px;
    background-image: url(../../../../public/img/fondo/nubes2.png);
    background-size: cover;
    background-repeat: repeat;
    z-index: 3;
}
/**/
/**/
.box_servicios .title{
    position: absolute;
    top: 21px;
    left: 0;
    right: 0;
    width: 100%;
    text-align: center;
    z-index: 20;
    color: #000;
    font-weight: 700;
    -webkit-transition: all cubic-bezier(0.25, 0.1, 0.3, 0.71) 150ms;
    -o-transition: all cubic-bezier(0.25, 0.1, 0.3, 0.71) 150ms;
    transition: all cubic-bezier(0.25, 0.1, 0.3, 0.71) 150ms;
}
.box_servicios:hover .title{
    top: -20px;
    -webkit-transition: all cubic-bezier(0.25, 0.1, 0.3, 0.71) 150ms;
    -o-transition: all cubic-bezier(0.25, 0.1, 0.3, 0.71) 150ms;
    transition: all cubic-bezier(0.25, 0.1, 0.3, 0.71) 150ms;
}
/**/
.box_servicios .box_img{
    position: relative;
    display: block;
}
.box_servicios .box_img:before{
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: #000;
    opacity: 0;
    z-index: 1;
    -webkit-transition: all ease 500ms;
    -o-transition: all ease 500ms;
    transition: all ease 500ms;
}
.box_servicios:hover .box_img:before{
    -webkit-transition: all ease 500ms;
    -o-transition: all ease 500ms;
    transition: all ease 500ms;
    opacity: .4;  
}
/****************************************** END SECTION SERVICIOS ******************************/

/**************************************** SECTION GALERIA *******************************************/
.sect_galeria{
    padding: 80px 0;
    padding-bottom: 50px;
    background-image: url(../../../../public/img/fondo/fondo-galeria.jpg);
    background-size: cover;
    position: relative;
    z-index: 1;
}
.sect_galeria:before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 28px;
    background-image: url(../../../../public/img/fondo/nubes2.png);
    background-size: cover;
    background-repeat: repeat;
    z-index: 2;
}
.sect_galeria:after {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: #000;
    opacity: .6;
    z-index: -1;
}
/**/
.sect_galeria .title_general h2{
    color: #ffffff;
}
.sect_galeria .title_general h2 span{
    color: #ffc815;
}
.sect_galeria .title_general h5{
    color: #ffffff;
}
/**/
.content_mixitup{
    width: 100%;
}
.box_portafolio{
    margin-top: 40px;
}
.box_galeria a{
    text-decoration: none;
}
.box_galeria a h6{
    margin-bottom: 0;
    padding: 10px;
    color: #fff;
    background: #04172a;
    -webkit-transition: all ease 500ms;
    -o-transition: all ease 500ms;
    transition: all ease 500ms;
}
.box_galeria a:hover h6{
    background: #ffc815;
    -webkit-transition: all ease 500ms;
    -o-transition: all ease 500ms;
    transition: all ease 500ms;
}
/**************************************** END SECTION GALERIA *****************************************/


/*SECTION NUESTROS ESPECIALISTAS*/
.sect_our_especialistas{
   padding: 120px 0;
    padding-bottom: 100px;
    background-image: url(../../../../public/img/fondo/fondo-team.jpg);
    background-size: cover;
    position: relative;
    z-index: 1;
}
.sect_our_especialistas:before{
    content: "";
    position: absolute;
    top: -99px;
    left: 0;
    width: 100%;
    height: 100px;
    /*background-image: url(../../../../public/img/fondo/bottom_fondo2.png);*/
    background-size: 100% 100%;
}
.sect_our_especialistas:after{
    content: "";
    position: absolute;
    top: 0px;
    left: 0;
    width: 100%;
    height: 100%;
    background: #000;
    opacity: .4;
    z-index: -1;
}
.box_testimonio{
    margin-top: 60px;
}
.box_testimonio .box_body{
    margin-top: 15px;
}
.box_testimonio .box_body center{
    color: #fff;
}
.box_testimonio .box_body h5{
    color: #fff;
    text-align: center;
}
.btn_verasesor{
    display: block;
    text-align: center;
    background: #ffc815;
    padding: 10px;
    margin-top: 10px;
    color: #04172a;
    font-weight: 670;
    border: 2px solid #ffc815;
    transition: all ease 500ms;
}
.box_testimonio:hover .btn_verasesor{
    background: transparent;
    color: #ffc815;
    text-decoration: none;
    transition: all ease 500ms;
}
.content-flex{
    display: flex;
    flex-flow: row wrap;
}
.content-flex .flex_left{
    width: 30%;
    background: #ffc815;
    padding: 30px;
}
.content-flex .flex_left .title_flex{
    margin-bottom: 40px;
}
.content-flex .flex_left span{
    color: #fff;
    font-size: 70px;
}
.content-flex .flex_left h2{
    color: #fff;
    font-size: 50px;
}
.content-flex .flex_left img{
    position: relative;
    right: -100px;
}

.content-flex .flex_right{
    width: 70%;
    display: flex;
    align-items: center;
    padding: 30px;
    padding-left: 124px;
}
.content-flex .flex_right h3{
    font-size: 30px;
    font-weight: 600;
}
.content-flex .flex_right .text_descrip{
    text-align: justify;
}
.content-flex .flex_right .text_descrip p{ 
    color: #9c9c9c;
    font-weight: 300;
    font-size: 20px;
}
.modalbody .close{
    font-size: 30px;
    margin-right: 13px;
    margin-top: 10px;
}

/*MODAL*/
@media(max-width: 992px){
    .modal {
        padding: 0 17px;
    }
}
@media(max-width: 767px){
    .content-flex .flex_left span {
        font-size: 35px;
    }
    .content-flex .flex_left h2 {
        font-size: 30px;
    }
    .content-flex .flex_right h3 {
        font-size: 20px;
    }
    .content-flex .flex_left img {
        right: -70px;
    }
    .content-flex .flex_right {
        padding-left: 70px;
    }
    .content-flex .flex_right .text_descrip p {
        font-size: 17px;
    }
}
@media(max-width: 630px){
    .content-flex .flex_left {
        padding: 30px;
        width: 100%;
    }
    .content-flex .flex_right {
        width: 100%;
        padding-left: 30px;
    }
    .content-flex .flex_left img {
        right: 0px;
    }
    .modalbody .close{
        position: absolute;
        right: 0;
    }
}
@media (min-width: 576px){
    #espe1 .modal-dialog {
        max-width: 990px;
    }
    #espe2 .modal-dialog {
        max-width: 990px;
    }  
    #espe3 .modal-dialog {
        max-width: 990px;
    }  
    #espe4 .modal-dialog {
        max-width: 990px;
    }  
}

/****************************************** SECTION CLIENTES ******************************/
.sect_clientes{
    padding: 80px 0;
    position: relative;
}
.sect_clientes:before {
    content: "";
    position: absolute;
    top: -15px;
    left: 0;
    width: 100%;
    height: 28px;
    background-image: url(../../../../public/img/fondo/nubes2.png);
    background-size: cover;
    background-repeat: repeat;
    transform: rotate(-180deg);
    z-index: 2;
}
/**/
.sect_clientes .title_general{
    margin-bottom: 60px;
}
/**/
.sect_clientes .clientes .flex_item{
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: flex;
    -webkit-flex-flow: row wrap;
    -moz-flex-flow: row wrap;
    -ms-flex-flow: row wrap;
    -o-flex-flow: row wrap;
    flex-flow: row wrap;
    padding: 5px 0;
}
.sect_clientes .clientes .flex_item .item_cliente{
    width: 23%;
    /* border: 1px dashed #ccc; */
    background: #ffffff;
    margin: 0 auto;
    margin-bottom: 22px;
    -webkit-box-shadow: 0px 10px 35px 0px rgb(208, 208, 208);
    box-shadow: 0px 10px 35px 0px rgb(208, 208, 208);

}
/*.sect_clientes .clientes .flex_item img{
    filter: grayscale(100%);
    transition: all ease 500ms;
}
.sect_clientes .clientes .flex_item .item_cliente:hover img{
    filter: grayscale(0%);
}*/
@media(max-width: 991px){
    .sect_clientes .clientes .flex_item .item_cliente {
        width: 23%;
    }
}
@media(max-width: 767px){
    .sect_clientes .clientes .flex_item .item_cliente {
        width: 42%;
    }
    .sect_clientes .title_general h2 {
        font-size: 30px;
    }
}
@media(max-width: 540px){
    .sect_clientes .clientes .flex_item .item_cliente {
        width: 45%;
    }
}