.homepage {
  max-width: none; /* Sets the HP to Full Bleed */
  margin-top: 0; /* We set top marging with */
}

@font-face {
  font-family: modernline;
  src: url("modernline.otf?$staticlink$") format("opentype");
}

.g3-hp {
  position: relative;
  width: 100%;
  height: auto;
  z-index: 1;
  margin: 0 auto;
  padding: 0;
  overflow: hidden;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  font-family: "sofia-pro", sans-serif;
  font-size: 1.56vw;
  -webkit-text-decoration-skip: none;
  text-decoration-skip-ink: none;
}

@media all and (min-width: 1024px) and (max-width: 1680px) {
  .g3-hp {
    font-size: 0.95vw !important;
  }
}

@media (min-width: 1680px) {
  .g3-hp {
    font-size: 1em;
  }
}

.g3-hp *,
.g3-hp *::before,
.g3-hp *::after {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
}

.g3-hp img {
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  max-width: none;
}

.g3-hp a {
  color: inherit;
}

.g3-hp h1,
.g3-hp h2,
.g3-hp h3,
.g3-hp h4,
.g3-hp h5,
.g3-hp h6,
.g3-hp blockquote,
.g3-hp p {
  position: relative;
  display: block;
  margin: 0;
}

.g3-hp p {
  color: inherit;
  font-family: "sofia-pro", sans-serif;
  font-size: 1.35em;
  font-weight: 400;
  line-height: 1.3;
  letter-spacing: normal;
}

.g3-hp h1 {
  color: inherit;
  font-family: "kudryashev-d-contrast", serif;
  font-size: 4.21875em;
  font-weight: 400;
  line-height: 1.15;
  letter-spacing: normal;
}

/* used thoughout for section titles and heros */
.g3-hp h2 {
  color: inherit;
  font-family: "sofia-pro", sans-serif;
  font-size: 2.53125em;
  font-weight: 600;
  line-height: 1.3;
  letter-spacing: 0.1em;
}

/* used thoughout for 3x grid titles */
.g3-hp h3 {
  color: inherit;
  font-family: "sofia-pro", sans-serif;
  font-size: 2.53125em;
  font-weight: 600;
  line-height: 1.3;
  letter-spacing: 0.12em;
}

/* serif used for 3x grid text */
.g3-hp h4 {
  color: inherit;
  font-family: "kudryashev-d-contrast", serif;
  font-size: 4.21875em;
  font-weight: 400;
  line-height: 1.15;
  letter-spacing: 0.01;
}

/* sofia-pro semi-bold heading */
.g3-hp h5 {
  color: inherit;
  font-family: "sofia-pro", sans-serif;
  font-size: 4.455em;
  font-weight: 600;
  line-height: 1.1;
  letter-spacing: 0.02em;
}

/* sofia-pro semi-bold heading */
.g3-hp h6 {
  color: inherit;
  font-family: "sofia-pro", sans-serif;
  font-size: 1.755em;
  font-weight: 600;
  line-height: 1.1;
  letter-spacing: 0.02em;
}

.g3-hp blockquote {
  color: inherit;
  font-family: "kudryashev-d-contrast", serif;
  font-size: 4.21875em;
  font-weight: 400;
  line-height: 1.1;
  letter-spacing: normal;
}

@media (min-width: 1024px) {
  .g3-hp p {
    font-size: 1.164em;
  }

  .g3-hp h2 {
    font-size: 1.25em;
  }

  .g3-hp h3 {
    font-size: 1.5132em;
  }

  .g3-hp h4 {
    font-size: 4.1904em;
  }

  .g3-hp h5 {
    font-size: 4.074em;
  }

  .g3-hp h6 {
    font-size: 1.8915em;
  }

  .g3-hp blockquote {
    font-size: 2.91em;
  }
}

.g3-hp h3 > sup,
.g3-hp h4 > sup {
  font-size: 0.7em;
  vertical-align: 0.4em;
  margin-left: 0.1em;
}

