@charset "UTF-8";

html {
  font-size: 10px;
}

@media screen and (max-width: 2100px) {
  html {
    font-size: calc(10 * (100vw / 2100));
  }
}


/***** 共通 *****/

body{
  animation: fadeIn 1s ease 1s 1 normal forwards;
  opacity: 0;
}

.js-logo{
  animation: fadeIn 1s ease 2s 1 normal forwards;
  opacity: 0;
}

.js-typ span{
  opacity: 0;
}

@keyframes fadeIn {
  0% { opacity: 0; }
  100% { opacity: 1; }
}

.pc-header{
  display: none;
}

.l-header,
.l-footer {
  display: none;
}

.l-footer {
  padding: 0;
}

.l-container {
  width: auto;
}

.l-container:after {
  display: none;
}

img {
  max-width: 100%;
}

/**a img {
  transition: 0.3s;
}

a img:hover {
  opacity: 0.7;
}**/

.l-container a:hover{
  text-decoration: none;
}

/***** スクロール *****/

#container {
  width: 100%;
  height: 100vh;
  scroll-snap-type: both mandatory;
  overflow: auto;
  scroll-behavior: smooth;
  scroll-snap-align: start;
  overflow-y: scroll;
  -ms-overflow-style: none;
  scrollbar-width: none;
  font-family: "Times New Roman";
}

#container::-webkit-scrollbar {
  display: none;
}

/***** マウスオーバー *****/

.image-container {
  position: relative;
  display: inline-block;
}

.image-container img{
  height: 100vh;
}

.image-container_flex {
  display: flex;
}

.image-text {
  position: absolute;
  color: #fff;
  font-size: 2.13rem;
  display: none;
  animation-name: fadeInOut;
  animation-duration: 0.5s;
}

@keyframes fadeInOut {
  0% {
    opacity: 1;
  }

  100% {
    opacity: 0;
  }
}

.blur {
  animation-name: blurAnime;
  animation-duration: 1s;
  animation-fill-mode: forwards;
}

@keyframes blurAnime {
  from {
    filter: blur(10px);
    transform: scale(1.02);
    opacity: 0;
  }

  to {
    filter: blur(0);
    transform: scale(1);
    opacity: 1;
  }
}

/***** スライダー ******/
.slideshow-container {
  position: relative;
  width: 100%;
  /* margin: auto; */
  z-index: 0;
  background: #fff;
}

.fade {
  position: absolute;
  width: 100%;
  height: auto;
  opacity: 0;
  transition: opacity 1s ease;
}

.number-container {
  position: absolute;
  top: 2rem;
  right: 2rem;
  /* transform: translateX(-50%); */
  display: flex;
  justify-content: end;
  align-items: start;
  color: #fff;
}

.number {
  cursor: pointer;
  font-size: 1.5rem;
  margin: 0 .8rem;
}

.underline {
  width: 3rem;
  height: 0.1rem;
  background-color: black;
  margin-top: 1.5rem;
}

/** ALL **/

.all01 {
  bottom: 11.4rem;
  right: 12.5rem;
  text-align: center;
  font-size: 2.3rem;
}

.circle01 {
  position: absolute;
  border: 0.1rem solid #fff;
  border-radius: 50%;
  height: 14.3rem;
  width: 14.3rem;
  bottom: 5.7rem;
  right: 7.6rem;
  display: none;
}

.all02 {
  bottom: 11.4rem;
  right: 9.4rem;
  text-align: center;
  font-size: 2.3rem;
}

.circle02 {
  position: absolute;
  border: 0.1rem solid #fff;
  border-radius: 50%;
  height: 14.3rem;
  width: 14.3rem;
  bottom: 5.7rem;
  right: 4.4rem;
  display: none;
}

/***** 追加 *****/

#container .container{
  box-sizing: border-box;
  width: 100%;
  height: 100%;
  scroll-snap-align: center;
  scroll-snap-stop: always;
}

#container div img{
  width: 100%;
  object-fit: cover;
  object-position: top center;
}

.feature .container__img,
.feature .container__img img{
  height: 100%;
}

