@charset "UTF-8";

html{
  font-size: 10px;
}

html{
  font-size: calc(10 * (100vw / 1200));
}

body{
  overflow-x: clip;
}

.l-container{
  background: #e3e3e3;
  color: #555;
  font-feature-settings: "palt";
  font-family: "yu-gothic-pr6n", sans-serif;
  font-family: "Yu Gothic", "游ゴシック", "YuGothic", "游ゴシック体", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN", sans-serif;
  font-weight: 500;
  font-style: normal;
  margin: 0 auto;
  width: 100%;
}
.l-container a{
  display: block;
  color: #fff;
  text-decoration: none;
  transition: opacity 0.4s;
}

.l-container a:hover{
  cursor: pointer;
}
/* .l-container #feature a::after{
  content: "";
  opacity: 0;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(255, 255, 255, 0.6);
  transition: all 0.4s;
} */
.l-container #feature a:hover{
  opacity: .7;
}

.l-container img{
  width: 100%;
  height: 100%;
  vertical-align: top;
}

.l-container .default-img{
  display: block;
  height: auto;
  width: 100%; 
}

.l-container .video__body{
  height: 100%;
  width: 100%;
}

.l-container .video__body--content{
  top: 0;
  left: 0;
  position: absolute;
  width: 100%;
  height: 100%;
}

.l-container .feature{
  display: flex;
  margin: 0 auto;
  width: 100%;
}

.l-container #sp-only{
  display: none !important;
}

/*******************************
credit
*******************************/

.l-container .creditList{
  margin: calc(38 *(100vw / 1400) * 0.6) auto 0;
  width: calc(660 *(100vw / 1400) * 0.6);
}

.l-container .creditList .credit{
  display: flex;
  flex-direction: column;
  gap: calc(12.5 *(100vw / 1400) * 0.6) 0;
}

.l-container .creditList .credit li{
  position: relative;
  width: fit-content;
}

.l-container .creditList .credit li,
.l-container .creditList .credit a{
  color: #555;
  font-size: calc(22 *(100vw / 1400) * 0.6);
  letter-spacing: 0.05em;
  line-height: 1.8;
}

/*******************************
mv
*******************************/

.feature .mv{
  position: sticky;
  top: 80px;
  transition: all 1.5s ease;
  height: calc(100vh - 80px);
  width: calc(700 *(100vw / 1400));
}

.feature .mv .inner{
  height: 100%;
}

.feature .mv__img{
  background: url(../img/mv.jpg) 100% 30% / cover no-repeat;
  height: 100%;
  width: 100%;
  z-index: 2;
}

.feature .mv__ttl{
  position: absolute;
  top: calc(128 *(100vw / 750));
  left: calc(22 *(100vw / 750));
  width: calc(246.1 *(100vw / 1400));
  z-index: 3;
}

/*******************************
hero
*******************************/

.feature .main{
  width: calc(700 *(100vw / 1400));
}

.feature .hero{
  margin: 0 auto;
  padding-top: calc(74 *(100vw / 1400));
  width: calc(450 *(100vw / 1400));
}

.feature .hero .hero__text{
  font-weight: 500;
  font-size: calc(24 *(100vw / 1400) * 0.6);
  letter-spacing: 0.1em;
  line-height: 2;
  margin: 0 auto;
  text-align: center;
}

/*******************************
container
*******************************/

.feature .sec{
  position: relative;
  margin: auto;
  width: calc(450 *(100vw / 1400));
}

.feature .sec .inner{
  margin: auto;
  position: relative;
  width: 100%;
}

.feature .sec .sec__flex{
  display: flex;
}

.feature .sec .sec__img{
  position: relative;
  margin: 0 auto;
  width: calc(660 *(100vw / 1400) * 0.6);
}

.feature .sec .sec__ttl{
  display: flex;
  margin: 0 auto;
  width: calc(660 *(100vw / 1400) * 0.6);
}