.g3-hp section {
  position: relative;
  width: 100%;
  height: auto;
  margin: 0;
  padding: 0;
  overflow: hidden;
}

.g3-hp picture {
  position: relative;
  display: block;
  width: 100%;
}

.g3-hp picture img {
  display: block;
  position: relative;
  width: 100%;
  height: auto;
  margin: 0;
}

.g3-hp .g3-video-responsive video {
  display: block;
  position: relative;
  width: 100%;
  height: auto;
  object-fit: cover;
  margin: 0;
  display: none;
}

@media (min-width: 1024px) {
  div.g3-16-9::before,
  section.g3-16-9::before {
    content: "";
    display: block;
    padding-top: 56.25%;
  }
}

.g3-rel {
  position: relative;
  width: 100%;
  height: auto;
  margin: 0;
  padding: 0;
  overflow: hidden;
}

.g3-abs {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  margin: 0;
  padding: 0;
  overflow: hidden;
}

.g3-flex-break {
  flex-basis: 100%;
  height: 0;
}

.g3-modernline {
  display: inline-block;
  color: inherit;
  font-family: "modernline", sans-serif;
  font-size: 1.35em;
  font-weight: 400;
  line-height: 2.1;
  letter-spacing: normal;
  padding-top: 0.2em;
  width: 100%;
}

.g3-kudryashev {
  display: inline-block;
  color: inherit;
  font-family: "kudryashev-d-contrast", serif;
  font-size: 1.35em;
  font-weight: 400;
  line-height: 1.15;
  letter-spacing: normal;
}

.g3-it {
  font-style: italic;
}

.g3-white {
  color: #ffffff;
}

.g3-black {
  color: #000000;
}

.g3-sb {
  font-weight: 600 !important;
}

.g3-bold {
  font-weight: 700 !important;
}

.g3-fadein {
  opacity: 0;
}

.g3-ctas {
  position: relative;
  margin: 0;
  padding: 0;
  overflow: visible;
}

.g3-hp a.g3-cta--block,
.g3-hp span.g3-cta--block {
  display: inline-block;
  position: relative;
  height: auto;
  width: auto;
  margin: 0 0.8em;
  padding: 0 2em;
  overflow: hidden;
  font-family: "sofia-pro", sans-serif;
  font-size: 2.7em;
  font-weight: 600;
  line-height: 2.3;
  letter-spacing: normal;
  text-align: center;
  color: inherit;
  border: solid 0.08em;
  white-space: nowrap;
  text-decoration: none !important;
}

.g3-hp a.g3-cta--block-solid,
.g3-hp span.g3-cta--block-solid {
  display: inline-block;
  position: relative;
  height: auto;
  width: auto;
  margin: 0 0.8em;
  padding: 0 1.6em;
  overflow: hidden;
  font-family: "sofia-pro", sans-serif;
  font-size: 2.7em;
  font-weight: 600;
  line-height: 2.6;
  letter-spacing: normal;
  text-align: center;
  background-color: #ffffff;
  color: #000000;
  white-space: nowrap;
  text-decoration: none !important;
}

.g3-hp a.g3-cta--block-solid--black {
  color: #ffffff;
  background-color: #000000;
}

.g3-hp a.g3-cta--block--outline,
.g3-hp span.g3-cta--block--outline {
  display: inline-block;
  position: relative;
  height: auto;
  width: auto;
  margin: 0 0.4em;
  padding: 0 2.4em 0 2.4em;
  overflow: hidden;
  font-family: "sofia-pro", sans-serif;
  font-size: 2.7em;
  font-weight: 400;
  line-height: 2.6;
  letter-spacing: 0.06em;
  text-align: center;
  color: #000000;
  background-color: transparent;
  border: solid 1px;
  white-space: nowrap;
  text-decoration: none !important;
}

