/*
  Default Carousel Styling.
  Same as .products on the landing page.
  Variant stylings can be found below.
*/

/* stylelint-disable no-descending-specificity */

main div.carousel-wrapper {
  width: 100%;
  max-width: unset;
}

main div.carousel-wrapper,
main div.carousel-wrapper.container-width-carousel {
  position: relative;
}

main div.fragments-carousel-wrapper.carousel-wrapper,
main div.carousel-wrapper.container-width-carousel {
  width: var(--layout-max-width);
}

main div.carousel-wrapper:last-child {
  margin-bottom: 0 !important;
}

main .carousel,
main .carousel-item {
  display: flex;
}

main .carousel {
  overflow: hidden;
  margin: auto;
  width: 100%;
  padding-inline: 200px;
}

main .carousel-item {
  width: 100%;
  margin-right: 30px;
  flex: 1 0 auto;
  align-items: center;
  justify-content: center;
  padding: 50px 80px;
}

main .carousel-item[style*="background-image"] {
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}

main .carousel-item-columns-container {
  max-width: var(--layout-carousel-max-width);
  display: flex;
  align-items: center;
  justify-content: center;
}

main .carousel-item-column {
  width: 50%;
}

main .carousel-item-column:empty {
  display: none;
}

main .carousel-item-column:has(+ .carousel-item-column:empty) {
  width: 100%;
  max-width: 100%;
}

main .carousel-item-image img {
  display: block;
  object-fit: contain;
  width: 100%;
  max-height: 400px;
}

main .carousel.full-bg .carousel-item {
  position: relative;
  border-width: 1px;
}

main .carousel-item-text h3 {
  font-size: 32px;
  font-weight: lighter;
}

main .carousel-item-text .button-container {
  display: inline-block;
  margin-top: 0;
}

main .carousel.full-bg .carousel-item-text .button-container {
  width: 100%;
  max-width: 80%;
}

main .carousel.full-bg .primary {
  width: 100%;
}

main .carousel-item-text .button-container .secondary {
  margin-left: 15px;
}

main .carousel-nav-button {
  z-index: 99;
  min-width: unset;
  padding: 0;
  border-radius: 50%;
  position: absolute;
  top: 50%;
  transform: translate(0, -50%);
  display: flex;
  justify-content: center;
  align-items: center;
  color: var(--color-gray-400);
  border: 1.5px solid var(--color-gray-400);
  background-color: inherit;
}

main .carousel-nav-button.disabled {
  display: none;
}

main .carousel-nav-button:hover {
  background-color: var(--color-gray-400);
  color: var(--color-white);
  border-color: var(--color-white);
}

main .carousel-nav-button .icon {
  height: 38px;
  width: 38px;
  stroke-width: 20;
}

main .carousel-nav-left {
  left: 20px;
}

main .carousel-nav-right {
  right: 20px;
}

main .carousel-dot-buttons {
  display: flex;
  justify-content: center;
  gap: 10px;
  min-width: unset;
  margin-top: 2rem;
}

main .carousel-dot-button {
  min-width: unset;
  height: 20px;
  width: 20px;
  background-color: transparent;
  border: 1px solid var(--color-gray-350);
  border-radius: 50%;
  padding: 0;
}

main .carousel-dot-button.selected {
  background-color: var(--color-gray-350);
  border: 0;
}

main .carousel-dot-img-buttons {
  display: flex;
  flex-wrap: wrap;
  margin-top: 50px;
  justify-content: center;
}

main .carousel-dot-img-buttons .carousel-dot-button {
  max-width: 100px;
  background: var(--color-white);
  padding: 10px;
  margin-right: 10px;
  opacity: 0.7;
  width: 100%;
  border-radius: inherit;
  height: 100%;
  border: none;
}

main .carousel-dot-img-buttons .carousel-dot-button img {
  display: block;
  aspect-ratio: 1/1;
  object-fit: contain;
}

main .carousel-dot-img-buttons .carousel-dot-button.selected {
  opacity: 1;
}

/* GLOBAL CAROUSEL */
main .global-carousel .carousel-item-column:has(+ .carousel-item-column:empty) {
  width: 100%;
}

main .global-carousel .carousel-item-column:empty {
  display: none;
}

main .global-carousel.blue-title h2 {
  color: var(--color-primary);
}

main .global-carousel.title-center h2 {
  text-align: center;
}

main .section.global-carousel .carousel h2:only-child,
main .section.global-carousel .carousel h2 + h3 {
  margin-bottom: 18px;
}

@media only screen and (min-width: 768px) {
  main .section.global-carousel .carousel h2:only-child,
  main .section.global-carousel .carousel h2 + h3 {
    margin-bottom: 48px;
  }
}

