@charset "UTF-8";

html{
  font-size: 10px;
}

html{
  font-size: calc(10 * (100vw / 1200));
}

body{
  overflow-x: clip;
}

.l-container{
  background: #fff8e9;
  color: #000;
  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;
}

/*******************************
credit
*******************************/

.feature .creditList{
  margin-top: calc(40 *(100vw / 1400) * 0.5866);
  position: relative;
  width: fit-content;
}

.feature .creditList .credit{
  display: flex;
  flex-direction: column;
  gap: calc(17.5 *(100vw / 1400) * 0.5866) 0;
}
.feature .creditList.end .credit{
  align-items: flex-end;
}
.feature .creditList.center .credit{
  align-items: center;
}

.feature .creditList .credit li{
  position: relative;
}

.feature .creditList .credit li,
.feature .creditList .credit a{
  color: #000;
  display: flex;
  font-feature-settings: "palt";
  font-family: "noto-sans-semicondensed", sans-serif;
  font-weight: 400;
  font-size: calc(21 *(100vw / 1400) * 0.5866);
  letter-spacing: 0.06em;
  line-height: 1;
}

.feature .creditList .credit li .price{
  margin-left: calc(6 *(100vw / 1400) * 0.5866);
}

.feature .credit01,
.feature .credit05{
  margin-left: calc(40 *(100vw / 1400) * 0.5866);
}
.feature .credit02,
.feature .credit04{
  margin: calc(40 *(100vw / 1400) * 0.5866) calc(40 *(100vw / 1400) * 0.5866) 0 auto;
}
.feature .credit03{
  margin: auto;
  position: absolute;
  top: calc(980 *(100vw / 1400) * 0.5866);
  left: 0;
  right: 0;
}
.feature .credit06{
  margin: calc(40 *(100vw / 1400) * 0.5866) auto 0;
}
.feature .credit07{
  margin: calc(40 *(100vw / 1400) * 0.5866) calc(34 *(100vw / 1400) * 0.5866) 0 auto;
}

/*******************************
mv
*******************************/

.feature .mv{
  margin: 0 auto;
  position: sticky;
  top: 80px;
  height: calc(100vh - 80px);
  width: calc(700 *(100vw / 1400));
}

.feature .mv .inner{
  height: 100%;
  width: 100%;
}

.feature .mv .mv__img{
  position: relative;
  height: 100%;
  width: 100%;
}
.feature .mv .mv__img a{
  height: 100%;
  width: 100%;
}
.feature .mv .mv__img a > img{
  object-fit: cover;
  object-position: 25% center;
  height: 100vh;
}

.feature .mv .mv__ttl{
  animation-delay: 1s !important;
  margin: auto;
  position: absolute;
  pointer-events: none;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  height: fit-content;
  width: calc(468 *(100vw / 1400));
}

/*******************************
main
*******************************/

.feature{
  display: flex;
}

.feature .main{
  margin: calc(108 *(100vw / 1400) * 0.5866) auto 0;
  position: relative;
  width: calc(700 *(100vw / 1400));
}

/*******************************
container
*******************************/

.feature .sec{
  position: relative;
  margin: auto;
  width: calc(440 *(100vw / 1400));
}

.feature .sec .sec__flex{
  display: flex;
}

.feature .sec .sec__img{
  position: relative;
}

.feature .sec .sec__img-ttl{
  margin: 0;
  position: absolute;
  z-index: 2;
}

.feature .sec .sec__text{
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 300;
  font-size: calc(24 *(100vw / 1400) * 0.5866);
  letter-spacing: 0.04em;
  line-height: 2;
  text-align: center;
  margin: 0 auto;
}

/*******************************
sec01
*******************************/

.feature .sec01{
  margin: 0 auto;
}

.feature .sec01 .img02{
  margin: calc(168 *(100vw / 1400) * 0.5866) auto 0;
  width: 100%;
}
.feature .sec01 .img03{
  margin: calc(60 *(100vw / 1400) * 0.5866) 0 0 calc(40 *(100vw / 1400) * 0.5866);
  width: calc(560 *(100vw / 1400) * 0.5866);
}