/* Fix Sofia Pro CTA Centering  */
.g3-hp a.g3-cta--block::after,
.g3-hp span.g3-cta--block::after,
.g3-hp a.g3-cta--mob-ul-dt-block::after,
.g3-hp span.g3-cta--mob-ul-dt-block::after,
.g3-hp a.g3-cta--block-solid::after,
.g3-hp span.g3-cta--block-solid::after,
.g3-hp a.g3-cta--block-solid::after,
.g3-hp span.g3-cta--block-solid::after {
  content: "";
  display: block;
  padding-top: 0.2em;
}

.g3-hp a.g3-cta--block--tight,
.g3-hp span.g3-cta--block--tight {
  padding: 0 1.2em !important;
}

.g3-hp a.g3-cta--block--med,
.g3-hp span.g3-cta--block--med {
  padding: 0 1.6em !important;
}

.g3-hp a.g3-cta--ul,
.g3-hp span.g3-cta--ul {
  display: inline-block;
  position: relative;
  font-family: "sofia-pro", sans-serif;
  font-size: 2.5em;
  font-weight: 600;
  line-height: normal;
  letter-spacing: 0.02em;
  color: inherit;
  text-decoration: underline;
  text-underline-offset: 0.2em;
  margin: 0 0.95em;
}

.g3-hp a.g3-cta--ul--kud,
.g3-hp span.g3-cta--ul--kud {
  display: inline-block;
  position: relative;
  font-family: "kudryashev-d-contrast", serif;
  font-size: 2.86875em;
  font-weight: 400;
  line-height: normal;
  letter-spacing: 0.01em;
  color: inherit;
  text-decoration: underline;
  text-underline-offset: 0.2em;
  margin: 0;
}

.g3-hp a.g3-cta--mob-ul-dt-block,
.g3-hp span.g3-cta--mob-ul-dt-block {
  display: inline-block;
  position: relative;
  font-family: "sofia-pro", sans-serif;
  font-size: 2.025em;
  font-weight: 400;
  line-height: normal;
  letter-spacing: 0.02em;
  color: inherit;
  text-decoration: underline;
  text-underline-offset: 0.2em;
  margin: 0 1em;
  white-space: nowrap;
}

.g3-plus {
  position: relative;
  height: auto;
  margin: 0;
  padding: 0.2em 0 0 0;
  text-align: center;
  font-family: "sofia-pro", sans-serif;
  font-size: 2.7em;
  font-weight: 400;
  line-height: 0.75;
  letter-spacing: 0.02em;
  color: inherit;
}

.g3-ctas {
  position: relative;
  width: 100%;
  height: auto;
  margin: 0;
  padding: 0;
  overflow: hidden;
  text-align: center;
}

@media (min-width: 1024px) {
  .g3-hp a.g3-cta--block,
  .g3-hp span.g3-cta--block {
    font-size: 1em;
    padding: 0 2.5em;
    line-height: 2.3;
  }

  .g3-hp a.g3-cta--block-solid {
    font-size: 1em;
    padding: 0 1.8em;
    line-height: 2.3;
  }

  .g3-hp a.g3-cta--block--outline,
  .g3-hp span.g3-cta--block--outline {
    padding: 0 2.4em 0 2.4em;
    font-size: 1em;
    line-height: 2.6;
  }

  .g3-hp a.g3-cta--ul,
  .g3-hp span.g3-cta--ul {
    font-size: 1.364em;
    margin: 0 1em;
  }

  .g3-hp a.g3-cta--ul--kud,
  .g3-hp span.g3-cta--ul--kud {
    font-size: 1.3125em;
  }

  .g3-hp a.g3-cta--mob-ul-dt-block,
  .g3-hp span.g3-cta--mob-ul-dt-block {
    margin: 0 0.8em;
    padding: 0 2.8em;
    overflow: hidden;
    font-size: 1.164em;
    line-height: 2.3;
    letter-spacing: normal;
    text-align: center;
    border: solid 0.08em;
    white-space: nowrap;
    text-decoration: none !important;
  }
}

