body {
  font-family: "Noto Sans JP", sans-serif;
}
:root {
  --comp-w: 375;
  /* units */
  --rem: calc(1rem / 16);
  --vw: calc(min(100vw) / var(--comp-w));
  --vh: calc(100vh / var(--comp-h));
  --vh: calc(100dvh / var(--comp-h));
  --lvh: calc(100lvh / var(--comp-h));
  @media screen and (min-width: 769px) {
    --comp-w: 1512;
    --max-w: 1100px;
    /* --vw: min(calc(100vw / var(--comp-w)), 0.0625rem); */
  }
}
.only-sp {
  @media screen and (min-width: 769px) {
    display: none !important;
  }
}

.only-pc {
  @media screen and (max-width: 768px) {
    display: none !important;
  }
}

:where(.nexturn) {
  .popup {
    position: fixed;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: -1;
    &.is-shown {
      z-index: 1000;
      .popup__overlay, .popup__inner {
        opacity: 1;
      }
    }
  }
  .popup__overlay {
    background: rgba(0, 0, 0, 0.7);
    width: 100vw;
    height: 120vh;
    transition: opacity 0.2s linear;
    opacity: 0;
  }
  .popup__content {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
  }
  .popup__inner {
    display: block;
    width: calc(var(--vw) * 600);
    transition: opacity 0.2s linear;
    opacity: 0;
    @media screen and (max-width: 768px) {
      width: calc(var(--vw) * 270);
    }
    &:hover {
      opacity: 1;
    }
  }
  .popup__close {
    cursor: pointer;
    right: calc(var(--vw) * 0);
    top: calc(var(--vw) * -30);
    position: absolute;
    width: calc(var(--vw) * 15);
    @media screen and (min-width: 767px) {
      right: calc(var(--vw) * -55);
      width: calc(var(--vw) * 20);
      top: calc(var(--vw) * -35);
    }
  }

  .section-5 {
    overflow-x: scroll;
    img {
      padding-left: 20px;
      width: calc(var(--vw) * 785);
    }
  }
  .section-5 {
    @media screen and (max-width: 768px) {
      padding-top: calc(var(--vw) * 10);
    }
    img {
      @media screen and (max-width: 768px) {
        padding-bottom: calc(var(--vw) * 40);
      }
    }
  }
  .section-6-cta {
    position: relative;
    .section-6-cta-link {
      position: absolute;
      bottom: calc(var(--vw) * 120);
      width: calc(var(--vw) * 350);
      right: 0;
      left: 0;
      margin: 0 auto;
      @media screen and (max-width: 768px) {
        width: calc(var(--vw) * 252);
        bottom: calc(var(--vw) * 88);
      }
    }
  }
  .section-8 {
    display: flex;
    @media screen and (min-width: 767px) {
      gap: calc(var(--vw) * 45);
      margin-bottom: calc(var(--vw) * 60);
    }
    @media screen and (max-width: 768px) {
      flex-direction: column;
      margin-bottom: calc(var(--vw) * 55);
    }
  }
  .section-8-title {
    @media screen and (min-width: 767px) {
      width: calc(var(--vw) * 621);
    }
  }
  .section-8-list {
    display: flex;
    overflow-x: scroll;
    gap: calc(var(--vw) * 25);
    @media screen and (max-width: 768px) {
      gap: calc(var(--vw) * 10);
      padding-left: calc(var(--vw) * 26);
    }
    li {
      flex-shrink: 0;
      width: calc(var(--vw) * 450);
      @media screen and (max-width: 768px) {
        width: calc(var(--vw) * 335);
      }
    }
  }
  .section-10 {
    position: relative;
    .section-10-cta-link {
      position: absolute;
      bottom: calc(var(--vw) * 56);
      width: calc(var(--vw) * 350);
      right: 0;
      left: 0;
      margin: 0 auto;
      @media screen and (max-width: 768px) {
        width: calc(var(--vw) * 280);
        bottom: calc(var(--vw) * 72);
      }
    }
  }
}

.footer {
  font-weight: bold;
  color: #FFF;
  background: #121212;
  padding: 50px 22px;
  @media screen and (min-width: 769px) {
    padding: 80px 118px 80px 70px;
    letter-spacing: 0.7px;
    font-size: calc(var(--rem) * 14);
  }
  .logo {
    width: 165px;
    @media screen and (max-width: 768px) {
      width: 110px;
    }
  }
}
.footer__innner {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  margin-bottom: 170px;
  @media screen and (min-width: 769px) {
    margin-bottom: 174px;
  }
}
.footer__menu {
  display: flex;
  @media screen and (min-width: 769px) {
    gap: 90px;
    font-size: calc(var(--rem) * 16);
    letter-spacing: 0.8px;
  }
  @media screen and (max-width: 768px) {
    gap: 11px;
    flex-direction: column;
    font-size: calc(var(--rem) * 12);
    letter-spacing: 0.6px;
  }
}
.footer__list {
  display: flex;
  flex-direction: column;
  gap: 11px;
  @media screen and (min-width: 769px) {
    gap: 10px;
  }
}
.footer__line {
  width: calc(var(--vw) * 125);
  margin-top: 30px;
  @media screen and (min-width: 769px) {
    margin-top: 50px;
    width: calc(var(--vw) * 500);
  }
}
.footer__copyright {
  text-align: center;
  letter-spacing: 0.8px;
  font-size: calc(var(--rem) * 16);
  @media screen and (max-width: 768px) {
    letter-spacing: 0.6px;
    font-size: calc(var(--rem) * 12);
  }
}

.sticky {
  position: fixed;
  z-index: 100;
  display: flex;
  @media screen and (min-width: 769px) {
    flex-direction: column-reverse;
    gap: calc(var(--vw) * 15);
    right: 0;
    top: calc(var(--vw) * 115);
  }
  @media screen and (max-width: 768px) {
    justify-content: center;
    align-items: center;
    bottom: 0;
    width: 100vw;
  }
}
.sticky-cta {
  display: block;
  @media screen and (min-width: 769px) {
    width: calc(var(--vw) * 63);
  }
}