/* website uplift styles and overwrites */
@import url("https://fonts.googleapis.com/css2?family=Roboto:wght@300;400;500;700;900&display=swap");

:root {
  --body-font: "Roboto", sans-serif;
  font-weight: 400;
  --dark-yellow: #ffb81f;
  --green: #417571;
  --dark-green: #24423f;
  --hover-white: #d9d9d9;
}

.fs-5,
h1 {
  font-size: clamp(3rem, 2.8696rem + 0.6522vw, 3.375rem);
}
.fs-4,
h2 {
  font-size: clamp(2.5rem, 2.413rem + 0.4348vw, 2.75rem);
}
.fs-3,
h3 {
  font-size: clamp(1.875rem, 1.788rem + 0.4348vw, 2.125rem);
}
.fs-2,
h4 {
  font-size: clamp(1.5rem, 1.413rem + 0.4348vw, 1.75rem);
}
.fs-1,
h5 {
  font-size: clamp(1.25rem, 1.2065rem + 0.2174vw, 1.375rem);
}
.has-small-font-size {
  font-size: clamp(0.75rem, 0.7065rem + 0.2174vw, 0.875rem);
}
img {
  border-radius: 0.125rem;
}
details {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  background-color: var(--stone);
  padding: 0.75rem 1.5rem;
  border-radius: 0.5rem;
  border: 1px solid #d9d9d9;
}
details summary {
  margin-top: 0.5rem;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
details summary::after {
  content: "+";
}
details[open] summary::after {
  content: "-";
}
details summary::marker {
  font-size: 0;
}
.w-auto img {
  width: auto;
}
.has-radius-xs {
  border-radius: 0.125rem;
}
.has-radius-small {
  border-radius: 0.25rem;
}
.has-radius-base {
  border-radius: 0.5rem;
}
.has-radius-md {
  border-radius: 0.75rem;
}
.no-border-radius,
.no-border-radius img {
  border-radius: 0 !important;
}
.flowio-split-content-rearrange-true.has-radius-base img {
  border-radius: 0.5rem;
}

.logo-carousel-uplifted .logo-item {
  background-color: #f5f5f5;
  border-radius: 0.5rem;
  padding: 1rem;
  display: flex;
  align-items: center;
}
@media screen and (min-width: 672px) and (max-width: 1441px) {
  .content-width-right-aligned {
    margin-right: 0;
    width: calc(100% - (100% - var(--content-width)) / 2);
  }
  .content-width-left-aligned {
    margin-left: 0;
    width: calc(100% - (100% - var(--content-width)) / 2);
  }
}
.wp-block-lazyblock-youtube-video .youtube-block.with-thumbnail {
  position: relative;
  border-radius: 0.75rem;
  overflow: hidden;
  cursor: pointer;
}
.no-border-radius .youtube-block.with-thumbnail {
  border-radius: 0;
}
/* .wp-block-lazyblock-youtube-video .youtube-block .video-thumbnail, */
.wp-block-lazyblock-youtube-video .youtube-block.with-thumbnail iframe {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 10;
  height: 100%;
  opacity: 0;
  cursor: pointer;
}
.wp-block-lazyblock-youtube-video .youtube-block .video-thumbnail,
.testimonial .testimonial-thumbnail {
  position: relative;
  cursor: pointer;
}
.wp-block-lazyblock-youtube-video .youtube-block .video-thumbnail {
  z-index: 9;
}
.wp-block-lazyblock-youtube-video.has-gradient-bottom
  .youtube-block
  .video-thumbnail::before {
  content: "";
  background: linear-gradient(180deg, rgba(0, 0, 0, 0) 80.47%, #417571 100%);
  height: 100%;
  width: 100%;
  z-index: 99;
  position: absolute;
  top: 0;
  left: 0;
}

.wp-block-lazyblock-youtube-video .youtube-block .video-thumbnail:after,
.testimonial .testimonial-thumbnail:after {
  content: "";
  background-image: url("data:image/svg+xml,%3Csvg stroke='currentColor' fill='currentColor' stroke-width='0' viewBox='0 0 384 512' height='1em' width='1em' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M73 39c-14.8-9.1-33.4-9.4-48.5-.9S0 62.6 0 80V432c0 17.4 9.4 33.4 24.5 41.9s33.7 8.1 48.5-.9L361 297c14.3-8.7 23-24.2 23-41s-8.7-32.2-23-41L73 39z'%3E%3C/path%3E%3C/svg%3E");
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  height: 3rem;
  width: 3rem;
  border-radius: 50%;
  background-color: #fff;
  cursor: pointer;
  background-repeat: no-repeat;
  background-position: center;
}
.wp-block-lazyblock-youtube-video.has-gradient-bottom
  .youtube-block
  .video-thumbnail::after {
  transform: inherit;
  top: unset;
  left: 1rem;
  bottom: 1rem;
  z-index: 99;
}
.gradient-ends {
  -webkit-mask-image: -webkit-gradient(
    linear,
    left,
    right,
    from(rgba(0, 0, 0, 0)),
    color-stop(0.4, rgba(0, 0, 0, 1)),
    color-stop(0.6, rgba(0, 0, 0, 1)),
    to(rgba(0, 0, 0, 0))
  );
  -webkit-mask-image: linear-gradient(
    to right,
    rgba(0, 0, 0, 0) 0%,
    rgba(0, 0, 0, 1) 20%,
    rgba(0, 0, 0, 1) 80%,
    rgba(0, 0, 0, 0) 100%
  );
}
.logo-carousel-block-wrapper {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0) 0%, #fff 91.82%);
}
.gradient-ends .splide__list {
  gap: 1.5rem;
  /* align-items: center; */
}
.center-content {
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.custom-3-columns {
  display: grid;
  gap: 1.125rem;
}
.custom-column {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}
.column-thumbnail {
  position: relative;
  border-radius: 0.25rem;
  overflow: hidden;
}
.column-thumbnail img:not(.icon-over-image img) {
  aspect-ratio: 16/9;
}
.icon-over-image {
  position: absolute;
  top: 1rem;
  right: 1rem;
  background-color: var(--stone);
  height: 2.5rem;
  width: 2.5rem;
  padding: 0.5rem;
  border-radius: 0.25rem;
}
.icon-over-image img {
  aspect-ratio: 1;
}
.custom-3-columns .column-title {
  background-color: var(--yellow);
  margin: 0;
  border-radius: 0.25rem;
  text-align: center;
  padding: 0.5rem;
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
}
@media screen and (min-width: 767px) {
  .custom-3-columns {
    grid-template-columns: repeat(3, 1fr);
  }
}
p.has-background {
  max-width: max-content;
  padding: 0.25rem 1.5rem;
  border-radius: 0.25rem;
}

.wp-block-pullquote {
  border: none;
  padding: 0;
  text-align: left;
}
.collage-gallery {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1rem;
}
.collage-gallery .collage-image {
  border-radius: 0.25rem;
  overflow: hidden;
}
.collage-gallery .collage-image:first-child {
  grid-column-start: 1;
  grid-column-end: 2;
  grid-row-start: 1;
  grid-row-end: 3;
}
.collage-gallery .collage-image:first-child img {
  height: 100%;
}
.collage-gallery .collage-image:nth-child(2) {
  grid-row-start: 1;
  grid-row-end: 2;
}
.collage-gallery .collage-image:nth-child(2),
.collage-gallery .collage-image:nth-child(3) {
  grid-column-start: 2;
  grid-column-end: 3;
}
.collage-gallery .collage-image:nth-child(3) {
  grid-row-start: 2;
  grid-row-end: 3;
}
.child-flow-sm .flow > * + * {
  margin-block-start: 0.5rem;
  margin-block-end: 0;
}
.child-flow-sm .flow img {
  border-radius: 0.25rem;
}
.video-testimonial .testimonial {
  padding: 0.75rem;
  background-color: #fff;
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.video-testimonial .testimonial img {
  aspect-ratio: 16/9;
}
.video-modal {
  position: fixed;
  z-index: 999999;
  background-color: rgba(0, 0, 0, 0.5);
  height: 100%;
  width: 100%;
  top: 0;
  left: 0;
  backdrop-filter: blur(3px);
  align-items: center;
  justify-content: center;
}
/* 
.video-modal iframe {
  position: fixed;
  z-index: 10;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
} */

.video-visible {
  overflow: hidden;
  position: relative;
}
/* .video-visible:before {
  content: "";
  height: 100%;
  width: 100%;
  background: rgba(0, 0, 0, 70%);
  position: absolute;
  top: 0;
  left: 0;
  display: block;
  z-index: 99999;
} */
.close-testimonial-modal {
  position: absolute;
  top: 0;
  right: 0;
  background: #000;
  z-index: 99;
  color: #fff;
}
.splide__list.no-translate,
.no-translate {
  transform: unset !important;
  z-index: -1;
}
.theme-header.no-zIndex,
.wp-block-flowio-section-block.no-zIndex {
  z-index: -1;
}
.animated-color-swap-gradient * {
  z-index: 3;
  position: relative;
}
.animated-color-swap-gradient {
  position: relative;
  overflow: hidden;
}
.animated-color-swap-gradient {
  padding: 3rem 0 3rem 0;
}

.animated-color-swap-gradient::after {
  content: "";
  border-radius: 0.75rem 0 0 0.75rem;
  width: 100%;
  height: 100%;
  opacity: 0.75;
  /* background: radial-gradient(circle at top left, #bcc5db, #ffd26f, #ffffff); */
  background: radial-gradient(
    circle at top left,
    rgba(188, 197, 219, 0.8),
    rgba(255, 210, 111, 0.8),
    rgba(255, 210, 111, 0.8)
  );
  animation: gradientAnimation 15s infinite ease-in-out,
    fadeEffect 50s infinite ease-in-out;
  position: absolute;
  width: 30%;
  right: 0;
  z-index: 1;
}
@media screen and (max-width: 671px) {
  .first-block-negative-margin {
    margin-top: 0;
  }
  .animated-color-swap-gradient {
    padding: 3rem;
    width: 100%;
  }
  .animated-color-swap-gradient::after {
    width: 100%;
  }
}
.membership-group.animated-color-swap-gradient::after {
  top: 0;
  left: 0;
  height: 100%;
  width: 100%;
}
.membership {
  position: relative;
}
.membership .saving {
  position: absolute;
  top: -1rem;
  left: 50%;
  transform: translateX(-50%);
}

.additional-info,
.membership .amount-suffix {
  color: #434343;
}
.additional-info p {
  line-height: 1.625;
}
@keyframes gradientAnimation {
  0% {
    background: radial-gradient(
      circle at bottom left,
      rgba(188, 197, 219, 0.8),
      rgba(255, 210, 111, 0.8),
      rgba(255, 210, 111, 0.8)
    );
  }

  25% {
    background: radial-gradient(
      circle at top left,
      rgba(255, 210, 111, 0.8),
      rgba(188, 197, 219, 0.8),
      rgba(255, 210, 111, 0.8)
    );
  }
  50% {
    background: radial-gradient(
      circle at top right,
      rgba(255, 210, 111, 0.8),
      rgba(188, 197, 219, 0.8),
      rgba(255, 210, 111, 0.8)
    );
  }
  75% {
    background: radial-gradient(
      circle at bottom right,
      rgba(188, 197, 219, 0.8),
      rgba(255, 210, 111, 0.8),
      rgba(255, 210, 111, 0.8)
    );
  }
  100% {
    background: radial-gradient(
      circle at bottom left,
      rgba(188, 197, 219, 0.8),
      rgba(255, 210, 111, 0.8),
      rgba(255, 210, 111, 0.8)
    );
  }
}

@keyframes fadeEffect {
  10% {
    opacity: 0.3;
  }
  20% {
    opacity: 0.3;
  }
  30% {
    opacity: 0.3;
  }
  40% {
    opacity: 0.4;
  }
  50% {
    opacity: 0.5;
  }
  60% {
    opacity: 0.4;
  }
  70% {
    opacity: 0.3;
  }
  80% {
    opacity: 0.3;
  }
  90% {
    opacity: 0.3;
  }
}

.arrow-button {
  --color: var(--black);
  --hColor: var(--black);
  --fColor: var(--black);
  --aColor: var(--black);
  --background: none;
  --padding: 0 2rem 0 0;
  --hPadding: 0 2rem 0 0;
  --aPadding: 0 2rem 0 0;
  --fPadding: 0 2rem 0 0;
  --hBackground: transparent;
  --fBackground: transparent;
  --aBackground: transparent;
  --border: transparent;
  --hBorder: transparent;
  --fBorder: transparent;
  --aBorder: transparent;
  font-size: 1rem !important;
  letter-spacing: normal !important;
  font-weight: 500 !important;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none'%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M16.7197 7.71967C17.0126 7.42678 17.4874 7.42678 17.7803 7.71967L21.5303 11.4697C21.8232 11.7626 21.8232 12.2374 21.5303 12.5303L17.7803 16.2803C17.4874 16.5732 17.0126 16.5732 16.7197 16.2803C16.4268 15.9874 16.4268 15.5126 16.7197 15.2197L19.1893 12.75H3C2.58579 12.75 2.25 12.4142 2.25 12C2.25 11.5858 2.58579 11.25 3 11.25H19.1893L16.7197 8.78033C16.4268 8.48744 16.4268 8.01256 16.7197 7.71967Z' fill='%230F172A'/%3E%3C/svg%3E") !important;
  background-position: 95% center !important;
  background-repeat: no-repeat !important;
  line-height: 1 !important;
  text-transform: initial !important;
}
.arrow-button:hover {
  background-position: right center !important;
}

.rounded-yellow {
  --color: var(--black);
  --hColor: var(--black);
  --fColor: var(--black);
  --aColor: var(--black);
  --background: var(--yellow);
  --padding: 0.5rem 2rem;
  --hPadding: 0.5rem 2rem;
  --aPadding: 0.5rem 2rem;
  --fPadding: 0.5rem 2rem;
  --borderRadius: 100px;
  --hBorderRadius: 100px;
  --fBorderRadius: 100px;
  --aBorderRadius: 100px;
  --textTransform: none;
  --fontSize: 1rem;
  --fontWeight: 500;
  --letterSpacing: 0;
  --hBackground: var(--dark-yellow);
  --fBackground: var(--dark-yellow);
  --aBackground: var(--dark-yellow);
  --fOpacity: 0.8;
  --border: 1px solid #d9d9d9;
  --hBorder: 1px solid #7b7b7b;
  --fBorder: 1px solid #7b7b7b;
  --aBorder: 1px solid #7b7b7b;
}
.rounded-green {
  --color: var(--white);
  --hColor: var(--white);
  --fColor: var(--white);
  --aColor: var(--white);
  --padding: 0.5rem 2rem;
  --hPadding: 0.5rem 2rem;
  --aPadding: 0.5rem 2rem;
  --fPadding: 0.5rem 2rem;
  --borderRadius: 100px;
  --hBorderRadius: 100px;
  --fBorderRadius: 100px;
  --aBorderRadius: 100px;
  --textTransform: none;
  --fontSize: 1rem;
  --fontWeight: 500;
  --letterSpacing: 0;
  --background: var(--green);
  --hBackground: var(--dark-green);
  --fBackground: var(--dark-green);
  --aBackground: var(--dark-green);
  --fOpacity: 0.8;
  --border: transparent;
  --hBorder: transparent;
  --fBorder: transparent;
  --aBorder: transparent;
}
.rounded-white {
  --color: var(--black);
  --hColor: var(--black);
  --fColor: var(--black);
  --aColor: var(--black);
  --padding: 0.5rem 2rem;
  --hPadding: 0.5rem 2rem;
  --aPadding: 0.5rem 2rem;
  --fPadding: 0.5rem 2rem;
  --borderRadius: 100px;
  --hBorderRadius: 100px;
  --fBorderRadius: 100px;
  --aBorderRadius: 100px;
  --textTransform: none;
  --fontSize: 1rem;
  --fontWeight: 500;
  --letterSpacing: 0;
  --background: var(--white);
  --hBackground: var(--hover-white);
  --fBackground: #c4c4c4;
  --aBackground: var(--hover-white);
  --fOpacity: 0.8;
  --border: 1px solid #7b7b7b;
  --hBorder: 1px solid #7b7b7b;
  --fBorder: 1px solid #c4c4c4;
  --aBorder: 1px solid #7b7b7b;
}
