.adv-img {
  position: relative;
  display: block;
  background: none;
}

.adv-img.text-left h2,
.adv-img.text-left h3,
.adv-img.text-left p {
  text-align: left;
}

div.adv-img p,
.caption-bottom p,
a.adv-circle .caption p {
  color: #f5f5f5;
  font-weight: 400;
  height: initial;
}

div.caption-bottom p {
  color: #929292;
}

.adv-img:before {
  display: none !important;
}

.img-box.adv-img img {
  opacity: 1 !important;
}

.adv-img a:focus {
  outline: none;
}

.adv-img .img-box {
  display: block;
  max-width: 100%;
}

.adv-img .caption {
  position: absolute;
  z-index: 9;
  overflow: hidden;
  color: #fff;
  cursor: pointer;
  transform: translate3d(0, 0, 0);
}

.adv-img > i,
.adv-img span > i {
  margin: 15px;
  z-index: 10;
}

.adv-img .sub i {
  opacity: 1 !important;
  position: static !important;
  font-size: 14px !important;
  margin: 0 5px 0 0 !important;
  color: white;
}

.adv-img h2,
.adv-circle h2,
.caption-bottom h2 {
  margin: 0;
  font-size: 19px;
  line-height: 25px;
  font-weight: 600;
}

.caption-bottom {
  text-align: center;
  line-height: 28px;
  padding: 15px;
}

.adv-img-down-text .caption-bottom p {
  margin-bottom: 5px;
}

.adv-img-down-text .img-box:before {
  background: rgba(255, 255, 255, 0);
}

.adv-img .white.circle-button:hover,
.adv-img .white .circle-button:hover {
  background-color: rgba(19, 19, 19, 0.49);
}

.adv-img-down-text.boxed-inverse,
.adv-img-down-text.boxed {
  padding: 0 !important;
}

.section-bg-color .boxed-inverse {
  background-color: #fff;
}

/* 
============================== 
HALF CONTENT & SIDE CONTENT & FULL CONTENT
============================== 
*/

.img-box.adv-img-half-content .caption,
.img-box.adv-img-side-content .caption {
  position: absolute;
  bottom: 0;
  right: 0;
  left: 0;
  padding: 25px 15px;
  background-color: rgba(4, 4, 4, 0.7);
  background: linear-gradient(
    to top,
    rgba(0, 0, 0, 0.7) 0%,
    rgba(0, 0, 0, 0) 100%
  );
  transform: translate3d(0, 0, 0);
}

.img-box.adv-img-side-content .caption {
  background: linear-gradient(
    to right,
    rgba(0, 0, 0, 0.7) 0%,
    rgba(0, 0, 0, 0) 100%
  );
}

.adv-img-side-content .caption {
  top: 0;
  height: 100%;
  width: 70%;
  text-align: left;
  font-size: 11px;
}

.adv-img-half-content,
.adv-img-half-content .caption {
  height: auto !important;
}

.adv-img-half-content i.main-icon,
.adv-img-side-content i.main-icon {
  color: #585858;
}

.adv-img-half-content .caption.caption-top {
  top: 0;
  bottom: auto;
}

.adv-img-side-content .caption.caption-right {
  right: 0;
  left: auto;
}

.adv-img-half-content p,
.adv-img-side-content p {
  margin: 15px 0 0 0;
}

.adv-img-full-content .caption {
  text-align: center;
  margin: auto;
  width: 100%;
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  right: 0;
  display: table;
  height: 100%;
  padding: 15%;
  background: none !important;
}

.adv-img-full-content .caption-bg {
  background-color: rgba(0, 0, 0, 0.7);
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  right: 0;
  z-index: 9;
}

.adv-img .img-box img {
  width: 100%;
}

.adv-img-full-content img + h2 {
  margin-top: 10px;
}

.adv-img-full-content p.sub {
  margin-top: 10px;
}

.adv-img-full-content i.main-icon {
  margin: 0 0 15px 0;
  width: 100%;
  text-align: center;
  position: static !important;
  color: white;
  font-size: 50px;
}

/* 
============================== 
BUTTONS CONTENT
============================== 
*/