a.g3-cta--block--no-pad {
  padding-left: 0;
  padding-right: 0;
}

.g3-ctas {
  position: relative;
  width: 100%;
  height: auto;
  margin: 0;
  padding: 0;
  overflow: hidden;
}

.g3-promo-offer {
  position: relative;
  width: 100%;
  height: auto;
  margin: 0;
  padding: 0;
  overflow: visible;
  text-align: center;
}

.g3-promo-offer__lg,
.g3-promo-offer__sm {
  display: block;
  color: inherit;
  font-family: "sofia-pro", sans-serif;
  font-weight: 600;
  line-height: 1.1;
  letter-spacing: 0.01em;
  margin: 0;
}

.g3-promo-offer__lg sup {
  position: absolute;
  font-size: 0.5em;
  top: 0.2em;
  margin: 0 0 0 0.05em;
  line-height: inherit;
}

.g3-coupon-area {
  display: inline-block;
  position: relative;
  width: 100%;
  font-family: "sofia-pro", sans-serif;
  font-size: 1.35em;
  font-weight: 400;
  line-height: normal;
  letter-spacing: 0.01em;
}

.g3-coupon-area a {
  color: inherit;
  text-decoration: underline;
}

.g3-eyebrow {
  display: inline-block;
  font-family: "sofia-pro", sans-serif;
  font-size: 1.35em;
  font-weight: 400;
  line-height: normal;
  letter-spacing: 0.06em;
  width: 100%;
}

@media (min-width: 1024px) {
  .g3-coupon-area {
    font-size: 1.164em;
  }

  .g3-eyebrow {
    font-size: 1.164em;
  }
}

/* G3 CAROUSEL ========== */
.g3-carousel {
  position: relative;
  width: 100%;
  height: auto;
  margin: 0 0 0 0;
  padding: 0;
  overflow: hidden;
  opacity: 0;
}

.g3-carousel__stage {
  position: relative;
  width: 100%;
  height: 100%;
  margin: 0 auto;
  padding: 0;
  overflow: hidden;
}

.g3-carousel__offset {
  position: relative;
  left: 0;
  height: 100%;
  margin: 0;
  padding: 0;
  overflow: visible;
}

.g3-carousel__slider {
  position: relative;
  width: 100%;
  height: 100%;
  margin: 0;
  padding: 0;
  overflow: visible;
}

a.g3-carousel__slide {
  color: inherit;
  text-decoration: none;
}

.g3-carousel__slide {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  margin: 0;
  padding: 0;
  overflow: hidden;
  text-align: center;
}

.g3-carousel__slide img {
  display: block;
  position: relative;
  width: 100%;
  height: auto;
  margin: 0;
}

.g3-carousel__arrow {
  display: block;
  position: absolute;
  width: 4%;
  height: auto;
  top: 50%;
  transform: translateY(-50%);
  margin: 0 4.8em;
  z-index: 500;
  cursor: pointer;
}

.g3-carousel__arrow--l {
  left: 0;
}

.g3-carousel__arrow--r {
  right: 0;
}

.g3-disclaimer {
  display: block;
  position: relative;
  width: 100%;
  color: inherit;
  font-family: "sofia-pro", sans-serif;
  font-size: 1.51875em;
  font-weight: 400;
  letter-spacing: 0.02em;
  line-height: normal;
  z-index: 100;
}

.g3-disclaimer--fixed {
  display: block;
  position: absolute;
  width: 100%;
  bottom: 1em;
  left: 0;
  color: inherit;
  font-family: "sofia-pro", sans-serif;
  font-size: 1.51875em;
  font-weight: 400;
  letter-spacing: 0.02em;
  line-height: normal;
  z-index: 100;
}