@media only screen and (min-width: 992px) {
  main .carousel.full-bg .primary {
    background-color: transparent;
    border: 1px solid var(--color-white);
  }

  main .carousel.full-bg .primary:focus {
    color: var(--color-white);
  }

  main .carousel.full-bg .primary:hover {
    color: var(--color-link-hover);
    background-color: var(--color-white);
  }

  main .carousel.full-bg .primary:hover .button-border {
    display: none;
  }

  main .carousel.full-bg .carousel-item-column:first-child {
    position: absolute;
    width: 100%;
    left: 0;
    top: 0;
    padding: 0;
  }

  main .carousel.full-bg .carousel-item-column:last-child {
    color: var(--color-white);
    position: relative;
    display: flex;
    align-items: center;
  }

  main .carousel.full-bg .carousel-item-column:first-child,
  main .carousel.full-bg .carousel-item-image,
  main .carousel.full-bg .carousel-item-image .picture,
  main .carousel.full-bg .carousel-item-image img {
    height: 100%;
  }

  main .carousel.full-bg .carousel-item-columns-container {
    justify-content: flex-end;
    min-height: 500px;
  }

  main .carousel.full-bg .carousel-item-image img {
    object-fit: cover;
    max-height: 100%;
  }

  main .carousel.full-bg .carousel-item-column:first-child .picture:last-child {
    display: none;
  }
}

@media only screen and (min-width: 1200px) {
  main .three-items-visible .carousel-nav-button {
    display: none !important;
  }
}

@media only screen and (max-width: 1460px) {
  main .carousel {
    padding-inline: var(--center-space);
  }
}

@media only screen and (max-width: 991px) {
  main .carousel-item-columns-container {
    flex-direction: column;
    gap: 30px;
    padding: 30px 50px;
  }

  main .carousel-item-column {
    width: 100%;
    padding: 0;
    align-items: center;
  }

  main .carousel-item-image img {
    max-height: 300px;
  }

  main .carousel.full-bg .carousel-item-column:first-child .picture:first-child {
    display: none;
  }
}

@media only screen and (max-width: 767px) {
  main .carousel {
    padding-left: 40px;
    padding-right: 40px;
  }

  main .carousel-item {
    padding: 20px;
  }

  main .carousel-item-text h3 {
    font-size: 24px;
  }

  main .carousel-item-text .button-container {
    margin-top: 20px;
    margin-bottom: 0;
    max-width: 100%;
    width: 100%;
  }

  main .carousel-item-text .button-container .button {
    max-width: 100%;
    width: 100%;
    font-size: 12px;
  }

  main .carousel-nav-button .icon {
    height: 26px;
    width: 26px;
  }

  main .carousel-nav-button {
    width: unset;
  }
}

@media only screen and (max-width: 576px) {
  main .carousel-item-text .button-container {
    margin-bottom: 0;
  }

  main .carousel-item-text .button-container .button {
    margin-left: 0;
  }

  main .carousel-item-columns-container {
    padding: 0;
  }
}

@media only screen and (max-width: 420px) {
  main .carousel-item-text .button-container {
    max-width: unset !important;
    display: block;
  }

  main .carousel-item-text .button-container .button {
    max-width: unset !important;
  }

  main .carousel a.button {
    display: block;
  }
}

/* WAVE carousel variant */
main div.carousel-wrapper.wave {
  width: var(--layout-max-width);
}

main .carousel.wave {
  padding: 0;
}

main .carousel.wave .carousel-item-columns-container {
  gap: 2em;
}

main .carousel.wave .carousel-item {
  padding: 20px 15px;
  height: 100%;
}

main .carousel.wave .carousel-item-column {
  width: unset;
  padding: 0;
}

main .carousel.wave .carousel-item-image img {
  height: 353px;
  width: 330px;
}

main .carousel.wave .carousel-item-text {
  margin-top: 13%;
  max-width: 597px;
  padding-right: 15px;
  text-align: center;
  position: relative;
}

main .carousel.wave .carousel-item-text p {
  color: var(--color-white);
  font-size: 27px;
}

main .carousel.wave .carousel-item-text .button-container a.secondary,
main .carousel.wave .carousel-item-text .button-container a.secondary:hover {
  background-color: transparent;
  color: var(--color-white);
  border-color: var(--color-white);
}

main .carousel-wrapper.wave .carousel-dot-buttons {
  margin-top: 0;
}

main .carousel-wrapper.wave .carousel-dot-button {
  background-color: var(--color-white);
}

main .carousel-wrapper.wave .carousel-nav-button:hover {
  color: var(--color-gray-300);
  border-color: var(--color-gray-300);
  background-color: inherit;
}

