@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;
  font-size: 13px;
  font-family: "yu-gothic-pr6n", sans-serif;
  font-weight: 400;
  font-style: normal;
}

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

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

body.loaded {
  position: static;
}

body.looking {
  overflow: hidden;
}

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

a:hover,
a:active,
a.active {
  color: #C3C3C3;
}

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;
}

/* ------------------------------------------------------------------------------------------------------------------------ */

#container .kv-box {
  width: 100vw;
  margin: 0 auto;
  position: relative;
  background-color: #1E1E1E;
}

#container .kv-box .kv{
  display: flex;
  justify-content: center;
  align-items: flex-start;
}

#container .kv-box .sp{
  display: none;
  justify-content: center;
  align-items: flex-start;
}

#container .kv-box .kv .img{
  width:50%;
}

#container .kv-box .ttl-box{
  width: 33%;
  position: absolute;
  top: 25%;
    left: 50%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
}

#container .kv-box .ttl-box .sub-ttl{
  width: 70%;
  margin: 30px 0 0 auto;
}

#container .kv-box .brand{
  width: 20%;
  position: absolute;
  top: 98%;
    left: 50%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
}

#container .lead-box{
  background-color: #1E1E1E;
  color: #fff;
  padding-top: 100px;
  padding-bottom: 100px;
}

#container .lead-box .lead{
  font-family: "fot-udmincho-pr6n", sans-serif;
font-weight: 300;
font-style: normal;
line-height: 1.8;
font-size: 16px;
}

#container .look-box .bg-area{
  position: relative;
}

#container .look-box .bg-area .bg-bk{
  background-color:#1E1E1E;
  height:1200px;
  width:100%;
  position: absolute;
  top:0%;
}

#container .look-box .look{
  margin-bottom: 100px;
}

#container .look-box .lk1{
  position: relative;
  z-index: 10;
}

#container .look-box .lk1 .photo{
  width: 50%;
  max-width: 650px;
  margin: 0 auto 100px;
}

#container .look-box .lk1 .photo-box{
  width: 30%;
  max-width: 450px;
  margin: 0 auto;
}

#container .look-box .lk2{
  width: 50%;
  max-width: 650px;
  margin: 0 auto;
}

#container .look-box .lk2{
  width: 50%;
  max-width: 650px;
  margin: 0 auto 100px;
}

#container .look-box .lk2 .photo-box .slider4-wrap .slider-5 li{
  border: #000 1px solid;
}

#container .look-box .lk3 {
  margin-bottom: 0;
}

#container .look-box .lk3 .sticky-box{
  position: relative;
}

#container .look-box .lk3 .sticky-box .photo{
  position: sticky;
  top:-40%;
  z-index: -1;
}

#container .look-box .lk3 .sticky-box .flex{
  display: flex;
  width:70%;
  margin: 0 auto 100px;
  justify-content: space-between;
  align-items: flex-start;
  flex-wrap: wrap;
}

#container .look-box .lk3 .sticky-box .photoL{
  width: 50%;
  margin-left: 0;
  margin-right: auto;
  margin-top: -200px;
}

#container .look-box .lk3 .sticky-box .photoR{
  width: 70%;
  margin-left: auto;
  margin-right: 0;
}

#container .look-box .lk3 .photo-box{
  width: 50%;
  max-width: 650px;
  margin: 0 auto;
  padding-bottom: 100px;
}

#container .look-box .lk3 .photo-box div img{
  border: #000 1px solid;
}

#container .look-box .lk3 .photo-box .credit-box{
  background-color: rgba(255, 255, 255, 0.7);
}

#container .look-box .lk9 .photo-box .credit-box{
  background-color: rgba(255, 255, 255, 0.4);
}

#container .look-box .lk4{
  background-color: #1E1E1E;
  padding-bottom: 100px;
  padding-top: 100px;
  margin-bottom: 0;
}

#container .look-box .lk4 .photo{
  width:50%;
  max-width: 650px;
  margin: 0 auto 30px;
}

#container .look-box .lk4 .photo-box{
  width:50%;
  max-width: 650px;
  margin: 0 auto;
}

#container .look-box .lk4 .photo-box .credit-box p{
  color: #fff;
}

#container .look-box .lk5{
  margin-bottom: 0;
}

#container .look-box .lk5 .sticky-box{
  position: relative;
}

#container .look-box .lk5 .sticky-box .photo{
  position: sticky;
  top:-40%;
  z-index: -1;
}

#container .look-box .lk5 .sticky-box .small{
  width:80%;
  margin: 0 auto 100px;
  text-align: right;
}