.g3-disclaimer > a,
.g3-disclaimer--fixed > a {
  display: inline-block;
  color: inherit;
  line-height: 1;
  text-decoration: underline;
  text-underline-offset: 0.1em;
}

.g3-sep {
  position: relative;
  width: 1px;
  min-height: 1em;
  margin: 0;
  padding: 0;
  overflow: hidden;
  background-color: #000000;
  font-size: 1.85625em;
}

@media (min-width: 1024px) {
  .g3-disclaimer {
    font-size: 0.9312em;
  }

  .g3-disclaimer--fixed {
    font-size: 0.7275em;
    bottom: 1.8em;
  }
}

.g3-disclaimer > sup,
.g3-disclaimer--fixed > sup {
  font-size: 0.7em;
  vertical-align: top;
  top: 0;
  line-height: inherit;
}

picture.g3-hero__bg--abs,
img.g3-hero__bg--abs {
  display: block;
  position: absolute;
  width: 100%;
  height: auto;
  top: 0;
  left: 0;
  margin: 0;
  z-index: -1;
}

/* ===================================== MOBILE BUBBLE CATEGORIES =================================== */
.g3-mobile-cats__content {
  position: relative;
  display: flex;
  align-items: center;
  width: 100%;
  height: 9em;
  margin: 0;
  padding: 1.8em 0;
  overflow: hidden;
}

.g3-mobile-cats__slider {
  position: absolute;
  width: auto;
  min-width: 100%;
  height: auto;
  margin: 0;
  padding: 0 3.5em;
  overflow: hidden;
  white-space: nowrap;
}

.g3-mobile-cats__slider a {
  display: inline-block;
  padding: 0 1em;
  font-style: normal;
  text-decoration: none;
  color: #000000;
  font-family: "sofia-pro", sans-serif;
  font-size: 2.3625em;
  font-weight: 400;
  line-height: 2.2;
  letter-spacing: 0.04em;
  margin: 0;
  background-color: #eeeeee;
}

.g3-mobile-cats__slider a:not(:first-of-type) {
  margin-left: 0.7em;
}

@media (min-width: 1024px) {
  section.g3-mobile-cats {
    display: none;
  }
}

/* ===================================== MOBILE BUBBLE CATEGORIES =================================== */
.g3-mobile-cats__content {
  position: relative;
  display: flex;
  align-items: center;
  width: 100%;
  height: 9em;
  margin: 0;
  padding: 1.8em 0;
  overflow: hidden;
}

.g3-mobile-cats__slider {
  position: absolute;
  width: auto;
  min-width: 100%;
  height: auto;
  margin: 0;
  padding: 0 3.5em;
  overflow: hidden;
  white-space: nowrap;
}

.g3-mobile-cats__slider a {
  display: inline-block;
  padding: 0 1em;
  font-style: normal;
  text-decoration: none;
  color: #000000;
  font-family: "sofia-pro", sans-serif;
  font-size: 2.3625em;
  font-weight: 400;
  line-height: 2.2;
  letter-spacing: 0.04em;
  margin: 0;
  background-color: #eeeeee;
}

.g3-mobile-cats__slider a:not(:first-of-type) {
  margin-left: 0.7em;
}

@media (min-width: 1024px) {
  section.g3-mobile-cats {
    display: none;
  }
}

/* ===================================== CATEGORIES ===================================== */
section.g3-cats {
  padding-top: 5em;
  padding-bottom: 8.2em;
}

.g3-cats .g3-content {
  position: relative;
  width: 92.5%;
  height: auto;
  margin: 0 auto;
  padding: 0;
  overflow: visible;
  text-align: left;
}

.g3-cats .g3-cats__grid {
  position: relative;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  column-gap: 0;
  row-gap: 7em;
  width: 100%;
  height: auto;
  margin: 2em auto 0 auto;
  padding: 0;
  overflow: visible;
}

