:root {
  /* colors */
  --clr-neutral-900: #062630;
  --clr-neutral-700: #385159;
  --clr-neutral-200: #e6e1df;
  --clr-neutral-100: #faf5f3;
  --clr-neutral-0: #ffffff;

  --clr-accent-500: #fea36f;
  --clr-accent-100: #ffe2d1;
  --clr-accent-50: #fff5ef;

  --clr-gradient-700: linear-gradient(107deg, hsl(195, 23%, 28%) -11.37%, hsl(194, 78%, 11%) 61.84%);
  --clr-gradient-600: linear-gradient(107deg, hsl(22, 100%, 69%) -11.37%, hsl(194, 78%, 11%) 61.84%);
  --clr-gradient-100: linear-gradient(90deg, hwb(22 82% 0%) 0%, #fff5ef 100%);

  /* typography */
  --ff-martian-mono: "Martian Mono", monospace;
  --ff-inter: "Inter", sans-serif;

  --fs-xxxxl-62: 62px;
  --fs-xxxxl-60: 3.75rem;
  --fs-xxxl-50: 50px;
  --fs-xxl-38: 38px;
  --fs-xl-34: 34px;
  --fs-l-24: 24px;
  --fs-m-20: 20px;
  --fs-sm-18: 18px;
  --fs-s-16: 16px;
  --fs-xs-14: 14px;

  --fw-b-700: 700;
  --fw-sb-600: 600;

  /* spacing */
  --sp-1000-80: 80px;
  --sp-800-64: 64px;
  --sp-600-48: 48px;
  --sp-500-40: 40px;
  --sp-400-32: 32px;
  --sp-300-24: 24px;
  --sp-250-20: 20px;
  --sp-200-16: 16px;
  --sp-150-12: 12px;
  --sp-100-8: 8px;
  --sp-050-4: 4px;
  --sp-025-2: 2px;

  /* border-radus */
  --br-999: 999px;
  --br-24: 24px;
  --br-20: 20px;
  --br-16: 16px;
  --br-12: 12px;
  --br-10: 10px;
  --br-8: 8px;
  --br-6: 6px;
  --br-4: 4px;
}

/* css reset */
*,
*::before,
*::after {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

body {
  min-height: 100dvh;
  text-rendering: optimizeSpeed;
  font-family: var(--ff-inter);
  font-size: var(--fs-m-20);
  line-height: 1.4;
  letter-spacing: -0.5px;
  text-wrap: balance;
  color: var(--clr-neutral-700);
}

a {
  text-decoration: none;
}

img,
picture {
  display: block;
  max-width: 100%;
  height: auto;
  border: 0;
}

ul[role="list"],
ol[role="list"] {
  list-style: none;
}

/* TO DO: Update h1 font size */
h1 {
  font-family: var(--ff-martian-mono);
  font-size: var(--fs-xxxxl-60);
  font-size: clamp(2.175rem, 1.5323943661971828rem + 2.7417840375586855vw, var(--fs-xxxxl-60));
  font-weight: var(--fw-b-700);
  line-height: 1.2;
  letter-spacing: -2px;
  text-wrap: balance;
  margin-bottom: var(--sp-300-24);
  background-color: var(--clr-neutral-900);
  background-image: var(--clr-gradient-600);
  background-size: 100%;
  background-clip: text;

  -webkit-background-clip: text;
  -moz-background-clip: text;
  -webkit-text-fill-color: transparent;
  -moz-text-fill-color: transparent;

  /* Media Queries */
  @media (max-width: 1024px) {
    margin-top: var(--sp-500-40);
  }

  @media (max-width: 375px) {
    margin-top: var(--sp-300-24);
  }
}

h2 {
  position: relative;
  font-family: var(--ff-martian-mono);
  font-size: 50px;
  margin-bottom: 34px;
  line-height: 1.3;
  letter-spacing: -2px;
  text-wrap: balance;
  color: var(--clr-neutral-900);

  /* Media Queries */
  @media (max-width: 1024px) {
    /* max-width: 90%; */
  }

  @media (max-width: 600px) {
    font-size: 34px;
  }
}

h3 {
  font-family: var(--ff-martian-mono);
  font-size: 24px;
  font-weight: var(--fw-sb-600);
  line-height: 1.1;
  letter-spacing: -1px;
  text-wrap: balance;
  color: var(--clr-neutral-900);
}

/* UTILITIES */
.wrapper {
  max-width: 1440px;
  margin-inline: auto;
}

.container {
  max-width: 1170px;
  margin-inline: auto;
  padding: 32px;

  @media (max-width: 1024px) {
    padding: 32px 32px 80px 32px;
  }

  @media (max-width: 450px) {
    padding: 48px 16px 64px 16px;
  }
}

.button,
.ghost-button {
  display: inline-flex;
  flex-flow: row nowrap;
  justify-content: center;
  align-items: center;
  padding-block: var(--sp-200-16);
  padding-inline: var(--sp-300-24);
  border: var(--sp-025-2) solid var(--clr-neutral-900);
  border-radius: var(--sp-100-8);
  background: var(--clr-accent-50);

  font-family: var(--ff-martian-mono);
  font-size: 1rem;
  font-weight: var(--fw-sb-600);
  line-height: 1.3;
  letter-spacing: -1px;
  text-transform: uppercase;
  text-wrap: nowrap;
  color: var(--clr-neutral-900);

  & .button__icon {
    display: inline-block;
  }

  @media (max-width: 450px) {
    font-size: 14px;
  }
}

.button:hover,
.button:focus {
  background-image: var(--clr-gradient-100);
}

.ghost-button {
  max-width: fit-content;
  border: 3px solid var(--clr-neutral-0);
  background: transparent;
  color: var(--clr-neutral-0);
  margin: 0 auto;
  margin-bottom: var(--sp-400-32);
}

.ghost-button:hover,
.ghost-button:focus {
  background-image: var(--clr-gradient-700);
}

/* HEADER */

header {
  background-image: linear-gradient(130deg, hsla(20, 37%, 90%, 0.4) 60%, hsl(196, 46%, 73%, 0.5) 98.84%),
    url("/assets/images/pattern-light-bg.svg");
  margin-bottom: var(--sp-600-48);

  @media (max-width: 600px) {
    margin-bottom: var(--sp-300-24);
  }
}

nav {
  padding-block: var(--sp-200-16);
}

/* Hero */

.hero {
  display: flex;
  flex-flow: row wrap;
  padding-top: 50px;

  @media (max-width: 1024px) {
    flex-direction: column;
    gap: var(--sp-800-64);
    padding-top: 34px;
  }

  @media (max-width: 800px) {
    padding-top: 0;
  }
}

.hero > * {
  flex: 1;
}

.hero__content {
  margin: 50px 50px 50px 0;

  & .button {
    margin-bottom: var(--sp-250-20);
  }
  & .hero__content--text {
    line-height: 1.4;
    margin-bottom: var(--sp-400-32);
    text-wrap: balance;
  }

  /* Media Queries */
  @media (max-width: 1024px) {
    margin: 0;
  }
}

.hero__image {
  border-radius: var(--sp-150-12);
}

.social-proof {
  display: grid;
  grid-template-columns: 1fr 4fr;
  align-items: center;
  gap: var(--sp-150-12);

  & .social-proof__image {
    min-width: 110px;
  }

  & .social-proof__stats {
    font-family: var(--ff-martian-mono);
    font-size: var(--fs-xs-14);
    line-height: 1.2;
    letter-spacing: -1px;
  }

  & .social-proof__star {
    display: inline-block;
    max-width: 24px;
  }
}

/* FEATURES */

/* TODO: add social icons to right-feature */

.features {
  margin-bottom: 120px;

  @media (max-width: 1024px) {
    margin-bottom: 80px;
  }

  @media (max-width: 800px) {
    margin-bottom: 64px;
  }
}

.feature__left {
  display: flex;
  align-items: center;
  min-height: 100%;
  gap: 80px;
  margin-block-end: var(--sp-1000-80);

  @media (max-width: 1024px) {
    flex-direction: column;
    gap: 40px;

    .feature__left-content {
      order: -1;
    }
  }
}

.feature__left > * {
  flex: 1;
}

.feature_image--left {
  border-radius: var(--sp-150-12);
}

.feature__left-content {
  padding: 1rem 1rem 1rem 0;
}

.feature__left-grid {
  display: grid;
  grid-template-columns: 28px auto;
  align-items: center;
  gap: var(--sp-300-24);
}

.feature__right {
  position: relative;
  display: flex;
  align-items: center;
  min-height: 100%;
  gap: 80px;
  margin-block-end: var(--sp-1000-80);

  @media (max-width: 1024px) {
    flex-direction: column;
    gap: 40px;
  }
}

.feature__right > * {
  flex: 1;
}

.feature__right-content h2 {
  position: relative;
  font-size: 48.6px;

  & span > .feature__right-circle {
    position: absolute;
    top: 60px;
    left: 140px;
    z-index: 999;
  }

  /* Media Queries */
  @media (max-width: 1168px) {
    & span > .feature__right-circle {
      position: absolute;
      width: 150px;
      top: 125px;
      left: 150px;
      z-index: 999;
    }
  }

  @media (max-width: 1024px) {
    max-width: 85%;

    & span > .feature__right-circle {
      position: absolute;
      top: 60px;
      left: 155px;
      z-index: 999;
    }
  }

  @media (max-width: 675px) {
    max-width: 100%;
  }

  @media (max-width: 600px) {
    font-size: 34px;

    & span > .feature__right-circle {
      position: absolute;
      width: 110px;
      top: 40px;
      left: 100px;
      z-index: 999;
    }

    @media (max-width: 375px) {
      & span > .feature__right-circle {
        position: absolute;
        width: 110px;
        top: 85px;
        left: 100px;
        z-index: 999;
      }
    }
  }
}

.feature__right-image {
  border-radius: var(--sp-150-12);
}

.feature__right-image--overlay {
  position: absolute;
  top: 65%;
  right: 43%;

  @media (max-width: 1024px) {
    top: calc(100% - 18%);
    right: 5%;
  }

  @media (max-width: 800px) {
    top: calc(100% - 19%);
    right: 5%;
  }

  @media (max-width: 600px) {
    display: none;
  }
}
/* CALLOUT */

.callout {
  background-image: linear-gradient(130deg, hsla(20, 37%, 90%, 0.4) 60%, hsl(196, 46%, 73%, 0.5) 98.84%),
    url("/assets/images/pattern-light-bg.svg");
  border-radius: var(--sp-150-12);
  padding-block: var(--sp-1000-80);
  padding-inline: var(--sp-800-64);
  margin-bottom: 120px;

  @media (max-width: 1024px) {
    padding-inline: var(--sp-400-32);
    margin-bottom: 80px;
  }

  @media (max-width: 800px) {
    margin-bottom: 64px;
  }

  & h2 {
    width: 80%;
    text-align: center;
    margin-inline: auto;
    margin-bottom: var(--sp-800-64);

    /* Media Queries */
    @media (max-width: 1024px) {
      width: 100%;
      margin: 0;
      text-align: left;
      margin-bottom: var(--sp-600-48);
    }

    @media (max-width: 375px) {
      margin-bottom: var(--sp-400-32);
    }
  }
}

.callout__container {
  display: flex;
  justify-content: center;
  gap: 3rem;

  @media (max-width: 800px) {
    flex-direction: column;
  }
}

.callout__container > * {
  flex: 1;
}

.callout__step {
  display: grid;
  grid-template-columns: 40px auto;
  grid-template-rows: 40px auto;
  gap: var(--sp-250-20);

  font-family: var(--ff-martian-mono);
  font-size: var(--fs-sm-18);
  font-weight: var(--fw-sb-600);
  line-height: 1.3;
  letter-spacing: -1px;
  color: var(--clr-neutral-900);

  & p {
    grid-column: span 2;
  }

  /* Media Queries */
  @media (max-width: 600px) {
    font-size: var(--fs-s-16);
  }
}

.callout__numbered-box {
  display: flex;
  justify-content: center;
  align-items: center;
  outline: 3px solid var(--clr-neutral-900);
  border-radius: var(--sp-050-4);
}

.check-box--large {
  margin-left: auto;

  @media (max-width: 800px) {
    display: none;
  }
}

/* MEMBERSHIP OPTIONS */

.membership {
  padding-inline: 100px;
  margin-bottom: 120px;

  @media (max-width: 1024px) {
    padding-inline: var(--sp-400-32);
    margin-bottom: 80px;
  }

  @media (max-width: 800px) {
    margin-bottom: 64px;
  }

  & h2 {
    text-align: center;
    text-align: center;
    margin-inline: auto;
    margin-bottom: var(--sp-1000-80);

    /* Media Queries */
    @media (max-width: 1024px) {
      width: 100%;
      margin: 0;
      margin-bottom: var(--sp-600-48);
      text-align: left;
    }

    @media (max-width: 600px) {
      margin-bottom: var(--sp-300-24);
    }
  }

  & img {
    max-width: 24px;
  }
}

.membership__container {
  display: flex;
  flex-flow: row wrap;
  justify-content: center;
  gap: var(--sp-300-24);
}

.membership__container > * {
  flex: 1;

  @media (max-width: 1024px) {
    display: inline-flex;
  }
}

.membership__option {
  display: grid;
  gap: var(--sp-300-24);
  border: 1px solid var(--clr-neutral-200);
  border-radius: var(--sp-100-8);
  padding: var(--sp-300-24);
}

.membership__option:nth-child(odd) {
  margin-block: var(--sp-300-24);

  @media (max-width: 1024px) {
    margin-block: 0;
  }
}

.membership__option:nth-child(2) {
  background-image: linear-gradient(140deg, hsla(20, 37%, 90%, 0.4) 50%, hsl(196, 46%, 73%, 0.5) 98.84%);
}

.membership__option:nth-child(3) {
  @media (max-width: 1024px) {
    flex: 0 1 48.5%;
    margin-right: auto;
  }

  @media (max-width: 730px) {
    flex: 1;
  }
}

.membership__price {
  font-family: var(--ff-martian-mono);
  font-size: 34px;
  font-weight: var(--fw-sb-600);
  line-height: 1.3;
  letter-spacing: -1px;
  text-wrap: balance;
  color: var(--clr-neutral-900);
}

.membership__divider {
  height: 1px;
  border-bottom: 1px solid var(--clr-neutral-200);
}

.membership__benefits {
  display: grid;
  grid-template-columns: 24px auto;
  gap: var(--sp-150-12);

  & span {
    text-wrap: nowrap;
  }
}

/* TESTIMONIALS */
.testimonials {
  padding-inline: 100px;
  margin-bottom: 120px;

  @media (max-width: 1024px) {
    padding-inline: var(--sp-400-32);
    margin-bottom: 0;
  }

  @media (max-width: 800px) {
    margin-bottom: 0;
  }
}

.testimonial__container {
  display: grid;
  gap: var(--sp-400-32);
  text-align: center;
  text-wrap: balance;

  @media (max-width: 1024px) {
    text-align: left;
  }

  & .testimonial__star {
    display: inline-block;
    max-width: 24px;
  }
}

.testimonial__text {
  font-family: var(--ff-martian-mono);
  font-size: var(--fs-xl-34);
  font-weight: var(--fw-sb-600);
  line-height: 1.3;
  letter-spacing: -1px;
  color: var(--clr-neutral-900);

  @media (max-width: 600px) {
    font-size: var(--fs-l-24);
    line-height: 1.2;
  }
}

/* FOOTER */

.footer {
  border-radius: var(--sp-150-12) var(--sp-150-12) 0 0;
  background: var(--clr-neutral-900);
  background-image: url("/assets/images/pattern-light-bg.svg");
}
.footer-cta {
  margin-inline: auto;
  padding-inline: 135px;
  padding-block-start: 80px;
  /* padding-block-end: 24px; */

  @media (max-width: 1024px) {
    padding-inline: 32px;
    padding-block-start: 64px;
  }

  @media (max-width: 600px) {
    padding-inline: 16px;
    padding-block-start: 48px;
  }
}

.footer-cta__container {
  max-width: 1170px;
  margin-inline: auto;
  padding: 32px;

  @media (max-width: 1024px) {
    padding: 32px 32px 24px 32px;
  }
}

.footer-cta__content {
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding-inline: var(--sp-300-24);
  margin-block-end: var(--sp-800-64);
  color: var(--clr-neutral-0);

  @media (max-width: 600px) {
    padding-inline: 0;
    margin-block-end: var(--sp-800-64);
  }

  & h2 {
    text-align: center;
    color: var(--clr-neutral-0);
  }
}

.footer-cta__social-proof {
  display: flex;
  justify-content: center;
  align-items: center;
  min-height: 100%;
  gap: var(--sp-150-12);

  & .footer-cta__social-proof-image {
    max-width: 110px;
  }

  & .footer-cta__social-proof-stats {
    font-family: var(--ff-martian-mono);
    font-size: var(--fs-xs-14);
    line-height: 1.2;
    letter-spacing: -1px;
  }

  & .footer-cta__social-proof-star {
    display: inline-block;
    max-width: 24px;
  }
}

.footer-nav {
  color: var(--clr-neutral-0);
}

.footer-nav__container {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-block-start: var(--sp-300-24);
  border-top: 0.5px solid var(--clr-neutral-700);
  min-height: 100%;

  @media (max-width: 600px) {
    justify-content: center;
    flex-flow: row wrap;
    gap: var(--sp-200-16);
  }

  & .footer-nav__copywright {
    font-family: var(--ff-martian-mono);
    font-size: var(--fs-xs-14);
    line-height: 1.2;
    letter-spacing: -1px;
  }

  & .footer-nav__social-icons {
    display: flex;
    align-items: center;
    min-height: 100%;
  }

  & .footer-nav__social-icon {
    display: inline-block;
    padding-left: var(--sp-300-24);
    min-height: 24px;
  }

  & .footer-nav__social-icon:nth-child(1) {
    padding-left: 0;
  }
}