#container .look-box .lk5 .sticky-box .small img{
  width:60%;
}

#container .look-box .lk5 .sticky-box .photo-box{
  width:50%;
  max-width: 650px;
  margin: 0 auto;
  padding-bottom: 100px;
}

#container .look-box .lk5 .sticky-box .photo-box .credit-box{
  background-color: rgba(255, 255, 255, 0.5);
}

#container .look-box .lk6{
  width:45%;
  max-width: 550px;
  margin: 100px auto 100px;
}

#container .look-box .lk7 .flex{
  width:100%;
  margin-bottom:100px;
  display: flex;
}

#container .look-box .lk7 .photo-box{
  width:50%;
  max-width: 650px;
  margin: 0 auto;
}

#container .look-box .lk8{
  background-color: #1E1E1E;
  padding-bottom: 100px;
  padding-top: 100px;
  margin-bottom: 0;
}

#container .look-box .lk8 .photo{
  width: 60%;
  margin: 0 auto 100px;
  text-align: left;
}

#container .look-box .lk8 .photo img{
  width: 70%;
}

#container .look-box .lk8 .photo-box{
  width: 60%;
  margin: 0 auto;
  text-align: right;
}

#container .look-box .lk8 .photo-box img{
  width: 50%;
}

#container .look-box .lk8 .photo-box .credit-box{
  width: 50%;
  margin-right: 0;
  margin-left: auto;
}

#container .look-box .lk8 .photo-box .credit-box p{
  color: #fff;
}

#container .look-box .lk9{
  margin-bottom: 0px;
}

#container .look-box .lk9 .small{
  width:45%;
  max-width: 550px;
  margin: 100px auto;
}

#container .look-box .lk9 .sticky-box{
  position: relative;
}

#container .look-box .lk9 .sticky-box .photo{
  position: sticky;
  top:-30%;
  width: 100%;
  z-index: -1;
}

#container .look-box .lk9 .photo-box{
  width:45%;
  max-width: 550px;
  margin: 0 auto;
  padding-bottom: 100px;
}

#container .look-box .lk9 .staff{
  width:45%;
  max-width: 550px;
  margin: 0 auto;
  padding-bottom: 50px;
  padding-top: 50px;
  border-top: #000 1px solid;
}

#container .look-box .lk9 .staff p{
  line-height: 2;
  font-size: 10px;
  font-family: "forevs", sans-serif;
font-weight: 400;
font-style: normal;
letter-spacing: 0.13em;
}


.credit-box{
  text-align: left;
    margin-top: 20px;
    padding-left: 5px;
    padding-right: 5px;
}

.credit-box p{
  margin-bottom: 10px;
  font-family: "forevs", sans-serif;
font-weight: 400;
font-style: normal;
}

.credit-box p a{
  margin-left: 10px;
  text-decoration: none;
}

.credit-box p a:hover{
  color: #888888;
}

.credit-box .main-item{
  margin-bottom: 25px;
}

.credit-box .main-item p{
  font-weight: 500;
  margin-bottom: 10px;
  line-height: 1.5;
  font-size: 20px;
  letter-spacing: 0.1em;
}

.credit-box .other-item p{
  margin-bottom: 8px;
  line-height: 1.5;
  font-size: 14px;
  letter-spacing: 0.1em;
}

#container .look-box .lk4 .photo-box .credit-box p a{
  color: #fff;
}

#container .look-box .lk8 .photo-box .credit-box p a{
  color: #fff;
}

.footer-wrapper .navi-box ul li {
  font-size: 11px;
}

/*footer*/
.footer-wrapper{
  width: 100%;
  margin: 0 auto;
  background-color: #1E1E1E;
  z-index: 2000;
  position: relative;
  padding-top: 50px;
}

.footer-wrapper p{
  font-family: "forevs", sans-serif;
font-weight: 400;
font-style: normal;
  color: #fff;
}

.footer-wrapper a {
  color: #fff;
}

.footer-wrapper a:hover {
  text-decoration: none;
  color: #ffffffce;
}

.footer-wrapper .brand{
  width:150px;
  margin: 0 auto 50px;
}

.footer-wrapper .info{
  margin: 0 auto 50px;
}

.footer-wrapper .info p{
font-family: "fot-udmincho-pr6n", sans-serif;
font-weight: 300;
font-style: normal;
line-height: 1.8;
font-size: 12px;
}

.footer-wrapper .navi-box{
  margin-bottom: 50px;
}

