@charset "UTF-8";

html{
  font-size: 10px;
}

html{
  font-size: calc(10 * (100vw / 1200));
}

body{
  overflow-x: clip;
}

.l-container{
  background: #eaead8;
  font-family: "the-seasons", sans-serif;
  font-weight: 400;
  margin: 0 auto;
  overflow: clip;
  width: 100%;
}
.l-container a{
  display: block;
  color: #fff;
  text-decoration: none;
  transition: opacity 1s;
}

.l-container a:hover{
  cursor: pointer;
  opacity: .6;
}

.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 #sp-only{
  display: none !important;
}

.feature{
  display: flex;
  width: 100%;

  opacity: 0;
  transition: opacity 1s;
}
.feature.loadOn{
  opacity: 1;
}

/*******************************
credit
*******************************/

.feature .creditList{
  display: flex;
  margin-top: calc(20 *(100vw / 2100) * 0.9);
  position: relative;
  width: fit-content;
  z-index: 2;
}

.feature .creditList .credit{
  display: flex;
  flex-wrap: wrap;
  gap: calc(22 *(100vw / 2100) * 0.9) calc(7 *(100vw / 2100) * 0.9);
}
.feature .creditList.center .credit{
  justify-content: center;
}

.feature .creditList .credit li{
  position: relative;
}

.feature .creditList .credit li.separator::after{
  content: "/";
  margin-left: calc(20 *(100vw / 1400) * 0.573);
}
.feature .creditList .credit li:last-of-type::after{
  content: none !important;
}

.feature .creditList .credit li,
.feature .creditList .credit a{
  color: #353535;
  display: flex;
  font-size: calc(22 *(100vw / 2100) * 0.9);
  letter-spacing: 0.08em;
  line-height: 1;
}

.feature .creditList .credit li .price{
  margin-left: calc(6 *(100vw / 2100) * 0.9);
}

.feature .credit01{
  margin: calc(40 *(100vw / 2100) * 0.9) auto 0;
  width: calc(500 *(100vw / 2100) * 0.9);
}
.feature .credit02{
  margin: calc(40 *(100vw / 2100) * 0.9) 0 0 calc(48 *(100vw / 2100) * 0.9);
}
.feature .credit03,.feature .credit04,
.feature .credit05{
  margin: calc(40 *(100vw / 2100) * 0.9) auto 0;
}

/*******************************
mv
*******************************/

.feature .mv{
  position: sticky;
  top: 80px;
  height: calc(100vh - 80px);
  width: calc(1050 *(100vw / 2100));
}

.feature .mv .inner{
  position: relative;
  height: 100%;
  width: 100%;
}

.feature .mv .mv__img{
  overflow: hidden;
  position: relative;
  height: 100%;
  width: 100%;
}
.feature .mv .mv__img > a{
  background: url(../img/mv.jpg) top center / cover no-repeat;
  height: 100%;
  width: 100%;
}

.feature .mv .mv__ttl{
  color: #fff;
  font-weight: 400;
  font-size: calc(38 *(100vw / 2100));
  letter-spacing: 0.08em;
  line-height: 1;
  margin: 0 auto;
  bottom: calc(62 *(100vw / 2100) * 0.9);
  left: calc(4 *(100vw / 2100) * 0.9);
  right: 0;
  position: absolute;
  width: fit-content;
}
.feature .mv .mv__ttl span{
  display: inline-block;
  font-size: calc(72 *(100vw / 2100));
  letter-spacing: 0.08em;
  margin: calc(26 *(100vw / 2100) * 0.9) 0 0 calc(175 *(100vw / 2100) * 0.9);
}

/*******************************
main
*******************************/

.feature .main{
  margin: calc(130 *(100vw / 2100) * 0.9) auto 0;
  padding-bottom: calc(200 *(100vw / 2100) * 0.9);
  position: relative;
  width: calc(1050 *(100vw / 2100));
}

/*******************************
container
*******************************/

.feature .sec{
  position: relative;
  margin: 0 auto;
  width: calc(675 *(100vw / 2100));
}

.feature .sec .inner{
  position: relative;
  width: 100%;
}

.feature .sec .sec__flex{
  display: flex;
}

.feature .sec .sec__item,
.feature .sec .sec__img{
  position: relative;
}

.feature .sec .sec__text{
  color: #353535;
  font-size: calc(26 *(100vw / 2100) * 0.9);
  letter-spacing: 0.08em;
  line-height: 1.75;
  margin: 0;
}

/*******************************
sec01
*******************************/

.feature .sec01{
  margin: 0 auto;
}

.feature .sec01 .sec__text{
  margin-left: calc(50 *(100vw / 2100) * 0.9);
  position: relative;
  z-index: 2;
}
.feature .sec01 .sec__text span:nth-of-type(35){
  margin-right: calc(220 *(100vw / 2100) * 0.9);
}

.feature .sec01 .img02{
  margin: calc(-20 *(100vw / 2100) * 0.9) 0 0 auto;
  width: calc(600 *(100vw / 2100) * 0.9);
}

.feature .sec01 .img03{
  margin: calc(100 *(100vw / 2100) * 0.9) 0 0 calc(50 *(100vw / 2100) * 0.9);
  width: calc(540 *(100vw / 2100) * 0.9);
}

.feature .sec01 .sec__slide{
  margin: calc(100 *(100vw / 2100) * 0.9) auto 0;
  width: 100%;
}

/*******************************
sec02
*******************************/

