@media only screen and (min-width: 0rem) {
  /*-- -------------------------- -->
  <---           Hero             -->
  <--- -------------------------- -*/

  #hero-493 {
    /* Centers button */
    text-align: center;
    /* 200px - 300px - leaving extra space for the navigation */
    padding: clamp(12.5rem, 25.95vw, 18.75em) 2rem;
    padding-bottom: 12.5rem;
    /* prevents the topper line from causing an overflow */
    overflow: hidden;
    position: relative;
    z-index: 1;
  }
  #hero-493 .cs-background {
    width: 100%;
    height: 100%;
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    z-index: -2;
  }
  /* #hero-493 .cs-background:before {
    content: "";
    width: 100%;
    height: 100%;
    background: #001f3f;
    opacity: 0.7;
    position: absolute;
    display: block;
    top: 0;
    left: 0;
    z-index: 1;
    pointer-events: none;
  } */
  #hero-493 .cs-background img {
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    width: 100%;
    object-fit: cover;
  }
  #hero-493 .cs-container {
    width: 100%;
    max-width: 80rem;
    margin: auto;
    display: flex;
    flex-wrap: wrap;
    justify-content: start;
    align-items: center;
    /* changes at tablet */
    gap: 3rem;
  }
  #hero-493 .cs-content {
    width: 100%;
    max-width: 45rem;
  }
  #hero-493 .cs-topper {
    /* 16px - 20px */
    font-size: clamp(1rem, 1.5vw, 1.25rem);
    line-height: 1.2em;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-align: center;
    text-transform: uppercase;
    margin-bottom: 1rem;
    color: #fff;
    display: inline-block;
    position: relative;
  }
  #hero-493 .cs-topper:before {
    /* left yellow line */
    content: "";
    /* 70px - 100px */
    width: clamp(4.375rem, 5vw, 6.25rem);
    height: 2px;
    margin-right: 1.75rem;
    background: var(--primary);
    opacity: 1;
    position: absolute;
    display: block;
    top: 50%;
    transform: translateY(-50%);
    right: 100%;
  }
  #hero-493 .cs-topper:after {
    /* right yellow line */
    content: "";
    /* 70px - 100px */
    width: clamp(4.375rem, 5vw, 6.25rem);
    height: 2px;
    margin-left: 1.75rem;
    background: var(--primary);
    opacity: 1;
    position: absolute;
    display: block;
    top: 50%;
    transform: translateY(-50%);
    left: 100%;
  }
  #hero-493 .cs-title {
    font-size: clamp(3rem, 6.4vw, 5rem);
    font-weight: 400;
    line-height: 1em;
    text-align: start;
    max-width: 51.8125rem;
    margin: 0 auto clamp(1rem, 4vw, 1.5rem) 0;
    color: #fff;
    position: relative;
  }
  #hero-493 .cs-title span {
    color: var(--secondary);
  }
  #hero-493 .cs-text {
    /* 16px - 20px */
    font-size: clamp(1rem, 1.95vw, 1.5rem);
    line-height: 1.5em;
    text-align: start;
    width: 100%;
    /* 464px - 622px */
    margin: 0 auto 0;
    margin-bottom: 2.25rem;
    color: #fff;
  }
  #hero-493 .cs-button-transparent {
    line-height: clamp(2.875rem, 5.5vw, 3.5rem);
  }
  #hero-493 .button-group {
    display: flex;
    justify-content: start;
    gap: 1rem;
  }
  /*-- -------------------------- -->
  <---        Side By Side        -->
  <--- -------------------------- -*/

  .sbs-97 {
    padding: var(--sectionPadding);
    background-color: var(--backgroundLight);
  }
  .sbs-97 .cs-container {
    width: 100%;
    /* changes to 1280px at tablet */
    max-width: 34.375rem;
    margin: auto;
    display: flex;
    flex-direction: column;
    align-items: center;
    /* 48px - 64px, changed clamp at tablet */
    gap: clamp(3rem, 6vw, 4rem);
  }
  .sbs-97 .cs-content {
    /* set text align to left if content needs to be left aligned */
    text-align: left;
    width: 100%;
    max-width: 33.875rem;
    display: flex;
    flex-direction: column;
    /* centers content horizontally, set to flex-start to left align */
    align-items: flex-start;
  }

  /* .sbs-97 .cs-topper {
    text-transform: uppercase;
    font-weight: 700;
    color: var(--primary);
  } */
  .sbs-97 .cs-title {
    font-size: clamp(2.25rem, 6vw, 3rem);
    font-weight: 900;
    margin: 0;
    margin-bottom: 2rem;
    line-height: 1.2;
  }
  .sbs-97 .cs-text {
    margin-bottom: 1rem;
  }
  .sbs-97 .cs-text:last-of-type {
    margin-bottom: 3rem;
  }
  .sbs-97 .cs-ul {
    margin: 0 0 2rem 0;
    /* 16px - 20px */
    padding-left: clamp(1rem, 2vw, 1.25rem);
  }
  .sbs-97 .cs-li {
    list-style: none;
    /* 14px - 18px */
    font-size: clamp(0.875rem, 1.3vw, 1.125rem);
    line-height: 1.5em;
    /* 8px - 12px */
    margin-bottom: clamp(0.5rem, 1vw, 0.75rem);
    color: var(--bodyTextColor);
    position: relative;
    display: flex;
    justify-content: flex-start;
    align-items: center;
  }
  .sbs-97 .cs-li:last-of-type {
    margin-bottom: 0;
  }
  .sbs-97 .cs-number {
    font-size: clamp(0.875rem, 1.6vw, 1rem);
    width: clamp(1.5rem, 2.9vw, 1.75rem);
    height: clamp(1.5rem, 2.9vw, 1.75rem);
    margin-right: 0.75rem;
    border-radius: 50%;
    background: var(--primary);
    color: #fff;
    display: flex;
    justify-content: center;
    align-items: center;
    /* we set this element to align to the top of the li, so if there's 
        multiple lines it will stay at the top instead of the center of the text */
    align-self: flex-start;
    /* prevents flexbox from squishing it */
    flex: none;
  }
  .sbs-97 .cs-picture {
    width: 100%;
    margin: 0;
    position: relative;
    display: block;
    /* width divided by height */
    aspect-ratio: 0.78095238;
    order: 2;
  }
  .sbs-97 .cs-picture img {
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    width: 100%;
    object-fit: cover;
  }

  .sbs-97 .zeffy-container {
    position: relative;
    overflow: hidden;
    width: 100%;
    height: 700px;
  }

  /*-- -------------------------- -->
  <---          Events            -->
  <--- -------------------------- -*/

  #events-1652 {
    padding: var(--sectionPadding);
    overflow: hidden;
    position: relative;
    z-index: 1;
  }
  #events-1652 .cs-container {
    width: 100%;
    max-width: 80rem;
    margin: auto;
    display: flex;
    flex-direction: column;
    justify-content: center;
  }
  #events-1652 .cs-image {
    display: flex;
    position: relative;
    width: 100%;
  }
  #events-1652 .cs-picture {
    width: 100%;
    /* 328px - 752px */
    height: clamp(20.5rem, 80vw, 47rem);
    display: block;
    position: relative;
    overflow: hidden;
    z-index: 1;
  }
  #events-1652 .cs-picture img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    position: absolute;
    top: 0;
    left: 0;
  }
  #events-1652 .cs-events {
    max-width: 46.125rem;
    background-color: #f7f7f7;
    display: flex;
    /* 40px - 48px top */
    padding: clamp(2.5rem, 4vw, 3rem) clamp(1rem, 5vw, 3rem)
      clamp(1rem, 5vw, 3rem);
    flex-direction: column;
    align-items: center;
    gap: 2.5rem;
  }
  #events-1652 .cs-content {
    text-align: left;
    width: 100%;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
  }
  #events-1652 .cs-title {
    color: var(--headerColor);
    margin: 0;
  }
  #events-1652 .cs-card-group {
    width: 100%;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    /* 16px - 20px */
    gap: clamp(1rem, 3vw, 1.25rem);
  }
  #events-1652 .cs-item {
    list-style: none;
    background-color: #fff;
    overflow: hidden;
    position: relative;
    z-index: 1;
    text-decoration: none;
    width: 100%;
    /* 16px - 32px */
    padding: clamp(1rem, 2vw, 2rem);
    /* prevents padding from affecting height and width */
    box-sizing: border-box;
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    justify-content: center;
    /* 16px - 24px */
    gap: clamp(1rem, 2vw, 1.5rem);
  }
  #events-1652 .cs-date {
    font-size: 1rem;
    line-height: 1.2em;
    /* 80px - 100px */
    width: clamp(5rem, 10vw, 6.25rem);
    height: clamp(5rem, 10vw, 6.25rem);
    color: var(--primary);
    background-color: #111926;
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
    position: relative;
    z-index: 1;
    flex: none;
  }
  #events-1652 .cs-date strong {
    font-size: 1.9375rem;
    line-height: 1.2em;
    color: #fff;
  }
  #events-1652 .cs-info-wrapper {
    display: flex;
    flex-direction: column;
    /* 24px - 48px */
    gap: clamp(1.5rem, 3vw, 3rem);
  }
  #events-1652 .cs-info {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 0 0.5rem;
  }
  #events-1652 .cs-h3 {
    font-size: 1.25rem;
    line-height: 1.2em;
    font-weight: 700;
    margin: 0 0 0.5rem 0;
    color: var(--headerColor);
    text-align: center;
  }
  #events-1652 .cs-location {
    /* 14px - 16px */
    font-size: clamp(0.875rem, 1.6vw, 1rem);
    line-height: 1.5em;
    /* 8px -k 24px */
    margin: 0 0 clamp(0.5rem, 2vw, 1.5rem);
    color: var(--bodyTextColor);
    text-align: center;
  }
  #events-1652 .cs-time {
    /* 14px - 16px */
    font-size: clamp(0.875rem, 1.6vw, 1rem);
    line-height: 1.5em;
    margin: 0;
    color: var(--bodyTextColor);
    display: flex;
    gap: 0.5rem;
    align-items: center;
  }
  #events-1652 .cs-time svg {
    width: 50px;
    height: 100%;
  }
  #events-1652 .cs-time svg path {
    stroke: var(--primary);
  }
  #events-1652 .cs-icon {
    width: 1.5rem;
    height: auto;
  }
  #events-1652 .cs-button-wrapper {
    display: flex;
    position: relative;
    align-items: center;
    justify-content: center;
  }
  #events-1652 .cs-button-solid {
    font-size: 1rem;
    min-width: 8.375rem;
  }
  /* #events-1652 .cs-button-solid {
    font-size: 1rem;
    line-height: clamp(2.875rem, 5.5vw, 3.5rem);
    text-decoration: none;
    font-weight: 700;
    text-align: center;
    color: #fff;
    min-width: 9.375rem;
    padding: 0 1.5rem;
    background-color: var(--primary);
    display: inline-block;
    position: relative;
    z-index: 1;
    box-sizing: border-box;
  } */
  /* #events-1652 .cs-button-solid:before {
    content: "";
    position: absolute;
    height: 100%;
    width: 0%;
    background: #000;
    opacity: 1;
    top: 0;
    left: 0;
    z-index: -1;
    transition: width 0.3s;
  }
  #events-1652 .cs-button-solid:hover:before {
    width: 100%;
  } */

  /*-- -------------------------- -->
  <---           Verse            -->
  <--- -------------------------- -*/
  #cta-51 {
    padding: var(--sectionPadding);
    position: relative;
  }
  #cta-51 .cs-container {
    width: 100%;
    max-width: 80rem;
    margin: auto;
    display: flex;
    flex-direction: column;
    align-items: center;
    /* 48px - 64px */
    gap: clamp(3rem, 6vw, 4rem);
  }
  #cta-51 .cs-content {
    /* set text align to left if content needs to be left aligned */
    text-align: center;
    display: flex;
    flex-direction: column;
    /* centers content horizontally, set to flex-start to left align */
    align-items: center;
  }

  /* #cta-51 .cs-title {
    color: var(--bodyTextColorWhite);
    font-size: 3rem;
    margin: 0;
  } */
  #cta-51 .cs-text {
    font-family: "Teko", "Arial", sans-serif;
    font-size: clamp(1.5rem, 3vw, 2.25rem);
    line-height: 1.2;
    margin-bottom: 1rem;
    color: var(--bodyTextColorWhite);
  }
  #cta-51 .verse {
    color: #fff;
    font-size: 1.5rem;
    font-weight: 400;
    text-transform: uppercase;
    letter-spacing: 6px;
  }
  #cta-51 .cs-text:last-of-type {
    margin-bottom: 2rem;
    letter-spacing: 4px;
  }
  #cta-51 .cs-picture {
    height: 100%;
    width: 100%;
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    z-index: -1;
  }
  #cta-51 .cs-picture:before {
    content: "";
    position: absolute;
    display: block;
    height: 100%;
    width: 100%;
    background: #000;
    opacity: 0.85;
    top: 0;
    left: 0;
    z-index: 1;
  }
  #cta-51 .cs-picture img {
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    width: 100%;
    object-fit: cover;
  }

  /*-- -------------------------- -->
  <---           Stats            -->
  <--- -------------------------- -*/
  #stats-471 {
    padding: var(--sectionPadding);
    background: linear-gradient(
      135deg,
      var(--primary) 0%,
      var(--secondary) 130%
    );
    /* clips the glowing orbs from causing overflow issues when they overflow the container */
    overflow: hidden;
    position: relative;
    z-index: 1;
  }
  #stats-471 .cs-container {
    width: 100%;
    max-width: 59.6875rem;
    margin: auto;
  }
  #stats-471 .cs-card-group {
    width: 100%;
    margin: 0;
    padding: 0;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    row-gap: 3.75rem;
  }
  #stats-471 .cs-item {
    list-style: none;
    width: 47%;
    max-width: 15rem;
    margin: 0;
    padding: 0 0.75rem;
    /* prevents padding and border from affecting height and width */
    box-sizing: border-box;
    display: flex;
    flex-direction: column;
    align-items: center;
  }
  #stats-471 .cs-icon {
    width: clamp(3.125rem, 6vw, 4.75rem);
    height: auto;
    margin: 0 0 1.25rem;
    display: block;
    fill: #fff;
  }
  #stats-471 .cs-icon g g rect,
  #stats-471 .cs-icon g g path,
  #stats-471 .cs-icon g g line {
    stroke: #fff;
  }
  #stats-471 .cs-number {
    /* 31px - 61px */
    font-size: clamp(1.9375rem, 4.3vw, 3.8125rem);
    line-height: 1.2em;
    text-align: center;
    font-weight: 400;
    margin: 0 0 0.25rem 0;
    color: var(--bodyTextColorWhite);
  }
  #stats-471 .cs-desc {
    font-size: clamp(1rem, 2vw, 1.25rem);
    line-height: 1.5em;
    text-align: center;
    width: 100%;
    color: var(--bodyTextColorWhite);
  }
  #stats-471 .cs-picture {
    height: 100%;
    width: 100%;
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    z-index: -1;
    opacity: 0.05;
  }
  /* #stats-471 .cs-picture:before {
    content: "";
    position: absolute;
    display: block;
    height: 100%;
    width: 100%;
    background: linear-gradient(135deg, var(--primary) 80%, var(--tertiary));
    opacity: 0.8;
    top: 0;
    left: 0;
    z-index: 1;
  } */
  #stats-471 .cs-picture img {
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    width: 100%;
    object-fit: cover;
  }

  /*-- -------------------------- -->
  <---      Freedom's Finds       -->
  <--- -------------------------- -*/
  .sbs-97.reverse .cs-container .cs-picture {
    order: 2;
  }
}

