@charset "UTF-8";

/* body.no_scroll {
  overflow: hidden;
}
body.no_scroll .go-top{display: none!important;} */
body {
  overflow: visible;
}

/*******************************
LB240809catalog
*******************************/
#LB240809catalog {
  display: block;
  width: 100%;
  padding: calc(0 * (100vw / 1000)) 0 calc(0 * (100vw / 1000));
  box-sizing: border-box;
}

#LB240809catalog *{box-sizing: border-box;}


#LB240809catalog .lpWrap{
  display: block;
  margin: 0 auto;
}

.header__nav {
  /* display: none; */
}
.bredlist.lp.replace {
  display: none;
  opacity: 0;
}
.header__row+.header__row {
  /* border-top: none; */
}
/* #content__archive ,  #footer , .go-top {
  display: none;
}
#header {
  position: fixed;
  top: 0;
} */


/*******************************
lpStickyBlock
*******************************/
#LB240809catalog .lpStickyBlock{
  display: block;
  width: 100%;
}

/* #LB240809catalog .lpStickyBlock .mainTTLBlock{
  display: block;
  max-width: calc(463 * (100vw / 1000));
  width: 90rem;
  z-index: 1;
} */
a.main_ttl {
  display: block;
  position: relative;
/* 追加 */
  height: 81vh;
}
a.main_ttl video {
  width: 100%;
  height: auto;
/* 追加 */
  width: auto;
  height: 100%;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translateX(-50%) translateY(-50%);
}
a.main_ttl .lp_main_ttl {
  width: 67rem;
  max-width: calc(342* (100vw /1000));
  height: calc(66* (100vw /1000));
  position: absolute;
  top: 52%;
  left: 50%;
  transform: translate(-50%, -50%);
}
#LB240809catalog .lpStickyBlock .mainTTLBlock .outer,
#LB240809catalog .lpStickyBlock .mainTTLBlock a.outer,
#LB240809catalog .lpStickyBlock .mainTTLBlock picture,
#LB240809catalog .lpStickyBlock .mainTTLBlock img{display: block; width: 100%; height: auto;}



#LB240809catalog .lpStickyBlock {
  display: block;
  width: 100%;
  position: relative;
}

/*viewText ***/
 #viewText{
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
  justify-content: space-between;
  height: 100vh;
  width: 100%;
  /* position: fixed; */
  bottom: 0;
  left: 0;
  padding: calc(80 * (100vw / 1000)) calc(30 * (100vw / 1000)) calc(80 * (100vw / 1000));
  z-index: 2;
  pointer-events: none;
  opacity: 0;
  transition: opacity .3s ease;
}

 #viewText.fixed{
  opacity: 1;
}

 #viewText.fixed.bottom{
  position: absolute;
  bottom: 0;
  height: auto;
}

.numCredit{
  display: block;
  max-width: calc(236 * (100vw / 1000));
  pointer-events: auto;
}

 #viewCredit{
  display: block;
  transition: opacity .3s ease;
}
 #viewCredit.hide{opacity: 0;}


.viewNum{
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
  justify-content: flex-start;
  margin-bottom: calc(8.3 * (100vw / 1000));
  font-family: "Times New Roman";
  font-style: italic;
  font-size: calc(12 * (100vw / 1000));
  color: #000000;
  text-align: left;
}

.viewNum .text{padding-left: 1em;}




 #viewCredit .creditLinks{
  display: block;
}

 #viewCredit .creditLinks .credit{
  /*
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: flex-start;
  */
  text-align: left;
}

 #viewCredit .creditLinks .credit > a{
  /*display: block;*/
  font-family: "Times New Roman";
  font-size: calc(11 * (100vw / 1000));
  line-height: 1.25;
  letter-spacing: 0;
  color: #000000;
  white-space: nowrap;
  font-style: italic;
}

 #viewCredit .creditLinks  .credit > a:not(:nth-last-of-type(1))::after{
  content: '/';
  padding: 0 calc(2 * (100vw / 1000));
}


 #viewCredit .creditLinks .itemListBtn{
  font-family: "Times New Roman";
  font-size: calc(9 * (100vw / 1000));
  line-height: 1;
  letter-spacing: 0;
  color: #000000;
  white-space: nowrap;
  font-style: italic;
  margin-top: calc(8.5* (100vw /1000));
}


.pcViewNav{
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
  justify-content: center;
  gap: calc(18.7 * (100vw / 1000));
  font-family: "Times New Roman";
  font-style: italic;
  font-size: calc(12 * (100vw / 1000));
  text-align: right;
  pointer-events: auto;
}

