/* Rem Unit font sizes with relative fallback http:/seesparkbox.com/foundry/scss_rem_mixin_now_with_a_better_fallback
	Usage: @include font-size(1, large);
*/
.hero_media {
  --heading-color: var(--scheme-bg-text);
  --text-color: var(--scheme-bg-text);
  --btn-hover: var(--blue-alt);
  --btn-hover-txt: #000;
  --btn-bg: #00AA4C;
}
.hero_media,
.hero_media .layout--teaser .inner {
  background-color: var(--scheme-hero);
}
.hero_media .layout--teaser {
  margin: 0;
}
.hero_media .h1,
.hero_media h1 {
  font-size: 3.6rem;
  line-height: 1.3333333333;
  margin-bottom: 0 !important;
  margin-top: 0 !important;
}
.node--type-landing-page .hero_media .h1,
.node--type-landing-page .hero_media h1 {
  font-size: 5.4rem;
  line-height: 1.1111111111;
}
.hero_media figure {
  line-height: 0;
  width: 100%;
}
.hero_media .hero-title {
  color: var(--heading-color);
  margin: 0 4%;
  padding: 2.4rem 0 1.2rem;
}
.hero_media .hero-preface {
  font-size: 1.6rem;
  line-height: 1.5;
  margin-bottom: 0.6rem;
}
.hero_media .layout--teaser .caption,
.hero_media .hero-tagline {
  margin-top: 0.6rem;
  color: var(--scheme-bg-text-alt);
  font-size: 2.4rem;
  line-height: 1.5;
}
.hero_media .wrapper--video {
  padding-bottom: 0;
  height: auto;
}
.hero_media .wrapper--video video {
  position: static;
}

.hero-image-wrapper {
  display: flex;
  flex-direction: column-reverse;
}
.hero-image-wrapper .hero-image {
  display: flex;
}
.hero-image-wrapper .hero-image .media,
.hero-image-wrapper .hero-image img {
  width: 100%;
}
.hero-image-wrapper.no-image {
  display: block;
}
.hero-image-wrapper.no-image .hero-title {
  padding: 2.4rem 0;
}

@media (min-width: 768px) {
  .hero_media .b-text-wrapper,
  .hero_media .hero-title {
    display: flex;
    flex-direction: column;
    justify-content: flex-end !important;
    padding-bottom: 3.6rem;
  }
  .hero_media .hero-preface {
    font-size: 2.4rem;
  }
  .hero_media .teaser-featured.has-media.has-content:not(.slide) .inner, .hero_media .teaser-featured.has-media.has-content:not(.paragraph--type--slide) .inner {
    display: block;
  }
  .hero_media .layout--teaser.teaser-featured .b-media-wrapper {
    margin-left: 0 !important;
    justify-content: center;
    align-items: center;
  }
  .hero_media .wrapper--video {
    margin: -1px 0;
    width: 100%;
  }
  .hero-image-wrapper {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    align-content: stretch;
  }
  .hero-image-wrapper.no-image {
    display: block;
  }
  .hero-image-wrapper.no-image .hero-title {
    width: 96%;
    max-width: var(--constrain-width);
    margin-left: auto;
    margin-right: auto;
  }
  .hero-image-wrapper .hero-image,
  .hero-image-wrapper .hero-image img {
    height: 100%;
    -o-object-fit: cover;
       object-fit: cover;
  }
  .hero_media:not(.hero--tile-layout):not(.hero--image-layout),
  .hero_media:not(.hero--tile-layout):not(.hero--image-layout) .layout--teaser {
    height: 33vw;
    max-height: 853px;
  }
  .hero_media:not(.hero--tile-layout):not(.hero--image-layout) .hero-image .bg-title {
    padding-bottom: 3.6rem;
  }
}
@media (min-width: 980px) {
  .hero_media .teaser-featured.has-media.has-content:not(.slide) .inner, .hero_media .teaser-featured.has-media.has-content:not(.paragraph--type--slide) .inner {
    display: flex;
  }
  .hero_media .teaser-featured.has-media.has-content:not(.slide) .b-text-wrapper, .hero_media .teaser-featured.has-media.has-content:not(.paragraph--type--slide) .b-text-wrapper {
    padding: 3.6rem 0 3.6rem 2rem;
  }
}
@media (min-width: 1080px) {
  .hero_media .hero-title,
  .hero_media .b-text-wrapper {
    width: 96%;
    margin-left: auto;
    max-width: 480px;
  }
  .hero_media .teaser-featured.has-media.has-content:not(.slide) .b-text-wrapper, .hero_media .teaser-featured.has-media.has-content:not(.paragraph--type--slide) .b-text-wrapper {
    padding: 3.6rem 0;
  }
}
@media (min-width: 1366px) {
  .hero_media .hero-title {
    margin-bottom: 6rem;
  }
  .hero_media.no-image .hero-title {
    margin-bottom: 0;
    padding: 6rem 0;
  }
}
@media (min-width: 1680px) {
  .hero_media:not(.hero--tile-layout):not(.hero--image-layout) .wrapper--text,
  .hero_media:not(.hero--tile-layout):not(.hero--image-layout) .bg-title {
    padding-bottom: 7.2rem;
  }
}
/*# sourceMappingURL=../maps/components-override/hero-media.css.map */
