  @charset "utf-8";

@import url(https://fonts.googleapis.com/earlyaccess/notosansjapanese.css);


/*  add for Slider  */

.main_slider {
    position: relative;
    width: 100%;
    height: 45.5vw;
    padding: 0;
    overflow: hidden;
}
.main_slider.slick-initialized {
  opacity: 1;
  visibility: visible;
}

.slick-slide {
    position: relative;
    margin: 0;
    padding: 0;
    height: 45.5vw;
    overflow: hidden;
}
.slick-slide::before {
  background-color: #000;
  opacity: .3;
  z-index: 1;
}
.slick-slide img {
    line-height: 1;
}
.slick-slide video {
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  min-width: 100%;
  min-height: 100%;
  width: auto;
  height: auto;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
}
.slick-slide iframe {
  position: relative;
  pointer-events: none;
}
.slick-slide figure {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
  position: relative;
  height: 100%;
}
.slick-slide .slide-image {
  opacity: 0;
  height: 100%;
  background-size: cover;
  background-position: center;
  transition: all .8s ease;
}
.slick-slide .slide-image.show {
  opacity: 1;
}
.slick-slide .image-entity {
  width: 100%;
  opacity: 0;
  visibility: hidden;
}
.slick-slide .loading {
  position: absolute;
  top: 44%;
  left: 0;
  width: 100%;
}
.slick-slide.slick-active {
  z-index: 1;
}
.slick-slide.slick-active .caption {
  opacity: 1;
  -webkit-transform: translateY(0);
          transform: translateY(0);
  transition: all 0.7s cubic-bezier(0.32, 0.34, 0, 1.62) 0.6s;
}

.caption {
  position: absolute;
  top: 44%;
  left: 5%;
  text-align: center;
  padding: 20px;
  border: 3px solid;
  color: #fff;
  margin: 0;
  font-size: 40px;
  font-weight: bold;
  letter-spacing: .02em;
  opacity: 0;
  z-index: 1;
  transition: all .3s ease;
  -webkit-transform: translateY(100px);
          transform: translateY(100px);
}

.slick-dots {
    display: block!important;
    position: relative;
    margin: -40px 0 0;
    padding: 0;
    text-align: center;
    z-index: 2;
}
.slick-dots li {
    display: inline-block;
    vertical-align: top;
    margin: 0 10px;
}
.slick-dots li button {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
    width: 10px;
    height: 10px;
    border: none;
    cursor: pointer;
    border-radius: 50%;
    vertical-align: middle;
    color: #fff;
    background-color: #ccc;
    transition: all .3s ease;
    text-indent: -9999px;
}
.slick-dots li button:focus {
    outline: none;
}
.slick-dots li.slick-active button {
    background-color: #00a7ac;
}

.slick_prev,
.slick_next {
    position: absolute;
    top: 50%;
    left: 20px;
    z-index: 2;
    width: 40px;
    height: 40px;
    background: url("/jp/shared/images/btn_prev.png") center no-repeat;
    background-size: cover;
    border: none;
    cursor: pointer;
    text-indent: -9999px;
    transition: .3s;
    outline: none;
}
.slick_next {
    left: auto;
    right: 20px;
    background: url("/jp/shared/images/btn_next.png") center no-repeat;
    background-size: cover;
}
.slick_prev:hover,
.slick_next:hover {
    opacity: .7;
}


.mainSlideAdd img {
    width: 100%;
}
.mainSlideAdd img.spVis {
    display: none;
}

.mainSlideAdd .item a {
    margin: 0;
    padding: 0;
}


.youtube {
    position: relative;
    background: #000;
}
.youtube_area {
    position: absolute;
    top: -25vw;
    width: 100%;
    height: 100vw;
    overflow: hidden;
}
.youtube a {
    display: block;
}

/* slide height */

.main_slider,
.slick-slide {
    min-height: 575px;
}

/* random */

.slick-slide {
    display: none;
}


@media screen and (max-width: 767px){
    
    .mainSlideAdd img.spVis {
        display: block;
    }
    .mainSlideAdd img.pcVis {
        display: none;
    }
    
    .main_slider {
        height: 80vw;
    }
    .slick-slide {
        height: 80vw;
    }

    .slick_prev,
    .slick_next {
        display: none!important;    
    }

    .slick-dots {
        margin: -8vw 0 0;
    }
    .youtube_area {
        position: relative;
        top: auto;
        width: 144%;
        height: 80vw;
        margin: 0 0 0 -22%;
    }

    /* slide height */

    .main_slider,
    .slick-slide {
        min-height: auto;
    }

    .slick-slide .slidefade {
      -webkit-animation: slideOut 0.4s cubic-bezier(0.4, 0.29, 0.01, 1);
              animation: slideOut 0.4s cubic-bezier(0.4, 0.29, 0.01, 1);
    }
    .slick-slide.slick-active {
      z-index: 1;
    }
    .slick-slide.slick-active .slidefade {
      -webkit-animation: slideIn 2.4s cubic-bezier(0.4, 0.29, 0.01, 1);
              animation: slideIn 2.4s cubic-bezier(0.4, 0.29, 0.01, 1);
    }
    .slick-slide.slick-active .caption {
      opacity: 1;
      -webkit-transform: translateY(0);
              transform: translateY(0);
      transition: all 0.7s cubic-bezier(0.32, 0.34, 0, 1.62) 0.6s;
    }

}

@-webkit-keyframes slideIn {
  from {
    -webkit-filter: blur(15px);
            filter: blur(15px);
  }
  to {
    -webkit-filter: blur(0);
            filter: blur(0);
  }
}

@keyframes slideIn {
  from {
    -webkit-filter: blur(15px);
            filter: blur(15px);
  }
  to {
    -webkit-filter: blur(0);
            filter: blur(0);
  }
}
@-webkit-keyframes slideOut {
  from {
    -webkit-filter: blur(0);
            filter: blur(0);
  }
  to {
    -webkit-filter: blur(15px);
            filter: blur(15px);
  }
}
@keyframes slideOut {
  from {
    -webkit-filter: blur(0);
            filter: blur(0);
  }
  to {
    -webkit-filter: blur(15px);
            filter: blur(15px);
  }
}