@charset "UTF-8";

html{
  font-size: 10px;
}

html{
  font-size: calc(10 * (100vw / 1200));
}

body{
  overflow-x: clip;
}

.l-container{
  color: #000;
  font-family: "Zen Kaku Gothic Antique", sans-serif;
  font-weight: 300;
  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
*******************************/

.l-container .creditList{
  margin: calc(27 *(100vw / 1366) * 0.554) auto 0;
  position: relative;
  width: fit-content;
  z-index: 2;
}

.l-container .creditList .credit{
  align-items: center;
  display: flex;
  flex-wrap: wrap;
  flex-direction: column;
  gap: calc(15 *(100vw / 1366) * 0.554) 0;
}

.l-container .creditList .credit li{
  position: relative;
}

.l-container .creditList .credit li,
.l-container .creditList .credit a{
  color: #000;
  display: flex;
  font-family: "Roboto", sans-serif;
  font-weight: 300;
  font-style: italic;
  font-size: calc(20 *(100vw / 1366) * 0.554);
  letter-spacing: 0.004em;
  line-height: 1;
}
.l-container .creditList .credit li .price{
  margin-left: calc(5 *(100vw / 1366) * 0.554);
}

.l-container .credit03,
.l-container .credit04,
.l-container .credit05,
.l-container .credit06{
  margin: 0 auto;
  position: absolute;
  top: calc(941 *(100vw / 1366) * 0.554);
  left: 0;
  right: 0;
}
.l-container .credit04{
  top: calc(1026 *(100vw / 1366) * 0.554);
}
.l-container .credit05{
  top: calc(943 *(100vw / 1366) * 0.554);
}
.l-container .credit06{
  top: calc(943 *(100vw / 1366) * 0.554);
}
.l-container .credit07{
  margin: calc(24 *(100vw / 1366) * 0.554) auto 0;
}
.l-container .credit08{
  margin: calc(26 *(100vw / 1366) * 0.554) auto 0;
}

/*******************************
flex
*******************************/

.feature{
  display: flex;
  width: 100%;
}

/*******************************
mv
*******************************/

.feature .mv{
  position: sticky;
  top: 80px;
  height: fit-content;
  width: 50%;
}

.feature .mv .inner{
  position: relative;
}

.feature .mv .mv__img{
  width: 100%;
}

.feature .mv .mv__ttl{
  position: absolute;
  top: calc(44 *(100vw / 1366));
  left: calc(36 *(100vw / 1366));
  width: calc(284 *(100vw / 1366));
  z-index: 2;
}

/*******************************
lead
*******************************/

.feature .main{
  margin: calc(55 *(100vw / 1366) * 0.554) auto 0;
  width: 50%;
}

/*******************************
lead
*******************************/

.feature .lead{
  margin: 0 auto;
  position: relative;
  width: 100%;
}

.feature .lead .lead__text{
  font-size: calc(20 *(100vw / 1366) * 0.554);
  line-height: 2.2;
  margin: 0 auto;
  text-align: center;
}

/*******************************
container
*******************************/

.feature .sec{
  position: relative;
  margin: auto;
  width: calc(416 *(100vw / 1366));
}

.feature .sec .inner::before,
.feature .sec .inner::after{
  display: block;
  margin: auto;
  position: absolute;
  left: 0;
  width: 100%;
  z-index: 0;
}

.feature .sec .sec__flex{
  display: flex;
}

.feature .sec .sec__img{
  position: relative;
  z-index: 2;
}

.feature .sec .sec__text{
  font-size: calc(20 *(100vw / 1366) * 0.554);
  line-height: 2.2;
  margin: 0 auto;
  position: relative;
  text-align: center;
  z-index: 2;
}

/*******************************
sec01
*******************************/

.feature .sec01{
  background: #F4FAFC;
  margin: calc(180 *(100vw / 1366) * 0.554) auto 0;
  padding-bottom: calc(100 *(100vw / 1366) * 0.554);
}

.feature .sec01 .img01{
  width: 100%;
}

.feature .sec01 .img02{
  margin: calc(249 *(100vw / 1366) * 0.554) auto 0;
  width: calc(630 *(100vw / 1366) * 0.554);
}

.feature .sec01 .img03{
  margin: calc(20 *(100vw / 1366) * 0.554) auto 0;
  width: 100%;
}

/*******************************
sec02
*******************************/

.feature .sec02{
  margin: 0 auto;
  padding-bottom: calc(0 *(100vw / 1366) * 0.554);
}

.feature .sec02 .inner::before{
  background: #FCF4FB;
  content: "";
  top: 0;
  height: 70%;
}
.feature .sec02 .inner::after{
  background: #F5F1EA;
  content: "";
  bottom: 0;
  height: 24%;
}

.feature .sec02 .sec__text{
  margin: calc(16 *(100vw / 1366) * 0.554) auto 0;
}

.feature .sec02 .sec__box.box01{
  margin: 0 auto;
  position: relative;
  width: 100%;
}
.feature .sec02 .img04{
  margin: 0 auto;
  width: 100%;
  z-index: 1;
}
.feature .sec02 .img05,
.feature .sec02 .img06{
  margin: auto;
  position: absolute;
  top: calc(80 *(100vw / 1366) * 0.554);
  left: 0;
  right: 0;
  width: calc(630 *(100vw / 1366) * 0.554);
  z-index: 2;
}
.feature .sec02 .img05 > a{
  transform: rotate(-3deg);
}
.feature .sec02 .img06 > a{
  transform: rotate(3deg);
}

.feature .sec02 .img07{
  margin: calc(92 *(100vw / 1366) * 0.554) auto 0;
  width: calc(686 *(100vw / 1366) * 0.554);
}
.feature .sec02 .img08{
  margin: calc(20 *(100vw / 1366) * 0.554) auto 0;
  width: 100%;
}

/*******************************
sec03
*******************************/

.feature .sec03{
  padding: calc(268 *(100vw / 1366) * 0.554) 0 calc(210 *(100vw / 1366) * 0.554);
}

.feature .sec03 .inner::before{
  background: #F5F1EA;
  content: "";
  top: 0;
  height: 44%;
}
.feature .sec03 .inner::after{
  background: #F4FAFC;
  content: "";
  bottom: 0;
  height: 60%;
}

.feature .sec03 .img09{
  margin: 0 auto;
  width: calc(630 *(100vw / 1366) * 0.554);
}
.feature .sec03 .img09 > a{
  box-sizing: border-box;
  border: calc(6 *(100vw / 1366) * 0.554) solid #000;
  transform: rotate(-3deg);
}

.feature .sec03 .img10{
  margin: calc(66 *(100vw / 1366) * 0.554) auto 0;
  width: 100%;
}

.feature .sec03 .img11{
  margin: calc(20 *(100vw / 1366) * 0.554) auto 0;
  position: sticky;
  top: 80px;
  width: calc(686 *(100vw / 1366) * 0.554);
}
.feature .sec03 .sec__box.box01{
  margin: calc(50 *(100vw / 1366) * 0.554) auto 0;
  position: relative;
  width: calc(686 *(100vw / 1366) * 0.554);
}
.feature .sec03 .img12{
  width: calc(686 *(100vw / 1366) * 0.554);
}

/*******************************
sec04
*******************************/

.feature .sec04{
  padding: calc(76 *(100vw / 1366) * 0.554) 0 calc(220 *(100vw / 1366) * 0.554);
}

.feature .sec04 .inner::before{
  background: #F4FAFC;
  content: "";
  display: block;
  margin: auto;
  position: absolute;
  top: 0;
  left: 0;
  height: 60%;
}
.feature .sec04 .inner::after{
  background: #FCF4FB;
  content: "";
  display: block;
  margin: auto;
  position: absolute;
  bottom: 0;
  left: 0;
  height: 40%;
}

.feature .sec04 .img13{
  margin: 0 auto;
  width: calc(630 *(100vw / 1366) * 0.554);
}

.feature .sec04 .img14{
  margin: calc(20 *(100vw / 1366) * 0.554) auto 0;
  position: sticky;
  top: 80px;
  width: 100%;
}
.feature .sec04 .sec__box.box01{
  margin: calc(50 *(100vw / 1366) * 0.554) auto 0;
  position: relative;
  width: 100%;
}
.feature .sec04 .img15{
  width: 100%;
}

/*******************************
sec05
*******************************/

.feature .sec05{
  padding: calc(234 *(100vw / 1366) * 0.554) 0 calc(160 *(100vw / 1366) * 0.554);
}

.feature .sec05 .inner::before{
  background: #FCF4FB;
  content: "";
  position: absolute;
  top: 0;
  height: 36%;
}
.feature .sec05 .inner::after{
  background: #F5F1EA;
  content: "";
  position: absolute;
  bottom: 0;
  height: 54%;
}

.feature .sec05 .img16{
  margin: 0 auto;
  width: calc(630 *(100vw / 1366) * 0.554);
}
.feature .sec05 .img16 > a{
  box-sizing: border-box;
  border: calc(6 *(100vw / 1366) * 0.554) solid #000;
  transform: rotate(3deg);
}

.feature .sec05 .img17{
  margin: calc(66 *(100vw / 1366) * 0.554) auto 0;
  width: 100%;
}

.feature .sec05 .img18{
  margin: calc(22 *(100vw / 1366) * 0.554) auto 0;
  position: sticky;
  top: 80px;
  width: calc(686 *(100vw / 1366) * 0.554);
}
.feature .sec05 .sec__box.box01{
  margin: calc(50 *(100vw / 1366) * 0.554) auto 0;
  position: relative;
  width: calc(686 *(100vw / 1366) * 0.554);
}

/*******************************
sec06
*******************************/

.feature .sec06{
  padding: calc(260 *(100vw / 1366) * 0.554) 0 calc(437 *(100vw / 1366) * 0.554);
}

.feature .sec06 .inner::before{
  background: #F5F1EA;
  content: "";
  position: absolute;
  top: 0;
  height: 45%;
}
.feature .sec06 .inner::after{
  background: #F4FAFC;
  content: "";
  position: absolute;
  bottom: 0;
  height: 55%;
}

.feature .sec06 .img20{
  margin: 0 auto;
  width: calc(630 *(100vw / 1366) * 0.554);
}
.feature .sec06 .img20 > a{
  box-sizing: border-box;
  border: calc(6 *(100vw / 1366) * 0.554) solid #000;
  transform: rotate(-3deg);
}

.feature .sec06 .img21{
  margin: calc(67 *(100vw / 1366) * 0.554) auto 0;
  width: 100%;
}

.feature .sec06 .img22{
  margin: calc(20 *(100vw / 1366) * 0.554) auto 0;
  position: sticky;
  top: 80px;
  width: calc(686 *(100vw / 1366) * 0.554);
}
.feature .sec06 .sec__box.box01{
  margin: calc(50 *(100vw / 1366) * 0.554) auto 0;
  position: relative;
  width: calc(686 *(100vw / 1366) * 0.554);
}

/*******************************
sec07
*******************************/

.feature .sec07{
  background: #FCF4FB;
  padding-bottom: calc(190 *(100vw / 1366) * 0.554)
}

.feature .sec07 .img24{
  margin: 0 auto;
  width: 100%;
}

.feature .sec07 .sec__box.box01{
  margin: calc(102 *(100vw / 1366) * 0.554) auto 0;
  position: relative;
  width: 100%;
}
.feature .sec07 .img25{
  width: 100%;
  z-index: 1;
}
.feature .sec07 .img26{
  margin: auto;
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  width: calc(630 *(100vw / 1366) * 0.554);
  height: fit-content;
  z-index: 2;
}
.feature .sec07 .img26 > a{
  transform: rotate(-3deg);
}

.feature .sec07 .sec__staff{
  color: #000;
  font-family: "Roboto", sans-serif;
  font-weight: 300;
  font-style: italic;
  font-size: calc(20 *(100vw / 1366) * 0.554);
  line-height: 1.75;
  margin: calc(274 *(100vw / 1366) * 0.554) auto 0;
  text-align: center;
}

/*******************************
fade
*******************************/

.l-container #feature [data-fade="fade"]{
  opacity: 0;
  transition: opacity .5s, transform .5s;
  transform: translateY(20px);
}
.l-container #feature [data-fade="fade"][data-is-active="true"],
.l-container #feature .parent[data-is-active="true"] [data-fade="fade"]{
  opacity: 1;
  transform: translateY(0);
}