.g3-cats a.g3-cat {
  position: relative;
  margin: 0;
  padding: 0;
  overflow: visible;
  min-width: 0;
  text-align: center;
  font-size: 1em;
}

.g3-cats a.g3-cat .g3-cat__img {
  position: relative;
  margin: 0;
  padding: 0;
  overflow: visible;
}

.g3-cats a.g3-cat .g3-cat__img > img {
  display: block;
  position: relative;
  width: 100%;
  height: auto;
  margin: 0;
  z-index: -1;
}

.g3-cats a.g3-cat > span {
  display: inline-block;
  color: #000000;
  font-family: "kudryashev-d-contrast", serif;
  font-size: 2.86875em;
  font-weight: 400;
  line-height: 1.3;
  letter-spacing: 0.02em;
  text-decoration: underline;
  text-underline-offset: 0.2em;
  margin: 0.9em 0 0 0;
}

@media (min-width: 1024px) {
  section.g3-cats {
    padding-top: 2em;
    padding-bottom: 3.8em;
  }

  .g3-cats .g3-content {
    width: 91%;
  }

  .g3-cats .g3-cats__grid {
    width: 95.4%;
    grid-template-columns: repeat(6, 1fr);
    column-gap: 0.75em;
    row-gap: 0;
    margin: 0 auto;
  }

  .g3-cats a.g3-cat {
    margin: 0;
  }

  .g3-cats a.g3-cat > span {
    margin-top: 0.4em;
    font-size: 1.3125em;
  }
}

/* ===================================== TRIO EDITORIALS ==================================== */
section.g3-trio {
  padding: 5em 0;
}

div.g3-trio__content {
  position: relative;
  width: 85.3%;
  height: auto;
  margin: 0 auto;
  padding: 0;
  overflow: hidden;
}
a.g3-trio__item .TrioHeader {
  display: block;
  font-family: "kudryashev-d-contrast", serif;
  font-size: 4.2em;
}
a.g3-trio__item {
  display: block;
  position: relative;
  width: 71.5%;
  height: auto;
  margin: 0 auto;
  padding: 0 0 2px 0;
  overflow: hidden;
  text-align: center;
  text-decoration: none;
  color: inherit;
  font-size: 1em;
}

a.g3-trio__item:nth-of-type(2) {
  width: 100%;
}

a.g3-trio__item:not(:last-of-type) {
  margin-bottom: 9em;
}

a.g3-trio__item > img {
  display: block;
  position: relative;
  width: 100%;
  height: auto;
  margin: 0 0 1.5em 0;
}
a.g3-trio__item .g3-cta--block {
  margin-top: 0.5em;
}
@media (min-width: 1024px) {
  section.g3-trio {
    padding: 3em 0;
  }

  div.g3-trio__content {
    width: 88.690476%; /* 1490 */
    display: flex;
    flex-flow: nowrap;
    justify-content: space-between;
    align-items: center;
  }

  a.g3-trio__item {
    width: 28.85906%;
    margin: 0;
  }

  a.g3-trio__item .TrioHeader {
    font-size: 2em;
  }

  a.g3-trio__item:nth-of-type(2) {
    width: 34.765101%;
  }

  a.g3-trio__item:not(:last-of-type) {
    margin-bottom: 0;
  }

  a.g3-trio__item > img {
    margin: 0 0 1em 0;
  }
}

/* ===================================== RFK ===================================== */
section.g3-rfk {
  background-color: #f6f6f6;
  padding: 7.8em 0 15em 0;
}

.g3-rfk__content {
  position: relative;
  width: 100%;
  height: auto;
  margin: 0 auto;
  padding: 0;
  overflow: visible;
  text-align: center;
}

.g3-rfk__content > h3 {
  font-family: "sofia-pro", sans-serif;
  font-weight: 600;
  font-size: 4.725em;
  letter-spacing: 0.04em;
  line-height: 1;
}