.feature .container__flex{
  display: flex;
  position: relative;
}

.feature .container__flex .container__list,
.feature .container__flex .container__link{
  height: calc(100% - 0.76vh);
  width: 50% !important;
}

.feature .container__flex .container__list .slick-list{
  height: 100%;
}

.feature .container10 .container__link{
  background: #5c1e1c;
}

.feature .container17 .container__img{
  width: 50%;
}
.feature .container17 .container__img:nth-of-type(2){
  background: #5c1e1c;
}

/***** footer *****/

.feature .container__footer{
  margin: 6.71vh auto 0;
  padding: 0 0 4.58vh;
  scroll-snap-align: start;
}

.feature .container__footer .inner{
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: auto;
  width: 95.14vw;
}

.feature .container__footer .container__staff{
  color: #231815;
  display: flex;
  flex-direction: column;
  font-size: 1.22vh;
  gap: 0.23vh 0;
  letter-spacing: 0.055em;
  line-height: 1.578;
  width: 50%;
}

.feature .container__footer .container__ready{
  color: #231815;
  margin: 4.58vh 0.99vh 0 0;
  text-align: right;
}
.feature .container__footer .container__ready p{
  font-size: 1.68vh;
  letter-spacing: 0.025em;
}
.feature .container__footer .container__ready p:nth-of-type(2){
  font-size: 2.9vh;
  letter-spacing: 0.025em;
}

.feature .container__footer .container__view{
  margin: 1.98vh 0 0 0.08vh;
  width: 100%;
}

.feature .container__footer .container__view a{
  align-items: center;
  color: #231815;
  display: flex;
  font-size: 1.53vh;
  letter-spacing: 0.055em;
  width: fit-content;
}
.feature .container__footer .container__view a span:nth-of-type(1){
  font-family: "kozuka-gothic-pr6n", sans-serif;
  font-weight: 500;
  font-size: 0.88vh;
  margin: 0 0.15vh 0 0;
}
.feature .container__footer .container__view a span:nth-of-type(8),
.feature .container__footer .container__view a span:nth-of-type(12){
  width: 0.46vh;
}
.feature .container__footer .container__view a span{
  display: block;
}

/***** モーダルクレジット *****/

.feature .container__credit{
  background: #fff;
  border-top: 0.08vh solid #808080;
  border-bottom: 0.08vh solid #808080;
  box-sizing: border-box;
  opacity: 0;
  top: 0;
  position: absolute;
  pointer-events: none;
  transition: opacity 0.5s;
  height: calc(100% - 0.76vh);
  width: 50% !important;
  z-index: 5;
}
.feature .container__credit.left{
  right: 0;
}
.feature .container__credit.right{
  left: 0;
}

.feature .container__credit.on{
  opacity: 1;
  pointer-events: all;
}

.feature .container__credit .inner{
  position: relative;
  height: 100%;
}
.feature .container__credit .inner::before{
  content: "’24 AUTUMN COLLECTION / READY FOR";
  font-size: 1.07vh;
  letter-spacing: -0.015em;
  bottom: 1.83vh;
  left: 3.07vh;
  position: absolute;
}
.feature .container__credit.right .inner::before{
  left: inherit;
  right: 2.73vh;
}

.feature .container__credit .container__close{
  font-size: 1.68vh;
  bottom: 1.53vh;
  right: 2.61vh;
  position: absolute;
}
.feature .container__credit .container__close::before{
  content: "CLOSE";
}
.feature .container__credit.right .container__close{
  right: inherit;
  left: 2.27vh;
}

.feature .container__credit .credit__slide{
  margin: 0 2.16vh 0 auto;
  padding: 2.73vh 0 0;
  height: 25.32vh;
  width: 56.29vh;
}

.feature .container__credit .credit__slide .slick-slide{
  margin: 0 0 0 0.76vh;
}

.feature .container__credit .slick-list{
  height: 22.5vh;
}

.feature .container__credit .credit__slide .slick-slide.slick-current{
  opacity: .5;
}