@media only screen and (max-width: 1200px) and (min-width: 992px) {
  main .carousel.wave {
    max-width: 90%;
    height: auto;
    margin: auto;
  }

  main .carousel.wave .carousel-item-columns-container {
    gap: 1em;
  }

  main .carousel.wave .carousel-item-text {
    max-width: 530px;
  }

  main .carousel.wave .carousel-item-image img {
    height: 310px;
    width: 200px;
  }
}

@media only screen and (max-width: 991px) {
  main .carousel.wave .carousel-item-image img {
    display: none;
  }
}

@media only screen and (max-width: 767px) {
  main .carousel.wave {
    /*
      Ugly hack because you cannot mix overflow-x: hidden with overflow-y: visible
      https://stackoverflow.com/a/39554003
    */
    padding-top: 170px;
    margin-top: -170px;
  }

  main div.carousel-wrapper.wave {
    padding-top: 0;
    padding-bottom: 0;
  }

  main .carousel.wave .carousel-item {
    position: relative;
    padding: 0 30px;
    margin-right: 0;
  }

  main .carousel.wave .carousel-item-columns-container {
    gap: 0;
  }

  main .carousel.wave .carousel-item-image img {
    max-width: unset;
    display: block;
    height: 290px;
    width: 260px;
    flex-shrink: 0;
  }

  main .carousel.wave .carousel-item-image {
    position: absolute;
    left: 50%;
    transform: translate(-50%, 0);
    margin: auto;
    display: block;
    top: -180px;
  }

  main .carousel.wave .carousel-item-text {
    margin-top: 140px;
    padding-right: 0;
    padding-left: 0;
    padding-bottom: 25px;
    max-width: unset;
  }

  main .carousel-wrapper.wave .carousel-dot-buttons {
    margin-bottom: 25px;
  }

  main .section.global-carousel .carousel h2 + h3 {
    margin-bottom: 1.75rem;
  }

  .slas-page main .section:not(.slas-resource-list, .carousel-container) h3 {
    font-size: 24px;
  }

  .slas-page main .section.slas-resource-list .columns > div {
    padding-left: 15px;
    padding-right: 15px;
  }

  main .carousel-dot-img-buttons .carousel-dot-button {
    max-width: 60px;
    padding: 5px;
    margin-right: 0;
  }

  .slas-page main div.carousel-wrapper.container-width-carousel .carousel-dot-img-buttons {
    margin-top: 20px;
  }

  .slas-page main div.carousel-wrapper.container-width-carousel .columns > div > div:first-child {
    margin-bottom: 24px;
  }

  main div.carousel-wrapper.container-width-carousel .carousel-nav-left {
    left: -10px;
  }

  main div.carousel-wrapper.container-width-carousel .carousel-nav-right {
    right: -10px;
  }
}

/* WAVE Blue Variant */
main div.carousel-wrapper.wave.blue .carousel-dot-button.selected {
  background-color: var(--carousel-blue-wave-indicator);
}

/* WAVE BlueGreen Variant */
main div.carousel-wrapper.wave.bluegreen .carousel-dot-button.selected {
  background-color: var(--color-tertiary);
}

main .carousel .carousel-item-text blockquote {
  margin: 0;
  position: static;
}

main .carousel .carousel-item .carousel-item-text blockquote ~ p,
main .carousel .carousel-item .carousel-item-text blockquote > p {
  padding: 0;
  font-style: normal;
  font-size: 23px;
  line-height: 28px;
}

main .carousel .carousel-item .carousel-item-text blockquote > p::before,
main .carousel .carousel-item .carousel-item-text blockquote > p::after {
  content: none;
}

main .carousel blockquote::before,
main .carousel blockquote::after {
  content: "";
  position: absolute;
  width: 100px;
  height: 100px;
  background-position: center;
  background-size: 100px;
  background-repeat: no-repeat;
}

main .carousel blockquote::before {
  background-image: url("/images/quote-left.png");
  left: -50px;
  top: -89px;
}

main .carousel blockquote::after {
  background-image: url("/images/quote-right.png");
  right: -1.5em;
  bottom: -60px;
}

@media only screen and (max-width: 991px) {
  main .carousel blockquote::before,
  main .carousel blockquote::after {
    width: 33px;
    height: 33px;
    background-size: 33px;
  }

  main .carousel blockquote::before {
    left: -8px;
    top: -35px;
  }

  main .carousel blockquote::after {
    right: 0;
    bottom: 0;
  }
}

@media only screen and (max-width: 767px) {
  main .carousel .carousel-item .carousel-item-text blockquote > p {
    font-size: 16px;
  }

  main .carousel .carousel-item .carousel-item-text blockquote + p {
    font-size: 18px;
  }
}

main .block.carousel.full-size .carousel-item-column {
  width: auto;
}

main .block.carousel.full-size .carousel-item-image img {
  max-height: none;
}