.footer-wrapper .navi-box p{
  font-family: "acumin-pro", sans-serif;
font-weight: 300;
font-style: normal;
text-align: center;
  font-size: 12px;
}

.footer-wrapper .copy {
  margin: 0px auto;
  padding-bottom: 20px;
}

.footer-wrapper .copy p{
  font-family: "acumin-pro", sans-serif;
font-weight: 300;
font-style: normal;
text-align: center;
  font-size: 9px;
}



/*set*/

.pc {
  display: block;
}

.sp {
  display: none;
}

.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;
}

.delay1{
  animation-delay: 0.2s!important;
}

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

.delay3{
  animation-delay: 0.8s!important;
}

.delay-top{
  animation-delay: 1s!important;
}

.non-delay{
  animation-delay: 0s!important;
}

.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: 0.8s;
  animation-duration: 0.8s;
  -webkit-animation-fill-mode: both;
  animation-fill-mode: both;
  animation-delay: .2s;
}

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

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

  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(0px);
    -moz-filter: blur(0px);
    -ms-filter: blur(0px);
    -o-filter: blur(0px);
    filter: blur(0px);
  }

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

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

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

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

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

.slider .slick-prev {
  left: -25px !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: .7 !important;
  left: 5px;
	width: 20px;
	height: 20px;
	border-top: 1px solid #7e7e7e;
	border-right: 1px solid #7e7e7e;
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
}

.slick-prev:before {
  display: block;
  content: '' !important;
  opacity: .7 !important;
  left: 5px;
	width: 20px;
	height: 20px;
	border-top: 1px solid #7e7e7e;
	border-right: 1px solid #7e7e7e;
	-webkit-transform: rotate(225deg);
	transform: rotate(225deg);
}

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

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

/*モノクロから色づくCSS*/
.fadeInMonoTrigger {
  filter: grayscale(100%);
}

.fadeInMono {
  animation: fadeInMonoAnime .5s .8s both;
  filter: grayscale(1) brightness(1.1);
  transition: all 0.5s ease-in;
}

@keyframes fadeInMonoAnime {
  0% {}

  100% {
    -webkit-filter: grayscale(0%);
    filter: grayscale(0) brightness(1)
  }
}

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

.start0 {
  animation: fade 1s ease-in 0.2s 1 normal backwards;
}

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

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

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

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

  100% {
    opacity: 1;
  }
}

/*スクロールの設定*/

.scroll_container {
  height:400vh;
  margin: 0px calc(50% - 50vw);
  width: 100vw;
  padding-top: 80px;
  padding-bottom: 80px;
}

.horizontal_scroll {
  position: absolute;
  top: 25%;
  left: 5%;
  height: auto;
  width: 200vw;
  will-change: transform;
  display: flex;
  justify-content:flex-end;
}

.scroll_contents {
  height: 100%;
  width: 100vw;
}

.sticky_wrap {
  overflow: hidden;
  position: sticky;
  top: -10%;
  height:100vh;
}

/*=============== SVGアニメーション内の指定 =================*/

/*アニメーション前の指定*/
#mask path {
  fill-opacity: 0;/*最初は透過0で見えない状態*/
  transition: fill-opacity 1s;/*カラーがつく際のアニメーション0.5秒で変化*/
  fill: none;/*塗りがない状態*/
  stroke: #fff;/*線の色*/
}

/*アニメーション後に.doneというクラス名がで付与された時の指定*/
#mask.done path{
  fill: #fff;/*塗りの色*/
  fill-opacity: 1;/*透過1で見える状態*/
  stroke: none;/*線の色なし*/
}

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

  .sp {
    display: block !important;
  }


  body {
    position: relative;
  }

  #container {
    display: block;
  }

  #container .kv-box .sp{
    display: block;
  }

  #container .kv-box .pc{
    display: none;
  }
  
  #container .kv-box .kv .img {
    width: 100%;
}

#container .kv-box .ttl-box {
  width: 80%;
  top: 33%;
  left: 43%;
}

#container .kv-box .ttl-box .sub-ttl {
  width: 75%;
  margin: 20px 0 0 auto;
}

#container .kv-box .brand {
  width: 40%;
  top: 99%;
}

#container .lead-box {
  padding-top: 50px;
  padding-bottom: 50px;
}

#container .lead-box .lead {
  font-size: 13px;
}

#container .look-box .look {
  margin-bottom: 50px;
}

#container .look-box .lk1 .photo {
  width: 100%;
  margin: 0 auto 50px;
}

#container .look-box .lk1 .photo-box {
  width: 70%;
  max-width: 450px;
  margin: 0 auto;
}