.feature .sec01 .img02 .sec__img-ttl{
  top: calc(-21 *(100vw / 1400) * 0.5866);
  left: calc(40 *(100vw / 1400) * 0.5866);
  width: calc(321.17 *(100vw / 1400) * 0.5866);
}
.feature .sec01 .img03 .sec__img-ttl{
  top: calc(32 *(100vw / 1400) * 0.5866);
  right: calc(30 *(100vw / 1400) * 0.5866);
  width: calc(38.55 *(100vw / 1400) * 0.5866);
}

/*******************************
sec02
*******************************/

.feature .sec02{
  margin: calc(179 *(100vw / 1400) * 0.5866) auto 0;
  padding-bottom: calc(110 *(100vw / 1400) * 0.5866);
}

.feature .sec02 .box01{
  margin: 0 0 0 auto;
  position: relative;
  width: calc(660 *(100vw / 1400) * 0.5866);
}
.feature .sec02 .slide01{
  margin: 0;
  width: 100%;
}

.feature .sec02 .box02{
  margin: calc(180 *(100vw / 1400) * 0.5866) auto 0;
  position: sticky;
  top: calc((100vh - 36vw) / 2);
  width: 100%;
}
.feature .sec02 .img05{
  width: 100%;
}
.feature .sec02 .img06{
  margin: calc(160 *(100vw / 1400) * 0.5866) auto 0;
  padding-bottom: calc(133 *(100vw / 1400) * 0.5866);
  width: calc(536 *(100vw / 1400) * 0.5866);
}

.feature .sec02 .box01 .sec__img-ttl{
  top: calc(32 *(100vw / 1400) * 0.5866);
  left: calc(-21 *(100vw / 1400) * 0.5866);
  width: calc(42.83 *(100vw / 1400) * 0.5866);
}
.feature .sec02 .img06 .sec__img-ttl{
  margin: auto;
  bottom: calc(154 *(100vw / 1400) * 0.5866);
  left: 0;
  right: 0;
  width: calc(302.87 *(100vw / 1400) * 0.5866);
}

/*******************************
sec03
*******************************/

.feature .sec03{
  margin: calc(180 *(100vw / 1400) * 0.5866) auto 0;
}

.feature .sec03 .img07{
  margin: 0 0 0 auto;
  width: calc(680 *(100vw / 1400) * 0.5866);
}
.feature .sec03 .img08{
  margin: calc(30 *(100vw / 1400) * 0.5866) 0 0 auto;
  width: calc(680 *(100vw / 1400) * 0.5866);
}

.feature .sec03 .img09{
  margin: calc(180 *(100vw / 1400) * 0.5866) calc(40 *(100vw / 1400) * 0.5866) 0 auto;
  width: calc(492 *(100vw / 1400) * 0.5866);
  z-index: 2;
}
.feature .sec03 .img10{
  margin-top: calc(-40 *(100vw / 1400) * 0.5866);
  width: calc(660 *(100vw / 1400) * 0.5866);
  z-index: 1;
}

.feature .sec03 .ttl01{
  left: calc(40 *(100vw / 1400) * 0.5866);
  margin: calc(30 *(100vw / 1400) * 0.5866) auto 0;
  position: relative;
  width: calc(512.08 *(100vw / 1400) * 0.5866);
}
.feature .sec03 .img09 .sec__img-ttl{
  top: calc(2 *(100vw / 1400) * 0.5866);
  left: calc(-72 *(100vw / 1400) * 0.5866);
  width: calc(42.83 *(100vw / 1400) * 0.5866);
}

/*******************************
sec04
*******************************/

.feature .sec04{
  margin: calc(180 *(100vw / 1400) * 0.5866) auto 0;
  padding-bottom: calc(80 *(100vw / 1400));
}

.feature .sec04 .box01{
  margin: 0 auto;
  position: relative;
  width: 100%;
}
.feature .sec04 .slide01{
  margin: 0;
  width: 100%;
}

