@charset "UTF-8";
@import url("https://use.typekit.net/trc4hjw.css");

@keyframes bar-anime {
  0% {
    height: 40px;
    top: -40px;
  }

  75% {
    height: 40px;
    top: 50px;
  }

  100% {
    height: 40px;
    top: 50px;
  }
}

@keyframes bar-anime-sp {
  0% {
    height: 40px;
    top: -40px;
  }

  75% {
    height: 40px;
    top: 40px;
  }

  100% {
    height: 40px;
    top: 40px;
  }
}

@keyframes moveleft {
  0% {
    left: 100vw;
  }

  100% {
    left: -200vw;
  }
}

@keyframes moveright {
  0% {
    left: -200vw;
  }

  100% {
    left: 100vw;
  }
}

/* ------------------------------------------------------------------------------------------------------------------------ */
html,
body {
  width: 100%;
  height: auto;
  line-height: 1.8;
}

html {
  font-size: 62.5%;
  -ms-text-size-adjust: 100%;
  -webkit-text-size-adjust: 100%;
}

body {
  text-align: left;
  -webkit-text-size-adjust: 100%;
  margin: 0;
}


body.looking {
  overflow: hidden;
}

a {
  color: #000;
  text-decoration: none;
  cursor: pointer;
}

a:hover,
a:active,
a.active {
  color: #7e7e7e;
  text-decoration: underline;
}

img {
  width: 100%;
  height: auto;
  vertical-align: bottom;
}

i {
  font-style: normal;
}

form,
section,
p,
div,
ul,
li,
dl,
dt,
dd,
a,
span,
input,
textarea {
  padding: 0px;
  margin: 0px;
  box-sizing: border-box;
  list-style: none;
}

br.brsp {
  display: none;
}

.item-d-none p a {
  display: none;
}

/* ------------------------------------------------------------------------------------------------------------------------ */
/* setting 右*/

.inner {
  padding-top: 15px;
  font-family: "acumin-pro", sans-serif;
  font-weight: 400;
  font-style: normal;
  font-family: "yu-gothic-pr6n", sans-serif;
}

.a-look{
  position: relative;
}

.a-look .time{
  position: absolute;
  top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
    font-family: "classico-urw", sans-serif;
font-weight: 400;
font-style: italic;
}

.lk10 .time{
  top: 45%;
}

.a-look .time p{
    font-family: "classico-urw", sans-serif;
font-weight: 400;
font-style: italic;
color:#fff;
font-size: 24px;
white-space: nowrap;
}

.a-look .time .time-cap{
  margin-top: 20px;
  font-family: "hanken-grotesk", sans-serif;
font-weight: 400;
font-style: normal;
font-size: 12px;
line-height: 1;
text-align: center;
}

.pt50 {
  padding:50px;
 }

 .lk7 p{
  font-family: "hanken-grotesk", sans-serif;
font-weight: 400;
font-style: normal;
font-size: 10px;
line-height: 1;
 }

 .lk7 .cap-box .left{
  margin: 10px auto 80px 0;
 }

 .lk7 .cap-box .right p{
  margin: 0px 0 10px auto;
  text-align: left;
  display: inline-block;
 }

 .lk11{
  background-color: #000;
 }


 .lk11 .modal-trigger .flex{
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
 }

 .lk11 .modal-trigger .flex .slider4-wrap{
  width:50%;
 }

 .lk15{
  background-color: #000;
  padding-top: 50px;
  padding-bottom:50px;
 }

 .lk15 .flex{
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
 }

 .lk15 .flex .a-look:first-child{
  width:70%;
  margin-bottom: 50px;
 }

 .lk15 .flex .a-look:last-child{
  width:90%;
  margin:0 0 0 auto;
 }

 .lk18 .snap{
  position: absolute;
  top:4%;
  left: 50%;
    transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
    font-family: "classico-urw", sans-serif;
  display: flex;
  justify-content: flex-start;
  align-items: flex-start;
  width:90%;
  gap:10px
 }

 .lk18 .snap:last-child{
  position: absolute;
  top:auto;
  bottom: 1%;
 }

 .lk18 .snap .snap-ttl{
  width:40%;
 }

 .lk18 .snap .snap-cap{
  width:30%;
 }

 .lk18 .snap .snap-ttl p{
  font-family: "classico-urw", sans-serif;
font-weight: 400;
font-style: italic;
color:#fff;
font-size: 24px!important;
line-height: 1;
 }

 .lk18 .snap .snap-cap p{
  font-family: "hanken-grotesk", sans-serif;
font-weight: 400;
font-style: normal;
font-size: 12px!important;
line-height: 1;
color: #fff;
 }

 





