/* stylelint-disable no-descending-specificity */
.hero {
  position: relative;
  background-color: var(--color-black);
  margin: 0 auto;
  list-style: none;
  aspect-ratio: 16 / 9;
}

.hero .overlay h2 {
  color: #fff;
  font-family: Montserrat-Bold, var(--body-font-family);
  font-size: 4.1875rem;
  line-height: 1.1;
  letter-spacing: -.01em;
  margin: 0 0 1rem;
  padding: 0;
  text-transform: none;
}

.hero .overlay h2 a { 
  color: inherit 
}

.hero .overlay p {
  font-weight: 400;
  text-transform: uppercase;
  font-size: 0.875rem;
  letter-spacing: 0.05em;
  color: #fff;
}

.hero .item {
  position: absolute;
  width: 100%;
}

.hero .item.active:not(.first) {
  animation-name: fade;
  animation-duration: 1.5s;
}

.hero .image {
  position: relative;
  aspect-ratio: 16 / 9;
  min-height: 0;
}

.hero .image::before {
  content: '';
  background: var(--color-transparent-black);
  position: absolute;
  inset: 0;
}

.hero img {
  object-fit: cover;
  width: 100%;
  aspect-ratio: 16 / 9;
  min-height: 0;
}

.hero .img-credit {
color: var(--color-dark-gray);
margin-top: 6px;
text-align: right;
font-weight: 400;
font-size: 0.975rem;
}

.hero .img-credit p div {
  position: absolute;
  right: 20px;
}

.hero .img-credit p { margin: 0 40px }
.hero .img-credit a { color: inherit }

.hero .overlay {
  position: absolute;
  font-family: var(--system-font-family);
  color: #fff;
  width: 39vw;
  padding: 0 0 6vw;
  bottom: 0;
  left: 280px;
  user-select: none;
}

.hero .by-line {
  color: #fff;
  font-size: 0.875rem;
  text-transform: uppercase;
  margin: 0;
}

.hero .by-line a { 
  color: inherit 
}

.hero.carousel .item {
  display: none;
}

.hero.carousel .item.active { 
  display: list-item 
}

.hero.carousel .loading-spinner {
  filter: invert(1);
  position: absolute;
  z-index: 5;
}

.hero.carousel.loaded .loading-spinner,
.hero.carousel .carousel-wrapper .loading-animation { display: none}
.hero.carousel .carousel-wrapper.loading .loading-animation { display: block }

.hero.carousel .carousel-button {
  display: none;
  color: var(--color-transparent-white);
  cursor: pointer;
  font-family: var(--revolt-font-family);
  position: absolute;
  top: 42.5%;
  height: 6.25vw;
  width: 2.75vw;
  font-style: normal;
  font-weight: 400;
  font-variant: normal;
  font-size: 6.25vw;
  line-height: 1;
  z-index: 3;
}
.hero.carousel .carousel-button::before { content: '\e906' }
.hero.carousel .next-button { right: 1.6rem }
.hero.carousel .prev-button { left: 1.6rem; transform: rotate(180deg) }
body.font-loaded-revolt .hero.carousel .carousel-button.show-on-font-loaded-revolt { display: block }

.hero.carousel .button { border: 0 }

.hero.podcast .hero {
  aspect-ratio: unset;
}

.hero.podcast .overlay {
  top: 47%;
  left: 50%;
  transform: translate(-50%, -50%);
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  padding: 0;
}

.hero.podcast .overlay h2 {
  margin: 0 24px;
  font-size: 4.875rem;
}

.hero.podcast .item {
   display: block;
   height: 29.625rem;
}

.hero.podcast,
.hero.podcast .image,
.hero.podcast img {
  height: 29.625rem;
  width: 100%;
}

@media ( max-width: 1919px ) {
  .hero .overlay {
    left: calc((100vw - 1380px) / 2);
  }

  .hero.carousel .overlay { 
    left: 100px;
  }

  .hero .overlay h2 {
    font-size: 3.4vw;
  }
}

@media ( max-width: 1439px ) {
  .hero .overlay {
    left: 40px;
  }

  .hero.carousel .overlay { 
    left: 80px; 
  }

  .hero.carousel .next-button { 
    right: 1rem;
  }

  .hero.carousel .prev-button { 
    left: 1rem;
  }
}

@media ( max-width: 1023px ) {
  .hero.carousel .carousel-button { 
    top: 40.5% 
  }

  .hero.carousel .next-button { 
    right: .5rem 
  }
  
  .hero.carousel .prev-button { 
    left: .5rem 
  }

  .hero.carousel .overlay {
    left: 50px;
  }
  
  .hero .overlay h2 {
    font-size: 1.875rem; 
  }
}

@media ( max-width: 768px ) {
  .hero .overlay { 
    left: 20px; 
    width: 25rem; 
    padding: 0 0 4vw 
  }

  .hero.carousel .overlay {
    left: 20px;
  }

  .hero .by-line {
    font-size: .75rem;
  }
  
  .hero .overlay .col {
    margin-bottom: 1rem;
  }

  .hero .overlay h2 { 
    font-size: 1.625rem; 
    margin: 0 0 .5rem;
  }

  .hero p { 
    margin-bottom: 10px 
  }
  
  .hero, 
  .hero .item,
  .hero .image,
  .hero img {
    height: auto;
    width: 100vw;
    aspect-ratio: 1 / 1;
  }

  .hero .img-credit { 
    font-size: 0.75rem 
  }

  .hero.carousel .carousel-button { 
    display: none !important 
  }

  .hero.podcast .overlay h2 {
    font-size: 3.125rem;
  }

  .hero.podcast .item {
    height: 17.4375rem;
  }

  .hero.podcast,
  .hero.podcast .image,
  .hero.podcast img {
      height: 17.4375rem;
  }
}

@media (max-width: 424px) {
  .hero .overlay { width: calc(100vw - 30px) }

  .hero .img-credit {
    font-size: 0.75rem;
  }
}

@keyframes fade {
  from {opacity: 0}
  to {opacity: 1}
}
