@charset "UTF-8";

.container {
    width: 90%;
    max-width: 1140px;
    margin: 0 auto;
}

.wrap {
    width: 90%;
    margin: 0 auto;
  }
  
  .demo01 {
    margin: 0 auto;
  }
  
  .item {
    width: 300px;
    margin-bottom: 5px;
  }
  
  .item img {
    width: 100%;
  }


  /*全て共通：hideエリアをはじめは非表示*/
.hide-area{
	display: none;
}

.caption{
    display: block;
    padding: 10px 0;
    width: 200px;
    height: 100px;
    background-color: #fff;
}


/*画像の横幅を100%にしてレスポンシブ化*/
img{
	max-width:100%;
	height:auto;
	vertical-align: bottom;/*画像の下にできる余白を削除*/
}



.trigger {
  cursor: pointer;
}

.modal {
  display: none;
  position: fixed;
  height: 100vh;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 100;
}
.modal__overlay {
  background: rgba(0, 0, 0, 0.8);
  height: 100vh;
  position: absolute;
  width: 100%;
}
.modal__close {
  position: absolute;
  top: -80px;
  font-weight: 20;
  right: 0;
  font-size: 40px;
  color: #fff;
}
.modal__contents {
  background: transparent;
  width: 100%;
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  z-index: 100;
}
.modal__contents__detail {
  display: flex;
  position: relative;
  height: 100vh;
}
.modal__contents__detail__img {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  -webkit-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  width: 100%;
  text-align: center;
}

.modal__contents__detail__txt {
  background-color: #fff;
  position: absolute;
  top: 40px;
  left: 160px;
  width: 220px;
  height: 136px;
  font-size: 10px;
  padding: 10px;
}


.works-img__wrap {
  width: 100%;
  max-width: 1140px;
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-start;
}
.works-img__wrap-top {
  width: 100%;
  max-width: 1140px;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}

.works-item {
  margin-bottom: 2px;
  padding: 0 1px;
}
.works-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.item-01,.item-01-top {
  width: 16.6%;
}
.item-02,.item-02-top {
  width: 53%;
}
.item-03,.item-03-top {
  width: 29.6%;
}
.item-04,.item-04-top {
  width: 19%;
}
.item-05,.item-05-top {
  width: 19%;
}
.item-06,.item-06-top {
  width: 61.3%;
}
.item-07,.item-07-top {
  width: 63.6%;
}
.item-08,.item-08-top {
  width: 35.9%;
}

.item-01,.item-02,.item-03,
.item-04,.item-05,.item-06,
.item-07,.item-08 {
  max-height: 300px;
}

.item-01-top,.item-02-top,.item-03-top,
.item-04-top,.item-05-top,.item-06-top,
.item-07-top,.item-08-top {
  max-height: 400px;
}


@media screen and (max-width: 767px) {

.works-img__wrap-top {
  width: 100%;
  max-width: 1140px;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
}

.item-01-top,.item-02-top,.item-03-top,
.item-04-top,.item-05-top,.item-06-top,
.item-07-top,.item-08-top {
  width: 100%;
  max-height: 100%;
}

}



.big_img-cats-2 {
  position: absolute;
  font-size: 0.875rem;
  line-height: 1.16;
  left: 2vw;
  bottom: 10.625vw;
  font-family: "Helvetica";
  color: #000000;
}

@media screen and (max-width: 1050px) {
  .big_img-cats-2 {
    left: 49vw;
    top: -15vw;
    bottom: auto;
  }
}

.big_img-cats-2.open {
  z-index: 9998;
  color: #E5E5E5;
  position: fixed;
  bottom: 6.75vw;
}

@media screen and (max-width: 1050px) {
  .big_img-cats-2.open {
    top: 23.66667vw;
    bottom: auto;
  }
}

@media screen and (max-width: 1050px) {
  .big_img-cats a::after {
    position: absolute;
    right: 0;
    bottom: 0;
    width: 100%;
    height: 1px;
    background-color: #000;
    transition: all .3s;
    content: "";
  }
}