.g3-rfk__embed {
  position: relative;
  width: 100%;
  height: auto;
  min-height: 300px;
  margin: 6.6em 0 0 0;
  padding: 0;
  overflow: visible;
}

@media (min-width: 1024px) {
  section.g3-rfk {
    padding: 5.5em 0 6.5em 0;
  }

  .g3-rfk__content {
    width: 91.4%;
    position: relative;
  }

  .g3-rfk__content > h3 {
    font-size: 2.5em;
  }

  .g3-rfk__embed {
    margin: 2.4em 0 0 0;
  }
}
/* ===================================== AT EDITORIALS ===================================== */
.g3-editorial__hero-1 .g3-img-overlay {
  display: block;
  position: absolute;
  width: 100%;
  height: auto;
  bottom: 0;
  left: 0;
  margin: 0;
  padding: 0 0 8.3em 0;
}

.g3-editorial__hero-1__txt {
  position: relative;
  margin: 0;
  padding: 0;
  overflow: visible;
  text-align: center;
}

.g3-editorial__hero-1__txt h1 {
  font-size: 6.75em;
  line-height: 1.1;
  letter-spacing: 0.01em;
}

.g3-editorial__hero-1__txt sup {
  position: relative;
  vertical-align: 1.3em;
  font-size: 0.4em;
}

.g3-editorial__hero-1__txt p {
  color: inherit;
  font-family: "sofia-pro", sans-serif;
  font-size: 2.3625em;
  line-height: 1.4;
  letter-spacing: 0.03em;
}

.g3-editorial__hero-1__txt .g3-ctas {
  width: auto;
  margin-top: 3.5em;
  text-align: center;
}

.g3-editorial__hero-1__txt a.g3-cta--block-solid {
  margin: 0;
}

.g3-editorial__hero-1 .g3-disclaimer--fixed {
  width: 100%;
  text-align: center;
}

.g3-editorial__hero-1 .g3-background {
  display: block;
  position: relative;
  width: 100%;
  height: auto;
  margin: 0;
  z-index: -1;
}

@media (min-width: 1024px) {
  .g3-editorial__hero-1 .g3-img-overlay {
    padding: 0 0 8.3em 5.7em;
  }

  section.g3-editorial__hero-1.g3-text-block--left .g3-img-overlay {
    left: 0;
    right: auto;
    margin: 0;
    width: 50%;
  }

  section.g3-editorial__hero-1.g3-text-block--right .g3-img-overlay {
    right: 0;
    left: auto;
    margin: 0;
    width: 50%;
  }

  section.g3-editorial__hero-1.g3-text-block--center .g3-img-overlay {
    left: 0;
    right: 0;
    margin: 0 auto;
    width: 100%;
  }

  .g3-editorial__hero-1__txt {
    text-align: left;
  }

  .g3-editorial__hero-1__txt h1 {
    font-size: 3.75em;
    line-height: 0.9;
    letter-spacing: 0.01em;
    padding-bottom: 0.25em;
  }

  .g3-editorial__hero-1__txt p {
    font-size: 1em;
  }

  .g3-editorial__hero-1__txt .g3-ctas {
    margin-top: 1em;
    text-align: left;
  }

  .g3-editorial__hero-1__txt a.g3-cta--ul--kud {
    margin: 0 0.85em;
  }

  .g3-editorial__hero-1 .g3-disclaimer--fixed {
    bottom: 0.5em;
  }
}
/* ===================================== CURALATE ===================================== */
section.g3-curalate {
  padding: 10em 0 10em 0;
}

.g3-curalate__content {
  position: relative;
  width: 100%;
  height: auto;
  margin: 0 auto;
  padding: 0;
  overflow: visible;
  text-align: center;
}

.g3-curalate__content > h3 {
  font-family: "sofia-pro", sans-serif;
  font-weight: 600;
  font-size: 3.3em;
  letter-spacing: 0.08em;
  line-height: 1.3;
  padding: 0 3em 0.3em 3em;
}

