/**
 * Banner styles.
 */

.banner {
  top: -50px;
  overflow: hidden;
  margin-bottom: -50px;
}
.banner .contextual-region {
  position: static;
}

@media all and (min-width: 1366px) {
  .banner__hsf-branding {
    position: absolute;
    top: 100px;
    left: 50px;
    height: 62px;
    width: 456px;
    background-image: url(../../images/hsf-logo-stacked.svg);
    background-size: contain;
    background-repeat: no-repeat;
  }
}
.banner__media_image_video {
  position: absolute;
  left: 50%;
  margin-left: -50vw;
  top: 50%;
  margin-top: -50vh;
  margin-top: calc(var(--vh, 1vh) * -50);
  width: 100vw;
  height: 100vh;
  height: calc(var(--vh, 1vh) * 100);
}
.banner__media_image_video .image-style-fullscreen-2048-x-y- {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: opacity .2s linear;
}

.banner__media_image_video .vimeo-video {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: -1;
  pointer-events: none;
  overflow: hidden;
}
.banner__media_image_video .vimeo-video iframe {
  width: 100vw;
  height: 56.25vw; /* Given a 16:9 aspect ratio, 9/16*100 = 56.25 */
  min-height: 100vh;
  min-width: 177.77vh; /* Given a 16:9 aspect ratio, 16/9*100 = 177.77 */
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

.banner .banner__jump_button {
  position: absolute;
  left: 50%;
  bottom: 22.5px;
  margin-left: -22.5px;
  height: 45px;
  width: 45px;
  background-image: url(../../images/arrow-down-black.svg);
}

.banner .banner__info_button {
  position: absolute;
  right: 20px;
  bottom: 60px;
  height: 25px;
  width: 25px;
  background-image: url(../../images/info-circle.svg);
}
.path-frontpage .banner .banner__info_button {
  bottom: 16px;
}
@media all and (min-width: 410px) {
  .banner .banner__info_button {
    bottom: 16px;
  }
}

.banner__info_text {
  position: absolute;
  z-index: 100;
  box-sizing: border-box;
  overflow: hidden;
  right: 0;
  bottom: 0;
  width: 100vw;
  height: 348px;
  padding: 20px;
  background-color: rgba(255, 255, 255, .95);
}
.banner__info_text--hidden {
  display: none;
}
.banner__info_text_container {
  position: relative;
  height: 100%;
  width: 100%;
}
.banner__info_text_wrapper {
  position: absolute;
}

.banner__info_text .field--name-field-related-artwork {}
.banner__info_text .field--name-field-image-info {}
.banner__info_text .field--name-field-credit-copyright {
  padding-top: 50px;
  font-size: 10px;
  line-height: 12px;
}
.related-artwork__title {
  font-weight: 700;
}
.banner__info_text .field--name-field-artwork-category-nh,
.banner__info_text .field--name-field-artwork-category-rs {
  margin-top: 25px;
}
.related-artwork__link {
  display: inline-block;
  margin-top: 25px;
  font-weight: 700;
  font-size: 11px;
  letter-spacing: 1.1px;
  color: #DD6A2B;
  text-transform: uppercase;
}
.related-artwork__link:hover {
  text-decoration: none;
}

.banner__info_close_button {
  position: absolute;
  right: -8px;
  bottom: -8px;
  height: 16px;
  width: 16px;
  background-image: url(../../images/close-x-orange.svg);
}

.banner__title-wrapper {
  position: absolute;
  left: 20px;
  bottom: 0;
  width: 335px;
}
.banner__title {
  position: relative;
  padding: 7.5px 25px;
  background-color: rgba(255, 255, 255, .9);
  line-height: 30px;
  font-weight: 600;
  font-size: 30px;
  letter-spacing: 1.5px;
  text-transform: uppercase;
}


@media all and (min-width: 735px) {
  .banner .banner__info_button {
    right: 33px;
    bottom: 25px;
  }
  .banner__info_text {
    right: 30px;
    bottom: 0;
    width: 375px;
    height: 348px;
  }
  .banner__title-wrapper {
    position: absolute;
    left: 30px;
  }
}

@media all and (min-width: 1200px) {
  .banner .banner__info_button {
    right: 45px;
    bottom: 33px;
  }
  .banner__info_text {
    right: 37px;
    bottom: 25px;
    width: 375px;
    height: 348px;
  }
  .banner__title-wrapper {
    position: absolute;
    left: 50%;
    margin-left: -547.5px;
  }
}