.pcViewNav #changeOverview{
  cursor: pointer;
  transition: opacity .3s ease;
}

.pcViewNav #changeOverview:hover{opacity: .6;}


/*expansionList ***/
#LB240809catalog .lpStickyBlock ul#expansionList{
  display: block;
  background: #FFFFFF;
  position: relative;
  z-index: 1;
}

#LB240809catalog .lpStickyBlock ul#expansionList > li{
  display: block;
  width: calc(428 * (100vw / 1000));
  margin: 0 auto;
}

#LB240809catalog .lpStickyBlock ul#expansionList > li + li{
  margin-top: calc(10 * (100vw / 1000));
}

#LB240809catalog .lpStickyBlock ul#expansionList > li .imgOuter,
#LB240809catalog .lpStickyBlock ul#expansionList > li picture,
#LB240809catalog .lpStickyBlock ul#expansionList > li img{display: block; width: 100%; height: auto;}

#LB240809catalog .lpStickyBlock ul#expansionList > li picture{
  transition: opacity .3s ease;
  cursor: pointer;
}

#LB240809catalog .lpStickyBlock ul#expansionList > li picture:hover{opacity: .8;}


/*******************************
overViewBox
*******************************/
#overViewBox{
  display: flex;
  flex-direction: column;
  flex-wrap: nowrap;
  align-items: center;
  justify-content: center;
  /* width: 100svw; */
  width: 100px;
  height: 100svh;
  /* background: #FFFFFF; */
  opacity: 0;
  position: fixed;
  top: 0;
  right: 0;
  z-index: 10000;
  pointer-events: none;
  transition: opacity 0.3s ease;
  transform: translate(100vw,0);
  backface-visibility: hidden;
}

#overViewBox.active{
  transform: translate(0,0);
  opacity: 1;
  pointer-events: inherit;
}

#overViewBox .overViewHead{
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
  justify-content: center;
  width: 92.7%;
  height: calc(110 * (100vw / 1920));
  position: relative;
}

#overViewBox .overViewHead .title{
  font-family: "Times New Roman";
  font-style: normal;
  font-weight: 400;
  font-size: calc(18 * (100vw / 1920));
  text-align: left;
  margin: 0 auto 0 0;
}

#overViewBox .overViewHead .logo{
  display: block;
  width: calc(162 * (100vw / 1920));
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-56%,-50%);
}
#overViewBox .overViewHead .logo > img{
  display: block;
  width: 100%;
  height: auto;
}

#overViewBox .overViewHead .title2{
  font-family: "Times New Roman";
  font-size: calc(18 * (100vw / 1920));
  font-style: italic;
  text-align: right;
  margin: 0 0 0 auto;
}

#overViewBox .overViewList{
  display: block;
  height: calc(100svh - 110 * (100vw / 1920));
  padding: 0 0 calc(32 * (100vw / 1920));
  overflow-y: auto;
}

#overViewBox .overViewList > ul{
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-start;
  gap: calc(15 * (100vw / 1920)) 0;
}

#overViewBox .overViewList > ul > li{
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
  justify-content: center;
  /* width: calc(100% / 8); */
  aspect-ratio: 480 / 329;
  transition: opacity .3s ease;
  cursor: pointer;
  opacity: .6;
}

#overViewBox .overViewList > ul > li:hover{opacity: 1;}
#overViewBox .overViewList > ul > li.active {opacity: 1;}

#overViewBox .overViewList > ul > li img{
  display: block;
  width: 100%;
  height: auto;
}


#overViewBox .pcViewNav{
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
  justify-content: flex-end;
  gap: calc(18.7 * (100vw / 1000));
  height: 100vh;
  width: 100%;
  position: fixed;
  bottom: 0;
  left: 0;
  padding: calc(80*(100vw / 1000)) calc(30*(100vw / 1000)) calc(80*(100vw / 1000));
  z-index: 2;
  pointer-events: none;
  opacity: 1;
  transition: opacity .3s ease;
}

#overViewBox .pcViewNav > p{
  font-family: "Times New Roman";
  font-style: italic;
  font-size: calc(12 * (100vw / 1000));
  color: #000000;
  pointer-events: auto;
}

#overViewBox .pcViewNav > p#changeExpansion{
  cursor: pointer;
  transition: opacity .3s ease;
}

#overViewBox .pcViewNav > p#changeExpansion:hover{opacity: .6;}