/*あしらい*/


/*modal*/
.modal-trigger {
  margin-bottom: 0;
  position: relative;
  cursor: pointer;
  width: 100%;
  margin-right: -1px;
}
#container .modal-trigger .plus {
  display: inline-block;
  position: absolute;
  width: 50px;
  height:50px;
  right: 15px;
  bottom: 15px;
  z-index: 100;
}
#container .modal-trigger .plus::before {
  display: block;
  content: "";
  background-color: #fff;
  position: absolute;
  width: 3px;
    height: 100%;
    left: calc((100% - 2px) / 2);
    top: 0;
}
#container .modal-trigger .plus::after {
  display: block;
  content: "";
  background-color: #fff;
  position: absolute;
  width: 100%;
  height: 3px;
  left: 0;
  top: calc((100% - 2px) / 2);
}
@media (max-width: 768px) {
  .modal-trigger{
    margin-right: 0px;
  }
  #container .modal-trigger .plus {
    width: 30px;
    height: 30px;
    right: 10px;
    bottom: 10px;
  }
}
@media (max-width: 768px) {
  #container .modal-trigger .plus::before {
    width: 2px;
    height: 30px;
    bottom: 0px;
    right: 7px;
  }
}
@media (max-width: 768px) {
  #container .modal-trigger .plus::after {
    width: 30px;
    height: 2px;
    top: 13px;
    right: 0px;
  }
}
#modal-wrapper {
  background: #fff;
  width: 100%;
  height: 100vh;
  padding: 40px 0 220px 0;
  margin: 0px;
  position: fixed;
  left: 0px;
  top: 0px;
  z-index: 9999;
  overflow: scroll;
  opacity: 0;
  -webkit-overflow-scrolling: touch;
  pointer-events: none;
  transition: opacity 0.25s ease-in;
  color: #000;
}
#modal-wrapper.active {
  opacity: 1;
  pointer-events: auto;
}
#modal-wrapper .close {
  width: 40px;
  height: 40px;
  position: fixed;
  top: 40px;
  right: 19%;
  z-index: 999;
  cursor: pointer;
}
#modal-wrapper .close::before {
  content: "";
  width: 40px;
  height: 2px;
  background-color: #000;
  transform: rotate(-45deg);
  position: absolute;
  left: 0px;
  top: 0px;
  transition: all 0.5s 0s ease;
}
#modal-wrapper .close::after {
  content: "";
  width: 40px;
  height: 2px;
  background-color: #000;
  transform: rotate(45deg);
  position: absolute;
  left: 0px;
  top: 0px;
  transition: all 0.5s 0s ease;
}

.looking{
 overflow: hidden;
}

/*modalの中*/

#modal-wrapper .looks .look {
  width: 40%;
  margin: 0 auto 150px;
}

#modal-wrapper .looks .look .inner .m-img{
  position: relative;
  margin-top: 80px;
}

  #modal-wrapper .looks .look .inner .m-img .m-large{
    width:50%;
    }

    #modal-wrapper .looks .look .inner .m-img .m-small{
      width:28%;
      }

  #modal-wrapper .looks .look .inner .credit-box{
    width:100%;
    margin-bottom: 40px;
  }

  #modal-wrapper .looks .look .inner .credit-box .l-r p{
    margin-bottom: 20px;
    font-size: 16px;
    text-align: left;
    font-family: "acumin-pro", sans-serif;