.feature .sec04 .img12{
  margin-top: calc(178 *(100vw / 1400) * 0.5866);
  width: calc(552 *(100vw / 1400) * 0.5866);
}
.feature .sec04 .img13{
  margin: calc(66 *(100vw / 1400) * 0.5866) auto 0;
  width: calc(680 *(100vw / 1400) * 0.5866);
}

.feature .sec04 .box01 .sec__img-ttl{
  top: calc(337 *(100vw / 1400) * 0.5866);
  right: calc(30 *(100vw / 1400) * 0.5866);
  width: calc(42.83 *(100vw / 1400) * 0.5866);
}
.feature .sec04 .img13 .sec__img-ttl{
  top: calc(-20 *(100vw / 1400) * 0.5866);
  left: calc(30 *(100vw / 1400) * 0.5866);
  width: calc(309.59 *(100vw / 1400) * 0.5866);
}

.feature .sec04 .sec__btn{
  margin: calc(140 *(100vw / 1400) * 0.5866) auto 0;
  width: calc(480 *(100vw / 1400) * 0.5866);
}

.feature .sec04 .sec__staff{
  border-top: calc(1 *(100vw / 1400) * 0.5866) solid #808080;
  border-bottom: calc(1 *(100vw / 1400) * 0.5866) solid #808080;
  font-feature-settings: "palt";
  font-family: "noto-sans-semicondensed", sans-serif;
  font-weight: 400;
  font-size: calc(22 *(100vw / 1400) * 0.5866);
  letter-spacing: 0.06em;
  line-height: 1.8;
  margin: calc(140 *(100vw / 1400) * 0.5866) auto 0;
  padding: calc(28 *(100vw / 1400) * 0.5866) 0 calc(32 *(100vw / 1400) * 0.5866) calc(50 *(100vw / 1400) * 0.5866);
}

/*******************************
slick
*******************************/

.feature .sec__slide .slick-dots{
  box-sizing: border-box;
  bottom: calc(16 *(100vw / 1400) * 0.5866);
  left: calc(16 *(100vw / 1400) * 0.5866);
  display: flex;
  height: calc(20 *(100vw / 1400) * 0.5866);
}

.feature .sec__slide .slick-dots li{
  margin: 0;
  height: 100%;
  width: calc(20 *(100vw / 1400) * 0.5866);
}
.feature .sec__slide .slick-dots li button{
  box-sizing: border-box;
  padding: 0;
  height: calc(20 *(100vw / 1400) * 0.5866);
  width: calc(20 *(100vw / 1400) * 0.5866);
}
.feature .sec__slide .slick-dots li button::before{
  box-sizing: border-box;
  border-radius: 100%;
  border: calc(1 *(100vw / 1400) * 0.5866) solid #fff;
  content: "";
  margin: auto;
  opacity: 1;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  height: calc(10 *(100vw / 1400) * 0.5866);
  width: calc(10 *(100vw / 1400) * 0.5866);
}
.feature .sec__slide .slick-dots li.slick-active button::before{
  background: #fff;
}

/*******************************
fade
*******************************/

.feature [data-fade="fade"]{
  filter: blur(10px);
  opacity: 0;
  transform: scale(1.02);
}
.feature [data-fade="fade"][data-is-active="true"]{
  animation: fade 1s cubic-bezier(0.25, 0.46, 0.45, 0.94) forwards;
}

.feature [data-fade="text"] .js-text-list path{
  opacity: 0;
}
.feature [data-fade="text"][data-is-active="true"] .js-text-list path{
  opacity: 1;
}

.feature .delay01{
  transition-delay: 1s;
}

@keyframes fade{
  0% {filter: blur(10px); opacity: 0; transform: scale(1.02);}
  100% {filter: blur(0); opacity: 1; transform: scale(1);}
}

@media screen and (min-width: 1400px){

}

.pc-footer{
  margin: 0;
}
.l-footer{
  padding: 0;
}