/*******************************
modalSlider
*******************************/
#creditModal .modalBox{
  display: flex;
  flex-direction: column;
  flex-wrap: nowrap;
  align-items: center;
  justify-content: center;
  width: 100svw;
  height: 100svh;
  opacity: 0;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 10000;
  pointer-events: none;
  transition: opacity 0.3s ease;
  transform: translate(100vw,0);
  backface-visibility: hidden;
}

#creditModal .modalBox.active{
  transform: translate(0,0);
  opacity: 1;
  pointer-events: inherit;
}

#creditModal .modalBox .modalBg{
  display: block;
  width: 100%;
  height: 100vh;
  height: 100svh;
  position: fixed;
  background: rgba(255, 255, 255,1);
  opacity: 0;
  transition: opacity 0.2s ease;
  backface-visibility: hidden;
  z-index: -1;
}

#creditModal .modalBox.active .modalBg{opacity: 1;}

#creditModal .modalBox .closeBtn{
  display: block;
  width: calc(15.73 * (100vh / 670));
  height: calc(15.73 * (100vh / 670));
  position: absolute;
  top: calc(20.5 * (100vh / 670));
  right: calc(20 * (100vh / 670));
  cursor: pointer;
}

#creditModal .modalBox .closeBtn img{display: none;}


#creditModal .modalBox .closeBtn::before,
#creditModal .modalBox .closeBtn::after{
  content: '';
  display: block;
  width: calc(22.25 * (100vh / 670));
  height: 0.75px;
  background: #2B2E34;
  position: absolute;
  left: calc((-22.25 + 15.73) * (100vh / 670) / 2);
  top: 50%;
  transform-origin: 50% 50%;
}

#creditModal .modalBox .closeBtn::before{transform: rotate(45deg);}
#creditModal .modalBox .closeBtn::after{transform: rotate(-45deg);}

#creditModal .modalBox .lookWrap{
  display: block;
  width: calc(448 * (100vh / 670));
}



/*slider setting**/
#creditModal .modalSlide{
  width: 100%;
  margin-bottom: calc(14.1 * (100vh / 670));
  position: relative;
}

#creditModal .modalSlide .continer{
  margin-left: auto;
  margin-right: auto;
  position: relative;
  overflow: hidden;
  list-style: none;
  padding: 0;
  z-index: 1;
}

#creditModal .modalSlide .continer .sliderWrapper{
  align-items: center;
}

#creditModal .modalSlide .continer .slider{
  display: block;
  width: 100%;
  padding: 0 calc(10 * (100vh / 670));
  margin: 0;
}

/* img ***/
#creditModal .continer .slider .outer{display: block;}

#creditModal .continer .slider picture{
  display: flex;
  align-items: center;
  justify-content: center;
  height: calc(570.67 * (100vh / 670));
}

#creditModal .continer .slider picture > img{
  display: block;
  width: 100%;
  height: auto;
}


#creditModal .modalSlide ul.pager{
  display: inline-flex;
  flex-wrap: nowrap;
  align-items: center;
  justify-content: flex-end;
  gap: 0  calc(4.5 * (100vh / 670));
  position: absolute;
  right: calc(10 * (100vh / 670));
  bottom: calc(-21.3 * (100vh / 670));
  z-index: 1;
}

#creditModal .modalSlide ul.pager > li{
  display: block;
  width: calc(6 * (100vh / 670));
  height: calc(6 * (100vh / 670));
  border-radius: 50%;
  margin: 0;
  background-color: #D2D2D2;
  transition: background 0.3s ease;
  cursor: pointer;
  opacity: 1;
}

#creditModal .modalSlide ul.pager > li.swiper-pagination-bullet-active{
  background: #525252;
  pointer-events: none;
}



/* credit **/

#creditModal .creditLinks{
  display: block;
  width: calc(447 * (100vh / 670));
  margin: 0 auto 0 0;
  padding-left: calc(10 * (100vh / 670));
  padding-right: calc(78 * (100vh / 670));
}

#creditModal .creditLinks .credit{
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: flex-start;
  text-align: left;
}

#creditModal .creditLinks .credit > a{
  display: block;
  font-family: "Times New Roman";
  font-style: italic;
  font-size: calc(11 * (100vh / 670));
  line-height: 1.25;
  letter-spacing: 0;
  color: #000000;
  white-space: nowrap;
}

#creditModal .creditLinks .credit > a:not(:nth-last-of-type(1))::after{
  content: '/';
  padding: 0 0.5em;
}


#creditModal .creditLinks .itemListBtn{
  display: block;
  padding-top: calc(9 * (100vh / 670));
}

