body{
}

body::-webkit-scrollbar {
  width: 12px;               /* width of the entire scrollbar */
}

body::-webkit-scrollbar-track {
  background: #fff;        /* color of the tracking area */
}

body::-webkit-scrollbar-thumb {
  background-color: #606062;    /* color of the scroll thumb */
  border-radius: 20px;       /* roundness of the scroll thumb */
  border: 5px solid #FFF;  /* creates padding around scroll thumb */
}

a{
    color: #000 !important;
}

a:hover{
    color: #606062;
}

header{
    padding: 20px 0 !important;
}

.nav-link {
    color: #000;
}

.nav-link:hover {
    color: #606062;
}

.nav-pills .nav-link.active, .nav-pills .show>.nav-link {
    color: #000 !important;
    background-color: #ededed !important;
}

.menu-mobile{
    width: 100%;
}

.btn-menu {
    background: transparent;
    color: #000;
    font-size: 20px;
    border: none;
    margin-top: 6px;
    float: right;
}

.slider{
    position: relative;
}

.carousel-indicators{
    bottom: -7%;
    position: absolute;
}

.fondo-gris{
    background-color: #606062;
    color: #fff;
}

.fondo-gris-claro{
    background-color: #ededed;
    color: #000;
}

section h2{
    text-align: center;
    font-size: 24px;
}

.text-right{
    text-align: right !important;
}


.carousel-indicators [data-bs-target] {
    box-sizing: content-box;
    flex: 0 1 auto;
    width: 10px;
    height: 10px;
    border-radius: 10px;
    padding: 0;
    margin-right: 3px;
    margin-left: 3px;
    text-indent: -999px;
    /* cursor: ; */
    background-color: #fff;
    background-clip: padding-box;
    border: 0;
    border: none !important;
    /* opacity: .5; */
    /* transition: opacity .6s ease; */
}

 .carousel-item {
    transition: transform 1s ease-in-out;
  }
  .carousel-fade .active.carousel-item-start,
  .carousel-fade .active.carousel-item-end {
    transition: opacity 0s 1s;
  }

  .relative{
    position: relative;
    height: 100%; 
    min-height: 450px;
    background-position: center;
  }

   .relative:hover  .titulo_sobre_imagen{
    top: 45%
   }

  .relative .titulo_sobre_imagen{
    position: absolute;
    width: 80%;
    height: 50px;
    padding: 10px;
    left: 10%;
    top: 50%;
    font-size: 20px;
    color: white;
    background: url(../img/bg-titulo-obras.png) repeat;
    text-align: center;

  }

  .transition{
    -webkit-transition: all 0.8s 0s ease;
    -moz-transition: all 0.8s 0s ease;
    -o-transition: all 0.8s 0s ease;
    transition: all 0.8s 0s ease;
  }


.modal .carousel-indicators {
    bottom: 0%;
}

.obras .col-lg-3{
    padding:50px 25px;
}

.publicaciones .col-lg-3{
    padding:50px 25px;
}

.parent {
    width: 100%;
    margin: 20px 0;
    height: 420px;
    overflow: hidden;
    position: relative;
    float: left;
    display: inline-block;
  cursor: pointer;
}

.child {
    height: 100%;
    width: 100%;
    background-size: cover;
    background-repeat: no-repeat;
    -webkit-transition: all .5s;
    -moz-transition: all .5s;
    -o-transition: all .5s;
    transition: all .5s;
}

/* Several different images */
.bg-one {background-image: url(../img/residencial.png);}
.bg-two {background-image: url(../img/comercial.png);}
.bg-three {background-image: url(../img/industrial.png);}
.bg-four {background-image: url(../img/rural.png);}


.parent a {
   position: absolute;
    width: 80%;
    height: auto;
    padding:10px;
    left: 10%;
    top: 44%;
    font-size: 16px;
    text-transform: uppercase;
    color: white !important;
    background: url(../img/bg-titulo-obras.png) repeat;
    text-align: center;
    text-decoration: none;
    
    /* position: absolute;
    width: 80%;
    height: 100%;
    padding: 35% 10px;
    left: 10%;
    top: 0;
    font-size: 16px;
    text-transform: uppercase;
    color: white !important;
    background: url(../img/bg-titulo-obras.png) repeat;
    text-align: center;
    text-decoration: none; */
}

.parent:hover .child, .parent:focus .child {
    -ms-transform: scale(1.2);
    -moz-transform: scale(1.2);
    -webkit-transform: scale(1.2);
    -o-transform: scale(1.2);
    transform: scale(1.2);
}

.parent:hover .child:before, .parent:focus .child:before {
    display: block;
}

.parent:hover a, .parent:focus a {
    display: block;
}

.child a:hover{
    color: white;
}

.child:before {
    content: "";
    display: none;
    height: 100%;
    width: 100%;
    position: absolute;
    top: 0;
    left: 0;
    background-color: rgba(116,117,117,0.75);
}

.carousel-caption h3 {
    font-size: 42px;
    color: #FFF;
    text-align: left;
    text-transform: uppercase;
    
}

.carousel-caption {
    right: 6% !important;
    left: 6% !important;
}


.carousel-caption p{
    font-weight: 100;
    font-size:16px;
    color:#FFF;
    /*text-shadow: -2px 2px 3px rgba(0, 0, 0, 0.66);*/
    text-align:left;
    text-transform: uppercase;
}

.slider .carousel-item{
    height:85vh;
}

.titulo-publicaciones{
    color:#D93D8D;
}

h3.title-section{
    
      letter-spacing: 5px;
      padding:15px 0 25px 0;

}

.offcanvas-end {
    width: 400px !important;
}   

/* Media Queries */
@media screen and (max-width: 960px) {
    .parent {width: 100%; margin: 20px 0px}
    .wrapper {padding: 20px 20px;}
    

.carousel-caption h3{
    font-size:42px;
    line-height:40px;
}

.slider .carousel-item{
    height:71vh;
}



.carousel-caption p{
    font-size:18px;
    line-height:16px;
}
}

.offcanvas-end {
    width: 180px !important;
}   


.parent.project {
    width: 100%;
    margin: 20px 0;
    height: 260px;
    overflow: hidden;
    position: relative;
    float: left;
    display: inline-block;
  cursor: pointer;
}







@-webkit-keyframes zoom {
  from {
    -webkit-transform: scale(1, 1);
  }
  to {
    -webkit-transform: scale(1.5, 1.5);
  }
}

@keyframes zoom {
  from {
    transform: scale(1, 1);
  }
  to {
    transform: scale(1.2, 1.2);
  }
}

.carousel-inner .carousel-item {
  -webkit-animation: zoom 26s;
  animation: zoom 26s;
}

@keyframes fadeInUp {
    from {
        transform: translate3d(0,50px,0)
    }

    to {
        transform: translate3d(0,0,0);
        opacity: 1
    } 
}


.animated {
    animation-duration: 3s;
    animation-fill-mode: both;
    -webkit-animation-duration: 1.5s;
    -webkit-animation-fill-mode: both
}

.animatedFadeInUp {
    opacity: 0
}

.fadeInUp {
    opacity: 0;
    animation-name: fadeInUp;
    -webkit-animation-name: fadeInUp;
}


/* @-webkit-keyframes fadeInUp {
    from {
        transform: translate3d(0,40px,0)
    }

    to {
        transform: translate3d(0,0,0);
        opacity: 1
    }
} */