.adv-img-button-content h2 {
  margin-bottom: 15px;
}

.adv-img-button-content .caption i {
  position: static !important;
  background-color: rgb(255, 255, 255);
  color: #3c3c3c;
  margin: 10px;
}

.adv-img-button-content .caption i:hover {
  opacity: 0.8 !important;
}

.adv-img-button-content > .img-box:before {
  opacity: 0;
  transition-delay: 0s;
  transition: opacity 0.3s;
}

.adv-img-button-content.show > .img-box:before,
.adv-img-button-content:hover > .img-box:before {
  opacity: 0.6 !important;
  z-index: 9;
}

/* 
============================== 
DOWN TEXT
============================== 
*/

.adv-img-down-text .caption:hover {
  opacity: 1;
}

.adv-img-down-text .caption {
  opacity: 0;
  height: 100%;
  text-align: center;
  top: 0;
  position: absolute;
  width: 100%;
  background-color: rgba(0, 0, 0, 0.3);
  transition: opacity 0.5s;
}

.adv-img-down-text h2 a {
  color: #3e3e3e;
  padding-bottom: 10px;
  display: inline-block;
}

/* 
============================== 
CLASSIC BOX
============================== 
*/
.adv-img-classic-box .caption {
  top: 0;
  bottom: 0;
  position: absolute;
  width: 120%;
  width: calc(100% + 14px);
  height: 100%;
  background-color: rgba(0, 0, 0, 0.3);
  background: linear-gradient(
    to top,
    rgba(0, 0, 0, 0.7) 0%,
    rgba(0, 0, 0, 0) 100%
  ) !important;
  transform: translate3d(0, 0, 0);
  padding: 0;
}

.adv-img-classic-box .caption-inner {
  bottom: 0;
  position: absolute;
  padding: 20px 15px;
  text-align: left;
  overflow: hidden;
  max-height: 85px;
  transition: max-height 0.8s;
  max-width: 100%;
}

.adv-img-classic-box .caption-inner h2 {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  margin-bottom: 2px;
}

.adv-img-classic-box:hover .caption-inner {
  max-height: 500px;
}

.adv-img-classic-box .caption-inner p.sub-text {
  height: 20px;
  overflow: hidden;
  text-overflow: ellipsis;
  margin-bottom: 20px;
  color: #e8e8e8;
}

.adv-img-classic-box .caption-inner p.big-text {
  height: 53px;
  overflow: hidden;
  text-overflow: ellipsis;
  margin-bottom: 10px;
}

.adv-img-classic-box .caption a {
  margin-bottom: 5px;
  margin-top: 10px;
}

.adv-img-classic-box a.img-box:before,
.adv-img-full-content a.img-box:before {
  display: none;
}

.adv-img-classic-box .img-box {
  height: 100%;
}
/*
==============================
CIRCLE ADVANCED IMAGE BOX
==============================
*/

.adv-circle-center.show,
.adv-circle-center-2.show {
  transition: none;
}

.img-box.adv-circle.show img {
  opacity: 0.5;
}

.circle.show i,
.circle.show .caption,
.img-box.adv-circle.show:before {
  opacity: 1 !important;
}

.img-box.adv-circle-center.show:hover img,
.img-box.adv-circle-center-2.show:hover img {
  opacity: 0.3 !important;
}

.adv-circle .caption p {
  margin: 10px 0 0;
}

.adv-circle .caption {
  position: absolute;
  z-index: 9;
  overflow: hidden;
  color: #fff;
  background: none;
  transform: translate3d(0, 0, 0);
}

.adv-circle i {
  margin: 15px;
  z-index: 10;
}

.adv-circle .sub i {
  opacity: 1 !important;
  position: static !important;
  font-size: 14px !important;
  margin: 0 5px 0 0 !important;
}

.adv-circle h2 {
  font-size: 20px;
  font-weight: 600;
  margin: 0;
  text-transform: uppercase;
  color: #ffffff;
}

.adv-circle.adv-circle-center-2 .caption,
.adv-img-button-content .caption {
  margin: auto;
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  right: 0;
  display: table;
  height: 100%;
  width: 100%;
  padding: 15%;
  background: none;
}