font-weight: 700;
font-style: normal;
  }

  #modal-wrapper .looks .look .inner .credit-box .credit{
    border-bottom: 1px solid #000;
    text-align: left;
  }

  #modal-wrapper .looks .look .inner .credit-box .credit p{
    padding: 15px 5px;
    font-family: "acumin-pro", sans-serif;
font-weight: 400;
font-style: normal;
font-size: 14px;
  }

  #modal-wrapper .looks .look .inner .credit-box .credit p a{
  text-decoration: underline;
  padding: 1px 10px;
  border: #000 1px solid;
  margin-left: 15px;
  }

  #modal-wrapper .looks .look .inner .credit-box .credit p a:hover {
    background-color: #000;
    color: #fff;
  }




/*アコーディオン*/


/*footer*/
.footer-wrapper {
  width: 100%;
  margin: 0 auto;
  background-color: #000;
}

.footer-wrapper p,
.footer-wrapper ul li a{
  font-family: "classico-urw", sans-serif;
font-weight: 400;
font-style: italic;
color: #fff;
}

.footer-wrapper .navi-box {
  margin: 0px auto;
  width:95%;
  padding-top: 10px;
  font-family: "classico-urw", sans-serif;
font-weight: 400;
font-style: italic;
color: #fff;
}

.footer-wrapper .back {
  text-align: right;
  font-size: 12px;
  margin: 100px auto 20px;
  width:95%;
  font-family: "classico-urw", sans-serif;
font-weight: 400;
font-style: italic;
color: #fff;
}

.footer-wrapper .copy {
  text-align: center;
  font-size: 10px;
  margin: 0px auto 20px;
  font-family: "classico-urw", sans-serif;
font-weight: 400;
font-style: italic;
color: #fff;
}

.goods a:hover {
  opacity: 0.8;
}


/* setting 右ここまで*/

/* setting 左*/
.main_visual {
  width: 100%;
  margin-left: auto;
  margin-right: auto;
}

.main_visual .kv-box {
  height: 100vh;
  width: 100%;
  max-width: 440px;
}

.main_visual .kv-box .kv {
  position: relative;
}

.main_visual .kv-box .kv .ttl {
  position: absolute;
  top: auto;
  bottom:0;
  width: 100%;
}

.main_visual .kv-box .kv .ttl .textanimation{
  color: #fff;
  font-family: "ivyora-display", serif;
font-weight: 300;
font-style: normal;
font-size: 7rem;
line-height: 1;
white-space: nowrap;
}

.main_visual .kv-box .kv-text{
 display: flex;
 justify-content: space-between;
 align-items: flex-start;
}

.main_visual .kv-box .kv-text:first-child{
  margin-bottom: 10px;
  margin-top: 30px;
 }

 .main_visual .kv-box .kv-text:last-child{
  margin-bottom: 30px;
  margin-top: 10px;
 }

.main_visual .kv-box .kv-text p{
  font-size: 8px;
  line-height: 10px;
  font-family: "hanken-grotesk", sans-serif;
font-weight: 400;
font-style: normal;
 }

 .main_visual .kv-box .kv-text .brand{
  width:20%;
  margin-right: 0;
  margin-left: auto;
  display: flex;
  justify-content: center;
  align-items: center;
 }






/* setting 左ここまで*/




/*set*/

.mb20{
  margin-bottom: 20px;
}

.mt150{
  margin-top: 150px;
}

.mt-50{
  margin-top: -50px;
}

.mt-150{
  margin-top: -150px;
}

.re {
  flex-direction: row-reverse;
}

.posiR {
  position: relative;
}

.pc {
  display: block;
}

.sp {
  display: none;
}


.center {
  margin-left: auto;
  margin-right: auto;
}

.left {
  margin-left: 0;
  margin-right: auto;
  text-align: left;
}