.feature .sec .sec__ttl-text{
  margin-top: calc(26 *(100vw / 1400) * 0.6);
}
.feature .sec .sec__ttl-en{
  font-family: "jaf-bernina-sans", sans-serif;
  font-weight: 400;
  font-size: calc(25 *(100vw / 1400) * 0.6);
  letter-spacing: 0.15em;
  line-height: 1;
  margin: 0;
}
.feature .sec .sec__ttl-ja{
  font-weight: 500;
  font-size: calc(41 *(100vw / 1400) * 0.6);
  letter-spacing: 0.18em;
  line-height: 1;
  margin: calc(26 *(100vw / 1400) * 0.6) 0 0;
}
.feature .sec .sec__ttl-line{
  background: #555;
  margin-top: calc(23 *(100vw / 1400) * 0.6);
  position: relative;
  height: calc(2 *(100vw / 1400) * 0.6);
  width: calc(465 *(100vw / 1400) * 0.6);
}

.feature .sec .sec__ttl-color{
  margin: 0 0 0 auto;
  width: calc(150 *(100vw / 1400) * 0.6);
}

/*******************************
sec01
*******************************/

.feature .sec01{
  margin: calc(164 *(100vw / 1400) * 0.6) auto 0;
}

.feature .sec01 .sec__slide{
  margin: calc(60 *(100vw / 1400) * 0.6) auto 0;
  width: calc(660 *(100vw / 1400) * 0.6);
}

.feature .sec01 .img02,
.feature .sec01 .img03{
  margin: calc(130 *(100vw / 1400) * 0.6) auto 0;
}

.feature .sec01 .sec__slide .slick-dots{
  display: flex;
  justify-content: space-between;
  bottom: calc(20 *(100vw / 1400) * 0.6);
  right: calc(30 *(100vw / 1400) * 0.6);
  height: calc(14 *(100vw / 1400) * 0.6);
  width: calc(38 *(100vw / 1400) * 0.6);
}
.feature .sec01 .sec__slide .slick-dots li{
  display: block;
  margin: 0;
  height: 100%;
  width: calc(14 *(100vw / 1400) * 0.6);
}
.feature .sec01 .sec__slide .slick-dots li button{
  box-sizing: border-box;
  padding: 0;
  height: 100%;
  width: 100%;
}
.feature .sec01 .sec__slide .slick-dots li button::before{
  border: calc(2 *(100vw / 1400) * 0.6) solid #fff;
  border-radius: 100%;
  box-sizing: border-box;
  content: "";
  opacity: 1;
  height: 100%;
  width: 100%;
}
.feature .sec01 .sec__slide .slick-dots li.slick-active button::before{
  background: #fff;
}

/*******************************
sec02
*******************************/

.feature .sec02{
  margin: calc(150 *(100vw / 1400) * 0.6) auto 0;
}

.feature .sec02 .img04{
  margin: calc(60 *(100vw / 1400) * 0.6) auto 0;
}
.feature .sec02 .img05{
  margin: calc(130 *(100vw / 1400) * 0.6) auto 0;
}

/*******************************
sec03
*******************************/

.feature .sec03{
  margin: calc(150 *(100vw / 1400) * 0.6) auto 0;
  padding-bottom: calc(110 *(100vw / 1400) * 0.6);
}

.feature .sec03 .img06{
  margin: calc(60 *(100vw / 1400) * 0.6) auto 0;
}
.feature .sec03 .img07{
  margin: calc(130 *(100vw / 1400) * 0.6) auto 0;
}

/*******************************
sec04
*******************************/

.feature .sec04{
  border-top: calc(1 *(100vw / 1400) * 0.6) solid #5e5e5e;
  padding: calc(100 *(100vw / 1400)) 0;
  width: 100%;
}

.feature .sec04 .sec__ttl{
  font-family: "jaf-bernina-sans", sans-serif;
  font-weight: 400;
  font-size: calc(40 *(100vw / 1400) * 0.6);
  letter-spacing: 0.18em;
  line-height: 1;
  margin: 0 auto;
  width: fit-content;
}

.feature .sec04 .sec__other{
  margin: calc(45 *(100vw / 1400) * 0.6) auto 0;
  width: calc(420 *(100vw / 1400) * 0.6);
}

