.ff-en {
  font-family: "Barlow", sans-serif;
}

.ff-ja1 {
  font-family: "Noto Sans JP", sans-serif;
}

.ff-ja2 {
  font-family: "source-han-serif", serif;
}

.vertical-rl {
  -webkit-writing-mode: vertical-rl;
      -ms-writing-mode: tb-rl;
          writing-mode: vertical-rl;
}

.comingsoon {
  pointer-events: none !important;
}

.js-inview {
  opacity: 0;
  visibility: hidden;
  -webkit-transform: translateY(100px);
          transform: translateY(100px);
  -webkit-transition: all .8s;
  transition: all .8s;
}

.is-inview {
  opacity: 1;
  visibility: visible;
  -webkit-transform: none;
          transform: none;
}

.top-mv {
  position: relative;
}

.top-mv__slide {
  height: 100%;
}

.top-mv__slide a {
  display: block;
  height: 100%;
  position: relative;
}

.top-mv__slide span {
  -webkit-transform: scale(1.1);
          transform: scale(1.1);
  transition: transform 10s linear, -webkit-transform 10s linear;
  display: block;
  width: 100%;
  height: 100%;
  background-size: cover;
  background-position: center center;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
}

.top-mv__slide.slide-animation span {
  -webkit-transform: none;
          transform: none;
}

.top-mv__arrows {
  position: absolute;
  right: 0;
  bottom: 25px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 100%;
}

.top-mv__arrows button {
  display: block;
  width: 12px;
}

.top-mv__arrows button.prev {
  margin: 0 12.5px 0 0;
}

.top-mv__arrows button.next {
  margin: 0 0 0 12.5px;
}

.top-mv__arrows button.next img {
  -webkit-transform: rotate(180deg);
          transform: rotate(180deg);
}

.top-mv__arrows .dots {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin: 0 -2.5px;
}

.top-mv__arrows .dots li {
  width: 18px;
  height: 1px;
  background: #686868;
  margin: 0 2.5px;
}

.top-mv__arrows .dots li.is-active {
  background: #fff;
}

.top-head {
  padding-top: 43px;
}

.top-head__title {
  font-family: "source-han-serif", serif;
  font-size: 1.7rem;
  font-weight: 500;
  letter-spacing: 0.12em;
  line-height: 1.7;
}

.top-head__title span {
  display: block;
  font-size: 1.3rem;
}

.top-head__cat {
  margin: 47px 0 0;
  padding: 0 20px;
  border-bottom: solid 1px rgba(255, 255, 255, 0.3);
}

.top-head__cat__filter {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin: 0 -2.5px;
}

.top-head__cat__filter li {
  -ms-flex-preferred-size: 80px;
      flex-basis: 80px;
  margin: 0 2.5px;
}

.top-head__cat__filter label {
  display: block;
}

.top-head__cat__filter label span {
  cursor: pointer;
}

.top-head__cat__filter input {
  display: none;
}

.top-head__cat__filter input:checked + span {
  background: #4a4a4a;
  color: #b6b6b6;
  cursor: default;
}

.top-head__cat__filter input + span {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  height: 25px;
  background: #c0c0c0;
  border-radius: 3px 3px 0 0;
  font-size: 0.9rem;
  letter-spacing: 0.12em;
  color: #000;
  text-align: center;
}

.top-list {
  margin: 30px 0 0;
  -webkit-transition: opacity .3s;
  transition: opacity .3s;
}

.top-list.is-filter {
  opacity: 0;
}

@media only screen and (min-width: 769px) {
  .top-mv__slide a {
    height: 100%;
  }
  .top-mv__arrows {
    width: auto;
    right: 54px;
    bottom: 36px;
  }
  .top-mv__arrows button {
    width: 16px;
  }
  .top-mv__arrows button.prev {
    margin: 0 12px 0 0;
  }
  .top-mv__arrows button.next {
    margin: 0 0 0 12px;
  }
  .top-mv__arrows .dots {
    margin: 0 -4.5px;
  }
  .top-mv__arrows .dots li {
    width: 24px;
    margin: 0 4.5px;
  }
  .top-head {
    padding-top: 95px;
  }
  .top-head__title {
    font-size: 3.4rem;
  }
  .top-head__title span {
    font-size: 2.6rem;
  }
  .top-head__cat {
    margin: 66px 0 0;
    padding: 0 40px;
  }
  .top-head__cat__filter {
    -webkit-box-pack: end;
        -ms-flex-pack: end;
            justify-content: flex-end;
  }
  .top-head__cat__filter li {
    -ms-flex-preferred-size: 150px;
        flex-basis: 150px;
  }
  .top-head__cat__filter input + span {
    height: 30px;
    font-size: 1.4rem;
  }
  .top-list {
    margin-top: 40px;
  }
}

@media only screen and (max-width: 769px) {
  .top-head .c-l-column {
    padding: 0 20px;
  }
  .top-mv__slide span.for-sp{ display: block;}
  .top-mv__slide span.for-pc{ display: none;}
}