#creditModal .creditLinks .itemListBtn > a{
  font-family: "Times New Roman";
  font-size: calc(10 * (100vh / 670));
  line-height: 1.2;
  letter-spacing: 0;
  color: #000000;
  white-space: nowrap;
  text-align: left;
  transform-origin: 0 0;
  transform: scale(0.9);
}


/*******************************
allItemBtn
*******************************/
#LB240809catalog .allItemBtn{
  display: block;
  width: calc(480 * (100vw / 1920));
  margin: calc(0 * (100vw / 1920)) auto 0;
  padding: 0;
  position: relative;
}

#LB240809catalog .allItemBtn > a{
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: calc(64 * (100vw / 1920));
  border: 1px solid #000000;
  font-family: "Times New Roman";
  font-style: italic;
  font-size: calc(19 * (100vw / 1920));
  text-align: center;
  letter-spacing: 0;
  color: #000000;
}


#LB240809catalog .allItemBtn > a img{display: block; width: 9.51133rem;}


/*******************************
staffList
*******************************/
#LB240809catalog .staffList{
  display: block;
  padding-bottom: calc(14 * (100vw / 1920));
  padding-top: calc(64 * (100vw / 1920));
} 

#LB240809catalog .staffList p{
  display: block;
  font-family: "Times New Roman";
  font-style: italic;
  font-size: calc(18 * (100vw / 1920));
  line-height: 1.25; 
  text-align: center;
}

/*******************************
overRide
*******************************/
#LB240809catalog .spView{display: none;}








/* slick */
.model_slider_box .slider-thumb li {
  margin-right: 10px;
  overflow: hidden;
  width: calc(19.8% - 8px);
  cursor: pointer;
  background: #000;
}
.model_slider_box .slider-thumb li img {
opacity: 0.5;
}
.model_slider_box .slider-thumb li.thumbnail-current img {
  opacity: 1;
}

.model_slider_box .slider-thumbnail p {
  text-align: center;
  font-size: 18px;
  padding: 30px 0;
  height: auto !important;
}

.model_slider_box .slider-thumbnail {
  width: 100%;
  /* max-width: 940px; */
  height: auto;
  margin: 0 auto;
  /* background-color: #fff; */
  position: relative;
}

.model_slider_box .slider-thumbnail .slider-arrow {
  position: absolute;
  display: inline !important;
  z-index: 10;
  width: 50px;
  height: 50px;
}

.model_slider_box .slider-thumbnail .slider-prev {
  top: 50%;
  bottom: auto;
  left: -30px;
  transform: translateY(-50%);
}



.model_slider_box .slider-thumbnail .slider-next {
  top: 50%;
  bottom: auto;
  right: -30px;
  transform: translateY(-50%);
}


.model_slider_box .slider-thumbnail img {
  width: 100%;
  height: auto;
  cursor: pointer;
}

.model_slider_box .slider-thumb {
  /* max-width: 940px; */
  margin: 5px auto 0;
  overflow: hidden;
  display: flex;
  justify-content: space-between;
  position: relative;
  z-index: 1;
}

.model_slider_box .slider-thumb li img {
  height: 130px;
  width: auto;
  max-width: inherit;
}


.model_slider_box .slider-thumb li:last-child {
  margin-right: 0;
}


.sub-slider--note {
  margin: 1% 30px;
  padding: 0;
}

@media screen and (max-width: 767px) {
  .model_slider_box .slider-thumb li img {
      height: 80px;
  }
  .model_slider_box .slider-thumbnail .slider-prev {
      top: 50%;
      left: -10px;
      width: 30px;
      height: 30px;
  }
  .model_slider_box .slider-thumbnail .slider-next {
      top: 50%;
      right: -10px;
      width: 30px;
      height: 30px;
  }
  .sub-slider--note {
      padding: 0 20px;
      margin: 1% 0;
  }

  .model_slider_box .slider-thumb li {
      /* width: calc(16.5% - 8px); */
      text-align: center;
  }
  .model_slider_box .slider-thumb li {
      margin-right: 10.2px;
  }
   .model_slider_box .slider-thumb {
      margin: 5px auto 0;
  }
}

@media screen and (max-width: 650px) {
  .model_slider_box .slider-thumb li img {
      height: 50px;
  }

}




#js-main.main{
  /* display: grid; */
  display: flex;
  /* grid-template-columns: 1fr 100px; */
  position: relative;
  position: relative;
}
#js-main.main .swiper-slide{
  /* max-height: 100dvh; */
}

#js-main.main .swiper-slide {
  /* min-height: 100vh; */
}
#js-main.main .swiper-slide:hover {
  opacity: 1;
}