.header-nav--add {
  display: none!important;
}
.header-nav--add img {
  max-width: 15px;
}
.header-nav--add li {
  margin: 5px 0;
}

.header-nav_con-txt a {
  color: #000!important;
  position: relative;
}
.header-nav_con-txt a::after {
  position: absolute;
  right: 0;
  bottom: 0;
  width: 100%;
  height: 1px;
  background-color: #000;
  transition: all .3s;
  content: "";
} 

.big_img-cats-2 {
  bottom: 19vh;
}

@media screen and (max-width: 1050px) {

  .header-nav--add {
    display: block!important;
  }

  .big_img-cats.open, .big_img-cats-2.open {
    display: none;
  }

}



  /*--スライダーの位置とサイズ調整--*/
  .slider{
    width: 100%;
    max-width:62.1875vw;
    margin:0 auto;
    }
  
    /*--------画像サイズ調整---------*/
    img{
    max-width:62.1875vw;
    max-height: 100vh;
    }
    
    /*-----------height調整----------*/
    .slick-slide{
      height:auto!important;
    }
  
    /*-----------矢印表示----------*/
    .slick-next{
      right:0!important;
    }
    .slick-prev{
      left:0!important;
      width: 0px!important;
    }
    .slick-arrow{
      z-index:2!important;
    }
  /*------------------------------*/

  .slick-dots li button:before{
    font-size:10px!important;
    content: "●";
    top: -25px;
    left: 24vw;
    color: #fff;
  }

  @media screen and (max-width: 1050px) {
    .slider{
      max-width: 100%;
      }
    img{
      max-width: 100%;
      max-height: auto;
      }
    .slick-dots li button:before{
      left: 50%;
    }
  }


.works-menu__wrap {
  margin-bottom: 30px;
}
.works-menu__ttl {
  font-size: 40px;
  color: #000;
  margin-right: 30px;
  position: relative;
}
.works-menu__ttl.active::after {
  content: '';
  position: absolute;
  left: 0;
  bottom: -3px;
  width: 100%;
  height: 2px;
  background-color: #000;
}

.works-menu__ttl a {
  color: #000;
}

.works-menu__ttl a:visited {
  color: #000;
}


.con-insta__wrap {
  position: relative;
  height: 100vh;
}


.big_img-cats-3 {
  position: fixed;
  font-size: 0.875rem;
  line-height: 1.16;
  top: 64vh;
  left: 30px;
  font-family: "Helvetica";
  color: #000000;
}

.big_img-cats-3 a {
  color: #000000!important;
}

@media screen and (max-width: 1050px) {
  .big_img-cats-3 {
    /*
    left: 0vw;
    top: 0vw;
    bottom: auto;
    */
    display: none;
  }
}

.big_img-cats-3.open {
  z-index: 9998;
  color: #E5E5E5;
  position: fixed;
  top: auto;
  bottom: 9.75vw;
  left: 5.625vw;
}

@media screen and (max-width: 1050px) {
  .big_img-cats-3.open {
    top: 22.66667vw;
    bottom: auto;
  }
}


.big_img-cats-4 {
  position: fixed;
  font-size: 0.875rem;
  line-height: 1.16;
  top: 68vh;
  left: 30px;
  font-family: "Helvetica";
  color: #000000;
}


@media screen and (max-width: 1050px) {
  .big_img-cats-4 {
    /*
    left: 49vw;
    top: -15vw;
    bottom: auto;
    */
    display: none;
  }
}

.big_img-cats-4.open {
  z-index: 9998;
  color: #E5E5E5;
  position: fixed;
  top: auto;
  bottom: 6.75vw;
  left: 5.625vw;
}

@media screen and (max-width: 1050px) {
  .big_img-cats-4.open {
    top: 23.66667vw;
    bottom: auto;
  }
}