@charset "UTF-8";
.l-container {
  width: 100%;
}

.feature {
  background: #fff;
  color: #000;
  font-family: "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", YuGothic, "Yu Gothic", "Open Sans", "メイリオ", sans-serif;
  font-feature-settings: "palt";
  font-weight: 400;
  font-style: normal;
  overflow: clip;
  position: relative;
  text-align: center;
  width: 100%;
}
.feature p {
  margin: 0;
}
.feature a {
  color: #000;
  text-decoration: none;
  transition: all 0.3s ease-in;
}
.feature a:hover {
  opacity: 0.6;
}
.feature a:has(> img) {
  display: block;
}
.feature img {
  height: auto;
  width: 100%;
}
.feature .js-inview {
  opacity: 0;
  transition: opacity 3s;
}
.feature .js-inview.is-active {
  opacity: 1;
}
.feature img,
.feature video {
  height: auto;
  width: 100%;
}
.feature p {
  margin: 0;
}
.feature .credit {
  display: flex;
  flex-wrap: wrap;
}
.feature .credit::after {
  content: "";
  width: 100%;
}
.feature .credit li {
  font-family: "neue-haas-grotesk-display", sans-serif;
  font-size: 1.1291460833vw;
  font-style: normal;
  font-weight: 500;
  letter-spacing: 0.02em;
  line-height: 1;
  margin: 0 0.8468595625vw 1.1291460833vw 0;
  white-space: nowrap;
}
@media screen and (min-width: 1418px) {
  .feature .credit li {
    font-size: 16px;
    margin: 0 12px 16px 0;
  }
}
.feature .credit__text {
  margin-right: 0.1411432604vw;
}
@media screen and (min-width: 1418px) {
  .feature .credit__text {
    margin-right: 2px;
  }
}
.feature .content__wrap {
  display: flex;
  position: relative;
  width: 100%;
}
.feature .content__left {
  position: relative;
  width: 50%;
}
.feature .content__left .hero {
  box-sizing: border-box;
  display: block;
  height: calc(100vh - 80px);
  position: sticky;
  top: 80px;
  left: 0;
  width: 100%;
}
.feature .content__left .hero img {
  display: block;
  height: 100%;
  object-fit: cover;
  object-position: center top;
  width: 100%;
}
.feature .content__left .hero .ttl {
  position: absolute;
  top: 5.9985885674vw;
  left: 8.962597036vw;
  width: 31.6160903317vw;
}
.feature .content__right {
  width: 50%;
}
.feature .content__right .inner {
  margin: 0 auto;
  padding-top: 57px;
  padding-bottom: 13.9731827805vw;
  width: 35.2858151023vw;
}
@media screen and (min-width: 1418px) {
  .feature .content__right .inner {
    padding-bottom: 198px;
    width: 500px;
  }
}
.feature .lead {
  margin-bottom: 5.0811573747vw;
}
@media screen and (min-width: 1418px) {
  .feature .lead {
    margin-bottom: 72px;
  }
}
.feature .lead__img {
  margin: 0 auto 3.105151729vw;
  width: 13.4086097389vw;
}
@media screen and (min-width: 1418px) {
  .feature .lead__img {
    margin-bottom: 44px;
    width: 190px;
  }
}
.feature .lead p {
  font-size: 1.1714890614vw;
  letter-spacing: 0.025em;
  line-height: 3.0345800988vw;
}
@media screen and (min-width: 1418px) {
  .feature .lead p {
    font-size: 16.6px;
    line-height: 43px;
  }
}
.feature .c__01 {
  margin-bottom: 6.7043048694vw;
  position: relative;
  width: 100%;
}
@media screen and (min-width: 1418px) {
  .feature .c__01 {
    margin-bottom: 95px;
  }
}
.feature .c__01 .num {
  position: absolute;
  top: -1.8348623853vw;
  left: 2.6817219478vw;
  width: 4.3048694425vw;
  z-index: 2;
}
@media screen and (min-width: 1418px) {
  .feature .c__01 .num {
    top: -26px;
    left: 38px;
    width: 61px;
  }
}
.feature .c__01_img01 {
  margin: 0 auto 3.7402964008vw;
  width: 32.9569513056vw;
}
@media screen and (min-width: 1418px) {
  .feature .c__01_img01 {
    margin-bottom: 53px;
    width: 467px;
  }
}
.feature .c__01_img02 {
  margin: 0 auto 2.4700070572vw 0;
  width: 28.2286520819vw;
}
@media screen and (min-width: 1418px) {
  .feature .c__01_img02 {
    margin-bottom: 35px;
    width: 400px;
  }
}
.feature .c__01_img03 {
  margin: 0 0 20.2540578687vw auto;
  position: relative;
  width: 24.488355681vw;
}
@media screen and (min-width: 1418px) {
  .feature .c__01_img03 {
    margin-bottom: 287px;
    width: 347px;
  }
}
.feature .c__01_img03 .txt {
  position: absolute;
  bottom: -14.2554693013vw;
  left: -9.9505998589vw;
  width: 23.9237826394vw;
}
@media screen and (min-width: 1418px) {
  .feature .c__01_img03 .txt {
    bottom: -202px;
    left: -141px;
    width: 339px;
  }
}
.feature .c__01_img03 .txt.js-inview {
  clip-path: inset(0 100% 0 0);
  transition: clip-path 1s ease 0.6s, opacity 0.2s ease 0.6s;
}
.feature .c__01_img03 .txt.js-inview.is-active {
  clip-path: inset(0);
}
.feature .c__01 .credit {
  margin: 0 auto 3.5285815102vw 1.9054340155vw;
}
@media screen and (min-width: 1418px) {
  .feature .c__01 .credit {
    margin: 0 auto 50px 27px;
  }
}
.feature .c__02 {
  margin-bottom: 5.857445307vw;
  position: relative;
}
@media screen and (min-width: 1418px) {
  .feature .c__02 {
    margin-bottom: 83px;
  }
}
.feature .c__02 .num {
  position: absolute;
  top: 0.6351446718vw;
  right: 3.1757233592vw;
  width: 5.2223006351vw;
  z-index: 2;
}
@media screen and (min-width: 1418px) {
  .feature .c__02 .num {
    top: 9px;
    right: 45px;
    width: 74px;
  }
}
.feature .c__02_img01 {
  margin: 0 auto 0.9174311927vw;
  width: 30.0635144672vw;
}
@media screen and (min-width: 1418px) {
  .feature .c__02_img01 {
    margin-bottom: 13px;
    width: 426px;
  }
}
.feature .c__02_img02 {
  margin: 0 auto 5.7163020466vw;
  position: relative;
  width: 30.1340860974vw;
}
@media screen and (min-width: 1418px) {
  .feature .c__02_img02 {
    margin-bottom: 81px;
    width: 427px;
  }
}
.feature .c__02_img02 .txt {
  position: absolute;
  right: -2.0465772759vw;
  bottom: -0.8468595625vw;
  width: 15.878616796vw;
}
@media screen and (min-width: 1418px) {
  .feature .c__02_img02 .txt {
    right: -29px;
    bottom: -12px;
    width: 225px;
  }
}
.feature .c__02_img02 .txt.js-inview {
  clip-path: inset(0 100% 0 0);
  transition: clip-path 1s ease 0.6s, opacity 0.2s ease 0.6s;
}
.feature .c__02_img02 .txt.js-inview.is-active {
  clip-path: inset(0);
}
.feature .c__02_img03 {
  margin-bottom: 2.399435427vw;
}
@media screen and (min-width: 1418px) {
  .feature .c__02_img03 {
    margin-bottom: 34px;
  }
}
.feature .c__02 .credit {
  justify-content: center;
}
.feature .c__02 .credit li {
  margin: 0 0.4234297812vw 1.1291460833vw;
}
@media screen and (min-width: 1418px) {
  .feature .c__02 .credit li {
    margin: 0 6px 16px;
  }
}
.feature .c__02 .credit li:nth-of-type(n+3) {
  order: 1;
}
.feature .c__03 {
  margin-bottom: 6.7748764996vw;
  position: relative;
}
@media screen and (min-width: 1418px) {
  .feature .c__03 {
    margin-bottom: 96px;
  }
}
.feature .c__03 .num {
  position: absolute;
  top: 0.1411432604vw;
  right: 0.9174311927vw;
  width: 5.1517290049vw;
}
@media screen and (min-width: 1418px) {
  .feature .c__03 .num {
    top: 2px;
    right: 13px;
    width: 73px;
  }
}
.feature .c__03_img01 {
  margin: 0 auto 3.8108680311vw 0;
  width: 28.2286520819vw;
}
@media screen and (min-width: 1418px) {
  .feature .c__03_img01 {
    margin-bottom: 54px;
    width: 400px;
  }
}
.feature .c__03_img02 {
  margin: 0 0 2.399435427vw auto;
  position: relative;
  width: 31.9689484827vw;
}
@media screen and (min-width: 1418px) {
  .feature .c__03_img02 {
    margin-bottom: 34px;
    width: 453px;
  }
}
.feature .c__03_img02 .txt {
  position: absolute;
  top: 1.3408609739vw;
  right: 1.1997177135vw;
  width: 10.7268877911vw;
}
@media screen and (min-width: 1418px) {
  .feature .c__03_img02 .txt {
    top: 19px;
    right: 17px;
    width: 152px;
  }
}
.feature .c__03_img02 .txt.js-inview {
  clip-path: inset(0 0 100% 0);
  transition: clip-path 1s ease 0.6s, opacity 0.2s ease 0.6s;
}
.feature .c__03_img02 .txt.js-inview.is-active {
  clip-path: inset(0);
}
.feature .c__03 .credit {
  margin: 0 0 5.857445307vw 3.3168666196vw;
  width: 28.9343683839vw;
}
@media screen and (min-width: 1418px) {
  .feature .c__03 .credit {
    margin: 0 0 83px 47px;
    width: 410px;
  }
}
.feature .c__04 {
  margin-bottom: 8.2568807339vw;
  position: relative;
}
@media screen and (min-width: 1418px) {
  .feature .c__04 {
    margin-bottom: 117px;
  }
}
.feature .c__04 .num {
  position: absolute;
  top: 34.5800988003vw;
  right: 2.6111503176vw;
  width: 5.3634438956vw;
  z-index: 2;
}
@media screen and (min-width: 1418px) {
  .feature .c__04 .num {
    top: 490px;
    right: 37px;
    width: 76px;
  }
}
.feature .c__04_img01 {
  margin: 0 auto 3.7402964008vw;
  width: 31.9689484827vw;
}
@media screen and (min-width: 1418px) {
  .feature .c__04_img01 {
    margin-bottom: 53px;
    width: 453px;
  }
}
.feature .c__04_img02 {
  margin: 0 0 4.2342978123vw auto;
  position: relative;
  width: 24.488355681vw;
}
@media screen and (min-width: 1418px) {
  .feature .c__04_img02 {
    margin-bottom: 60px;
    width: 347px;
  }
}
.feature .c__04_img02 .txt {
  position: absolute;
  bottom: -1.1291460833vw;
  left: -9.7388849682vw;
  width: 24.3472124206vw;
}
@media screen and (min-width: 1418px) {
  .feature .c__04_img02 .txt {
    bottom: -16px;
    left: -138px;
    width: 345px;
  }
}
.feature .c__04_img02 .txt.js-inview {
  clip-path: inset(0 100% 0 0);
  transition: clip-path 1s ease 0.6s, opacity 0.2s ease 0.6s;
}
.feature .c__04_img02 .txt.js-inview.is-active {
  clip-path: inset(0);
}
.feature .c__04_img03 {
  margin: 0 auto 2.399435427vw 0;
  width: 30.1340860974vw;
}
@media screen and (min-width: 1418px) {
  .feature .c__04_img03 {
    margin-bottom: 34px;
    width: 427px;
  }
}
.feature .c__04 .credit {
  margin-left: 1.9054340155vw;
  width: 27.5229357798vw;
}
@media screen and (min-width: 1418px) {
  .feature .c__04 .credit {
    margin-left: 27px;
    width: 390px;
  }
}
.feature .btn {
  margin-bottom: 9.8800282287vw;
}
@media screen and (min-width: 1418px) {
  .feature .btn {
    margin-bottom: 140px;
  }
}
.feature .btn a {
  margin: 0 auto 1.4114326041vw;
  width: 31.7572335921vw;
}
@media screen and (min-width: 1418px) {
  .feature .btn a {
    margin-bottom: 20px;
    width: 450px;
  }
}
.feature .btn a:last-of-type {
  margin-bottom: 0;
}
.feature .staff .cap {
  font-family: "neue-haas-grotesk-display", sans-serif;
  font-size: 1.2702893437vw;
  font-weight: 600;
  letter-spacing: 0.15em;
  line-height: 1;
  margin-bottom: 0.8468595625vw;
}
@media screen and (min-width: 1418px) {
  .feature .staff .cap {
    font-size: 18px;
    margin-bottom: 12px;
  }
}
.feature .staff .credits {
  font-family: "neue-haas-grotesk-display", sans-serif;
  font-size: 1.1079745942vw;
  font-weight: 500;
  letter-spacing: 0.03em;
  line-height: 2.2582921665vw;
}
@media screen and (min-width: 1418px) {
  .feature .staff .credits {
    font-size: 15.7px;
    line-height: 32px;
  }
}
.feature .staff .credits span {
  margin: 0 0.352858151vw;
}
@media screen and (min-width: 1418px) {
  .feature .staff .credits span {
    margin: 0 5px;
  }
}

.l-footer {
  padding-top: 0;
}
.l-footer .pc-footer {
  margin-top: 0;
}