@charset "UTF-8";

html{
  font-size: 10px;
}

html{
  font-size: calc(10 * (100vw / 1200));
}

body{
  overflow-x: clip;
}

.l-container{
  color: #000;
  font-feature-settings: "palt";
  font-family: "yu-gothic-pr6n", 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{
  background: #f7f3e2;
  display: flex;
  transition: background 1s;
  width: 100%;
}
.feature.purple {
  background: #dfe1f3;
}

/*******************************
credit
*******************************/

.feature .creditList{
  display: flex;
  margin-top: calc(20 *(100vw / 1400) * 0.68);
  position: relative;
  width: fit-content;
  z-index: 2;
}

.feature .creditList .credit{
  display: flex;
  flex-wrap: wrap;
  gap: calc(22 *(100vw / 1400) * 0.68) calc(26 *(100vw / 1400) * 0.68);
  justify-content: center;
}

.feature .creditList .credit li{
  position: relative;
  text-decoration: underline;
  text-decoration-skip-ink: none;
}

.feature .creditList .credit li,
.feature .creditList .credit a{
  color: #9b3139;
  display: flex;
  font-family: "acumin-pro", sans-serif;
  font-weight: 300;
  font-size: calc(22 *(100vw / 1400) * 0.68);
  letter-spacing: 0.03em;
  line-height: 1;
}

.feature .creditList .credit li .price{
  letter-spacing: 0.05em;
}
.feature .creditList .credit li .price::before{
  content: "\0A0";
}

.feature .credit01,.feature .credit02,
.feature .credit04,.feature .credit05{
  margin: calc(33 *(100vw / 1400) * 0.68) auto 0;
  width: calc(600 *(100vw / 1400) * 0.68);
}
.feature .credit01 li:nth-of-type(1),
.feature .credit02 li:nth-of-type(1),
.feature .credit04 li:nth-of-type(1),
.feature .credit05 li:nth-of-type(1){
  margin: 0 18%;
}

.feature .credit03,
.feature .credit06{
  margin: calc(54 *(100vw / 1400) * 0.68) auto 0;
}

/*******************************
left right
*******************************/

.feature .left,
.feature .right{
  width: calc((100% - calc(510 *(100vw / 1400))) / 2);
}

.feature .left .inner,
.feature .right .inner{
  align-items: center;
  display: flex;
  justify-content: center;
  position: sticky;
  top: 80px;
  height: calc(100vh - 80px);
  width: 100%;
}

.feature .left .left__ttl{
  color: #9b3139;
  font-family: "ambroise-std", serif;
  font-weight: 400;
  font-size: calc(45 *(100vw / 1400));
  line-height: 1.2;
  letter-spacing: 0.075em;
  text-align: center;
  height: fit-content;
  width: fit-content;
}
.feature .left .left__ttl span{
  display: block;
  font-size: calc(20 *(100vw / 1400));
  letter-spacing: 0.05em;
  margin-bottom: calc(-49 *(100vw / 1400));
}

.feature .right .right__btn{
  height: fit-content;
}
.feature .right .right__btn a{
  color: #9b3139;
  font-family: "ambroise-std", serif;
  font-weight: 400;
  font-size: calc(28 *(100vw / 1400));
  letter-spacing: 0.05em;
  line-height: 1;
  padding-left: calc(30 *(100vw / 1400));
  position: relative;
}
.feature .right .right__btn a::before{
  background: #9b3139;
  clip-path: polygon(100% 50%, 0 0, 0 100%);
  content: "";
  display: block;
  margin: auto;
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  height: calc(12 *(100vw / 1400));
  width: calc(8 *(100vw / 1400));
}

/*******************************
mv
*******************************/

.feature .mv{
  background: #fbf7f1;
  padding-bottom: calc(90 *(100vw / 1400) * 0.68);
  position: relative;
  width: 100%;
}

.feature .mv .inner{
  position: relative;
  height: 100%;
  width: 100%;
}

.feature .mv .mv__img{
  width: 100%;
}

.feature .mv .mv__ttl{
  margin: 0 auto;
  position: absolute;
  top: calc(53 *(100vw / 1400) * 0.68);
  left: 0;
  right: 0;
  text-align: center;
  width: fit-content;
  z-index: 2;
}
.feature .mv .mv__ttl h2{
  color: #9b3139;
  font-family: "ambroise-std", serif;
  font-weight: 400;
  font-size: calc(84 *(100vw / 1400) * 0.68);
  letter-spacing: 0.05em;
  line-height: 1;
}
.feature .mv .mv__ttl h2 span{
  display: inline-block;
  font-size: calc(50 *(100vw / 1400) * 0.68);
  letter-spacing: 0.025em;
  margin-bottom: calc(18 *(100vw / 1400) * 0.68);
}
.feature .mv .mv__ttl p{
  font-weight: 400;
  font-size: calc(26 *(100vw / 1400) * 0.68);
  letter-spacing: 0.05em;
  line-height: 1;
  margin: calc(43 *(100vw / 1400) * 0.68) auto 0;
}

.feature .mv .mv__day{
  border-top: calc(2 *(100vw / 1400) * 0.68) solid #9b315c;
  border-bottom: calc(2 *(100vw / 1400) * 0.68) solid #9b315c;
  color: #9b3139;
  margin: calc(91 *(100vw / 1400) * 0.68) auto 0;
  padding-bottom: calc(36 *(100vw / 1400) * 0.68);
}

.feature .mv .mv__text{
  line-height: 1;
  position: relative;
  text-align: center;
}
.feature .mv .mv__text.text01{
  background: #fbf7f1;
  font-family: "ambroise-std", serif;
  font-weight: 300;
  font-size: calc(26 *(100vw / 1400) * 0.68);
  letter-spacing: 0.04em;
  margin: calc(-12 *(100vw / 1400) * 0.68) auto 0;
  padding: 0 calc(10 *(100vw / 1400) * 0.68);
  width: fit-content;
}
.feature .mv .mv__text.text02{
  font-family: "cormorant-infant", sans-serif;
  font-weight: 500;
  font-size: calc(40 *(100vw / 1400) * 0.68);
  letter-spacing: 0.05em;
  margin: calc(32 *(100vw / 1400) * 0.68) auto 0;
}
.feature .mv .mv__text.text02 span{
  font-size: calc(28 *(100vw / 1400) * 0.68);
  letter-spacing: 0.05em;
  margin-right: calc(10 *(100vw / 1400) * 0.68);
}
.feature .mv .mv__text.text03{
  font-size: calc(22 *(100vw / 1400) * 0.68);
  letter-spacing: 0.05em;
  margin: calc(22 *(100vw / 1400) * 0.68) auto 0;
}
.feature .mv .mv__text.text04{
  color: #000;
  font-size: calc(22 *(100vw / 1400) * 0.68);
  letter-spacing: 0.05em;
  margin: 0 auto;
  bottom: calc(-54 *(100vw / 1400) * 0.68);
  left: 0;
  right: 0;
  position: absolute;
}

/*******************************
main
*******************************/

.feature .main{
  background: #fbf7f1;
  margin: 0 auto;
  position: relative;
  width: calc(510 *(100vw / 1400));
}

/*******************************
container
*******************************/

.feature .sec{
  position: relative;
  margin: 0 auto;
  width: 100%;
}

.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__ttl{
  color: #9b3139;
  font-family: "ambroise-std", serif;
  font-weight: 400;
  font-size: calc(84 *(100vw / 1400) * 0.68);
  letter-spacing: 0.05em;
  line-height: 1;
  margin: 0 auto;
  text-align: center;
}
.feature .sec .sec__ttl span{
  display: inline-block;
  font-size: calc(40 *(100vw / 1400) * 0.68);
  letter-spacing: 0.025em;
  margin-bottom: calc(23 *(100vw / 1400) * 0.68);
}

/*******************************
sec01
*******************************/

.feature .sec01{
  background: #fbf7f1;
  padding: calc(100 *(100vw / 1400) * 0.68) 0;
}

.feature .sec01 .img01{
  margin: calc(104 *(100vw / 1400) * 0.68) auto 0;
  width: calc(540 *(100vw / 1400) * 0.68);
}

.feature .sec01 .img02{
  margin: calc(50 *(100vw / 1400) * 0.68) auto 0;
  width: calc(680 *(100vw / 1400) * 0.68);
}

.feature .sec01 .sec__slide{
  margin: calc(100 *(100vw / 1400) * 0.68) auto 0;
  width: 100%;
}

/*******************************
sec02
*******************************/

.feature .sec02{
  background: #fbf7f1;
  padding: calc(122 *(100vw / 1400) * 0.68) 0 calc(158 *(100vw / 1400) * 0.68);
  position: sticky;
  top: 0;
  z-index: 2;
}

.feature .sec02 .flex01{
  justify-content: space-between;
  margin: calc(160 *(100vw / 1400) * 0.68) auto 0;
  width: calc(700 *(100vw / 1400) * 0.68);
}

.feature .sec02 .img03{
  margin: 0 0 0 auto;
  width: calc(620 *(100vw / 1400) * 0.68);
}
.feature .sec02 .img04{
  margin-top: calc(140 *(100vw / 1400) * 0.68);
  width: calc(660 *(100vw / 1400) * 0.68);
}
.feature .sec02 .img05{
  margin-top: calc(30 *(100vw / 1400) * 0.68);
  width: calc(660 *(100vw / 1400) * 0.68);
}
.feature .sec02 .img06{
  width: calc(220 *(100vw / 1400) * 0.68);
}

.feature .sec02 .sec__text{
  color: #9b3139;
  font-family: "ambroise-std", serif;
  font-weight: 300;
  font-size: calc(40 *(100vw / 1400) * 0.68);
  letter-spacing: 0.05em;
  line-height: 1;
  margin: 0;
  position: absolute;
  transform: rotate(90deg);
  transform-origin: right;
}
.feature .sec02 .sec__text.text01{
  top: calc(1292 *(100vw / 1400) * 0.68);
  right: calc(56 *(100vw / 1400) * 0.68);
}
.feature .sec02 .sec__text.text02{
  top: calc(1766 *(100vw / 1400) * 0.68);
  right: calc(48 *(100vw / 1400) * 0.68);
}
.feature .sec02 .sec__text.text03{
  top: calc(2602 *(100vw / 1400) * 0.68);
  right: calc(50 *(100vw / 1400) * 0.68);
}

/*******************************
sec03
*******************************/

.feature .sec03{
  background: #edeef8;
  padding: calc(79 *(100vw / 1400) * 0.68) 0 calc(100 *(100vw / 1400) * 0.68);
  position: sticky;
  z-index: 3;
}

.feature .sec03 .sec__ttl span{
  margin-bottom: calc(20 *(100vw / 1400) * 0.68);
}

.feature .sec03 .img07{
  margin: calc(105 *(100vw / 1400) * 0.68) 0 0 auto;
  width: calc(670 *(100vw / 1400) * 0.68);
}
.feature .sec03 .img08{
  margin-top: calc(102 *(100vw / 1400) * 0.68);
  width: calc(600 *(100vw / 1400) * 0.68);
}
.feature .sec03 .img09{
  margin: calc(50 *(100vw / 1400) * 0.68) auto 0;
  width: calc(600 *(100vw / 1400) * 0.68);
}

/*******************************
sec04
*******************************/

.feature .sec04{
  background: #edeef8;
  padding: calc(120 *(100vw / 1400) * 0.68) 0 calc(180 *(100vw / 1400) * 0.68);
  position: sticky;
  z-index: 3;
}

.feature .sec04 .sec__slide{
  margin: 0 auto;
  width: 100%;
}
.feature .sec04 .sec__flex{
  justify-content: space-between;
  margin: calc(156 *(100vw / 1400) * 0.68) auto 0;
  width: calc(640 *(100vw / 1400) * 0.68);
}

.feature .sec04 .img10{
  margin-right: calc(30 *(100vw / 1400) * 0.68);
  width: calc(600 *(100vw / 1400) * 0.68);
}
.feature .sec04 .img11{
  margin: calc(140 *(100vw / 1400) * 0.68) auto 0;
  width: 100%;
}
.feature .sec04 .img12{
  width: calc(200 *(100vw / 1400) * 0.68);
}

.feature .sec04 .sec__btn{
  background: #9b3139;
  margin: calc(178 *(100vw / 1400) * 0.68) auto 0;
  position: relative;
  width: calc(620 *(100vw / 1400) * 0.68);
}
.feature .sec04 .sec__btn a{
  align-items: center;
  box-sizing: border-box;
  color: #edeef8;
  display: flex;
  font-family: "ambroise-std", serif;
  font-weight: 400;
  font-size: calc(50 *(100vw / 1400) * 0.68);
  justify-content: center;
  letter-spacing: 0.05em;
  line-height: 1;
  height: calc(80 *(100vw / 1400) * 0.68);
  width: 100%;
}

/*******************************
fade
*******************************/

.feature [data-fade="fade"]{
  opacity: 0;
  transition: ease-in, opacity 2.5s, transform 1s, -webkit-transform 1s;
}
.feature [data-fade="fadeUP"]{
  opacity: 0;
  transform: translateY(8vw);
  transition: opacity 1.1s ease, transform 1.1s ease;
}
.feature [data-fade="fade"][data-is-active="true"],
.feature [data-fade="fadeUP"][data-is-active="true"]{
  opacity: 1;
  transform: translate(0);
}

.feature [data-fade="scale"]{
  overflow: hidden;
}
.feature [data-fade="scale"] img{
  opacity: 0;
  transform: scale(1.2);
  transition: transform 3s cubic-bezier(0.22, 0.61, 0.36, 1), opacity 3s cubic-bezier(0.22, 0.61, 0.36, 1);
}
.feature [data-fade="scale"][data-is-active="true"] img{
  opacity: 1;
  transform: scale(1);
}

.feature [data-fade="text"]{
  opacity: 0;
  transform: translateY(120px);
  transition: opacity 1s, transform 1s;
}
.feature [data-fade="text"][data-is-active="true"]{
  opacity: 1;
  transform: translateY(0);
}

.feature .delay01{
  transition-delay: 1s !important;
}


@media screen and (min-width: 1400px){
  /*******************************
  credit
  *******************************/

  .feature .creditList{
    margin-top: calc(20px * 0.68);
  }

  .feature .creditList .credit{
    gap: calc(22px * 0.68) calc(26px * 0.68);
  }

  .feature .creditList .credit li,
  .feature .creditList .credit a{
    font-size: calc(22px * 0.68);
  }

  .feature .credit01,.feature .credit02,
  .feature .credit04,.feature .credit05{
    margin: calc(33px * 0.68) auto 0;
    width: calc(600px * 0.68);
  }

  .feature .credit03,
  .feature .credit06{
    margin: calc(54px * 0.68) auto 0;
  }

  /*******************************
  left right
  *******************************/

  .feature .left,
  .feature .right{
    width: calc((100% - 510px) / 2);
  }

  .feature .left .left__ttl{
    font-size: 45px;
  }
  .feature .left .left__ttl span{
    font-size: 20px;
    margin-bottom: -49px;
  }

  .feature .right .right__btn a{
    font-size: 28px;
    padding-left: 30px;
  }
  .feature .right .right__btn a::before{
    height: 12px;
    width: 8px;
  }

  /*******************************
  mv
  *******************************/

  .feature .mv{
    padding-bottom: calc(90px * 0.68);
  }

  .feature .mv .mv__ttl{
    top: calc(53px * 0.68);
  }
  .feature .mv .mv__ttl h2{
    font-size: calc(84px * 0.68);
  }
  .feature .mv .mv__ttl h2 span{
    font-size: calc(50px * 0.68);
    margin-bottom: calc(18px * 0.68);
  }
  .feature .mv .mv__ttl p{
    font-size: calc(26px * 0.68);
    margin: calc(43px * 0.68) auto 0;
  }

  .feature .mv .mv__day{
    border-top: calc(2px * 0.68) solid #9b315c;
    border-bottom: calc(2px * 0.68) solid #9b315c;
    margin: calc(91px * 0.68) auto 0;
    padding-bottom: calc(36px * 0.68);
  }

  .feature .mv .mv__text.text01{
    font-size: calc(26px * 0.68);
    margin: calc(-12px * 0.68) auto 0;
    padding: 0 calc(10px * 0.68);
  }
  .feature .mv .mv__text.text02{
    font-size: calc(40px * 0.68);
    margin: calc(32px * 0.68) auto 0;
  }
  .feature .mv .mv__text.text02 span{
    font-size: calc(28px * 0.68);
    margin-right: calc(10px * 0.68);
  }
  .feature .mv .mv__text.text03{
    font-size: calc(22px * 0.68);
    margin: calc(22px * 0.68) auto 0;
  }
  .feature .mv .mv__text.text04{
    font-size: calc(22px * 0.68);
    bottom: calc(-54px * 0.68);
  }

  /*******************************
  main
  *******************************/

  .feature .main{
    width: calc(510px);
  }

  /*******************************
  container
  *******************************/

  .feature .sec .sec__ttl{
    font-size: calc(84px * 0.68);
  }
  .feature .sec .sec__ttl span{
    font-size: calc(40px * 0.68);
    margin-bottom: calc(23px * 0.68);
  }

  /*******************************
  sec01
  *******************************/

  .feature .sec01{
    padding: calc(100px * 0.68) 0;
  }

  .feature .sec01 .img01{
    margin: calc(104px * 0.68) auto 0;
    width: calc(540px * 0.68);
  }

  .feature .sec01 .img02{
    margin: calc(50px * 0.68) auto 0;
    width: calc(680px * 0.68);
  }

  .feature .sec01 .sec__slide{
    margin: calc(100px * 0.68) auto 0;
  }

  /*******************************
  sec02
  *******************************/

  .feature .sec02{
    padding: calc(122px * 0.68) 0 calc(158px * 0.68);
  }

  .feature .sec02 .flex01{
    margin: calc(160px * 0.68) auto 0;
    width: calc(700px * 0.68);
  }

  .feature .sec02 .img03{
    width: calc(620px * 0.68);
  }
  .feature .sec02 .img04{
    margin-top: calc(140px * 0.68);
    width: calc(660px * 0.68);
  }
  .feature .sec02 .img05{
    margin-top: calc(30px * 0.68);
    width: calc(660px * 0.68);
  }
  .feature .sec02 .img06{
    width: calc(220px * 0.68);
  }

  .feature .sec02 .sec__text{
    font-size: calc(40px * 0.68);
  }
  .feature .sec02 .sec__text.text01{
    top: calc(1292px * 0.68);
    right: calc(56px * 0.68);
  }
  .feature .sec02 .sec__text.text02{
    top: calc(1766px * 0.68);
    right: calc(48px * 0.68);
  }
  .feature .sec02 .sec__text.text03{
    top: calc(2602px * 0.68);
    right: calc(50px * 0.68);
  }

  /*******************************
  sec03
  *******************************/

  .feature .sec03{
    padding: calc(79px * 0.68) 0 calc(100px * 0.68);
  }

  .feature .sec03 .sec__ttl span{
    margin-bottom: calc(20px * 0.68);
  }

  .feature .sec03 .img07{
    margin: calc(105px * 0.68) 0 0 auto;
    width: calc(670px * 0.68);
  }
  .feature .sec03 .img08{
    margin-top: calc(102px * 0.68);
    width: calc(600px * 0.68);
  }
  .feature .sec03 .img09{
    margin: calc(50px * 0.68) auto 0;
    width: calc(600px * 0.68);
  }

  /*******************************
  sec04
  *******************************/

  .feature .sec04{
    padding: calc(120px * 0.68) 0 calc(180px * 0.68);
  }

  .feature .sec04 .sec__flex{
    margin: calc(156px * 0.68) auto 0;
    width: calc(640px * 0.68);
  }

  .feature .sec04 .img10{
    margin-right: calc(30px * 0.68);
    width: calc(600px * 0.68);
  }
  .feature .sec04 .img11{
    margin: calc(140px * 0.68) auto 0;
  }
  .feature .sec04 .img12{
    width: calc(200px * 0.68);
  }

  .feature .sec04 .sec__btn{
    margin: calc(178px * 0.68) auto 0;
    width: calc(620px * 0.68);
  }
  .feature .sec04 .sec__btn a{
    font-size: calc(50px * 0.68);
    height: calc(80px * 0.68);
  }
}

.pc-footer{
  margin: 0;
}
.l-footer{
  padding: 0;
}