.feature .sec04 .sec__name{
  font-size: calc(34 *(100vw / 1400) * 0.6);
  letter-spacing: 0.085em;
  line-height: 1;
  margin: calc(80 *(100vw / 1400) * 0.6) auto 0;
  text-align: center;
}
.feature .sec04 .sec__name span{
  font-size: calc(28 *(100vw / 1400) * 0.6);
}

.feature .sec04 .sec__text{
  font-size: calc(24 *(100vw / 1400) * 0.6);
  letter-spacing: 0.04em;
  line-height: 2;
  margin: calc(50 *(100vw / 1400) * 0.6) auto 0;
  text-align: justify;
  width: calc(640 *(100vw / 1400) * 0.6);
}

.feature .sec04 .sec__logo{
  margin: calc(126 *(100vw / 1400) * 0.6) auto 0;
  width: calc(399.35 *(100vw / 1400) * 0.6);
}

.feature .sec04 .sec__copyright{
  margin: calc(60 *(100vw / 1400) * 0.6) auto 0;
  width: calc(376 *(100vw / 1400) * 0.6);
}

.feature .sec04 .sec__btn{
  align-items: center;
  background: #555;
  box-sizing: border-box;
  display: flex;
  justify-content: center;
  margin: calc(62 *(100vw / 1400) * 0.6) auto 0;
  position: relative;
  height: calc(84 *(100vw / 1400) * 0.6);
  width: calc(640 *(100vw / 1400) * 0.6);
}
.feature .sec04 .sec__btn::before{
  background: url(../img/arrow.svg) top left / contain no-repeat;
  content: "";
  display: block;
  margin: auto;
  position: absolute;
  top: 0;
  bottom: 0;
  right: calc(198 *(100vw / 1400) * 0.6);
  height: calc(25.41 *(100vw / 1400) * 0.6);
  width: calc(14.12 *(100vw / 1400) * 0.6);
}
.feature .sec04 .sec__btn a{
  box-sizing: border-box;
  color: #fff;
  font-family: "jaf-bernina-sans", sans-serif;
  font-weight: 300;
  font-size: calc(32 *(100vw / 1400) * 0.6);
  letter-spacing: 0.03em;
  line-height: 1;
  padding-right: calc(34 *(100vw / 1400) * 0.6);
  height: fit-content;
  width: fit-content;
}

/*******************************
fade
*******************************/

.l-container #feature .target[data-fade="fade"]{
  opacity: 0;
  transform: translateY(4rem);
  transition: opacity 1.5s ease, transform 1.5s ease;
}
.l-container #feature .target[data-fade="fade"][data-is-active="true"]{
  opacity: 1;
  transform: translateY(0);
}

.l-container #feature .target[data-fade="fadeIn"]{
  opacity: 0;
  transition: opacity 1.2s 0.3s, transform 1.2s 0.3s, -webkit-transform 1.2s 0.3s;
}
.l-container #feature .target[data-fade="fadeIn"][data-is-active="true"]{
  opacity: 1;
}
.l-container #feature .delay{
  transition-delay: 0.9s !important;
}

.l-container #feature .target[data-fade="text"] .sec__ttl-line{
  -webkit-clip-path: inset(0 100% 0 0);
  clip-path: inset(0 100% 0 0);
  transition: -webkit-clip-path 1.8s;
  transition: clip-path 1.8s;
  transition: clip-path 1.8s, -webkit-clip-path 1.8s;
  transition-delay: 0.2s;
}
.l-container #feature .target[data-fade="text"][data-is-active="true"] .sec__ttl-line{
  -webkit-clip-path: inset(0);
  clip-path: inset(0);
}

