:root {
  --heading: #333;
  --heading-dark: #f1f1f1;
  --text-dark: #f1f1f1;
}

.ova-heading-2 {
  text-align: left;
}
.ova-heading-2 .sub-title-wrapper {
  display: inline-flex;
  align-items: center;
  margin-bottom: 12px;
  padding-bottom: 3px;
  border-bottom: 1px dashed #000;
}
.ova-heading-2 .sub-title-wrapper .prefix {
  color: var(--primary);
  font-size: 20px;
  line-height: 1.1;
  margin: 0 4px 0 0;
}
.ova-heading-2 .sub-title-wrapper .sub-title {
  margin: 0;
  font-size: 16px;
  line-height: 1.1;
  font-weight: 700;
  text-transform: uppercase;
  color: #090505;
}
.ova-heading-2 .title {
  transition: all 0.3s linear;
  -moz-transition: all 0.3s linear;
  -webkit-transition: all 0.3s linear;
  -o-transition: all 0.3s linear;
  margin: 0 0 20px 0;
  font-size: 52px;
  font-weight: 700;
  color: #160647;
  line-height: 1.1;
  white-space: pre-line;
  position: relative;
  z-index: 1;
}
@media (max-width: 767px) {
  .ova-heading-2 .title {
    font-size: 42px;
  }
}
.ova-heading-2 .title:hover {
  transition: all 0.3s linear;
  -moz-transition: all 0.3s linear;
  -webkit-transition: all 0.3s linear;
  -o-transition: all 0.3s linear;
}
.ova-heading-2 .title .wrap-word {
  display: inline-block;
  position: relative;
}
.ova-heading-2 .title .word {
  background: linear-gradient(148deg, #FB5FD6 0%, #7D50FF 37.37%, #4BB3FE 75.57%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}
.ova-heading-2 .title a {
  transition: all 0.3s linear;
  -moz-transition: all 0.3s linear;
  -webkit-transition: all 0.3s linear;
  -o-transition: all 0.3s linear;
  color: var(--heading);
}
.ova-heading-2 .title a:hover {
  transition: all 0.3s linear;
  -moz-transition: all 0.3s linear;
  -webkit-transition: all 0.3s linear;
  -o-transition: all 0.3s linear;
  color: var(--text);
}
.ova-heading-2 .title img {
  display: inline-block;
  vertical-align: middle;
  margin: 0 4px 8px 16px;
  width: 59px;
  min-width: 59px;
  height: 59px;
  object-fit: cover;
  border-radius: 50%;
}
.ova-heading-2 .description {
  margin: 0;
  font-size: 18px;
  white-space: pre-line;
}
.ova-heading-2 .author {
  text-align: right;
  margin: 0;
}
.ova-heading-2 .author .divider {
  width: 26px;
  height: 2px;
  background-color: var(--primary);
  display: inline-block;
  vertical-align: middle;
}
.ova-heading-2 .author .author-prefix {
  color: var(--primary);
  font-size: 16px;
  margin: 0 5px 0 15px;
}
.ova-heading-2 .author .text {
  font-weight: 600;
  font-size: 16px;
  color: var(--heading);
}
.ova-heading-2.template2 .title {
  font-size: 100px;
  background: linear-gradient(98deg, #FF691C 0%, #FFCEF1 54.69%, #17E78F 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}
@media (max-width: 1200px) {
  .ova-heading-2.template2 .title {
    font-size: 82px;
  }
}
@media (max-width: 1024px) {
  .ova-heading-2.template2 .title {
    font-size: 62px;
  }
}
@media (max-width: 767px) {
  .ova-heading-2.template2 .title {
    font-size: 42px;
  }
}
.ova-heading-2.template2 .title .word {
  background: linear-gradient(47deg, #FF691C 0%, #FFCEF1 4.69%, #17E78F 100%);
  -webkit-background-clip: text;
}
.ova-heading-2.template2 .title img {
  position: absolute;
  left: -20px;
  bottom: 0;
  margin: 0;
  width: 100%;
  height: 100%;
  object-fit: contain;
  border-radius: 0;
}
.ova-heading-2.template2 .description {
  font-size: 20px;
  font-weight: 500;
  color: #969CD6;
}
.ova-heading-2.template3 {
  text-align: center;
}
.ova-heading-2.template3 .title {
  text-transform: uppercase;
  font-size: 80px;
  font-weight: 500;
  margin: 13px 0 0 0;
}
@media (max-width: 1400px) {
  .ova-heading-2.template3 .title {
    font-size: 60px;
  }
}
@media (max-width: 1024px) {
  .ova-heading-2.template3 .title {
    font-size: 50px;
  }
}
@media (max-width: 767px) {
  .ova-heading-2.template3 .title {
    font-size: 40px;
  }
}
.ova-heading-2.template3 .button-booking {
  transition: all 0.3s linear;
  -moz-transition: all 0.3s linear;
  -webkit-transition: all 0.3s linear;
  -o-transition: all 0.3s linear;
  display: inline-flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 120px;
  height: 120px;
  border-radius: 50%;
  background-color: var(--primary);
  color: #fff;
  z-index: 2;
}
.ova-heading-2.template3 .button-booking:hover {
  transition: all 0.3s linear;
  -moz-transition: all 0.3s linear;
  -webkit-transition: all 0.3s linear;
  -o-transition: all 0.3s linear;
  background-color: var(--heading);
  color: var(--primary);
}
.ova-heading-2.template3 .button-booking .text-booking {
  font-weight: 600;
  font-size: 16px;
  line-height: 1.2;
  text-transform: uppercase;
}