.feature .container__credit.right .credit__slide{
  margin: 0 0 0 2.16vh;
}
.feature .container__credit.right .credit__slide .slick-slide{
  margin: 0 0.76vh 0 0;
}

.feature .container__credit.left .credit__slide{
  margin: 0 2.16vh 0 auto;
  padding: 2.29vh 0 0;
  height: 25vh;
  width: 52.86vh;
}

.feature .container__credit .credit__slide.js-slide-twoPieces{
  width: 35.23vh;
}

.feature .container__credit .credit__slide.js-slide-fivePieces,
.feature .container__credit .credit__slide.js-slide-sixPieces{
  height: 48.51vh;
}
.feature .container__credit .credit__slide.js-slide-fivePieces .slick-track,
.feature .container__credit .credit__slide.js-slide-sixPieces .slick-track{
  display: flex;
  flex-wrap: wrap;
  gap: 0.76vh 0;
  height: 45.77vh;
}
.feature .container__credit .credit__slide.js-slide-fivePieces .slick-list,
.feature .container__credit .credit__slide.js-slide-sixPieces .slick-list{
  height: 45.77vh;
}
.feature .container__credit .credit__slide.js-slide-fivePieces .slick-slide,
.feature .container__credit .credit__slide.js-slide-sixPieces .slick-slide{
  height: fit-content;
  width: 16.88vh !important;
}

.feature .container02 .container__credit.left .credit__slide,
.feature .container08 .container__credit.right .credit__slide{
  width: 37.53vh;
}

/***** logo *****/

.feature .logo{
  margin: auto;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  position: fixed;
  height: fit-content;
  width: 52.7rem;
  z-index: 10;
}
.feature .logo .inner{
  transition: opacity 1s;
}
.feature .logo.off .inner{
  opacity: 0; 
}

.feature .main__logo.left{
  color: #fff;
  display: flex;
  font-size: 1.68vh;
  letter-spacing: 0.045em;
  margin: auto;
  top: 1.25vh;
  bottom: 0;
  left: 5vh;
  position: absolute;
  height: fit-content;
}
.feature .main__logo.right{
  color: #fff;
  display: flex;
  font-size: 1.68vh;
  letter-spacing: 0.045em;
  margin: auto;
  top: 2.52vh;
  bottom: 0;
  right: 3.98vh;
  position: absolute;
  height: fit-content;
}
.feature .main__logo span{
  opacity: 0;
}

/***** クレジット *****/

.feature .credit__all{
  display: block;
  font-size: 1.07vh;
  letter-spacing: -0.01em;
  margin: 0.11vh 2.27vh 0 auto;
  width: fit-content;
}
.feature .container__credit.right .credit__all{
  margin: 0.11vh 0 0 2.27vh;
}

.feature .creditList{
  display: flex;
  flex-wrap: wrap;
  gap: 0.17vh 0.17vh;
  margin: 1.3vh 0 0;
  width: fit-content;
}
.container__credit.left .creditList{
  margin: 1.6vh 2.21vh 0 auto;
}
.container__credit.right .creditList{
  margin-left: 2.33vh;
}

.container__credit.right .creditList .credit{
  gap: 0.17vh 0.43vh;
}

.feature .creditList a{
  display: flex;
  font-size: 0.67vw;
  letter-spacing: -0.007em;
}

.feature .credit02{
  width: 17vw;
}

.feature .credit03{
  align-items: flex-end;
  flex-direction: column;
}

.feature .credit05,
.feature .credit12{
  justify-content: flex-end;
  width: 24.41vh;
}

.feature .credit07{
  width: 16.67vw;
}

.feature .credit08{
  justify-content: flex-end;
  width: 14.29vw;
}

.feature .credit10{
  justify-content: flex-end;
  width: 15.24vw;
}
.feature .credit11{
  width: 15.24vw;
}

.feature .credit13{
  width: 14.29vw;
}

.feature .credit14{
  justify-content: flex-end;
  width: 13.81vw;
}

.feature .credit28{
  width: 15vw;
}

.feature .eventsNone{
  pointer-events: none;
}