.price__container{
  display: grid;
  align-items: center;
  padding: 0rem 2rem;
  position: absolute;
  width: 100%;
  height: 110dvh;
  z-index: 50;
  pointer-events: none;
}
/* .price__container .price__item:not(.show){
  display: none;
} */

.price__container .price__item {
  position: absolute;
  top: 45%;
  /* left: 50%;
  transform: translate(-50%, -50%); */
  visibility: hidden;
  opacity: 0;
  transition: 0.3s;
}
.price__container .price__item.show {
  opacity: 1;
  visibility: visible;
  transition: 0.3s;
}

.contents__container{
  margin-inline: auto;
  width: fit-content;
  height: 100vh;
  /* overflow-y: scroll
  
  ; */
}
.contents__container .contents__item{
  /* display: grid; */
  /* justify-content: center; */
  /* align-items: center; */
  /* gap: 1rem; */
  /* width: 100%; */
  /* height: 100%; */
}

.thumbnail__container{
  align-self: center;
  height: 82svh;
  /* height: 100svh; */
  /* overflow-y: scroll; */
  width: 12rem;
  max-width: calc(60* (100vw /1000));
  position: relative;
  right: 4rem;
  cursor: pointer;
  margin-top: 16.5rem;
  position: absolute;
}
.thumbnail__container .thumbnail__item{
  height: fit-content;
  opacity: 0.6;
  transition: opacity 0.3s ease;
  width: calc(60* (100vw /1000));
  height: calc(80* (100vw /1000));
}
.thumbnail__container .thumbnail__item.swiper-slide-thumb-active{
  opacity: 1;
}

.contents__item--image {
  display: flex;
  /* max-width: calc(435* (100vw /1000));
  width: 75rem; */
  justify-content: center;
  height: auto;
  padding-top: 19.5rem;

  /* 追加 */
  height: 100vh;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  padding-bottom: 5rem;
}
.contents__item--image img , .contents__item--image video {
  width: auto;
  height: 100%;
}
.swiper-slide.thumbnail__item img , .swiper-slide.thumbnail__item video {
  width: 100%;
  height: auto;
}

/* ===============================================
* 榎本 追記 *
=============================================== */
/* ヘッダーを固定 */
#header {
  position: fixed;
  top: 0;
}


/* ヘッダー分コンテンツを下げる */
#Wrap {
  /* padding-top: 17rem; */
  /* display: block; */
}

/* swiper部分を固定 */
#js-main.main {
  position: fixed;
  top: 0;
}

/* swiperのフリック可能範囲を画像幅から全画面幅に拡張 */
.swiper-wrapper {
  width: 100vw;
  max-width: 100%;
  /* height: 130vh;
  position: relative;
  top: 10%; */
  height: fit-content;
}

/* フッターを無くしてしまう */
#content__archive,
#Foot {
  display: none;
}

/* ファーストビューもスライダーの中に入れてしまう */
/* #LB240809catalog .lpStickyBlock .mainTTLBlock {
  display: none;
} */

/* スライド画像の大きさ指定 */
/* .contents__item--image {
  width: 60rem;
} */

/* .thumbnail__container .thumbnail__item {
  width: 8rem;
} */

/* .contents__item--image img,
.thumbnail__container .thumbnail__item img {
  width: 100%;
  height: auto;
}

.thumbnail__container .thumbnail__item video {
  width: 100%;
  height: auto;
} */

.header_search .box-input input {
  background: transparent;
}

@media screen and (max-width: 1100px) {
  .thumbnail__container {
    right: 0rem;
}
}

.price__wrapper {
  transition: 0.3s;
}
.price__container {
  transition: 0.3s;
}

.price__wrapper {
  transition: opacity .3s;
  /* opacity: 0; */
}
.price__wrapper.active {
  transition: opacity .3s;
  opacity: 1;
}


.price__container {
  transition: opacity 0.3s;
  opacity: 1;
}

.price__container.fade-out {
  transition: opacity 0.3s;
  opacity: 0;
}


.thumbnail__container {
  transition: 0.3s;
  opacity: 0;
}
.thumbnail__container.fade-in {
  transition: 0.3s;
  opacity: 1;
}

/* @media screen and (max-device-height: 1100px) {
  .contents__item--image {
    width: 60rem;
  }
}
@media screen and (max-device-height: 970px) {
  .contents__item--image {
    width: 50rem;
  }
}
@media screen and (max-device-height: 850px) {
  .contents__item--image {
    width: 40rem;
  }
} */

/* スタッフクレジット中央揃え */
.bottom .contents__item--image{
  display: grid;
  place-items: center;
}