.title {
  background: transparent;
}

.title:not(.title-h1) h1, .title:not(.title-h1) .field-title a {
  border-bottom-width: 1px;
  border-bottom-style: solid;
  border-bottom-color: #89C6CC;
  font-size: 24px;
  margin-bottom: 10px;
  color: #747474;
  line-height: normal;
  padding-bottom: 10px;
  display: block;
  text-decoration: none;
  cursor: pointer;
}

.title:not(.title-h1) h1:hover, .title:not(.title-h1) .field-title a:hover {
  color: #878787;
}

.title.section.title-h1 {
  padding-top: 40px;
  padding-bottom: 40px;
}

.title.section.title-h1 .component-content {
  padding-bottom: 40px;
  position: relative;
}

@media screen and (max-width: 767.98px) {
  .title.section.title-h1 .component-content {
    padding-bottom: 24px;
  }
}

.title.section.title-h1 .component-content h1 {
  margin-bottom: 0px;
}

.title.section.title-h1 .component-content::before {
  content: "";
  position: absolute;
  width: 100%;
  height: 1px;
  background-color: #E7E9EB;
  bottom: 0px;
  left: 0px;
}

@media screen and (max-width: 767.98px) {
  .title.section.title-h1 .component-content::before {
    width: -webkit-calc(80% - 30px);
    width: calc(80% - 30px);
  }
}