.l-container #feature [data-fade="blur"]{
  opacity: 0;
  -webkit-filter: blur(10px);
  filter: blur(10px);
  -webkit-transition: opacity 0.5s ease-in, filter 0.5s ease-in;
  transition: opacity 0.5s ease-in, filter 0.5s ease-in;
  -webkit-transition-duration: 0.6s;
  transition-duration: 0.6s;
}
.l-container #feature [data-fade="blur"][data-is-active="true"],
.l-container #feature .parent[data-is-active="true"] [data-fade="blur"]{
  opacity: 1;
  -webkit-filter: blur(0);
  filter: blur(0);
}

.l-container #feature [data-fade="layered"]{
  opacity: 0;
  transition: opacity .8s ease-in, transform .8s ease-in;
  transform: translate(5px, 10px) rotate(2deg);
}
.l-container #feature [data-fade="slide"]{
  opacity: 0;
  transition: opacity .8s ease-in, transform .8s ease-in;
  transform: translate(40px, 80px) rotate(-5deg);
}
.l-container #feature [data-fade="layered"][data-is-active="true"],
.l-container #feature [data-fade="slide"][data-is-active="true"]{
  opacity: 1;
  transform: translate(0) rotate(0deg);
}


.l-container #feature .delay01{
  transition-delay: .3s !important;
}
.l-container #feature .delay02{
  transition-delay: .6s !important;
}
.l-container #feature .delay03{
  transition-delay: .9s !important;
}

@media screen and (min-width: 1400px){
  
}

.pc-footer{
  margin: 0;
}
.l-footer{
  padding: 0;
}