@media screen and (min-width: 1400px){

/*******************************
credit
*******************************/

.l-container .creditList{
  margin: calc(38px * 0.6) auto 0;
  width: calc(660px * 0.6);
}

.l-container .creditList .credit{
  gap: calc(12.5px * 0.6) 0;
}

.l-container .creditList .credit li,
.l-container .creditList .credit a{
  font-size: calc(22px * 0.6);
}

  /*******************************
  hero
  *******************************/

  .feature .hero{
    padding-top: 74px;
    width: 450px;
  }

  .feature .hero .hero__text{
    font-size: calc(24px * 0.6);
  }

  /*******************************
  container
  *******************************/

  .feature .sec{
    width: 450px;
  }

  .feature .sec .sec__img{
    width: calc(660px * 0.6);
  }

  .feature .sec .sec__ttl{
    width: calc(660px * 0.6);
  }

  .feature .sec .sec__ttl-text{
    margin-top: calc(26px * 0.6);
  }
  .feature .sec .sec__ttl-en{
    font-size: calc(25px * 0.6);
  }
  .feature .sec .sec__ttl-ja{
    font-size: calc(41px * 0.6);
    margin: calc(26px * 0.6) 0 0;
  }
  .feature .sec .sec__ttl-line{
    margin-top: calc(23px * 0.6);
    height: calc(2px * 0.6);
    width: calc(465px * 0.6);
  }

  .feature .sec .sec__ttl-color{
    width: calc(150px * 0.6);
  }

  /*******************************
  sec01
  *******************************/

  .feature .sec01{
    margin: calc(164px * 0.6) auto 0;
  }

  .feature .sec01 .sec__slide{
    margin: calc(60px * 0.6) auto 0;
    width: calc(660px * 0.6);
  }

  .feature .sec01 .img02,
  .feature .sec01 .img03{
    margin: calc(130px * 0.6) auto 0;
  }

  .feature .sec01 .sec__slide .slick-dots{
    bottom: calc(20px * 0.6);
    right: calc(30px * 0.6);
    height: calc(14px * 0.6);
    width: calc(38px * 0.6);
  }
  .feature .sec01 .sec__slide .slick-dots li{
    width: calc(14px * 0.6);
  }
  .feature .sec01 .sec__slide .slick-dots li button::before{
    border: calc(2px * 0.6) solid #fff;
  }

  /*******************************
  sec02
  *******************************/

  .feature .sec02{
    margin: calc(150px * 0.6) auto 0;
  }

  .feature .sec02 .img04{
    margin: calc(60px * 0.6) auto 0;
  }
  .feature .sec02 .img05{
    margin: calc(130px * 0.6) auto 0;
  }

  /*******************************
  sec03
  *******************************/

  .feature .sec03{
    margin: calc(150px * 0.6) auto 0;
    padding-bottom: calc(110px * 0.6);
  }

  .feature .sec03 .img06{
    margin: calc(60px * 0.6) auto 0;
  }
  .feature .sec03 .img07{
    margin: calc(130px * 0.6) auto 0;
  }

  /*******************************
  sec04
  *******************************/

  .feature .sec04{
    border-top: calc(1px * 0.6) solid #5e5e5e;
    padding: 74px;
  }

  .feature .sec04 .sec__ttl{
    font-size: calc(40px * 0.6);
    width: fit-content;
  }

  .feature .sec04 .sec__other{
    margin: calc(45px * 0.6) auto 0;
    width: calc(420px * 0.6);
  }

  .feature .sec04 .sec__name{
    font-size: calc(34px * 0.6);
    margin: calc(80px * 0.6) auto 0;
  }
  .feature .sec04 .sec__name span{
    font-size: calc(28px * 0.6);
  }

  .feature .sec04 .sec__text{
    font-size: calc(24px * 0.6);
    margin: calc(50px * 0.6) auto 0;
    width: calc(640px * 0.6);
  }

  .feature .sec04 .sec__logo{
    margin: calc(126px * 0.6) auto 0;
    width: calc(399.35px * 0.6);
  }

  .feature .sec04 .sec__copyright{
    margin: calc(60px * 0.6) auto 0;
    width: calc(376px * 0.6);
  }

  .feature .sec04 .sec__btn{
    margin: calc(62px * 0.6) auto 0;
    height: calc(84px * 0.6);
    width: calc(640px * 0.6);
  }
  .feature .sec04 .sec__btn::before{
    right: calc(198px * 0.6);
    height: calc(25.41px * 0.6);
    width: calc(14.12px * 0.6);
  }
  .feature .sec04 .sec__btn a{
    font-size: calc(32px * 0.6);
    padding-right: calc(34px * 0.6);
  }
}

.pc-footer{
  margin: 0;
}
.l-footer{
  padding: 0;
}