.feature .sec02{
  margin: calc(204 *(100vw / 2100) * 0.9) auto 0;
}

.feature .sec02 .img06{
  margin: 0 auto;
  width: calc(700 *(100vw / 2100) * 0.9);
}
.feature .sec02 .img07{
  margin: calc(100 *(100vw / 2100) * 0.9) 0 0 auto;
  width: calc(640 *(100vw / 2100) * 0.9);
}
.feature .sec02 .img08{
  margin-top: calc(100 *(100vw / 2100) * 0.9);
  width: calc(560 *(100vw / 2100) * 0.9);
}

/*******************************
sec03
*******************************/

.feature .sec03{
  margin: calc(202 *(100vw / 2100) * 0.9) auto 0;
}

.feature .sec03 .sec__item{
  margin: 0 auto;
  width: 100%;
}

.feature .sec03 .sec__text{
  color: #fff;
  font-size: calc(26 *(100vw / 2100) * 0.9);
  line-height: 1.5;
  position: absolute;
  bottom: calc(70 *(100vw / 2100) * 0.9);
  left: calc(50 *(100vw / 2100) * 0.9);
  width: calc(280 *(100vw / 2100) * 0.9);
  z-index: 2;
}
.feature .sec03 .sec__text span:nth-of-type(12){
  margin-right: calc(30 *(100vw / 2100) * 0.9);
}
.feature .sec03 .sec__text span:nth-of-type(39){
  margin-right: calc(100 *(100vw / 2100) * 0.9);
}

.feature .sec03 .img10{
  margin-top: calc(200 *(100vw / 2100) * 0.9);
  width: calc(660 *(100vw / 2100) * 0.9);
}
.feature .sec03 .img11{
  margin: calc(102 *(100vw / 2100) * 0.9) 0 0 auto;
  width: calc(500 *(100vw / 2100) * 0.9);
}
.feature .sec03 .img12{
  margin: calc(100 *(100vw / 2100) * 0.9) auto 0;
  width: calc(680 *(100vw / 2100) * 0.9);
}

/*******************************
sec04
*******************************/

.feature .sec04{
  margin: calc(202 *(100vw / 2100) * 0.9) auto 0;
}

.feature .sec04 .sec__text{
  margin: calc(90 *(100vw / 2100) * 0.9) auto 0;
  position: relative;
  text-align: center;
  z-index: 2;
}
.feature .sec04 .sec__text span:nth-of-type(1){
  margin-left: calc(140 *(100vw / 2100) * 0.9);
}
.feature .sec04 .sec__text span:nth-of-type(34){
  margin-right: calc(140 *(100vw / 2100) * 0.9);
}

.feature .sec04 .sec__slide{
  margin: 0 auto;
  width: calc(600 *(100vw / 2100) * 0.9);
}

.feature .sec04 .img15{
  margin: calc(40 *(100vw / 2100) * 0.9) auto 0;
  width: calc(600 *(100vw / 2100) * 0.9);
}
.feature .sec04 .img16{
  margin: calc(-20 *(100vw / 2100) * 0.9) auto 0;
  width: 100%;
}

.feature .sec04 .sec__btn{
  margin: calc(197 *(100vw / 2100) * 0.9) auto 0;
  padding-bottom: calc(25 *(100vw / 2100) * 0.9);
  position: relative;
  width: fit-content;
}
.feature .sec04 .sec__btn a{
  color: #353535;
  font-size: calc(34 *(100vw / 2100) * 0.9);
  letter-spacing: 0.08em;
  line-height: 1;
}
.feature .sec04 .sec__btn::before{
  background: #353535;
  content: "";
  margin: 0 auto;
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  transform: scale(0);
  transition: 2s;
  height: calc(2 *(100vw / 2100) * 0.9);
  width: calc(160 *(100vw / 2100) * 0.9);
}

.feature .sec04 .sec__btn[data-is-active="true"]::before{
  transform: scale(1);
}

/*******************************
fade
*******************************/

.feature [data-fade="fade"]{
  opacity: 0;
  transition: opacity 1s;
}
.feature [data-fade="fade"][data-is-active="true"]{
  opacity: 1;
}

.feature [data-scale="scale"]{
  overflow: hidden;
}
.feature [data-scale="scale"] img,
.feature .mv__img[data-scale="scale"] a{
  transform: scale(1.1);
  transition: transform 3s ease;
}
.feature [data-scale="scale"][data-is-active="true"] img,
.feature .mv__img[data-scale="scale"][data-is-active="true"] a{
  transform: scale(1);
}

.feature [data-clip="left"] .clip-target{
  clip-path: polygon(0 0, 0 0, 0 100%, 0% 100%);
  display: block;
  transition: clip-path 1s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
.feature [data-clip="right"] .clip-target{
  clip-path: polygon(100% 0, 100% 0, 100% 100%, 100% 100%);
  display: block;
  transition: clip-path 1s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
.feature [data-clip="left"][data-is-active="true"] .clip-target,
.feature [data-clip="right"][data-is-active="true"] .clip-target{
  clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%);
}

.feature [data-fade="text"] span{
  opacity: 0;
  transition: 1s ease-out;
}
.feature [data-fade="text"][data-is-active="true"] span{
  opacity: 1;
}

.feature .delay01{
  transition-delay: 2s !important;
}


@media screen and (min-width: 1400px){
}

.pc-footer{
  margin: 0;
}
.l-footer{
  padding: 0;
}