@charset "UTF-8";
.jsf {
  background-color: #191A39;
  font-feature-settings: "palt" on;
}

.jsf-inner {
  max-width: 1127px;
  width: 100%;
  margin-inline: auto;
  padding: 0 20px;
}

/* mv */
.jsf-mv .img-wrap {
  position: relative;
  max-width: 1087px;
  margin-inline: auto;
  width: 100%;
  height: auto;
  aspect-ratio: 1087/445;
}
.jsf-mv .img-wrap figure {
  position: absolute;
  top: 0;
  width: 43.6982520699%;
  height: 100%;
}
.jsf-mv .img-wrap figure:nth-child(1) {
  left: 0;
}
.jsf-mv .img-wrap figure:nth-child(2) {
  left: 50%;
  transform: translateX(-50%);
}
.jsf-mv .img-wrap figure:nth-child(3) {
  right: 0;
}
.jsf-mv .img-wrap img {
  clip-path: polygon(35.5789473684% 0, 100% 0, 64.4210526316% 100%, 0 100%);
  -o-object-fit: cover;
     object-fit: cover;
}

/* mv下タイトル */
.jsf-head {
  margin-top: 51px;
  display: flex;
  flex-direction: column;
  gap: 6px;
  text-align: center;
  color: #fff;
}
.jsf-head .sub-txt {
  font-size: 2.4rem;
  font-weight: 700;
  line-height: 1.4;
  letter-spacing: 0;
}
.jsf-head .main-txt {
  font-size: 4.8rem;
  font-weight: 900;
  line-height: 1.4;
  letter-spacing: 0;
}

/* logo */
.jsf-logo {
  margin-top: 108px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.jsf-logo img {
  max-width: 355px;
  margin-inline: auto;
}

/* contents */
.jsf-contents {
  margin-top: 107px;
  padding-bottom: 38px;
  max-width: 840px;
  margin-inline: auto;
  color: #fff;
}
.jsf-contents .ttl {
  font-size: 2.6rem;
  font-weight: 700;
  line-height: 1.6;
  letter-spacing: 0;
}
.jsf-contents .txt-wrap {
  margin-top: 42px;
}
.jsf-contents .txt {
  font-size: 1.6rem;
  font-weight: 400;
  line-height: 1.7;
  letter-spacing: 0.03em;
}
.jsf-contents .txt + .txt {
  margin-top: 1.6875em;
}

/* ページ下部 */
.jsf-foot .bg img {
  width: 100%;
  height: auto;
}
.jsf-foot .img-wrap {
  display: flex;
  gap: 0;
}
.jsf-foot .img-wrap figure {
  width: 33.3333333333%;
}
.jsf-foot .img-wrap img {
  width: 100%;
  height: auto;
  -o-object-fit: cover;
     object-fit: cover;
}

/* スマホ */
@media screen and (max-width: 767px) {
  .jsf-inner {
    padding: 0 10.6666666667%;
  }
  /* mv */
  .jsf-mv {
    margin: 0 calc(50% - 50vw);
  }
  .jsf-mv .img-wrap {
    aspect-ratio: 410/168;
    width: 109.3333333333%;
    left: 50%;
    transform: translateX(-50%);
  }
  .jsf-mv .img-wrap figure {
    width: 43.6585365854%;
  }
  .jsf-mv .img-wrap img {
    clip-path: polygon(35.5789473684% 0, 100% 0, 64.4210526316% 100%, 0 100%);
    -o-object-fit: cover;
       object-fit: cover;
  }
  /* mv下タイトル */
  .jsf-head {
    margin-top: 34px;
    display: flex;
    flex-direction: column;
    gap: 9px;
  }
  .jsf-head .sub-txt {
    font-size: clamp(1.3rem, 4vw, 1.5rem);
  }
  .jsf-head .main-txt {
    font-size: clamp(2.4rem, 8vw, 3rem);
  }
  /* logo */
  .jsf-logo {
    margin-top: 58px;
  }
  .jsf-logo img {
    max-width: 190px;
  }
  /* contents */
  .jsf-contents {
    margin-top: 60px;
    padding-bottom: 16px;
  }
  .jsf-contents .ttl {
    font-size: 1.8rem;
  }
  .jsf-contents .txt-wrap {
    margin-top: 34px;
  }
  .jsf-contents .txt {
    font-size: 1.5rem;
    line-height: 1.73;
  }
  .jsf-contents .txt + .txt {
    margin-top: 1.7333333333em;
  }
  /* ページ下部 */
  .jsf-foot .img-wrap figure {
    position: relative;
    width: 33.3333333333%;
    height: auto;
    aspect-ratio: 1/1;
    overflow: hidden;
  }
  .jsf-foot .img-wrap figure:nth-child(1) img {
    width: 160%;
  }
  .jsf-foot .img-wrap figure:nth-child(2) img, .jsf-foot .img-wrap figure:nth-child(3) img {
    width: 131.2%;
  }
  .jsf-foot .img-wrap img {
    position: absolute;
    top: 0;
    right: 0;
    width: 100%;
    height: 100%;
    max-width: none;
  }
}