@media only screen and (min-width: 37.5rem) {
  #hero .background img {
    bottom: 130px;
  }
}

@media only screen and (min-width: 48rem) {
  /*-- -------------------------- -->
  <---        Side By Side        -->
  <--- -------------------------- -*/
  .sbs-97 .cs-container {
    max-width: 80rem;
    justify-content: flex-start;
    align-items: center;
    /* 60px - 108px */
    gap: clamp(3.75rem, 7.8vw, 6.75rem);
  }

  .sbs-97 .cs-picture {
    /* 284px - 522px */
    height: 22rem;
    /* prevents flexbox from squishing it */
    flex: none;
    max-width: 33.875rem;
  }

  /*-- -------------------------- -->
  <---          Events            -->
  <--- -------------------------- -*/

  #events-1652 .cs-container {
    flex-direction: row;
    align-items: stretch;
  }
  #events-1652 .cs-image {
    width: 45%;
    max-width: 33.875rem;
    height: auto;
    padding-top: 0;
    /* sends it to the right in the 2nd position */
    order: 2;
  }
  #events-1652 .cs-picture {
    max-height: none;
    height: auto;
  }
  #events-1652 .cs-events {
    min-width: 26.25rem;
    /* 420px - 738px */
    width: clamp(26.25rem, 52.8vw, 46.125rem);
    /* 24px - 48px */
    padding: clamp(1.5rem, 3vw, 3rem);
    justify-content: flex-start;
  }
  #events-1652 .cs-info {
    align-items: flex-start;
  }
  #events-1652 .cs-button-wrapper {
    justify-content: flex-start;
  }
  #events-1652 .cs-h3,
  #events-1652 .cs-location {
    text-align: start;
  }
}

@media only screen and (min-width: 58.75rem) {
  /*-- -------------------------- -->
  <---           Stats            -->
  <--- -------------------------- -*/
  #stats-471 .cs-card-group {
    justify-content: space-between;
  }
}

@media only screen and (min-width: 64rem) {
  .sbs-97 .cs-container {
    flex-direction: row;
    align-items: flex-start;
  }
  .sbs-97 .cs-picture {
    height: 45rem;
    width: clamp(25rem, 40vw, 33.875rem);
  }
  .sbs-97 .cs-content {
    order: 2;
  }
  #events-1652 .cs-info-wrapper {
    flex-direction: column;
  }
}

@media only screen and (min-width: 81.25rem) {
  /*-- -------------------------- -->
  <---          Events            -->
  <--- -------------------------- -*/

  #events-1652 .cs-info-wrapper {
    flex-direction: row;
  }
  #events-1652 .cs-item {
    flex-wrap: nowrap;
  }
  #events-1652 .cs-h3 {
    width: 200%;
  }
}