.right {
  margin-left: auto;
  margin-right: 0;
  text-align: right;
}

.slick-slide img {
  display: block;
}

/*========= LoadingのためのCSS ===============*/

/* Loading背景画面設定　*/
#loading {
  /*fixedで全面に固定*/
  position: fixed;
  width: 100%;
  height: 100%;
  z-index: 10000000;
  background: #fff;
  text-align: center;
  color: #fff;
}

/* Loading画像中央配置　*/
#loading_logo {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

/* Loading アイコンの大きさ設定　*/
#loading_logo img {
  width: 180px;
}

/* LINE文字 */


/* fadeUpをするアイコンの動き */

.fadeUp {
  animation-name: fadeUpAnime;
  animation-duration: 1.5s;
  animation-fill-mode: forwards;
  opacity: 0;
}

@keyframes fadeUpAnime {
  from {
    opacity: 0;
    transform: translateY(30px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/*animation*/
.inview-blur {
  opacity: 0;
  -moz-transition: -moz-transform 0.5s linear;
  -webkit-transition: -webkit-transform 0.5s linear;
  -o-transition: -o-transform 0.5s linear;
  -ms-transition: -ms-transform 0.5s linear;
  transition: transform 0.5s linear;
  -webkit-animation-duration: 1s;
  animation-duration: 1s;
  -webkit-animation-fill-mode: both;
  animation-fill-mode: both;
}

.blur {
  -webkit-animation-name: imageBlur;
  animation-name: imageBlur;
  opacity: 1;
  transition: .4s;
}

@-webkit-keyframes imageBlur {
  from {
    opacity: 0;
    -webkit-filter: blur(15px);
    -moz-filter: blur(15px);
    -ms-filter: blur(15px);
    -o-filter: blur(15px);
    filter: blur(15px);
  }

  to {
    opacity: 1;
    -webkit-filter: blur(0px);
    -moz-filter: blur(0px);
    -ms-filter: blur(0px);
    -o-filter: blur(0px);
    filter: blur(0px);
  }
}

@keyframes imageBlur {
  from {
    opacity: 0;
    -webkit-filter: blur(15px);
    -moz-filter: blur(15px);
    -ms-filter: blur(15px);
    -o-filter: blur(15px);
    filter: blur(15px);
  }

  to {
    opacity: 1;
    -webkit-filter: blur(0px);
    -moz-filter: blur(0px);
    -ms-filter: blur(0px);
    -o-filter: blur(0px);
    filter: blur(0px);
  }
}

.delay{
  animation-delay: 0.5s;
}

.start1 {
  animation: fade 0.8s ease-in 0.4s 1 normal backwards;
}

.start2 {
  animation: fade 1s ease-in 0.5s 1 normal backwards;
}

.start3 {
  animation: fade 1.2s ease-in 1s 1 normal backwards;
}

.start4 {
  animation: fade 1.4s ease-in 1.2s 1 normal backwards;
}

@keyframes fade {
  0% {
    opacity: 0;
  }

  100% {
    opacity: 1;
  }
}

/* fadeUpをするアイコンの動き */

.fadeUp-1 {
  animation-name: fadeUpAnime1;
  animation-duration: 1.5s;
  animation-fill-mode: forwards;
  opacity: 0;
}

.fade-1 {
  opacity: 0;
    transform: translateY(80px);
}


@keyframes fadeUpAnime1 {
  from {
    opacity: 0;
    transform: translateY(80px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.delay{
  animation-delay: 0.5s!important;
}

.start-top {
  animation-delay: 3s;
}

.start-top2 {
  animation-delay: 6s;
}

.top-ttl{
  width: 100%;
  height: 100vh;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  align-items: center;
}

@keyframes showTextFromBottom{
0%{
transform: translateY( 100% );

}
100%{
transform: translateY( 0px );
}
}
.textanimation span{
animation: showText 2s backwards;
display: inline-block;
}
.textanimation > span{
overflow: hidden;
}

.textanimation > span > span{
  animation: showTextFromBottom 0.5s backwards;
}

/*ループ*/

.loop-wrap {
  display: flex;
  align-items: center;
  overflow: hidden;
  height: 50px;
  border-top: #000 2px solid;
  border-bottom: #000 2px solid;
  margin-bottom: 30px;
}

.loop-area {
  display: flex;
  animation: loop-slide 20s infinite linear 1s both;
  list-style: none;
  margin: 0;
  padding: 0;
}

.loop-area .content {
  width: 250px;
  font-family: "zuume", sans-serif;
  font-weight: 700;
  font-style: normal;
  font-size: 40px;
}

@keyframes loop-slide {
  from {
    transform: translateX(0);
  }

  to {
    transform: translateX(-100%);
  }
}

/*スライダーの設定*/
/*------ スライダーの横幅 ------*/
.slider {
  width: 100%;
  margin: 0 auto;
}

/*------ スライダー画像 ------*/
.slider img {
  width: 100%;
  height: auto;
}

/*-------- 高さ調整 ----------*/
.slider .slick-slide {
  height: auto !important;
}

/*---------- 矢印 ----------*/
.slider .slick-next {
  right: 15px !important;
}

.slider .slick-prev {
  left: 15px !important;
}

.slider .slick-arrow {
  width: initial !important;
  height: initial !important;
  z-index: 2 !important;
}

.slider .slick-arrow:before {
  font-size: 36px !important;
}

.slick-next:before {
  display: block;
  content: '' !important;
  opacity: 1 !important;
  left: 5px;
  width: 0px;
  height: 0px;
  border-left: 16px solid #fff;
  border-top: 12px solid transparent;
  border-bottom: 12px solid transparent;

}

.slick-prev:before {
  display: block;
  content: '' !important;
  opacity: 1 !important;
  left: 5px;
  width: 0px;
  height: 0px;
  border-right: 16px solid #fff;
  border-top: 12px solid transparent;
  border-bottom: 12px solid transparent;
}

.slick-dots {
  display: none !important;
}

#container .item-wrapper .item-box .slider .slick-dots {
  display: none !important;
  position: absolute;
  width: 100%;
  padding: 0;
  margin: 0;
  list-style: none;
  text-align: center;
  top: 92%;
}

.slick-slide {
  height:auto !important;
  line-height: 0;
}

.slick-slide div{
  height:100%;
}

#js-slider-7 img {
  width: calc(100vw / 3);
}

@media screen and (max-width: 768px) {
  #js-slider-7 img {
    width: 100vw;
  }
}

/*sp*/
@media screen and (max-width: 768px) {
  .pc {
    display: none !important;
  }

  .sp {
    display: block !important;
  }

  .font {
    font-size: 1.9em !important;
  }

  .posiR {
    position: relative;
  }

  .small {
    width: 70%;
  }

  .mid {
    width: 90%;
  }

  .large {
    width: 100%;
  }

  body {
    position: relative;
    overflow-x: hidden;
  }

.main_visual .kv-box {
  height: auto;
}

.main_visual .kv-box .kv-text:first-child {
  margin-bottom: 10px;
  margin-top: 10px;
  width: 98%;
  margin-right: auto;
  margin-left: auto;
}

.main_visual .kv-box .kv-text:last-child {
  margin-bottom: 30px;
  margin-top: 10px;
  width: 98%;
  margin-right: auto;
  margin-left: auto;
}

.main_visual .kv-box .kv .ttl .textanimation {
  color: #fff;
  font-family: "ivyora-display", serif;
  font-weight: 300;
  font-style: normal;
  font-size: 6.2rem;
  line-height: 1;
  white-space: nowrap;
}

.a-look .time p {
  font-size: 17px;
}

.a-look .time .time-cap {
  margin-top: 10px;
  font-size: 10px;
}

#modal-wrapper .looks .look {
  width: 90%;
  margin: 0 auto 80px;
}

#modal-wrapper .close {
  width: 40px;
  height: 40px;
  position: fixed;
  top: 30px;
  right: 2%;
  z-index: 999;
  cursor: pointer;
}

#modal-wrapper .looks .look .inner .m-img {
  position: relative;
  margin-top: 20px;
}

.pt50 {
  padding: 30px;
}

.lk18 .snap .snap-ttl{
  width:36%;
 }

 .lk18 .snap .snap-cap{
  width:30%;
 }

.lk18 .snap .snap-ttl p{
  font-size: 15px!important;
}

.lk18 .snap .snap-cap p{
  font-size: 7px!important;
}

.footer-wrapper p,
.footer-wrapper ul li a{
  font-family: "classico-urw", sans-serif!important;
font-weight: 400!important;
font-style: italic!important;
color: #fff;
}

#modal-wrapper .looks .look .inner .credit-box .credit p {
  padding: 15px 5px;
  font-family: "acumin-pro", sans-serif;
  font-weight: 400;
  font-style: normal;
  font-size: 12px;
}