.adv-img-button-content .caption .inner {
  display: table-cell;
  vertical-align: middle;
  position: relative;
  height: 100%;
}

.adv-circle.adv-circle-center-2 .caption .inner,
.adv-img-full-content .caption .inner {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  position: relative;
  height: 100%;
}

/* 
============================== 
EASY
============================== 
*/
.adv-circle.adv-circle-center i {
  left: 0;
  right: 0;
  top: 25%;
  font-size: 35px;
  text-align: center;
  color: #ffffff;
}

.adv-circle.adv-circle-center i.circle,
.adv-circle.adv-circle-center i.square {
  left: 50%;
  right: auto;
  margin-left: -45px;
  top: 10px;
}

.adv-circle.adv-circle-center .caption {
  top: 50%;
  padding: 0 7%;
  width: 100%;
  color: #585858;
  margin-top: -10px;
}

/* 
============================== 
HALF
============================== 
*/
.adv-circle.adv-circle-half i,
.adv-circle.adv-circle-bottom i {
  left: 0;
  right: 0;
  top: 50%;
  font-size: 35px;
  margin: -18.5px 0 0 0;
  text-align: center;
  color: white;
  text-shadow: 0px 1px 3px rgba(0, 0, 0, 0.5);
}

.adv-circle.img-box.i-center i::before {
  margin-left: 0;
}

.adv-circle-half:before,
.adv-circle-bottom:before,
.adv-circle-bg:before {
  display: none !important;
}

.img-box.adv-circle.adv-circle-half img,
.img-box.adv-circle.adv-circle-bottom img,
.img-box.adv-circle.adv-circle-bg img {
  opacity: 1 !important;
}

.img-box.adv-circle.adv-circle-half.show:hover img,
.img-box.adv-circle-bottom.show:hover img,
.img-box.adv-circle-bg.show:hover img {
  transform: scale(1.2);
}

.adv-circle.adv-circle-half .caption,
.adv-circle.adv-circle-bottom .caption {
  top: 50%;
  padding: 10% 20%;
  width: 100%;
  height: 50%;
  background-color: rgba(0, 0, 0, 0.5);
  border-radius: 0 0 1000px 1000px;
}

.adv-circle.adv-circle-half .caption p {
  margin: 10px 0 0;
}

.adv-circle.adv-circle-bottom .caption {
  background-color: transparent;
  padding: 20%;
}

.adv-circle.adv-circle-bottom .caption:before {
  content: "";
  background-color: rgba(0, 0, 0, 0.5);
  width: 100%;
  position: absolute;
  height: 100%;
  left: 0;
  z-index: -1;
}

.adv-circle.adv-circle-bottom .caption h2 {
  padding-top: 5%;
}

.adv-circle.adv-circle-bottom .caption p {
  margin-bottom: 2px;
}

/* 
============================== 
BORDER
============================== 
*/
.adv-circle.adv-circle-bg i {
  left: 50%;
  top: 18%;
  font-size: 35px;
  margin-left: -18.5px;
}

.adv-circle.adv-circle-bg .caption {
  top: 4%;
  left: 4%;
  right: 4%;
  bottom: 4%;
  background-color: rgba(0, 0, 0, 0.5);
  border-radius: 50%;
  padding: 40% 15%;
}

/* 
============================== 
SIDE
============================== 
*/
.adv-circle.adv-circle-center-2 i {
  display: none;
}

.adv-circle.adv-circle-center-2 .sub i {
  display: inline-block;
}

.adv-circle.adv-circle-center-2 .caption p {
  text-align: right;
  margin-top: 5%;
  border-right: 3px solid #f7f7f7;
  padding-right: 10px;
}

.adv-circle.adv-circle-center-2 .caption h2 {
  text-align: right;
}
/* 
============================== 
MOBILE
============================== 
*/

@media (max-width: 994px) {
  .img-box.adv-img-side-content .caption {
    position: static;
  }

  .adv-img-side-content > .img-box {
    position: absolute;
    height: 100%;
    z-index: 0;
  }

  .adv-img-side-content > .img-box img {
    min-height: 100%;
  }
}