.g3-curalate__content > p {
  font-family: "sofia-pro", sans-serif;
  font-weight: 400;
  font-size: 2.025em;
  letter-spacing: 0.06em;
}

.g3-curalate__embed {
  position: relative;
  width: 100%;
  height: auto;
  min-height: 300px;
  margin: 9em 0 0 0;
  padding: 0;
  overflow: visible;
}

.g3-curalate .g3-ctas {
  padding: 0 1em;
  margin-top: 5.4em;
}

.g3-curalate a.g3-cta--block--outline {
  margin-bottom: 0.5em;
}

@media (min-width: 1024px) {
  section.g3-curalate {
    padding: 5em 0 5em 0;
  }

  .g3-curalate__content {
    width: 75%;
  }

  .g3-curalate__content > h3 {
    letter-spacing: 0.04em;
    line-height: 1;
    font-size: 2.5em;
    padding: 0 0 0.4em 0;
  }

  .g3-curalate__content > p {
    font-weight: 600;
    font-size: 1em;
  }

  .g3-curalate__embed {
    margin: 4em 0 0 0;
  }

  .g3-curalate .g3-ctas {
    padding: 0;
    margin-top: 3em;
  }

  .g3-curalate a.g3-cta--block--outline {
    margin: 0 0.9em;
  }
}

@media (max-width: 1023px) {
  .g3-curalate a.g3-cta--block--outline {
    border: none;
    background-color: transparent;
    text-decoration: underline !important;
    text-underline-offset: 0.2em;
  }
}

/* ===================================== Utility classes  ===================================== */
.g3-hp .baskerville {
  font-family: "baskerville-urw", serif;
}

.g3-hp .kfont {
  font-family: "kudryashev-d-contrast", serif;
}

.g3-desktop-only {
  display: none !important;
}

.g3-mobile-only {
  display: revert !important;
}

@media (min-width: 1024px) {
  .g3-desktop-only {
    display: revert !important;
  }

  .g3-mobile-only {
    display: none !important;
  }
}

.g3-nobreak--dt > br {
  display: revert;
}

.g3-nobreak--mob > br {
  display: none;
}

@media (min-width: 1024px) {
  .g3-nobreak--mob > br {
    display: revert;
  }

  .g3-nobreak--dt > br {
    display: none;
  }
}

@media (max-width: 1024px) {
  .g3-margin-bot-1--m {
    margin-bottom: 5px !important;
  }

  .g3-margin-bot-2--m {
    margin-bottom: 1rem !important;
  }

  .g3-margin-top-1--m {
    margin-top: 5px !important;
  }

  .g3-margin-top-2--m {
    margin-top: 1rem !important;
  }
}

@media (min-width: 1024px) {
  .g3-margin-bot-1--dt {
    margin-bottom: 0.7px !important;
  }

  .g3-margin-bot-2--dt {
    margin-bottom: 1rem !important;
  }

  .g3-margin-top-1--dt {
    margin-top: 7px !important;
  }

  .g3-margin-top-2--dt {
    margin-top: 1rem !important;
  }
}

@media (max-width: 1024px) {
  .g3-pad-bot-1--m {
    padding-bottom: 0.5rem !important;
  }

  .g3-pad-bot-2--m {
    padding-bottom: 1rem !important;
  }

  .g3-pad-top-1--m {
    padding-top: 0.5rem !important;
  }

  .g3-pad-top-2--m {
    padding-top: 1rem !important;
  }
}

@media (min-width: 1024px) {
  .g3-pad-bot-1--dt {
    padding-bottom: 0.5rem !important;
  }

  .g3-pad-bot-2--dt {
    padding-bottom: 1rem !important;
  }

  .g3-pad-top-1--dt {
    padding-top: 0.5rem !important;
  }

  .g3-pad-top-2--dt {
    padding-top: 1rem !important;
  }
}