.lk10 .time {
  top: 46%;
}

  /*----------sliderSp ----------*/
  .slider .slick-arrow:before {
    font-size: 24px !important;
  }

  .slick-dotted.slick-slider {
    margin-bottom: 10px !important;
  }

  .slider .slick-next {
    right: 8px !important;
  }

  .slider .slick-prev {
    left: 8px !important;
  }

  #container .item-wrapper .item-box .slider .slick-dots {
    top: 88%;
  }
}

/*----------Sp ----------*/
@media screen and (max-width: 768px) {
  /* sp */

  .start-top {
    animation-delay: 0s;
  }

  .start-top2 {
    animation-delay: 2.2s;
  }

  .delay{
    animation-delay: 0.5s!important;
  }


}

/* fixed設定 */
.pc {
  display: block;
}

@media screen and (max-width: 768px) {
  .pc {
    display: none;
  }
}

.sp {
  display: none;
}

@media screen and (max-width: 768px) {
  .sp {
    display: block;
  }
}

.description>#container {
  overflow: visible;
}

#container {
  background-color: #fff;
  max-width: 100vw;
  position: relative;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  margin-right: calc(50% - 50vw + var(--scroll-bar-width) / 2);
  margin-left: calc(50% - 50vw + var(--scroll-bar-width) / 2);
}

