.portfolio-item {

  position: relative;

  min-height: 100px;

  margin-bottom: 30px;

  -webkit-transition: all 0.3s;

  transition: all 0.3s;

  display: block;

}

@media (min-width: 768px) {

  .portfolio-item {

    margin-bottom: 24px;

  }

}

@media (min-width: 1400px) {

  .portfolio-item {

    margin-bottom: 30px;

  }

}

@media (min-width: 1670px) {

  .portfolio-item {

    margin-bottom: 40px;

  }

}

.portfolio-item:hover .overlay-wrapper .overlay,

.portfolio-item:hover .portfolio-info .cat,

.portfolio-item:hover .portfolio-info .heading {

  opacity: 1;

}

.portfolio-item:hover .portfolio-info .cat,

.portfolio-item:hover .portfolio-info .heading {

  -webkit-transform: translateY(0);

  transform: translateY(0);

}

.portfolio-item .portfolio-thumb {

  position: relative;

  overflow: hidden;

  height: 100%;

  width: 100%;

  display: -ms-flexbox;

  display: -webkit-box;

  display: flex;

  -ms-flex-align: start;

  -webkit-box-align: start;

  align-items: flex-start;

  margin-bottom: 0px;

  overflow: hidden;

}

.portfolio-item .portfolio-thumb > img {

  width: 100%;

  -webkit-transition: ease-in-out 0.4s;

  transition: ease-in-out 0.4s;

  -o-object-fit: cover;

  object-fit: cover;

}

.portfolio-item .overlay-wrapper {
    width: calc(100% - 0px);
    height: calc(100% - 20px);
    position: absolute;
    top: 0px;
    left: 0px;
    overflow: hidden;
}

.portfolio-item .overlay-wrapper .overlay {

  position: absolute;

  top: 0px;

  left: 0px;

  width: 100%;

  height: 100%;

  background-color: rgba(0, 0, 0, 0.6);

  -webkit-transition: ease-in-out 0.35s;

  transition: ease-in-out 0.35s;

  opacity: 0;

}

.portfolio-item .portfolio-info {

  position: absolute;

  bottom: 23px;

  left: 20px;

}

@media (min-width: 576px) {

  .portfolio-item .portfolio-info {

    bottom: 26px;

    left: 30px;

  }

}

@media (min-width: 768px) and (max-width: 1669px) {

  .portfolio-item .portfolio-info {

    bottom: 23px;

    left: 20px;

  }

}

.portfolio-item .portfolio-info .heading {

  font-size: 20px;

  position: relative;

  -webkit-transition: all 0.3s;

  transition: all 0.3s;

  line-height: 1.2;

  color: white;

  opacity: 0;

  margin-bottom: 0;

  -webkit-transform: translateY(20px);

  transform: translateY(20px);

}

@media (min-width: 1200px) {

  .portfolio-item .portfolio-info .heading {

    font-size: 22px;

  }

}

@media (min-width: 1670px) {

  .portfolio-item .portfolio-info .heading {

    font-size: 24px;

  }

}

.portfolio-item .portfolio-info .heading:hover {

  color: #e9204f;

}

.portfolio-item .portfolio-info .cat {

  color: #e0e0e0;

  font-size: 13px;

  font-weight: 600;

  margin-bottom: 5px;

  opacity: 0;

  -webkit-transition: all 0.3s;

  transition: all 0.3s;

  -webkit-transform: translateY(-20px);

  transform: translateY(-20px);

}

@media (min-width: 576px) {

  .portfolio-item .portfolio-info .cat {

    font-size: 14px;

  }

}