#container .look-box .bg-area .bg-bk {
  height: 680px;
}

#container .look-box .lk2 {
  width: 80%;
  max-width: 650px;
  margin: 0 auto 50px;
}

#container .look-box .lk3 {
  margin-bottom: 0;
}

#container .look-box .lk3 .sticky-box .flex {
  width: 90%;
  margin: 0 auto 50px;
}

#container .look-box .lk3 .sticky-box .photo {
  top: 20%;
  margin-bottom: 355px;
}

#container .look-box .lk3 .sticky-box .photoR {
  width: 85%;
}

#container .look-box .lk3 .sticky-box .photoL {
  width: 60%;
  margin-left: 0;
  margin-right: auto;
  margin-top: -40px;
}

#container .look-box .lk3 .photo-box {
  width: 90%;
  padding-bottom: 50px;
}

#container .look-box .lk4 {
  padding-bottom: 50px;
  padding-top: 50px;
}

#container .look-box .lk4 .photo {
  width: 80%;
  margin: 0 auto 20px;
}

#container .look-box .lk4 .photo-box {
  width: 80%;
}

#container .look-box .lk4 {
  margin-bottom: 0px;
}

#container .look-box .lk5 .sticky-box .photo {
  top: 7%;
}

#container .look-box .lk5 .sticky-box .small {
  width: 100%;
  margin: 0 auto 50px;
}

#container .look-box .lk5 .sticky-box .small img {
  width: 70%;
}

#container .look-box .lk5 .sticky-box .photo-box {
  width: 70%;
  margin: 0 auto;
  padding-bottom: 50px;
}

#container .look-box .lk6 {
  width: 80%;
  margin: 50px auto 0px;
}

.scroll_container {
  padding-top: 0px;
  padding-bottom: 0px;
  height: 200vh;
}

.horizontal_scroll {
  position: absolute;
  top: 25%;
  left: 20%;
  height: auto;
  width: 200vw;
  will-change: transform;
  display: flex;
  justify-content: flex-end;
  margin-top: -100px;
}

#container .look-box .lk7 .photo-box {
  width: 100%;
  max-width: 650px;
  margin: -300px auto 0;
}

#container .look-box .lk7 .photo-box .credit-box{
  width: 90%;
  margin-left: auto;
  margin-right: auto;
}

#container .look-box .lk8 {
  padding-bottom: 50px;
  padding-top: 50px;
  margin-bottom: 0;
}

#container .look-box .lk8 .photo {
  width: 90%;
  margin: 0 auto 50px;
}

#container .look-box .lk8 .photo img {
  width: 80%;
}

#container .look-box .lk8 .photo-box {
  width: 90%;
}

#container .look-box .lk8 .photo-box img {
  width: 70%;
}

#container .look-box .lk8 .photo-box .credit-box {
  width: 70%;
  margin-right: 0;
  margin-left: auto;
}

#container .look-box .lk9 {
  margin-bottom: 0px;
}

#container .look-box .lk9 .small {
  width: 80%;
  max-width: 550px;
  margin: 50px auto;
}

#container .look-box .lk9 .sticky-box .photo {
  top: 20%;
  margin-bottom: 500px;
}

#container .look-box .lk9 .photo-box {
  width: 90%;
  margin: 0 auto;
  padding-bottom: 50px;
}

#container .look-box .lk9 .staff {
  width: 50%;
  margin: 0 auto;
  padding-bottom: 30px;
  padding-top: 30px;
}

.credit-box {
  margin-top: 15px;
}

.credit-box p{
  font-size: 10px;
}

.credit-box .main-item {
  margin-bottom: 20px;
}

.credit-box .main-item p {
  font-size: 14px;
}

.credit-box .other-item p {
  font-size: 13px;
}



.footer-wrapper {
  padding-top: 50px;
}

.footer-wrapper .brand {
  width: 120px;
  margin: 0 auto 30px;
}

.footer-wrapper .info {
  margin: 0 auto 30px;
}

.footer-wrapper .navi-box {
  margin-bottom: 30px;
}

.footer-wrapper .copy {
  padding-bottom: 40px;
}

#container .look-box .lk3 .photo-box .credit-box{
  background-color: rgba(255, 255, 255, 0);
}

#container .look-box .lk9 .photo-box .credit-box{
  background-color: rgba(255, 255, 255, 0);
}

#container .look-box .lk5 .sticky-box .photo-box .credit-box{
  background-color: rgba(255, 255, 255, 0);
}

}