.hero-banner {
  width: 100%;
  flex-wrap: wrap;
  position: relative;
  padding: 0;
  overflow-y: clip;
}

.hero-small .hero-content {
  padding-top: 46.25%;
}

.hero-banner .container{
  padding: 0;
}

.hero-banner-bg {
  position: absolute;
  left: calc(-50vw - -50%);
  width: 100vw;
  z-index: -1;
  height: 100%;
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
}

.hero-image__main {
  position: absolute;
  height: 50rem;
  right: 10rem;
}

.hero-image__bg {
  position: absolute;
  right: -23rem;
}

.hero-svg {
  width: 100vw;
  position: absolute;
  top: 0;
}

.hero-svg svg {
  position: absolute;
  left: 50vw;
  top: 0;
}

.hero-svg svg path {
  transform: translateY(-95px);
}

.hero-content {
  display: flex;
  z-index: 1;
  position: relative;
  width: 100%;
  padding-top: 62.25%;
  height: 0;
}

.hero-content .hs_cos_wrapper_hero_get_access_form p {
    font-size: 1.6rem;
}

.hero-play-icon {
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  bottom: 0;
  margin-left: auto;
  margin-right: auto;
  margin-top: auto;
  margin-bottom: auto;
  height: 8em;
  width: 8em;
  background-size: contain;
  background-repeat: no-repeat;
}

.hero-image {
  width: 100%;
  height: 100%;
  display: flex;
  background-size: cover;
}

.hero-background {
  display: flex;
  position: relative;
  width: 100%;
  background-size: cover;
  padding-top: 60.25%;
  height: 0;
}

.hero-text .cta-classic {
  margin-top: 4rem;
}

.hero-text {
  width: 100%;
  padding: 0 5% 3% 0;
  font-size: 0.8em;
  display: flex;
  flex-flow: column;
}

.hero-title {
  color: var(--white);
  margin: 0 0 2% 0;
  font-weight: normal;
}

@media (max-width: 1200px) {

  .hero-title {
    font-size: 5rem;
  }
}

@media (max-width: 768px) {

  .hero-title {
    font-size: 3.4rem;
  }
}

@media (max-width: 520px) {

  .hero-text__wrapper {
    top: 10%;
  }

  .hero-small .hero-content {
    padding-top: 75.25%;
  }
}

@media (max-width: 768px) {

  .hero-small .hero-content {
    padding-top: 70.25%;
  }
}

@media (max-width: 992px) {
  .hero-small .hero-content {
    display: contents;
  }

  .hero-small .hero-text__wrapper {
    position: relative;
    padding: 3rem 0;
  }
}


@media (max-width: 768px) {

  .hero-small .hero-content {
    padding-top: 70.25%;
  }
}

.hero-date {
  margin: 1rem 0;
}

.hero-text__wrapper {
  width: 70%;
  flex-flow: column;
  position: absolute;
  top: 25%;
  left: 0;
  color: var(--white);
  transition: visibility 0s, opacity 0.2s linear;
  visibility: visible;
  opacity: 1;
}

.hero-icon__button {
  display: none;
}

.hero-icon__link {
  width: 100%;
  height: 100%;
}

.hero-favorite {
  height: 1.6em;
}

.hero-icon__favorite path {
  pointer-events: none;
}

.hero-icon__favorite path:nth-of-type(2) {
  display: none;
}

.hero-icon__favorite.favorited path:nth-of-type(2) {
  display: block;
}

.hero-locked {
  background-position-x: center;
  height: 1.8em;
  width: 30px;
  margin-top: 1rem;
  background-size: contain;
  background-repeat: no-repeat;
}

.hero-register {
  border-radius: 28px;
  color: var(--primary);
  background: var(--white);
  font-family: Arial;
  font-size: 17px;
  text-decoration: none;
}

.hero-icon__favorite {
  width: 30px;
  height: auto;
  max-height: 30px;
}

.hero-register__button {
  background: var(--white);
  color: var(--primary);
  padding: 0 3.2rem;
}


@media only screen and (max-width: 992px) {
  .hero-text__wrapper {
    width: 100%;
    display: flex;
    flex-direction: column;
    position: absolute;
    padding: 3rem;
  }

  .hero-svg {
    display: none;
  }

  .hero-content {
    padding-top: 92.25%;
  }

  .hero-image__bg {
    top: 0;
  }

  .hero-image__main {
    opacity: 0.3;
  }

  .hero-text {
    width: 100%;
    padding: 0 15px;
  }

  .hero-buttons > *:first-child {
    margin-bottom: 2rem;
  }
  .hero-date {
    display: none;
  }
}

@media (max-width: 768px) {
  .hero-text__wrapper {
    padding-top: 70.25%;
  }
}

@media only screen and (min-width: 992px) {

  .hero-buttons {
    padding: 1% 5%;
  }

  .hero-buttons__left {
    margin: auto;
  }

  .hero-description {
    margin-bottom: 0;
    font-size: 1.8rem;
  }

  .hero-buttons__right {
    display: none;
  }

  .hero-icon__button {
    background-repeat: no-repeat;
    background-size: contain;
    display: flex;
    width: 30px;
    height: 30px;
    background-position: center;
    margin: 1rem;
  }
}