@media screen and (max-width: 1002px) {
  #container {
    margin: 0;
  }
}

#container img {
  width: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}

#container .l-articleLayout__wrap {
  margin: 0 auto;
  display: flow-root;
  max-width: 1280px;
  width: 90%;
}

@media screen and (max-width: 768px) {
  #container .l-articleLayout__wrap {
    width: 100%;
  }
}

#container .l-articleLayout__article {
  float: right;
  width: 59%;
  transition: 0.85s ease;
  position: relative;
  top: 0;
}

@media screen and (max-width: 768px) {
  #container .l-articleLayout__article {
    float: none;
    left: 0;
    margin: 0 auto;
    width: auto;
  }
}

#container .l-articleLayout__title {
  background-color: #fff;
  position: sticky !important;
  float: left;
  width: 40%;
  height: 100vh;
}

#container .l-articleLayout__title>.wrap {
  height: calc(100vh - 120px);
  display: block;
  flex-wrap: wrap;
  align-items: center;
}

#container .d-fixed-area {
  position: relative;
}

#container .d-fixed-element {
  position: absolute;
  top: 0;
}

#container .d-fixed-element.is-fixed {
  position: fixed;
}

#container .l-articleLayout {
  background-attachment: fixed;
  background-position: top left;
  background-size: cover;
}

#container .main_visual {
  width: 100%;
  margin: 0 auto;
}

@media screen and (max-width: 768px) {
  #container .main_visual {
    width: 100%;
  }
}

#container #contents {
  background-color: #fff;
  width: 100%;
}

@media screen and (max-width: 768px) {
  #container #contents {
    width: 100vw;
  }
}