@charset "euc-jp";

/* indexPage
-------------------- */
.indexMv {
  padding-bottom: 30px;
}
.indexMv__img {
  position: relative;
  padding-top: 140%;
}
.indexMv__img img {
  width: 100%;
}
.indexMv .swiper {
  overflow: hidden;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.indexMv .indexMv__img .swiper-pagination {
  --swiper-pagination-color: #222;
  --swiper-pagination-bullet-size: 10px;
  --swiper-pagination-bullet-horizontal-gap: 6px;
  bottom: -30px;
  padding-left: 10px;
  text-align: left;
}
@media print, (min-width: 600px) {
  .indexMv {
    padding-bottom: 35px;
  }
  .indexMv .indexMv__img .swiper-pagination {
    bottom: -35px;
    padding-left: 15px;
  }
}
@media print, (min-width: 960px) {
  .indexMv__img {
    padding-top: 50%;
  }
}

.indexItem {
  font-size: 0.875rem;
  line-height: 1.66;
  text-align: center;
}
.indexItem a {
  display: block;
  color: #222;
  text-decoration: none;
}
.indexItem__img {
  display: block;
  margin-bottom: 0.33em;
}
.indexItem__img img {
  width: 100%;
}
.indexItem__name {
  display: block;
}
@media print, (min-width: 600px) {
  .indexItem__img {
    margin-bottom: 0.66em;
  }
}

.indexCurl__list {
  overflow: hidden;
  position: relative;
  padding-bottom: 40px;
}
.indexCurl .swiper {
  overflow: visible;
  margin-top: calc(2vw + 22px);
  margin-left: 5%;
  margin-right: 5%;
}
.indexCurl .swiper-pagination {
  --swiper-pagination-color: #222;
  --swiper-pagination-bullet-size: 10px;
  --swiper-pagination-bullet-horizontal-gap: 6px;
  bottom: 0;
}
@media print, (min-width: 960px) {
  .indexCurl__list {
    overflow-x: visible;
    padding-bottom: 0;
  }
  .indexCurl .swiper {
    overflow: hidden;
    width: 90%;
    max-width: 1406px;
    margin: 0 auto;
  }
  .indexCurl .swiper-pagination {
    display: none;
  }
}
@media print, (min-width: 1400px) {
  .indexCurl__list {
    margin-top: 50px;
  }
}

.indexColor,
.indexType,
.indexCategory {
  margin-top: calc(5vw + 60px);
}
@media print, (min-width: 600px) {
  .indexColor,
  .indexType,
  .indexCategory {
    margin-top: calc(5vw + 45px);
  }
}
@media print, (min-width: 960px) {
  .indexColor,
  .indexType,
  .indexCategory {
    margin-top: calc(5vw + 30px);
  }
}
@media print, (min-width: 1400px) {
  .indexColor,
  .indexType,
  .indexCategory {
    margin-top: 100px;
  }
}

.indexColor__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  width: 85%;
  margin: calc(2vw + 22px) auto 0;
}
.indexColor .indexItem {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 50%;
          flex: 0 0 50%;
}
.indexColor .indexItem:nth-child(n+3) {
  margin-top: 8%;
}
.indexColor__black a {
  color: #000;
}
.indexColor__grayish a {
  color: #716c5c;
}
.indexColor__darkbrown a {
  color: #3c2b20;
}
.indexColor__burgundy a {
  color: #7d0000;
}
.indexColor .indexItem__img {
  margin-bottom: 6%;
}
.indexColor .indexItem__img img {
  width: 70%;
}
@media print, (min-width: 960px) {
  .indexColor__list {
    -ms-flex-wrap: nowrap;
        flex-wrap: nowrap;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    width: 91%;
  }
  .indexColor .indexItem {
    -webkit-box-flex: 0;
        -ms-flex: 0 0 19%;
            flex: 0 0 19%;
    margin: 0 0.5%;
  }
  .indexColor .indexItem:nth-child(n+3) {
    margin-top: 0;
  }
  .indexColor .indexItem__img img {
    max-width: 160px;
  }
}
@media print, (min-width: 1400px) {
  .indexColor__list {
    margin-top: 50px;
  }
  .indexColor .indexItem {
    -webkit-box-flex: 0;
        -ms-flex: 0 0 240px;
            flex: 0 0 240px;
    margin: 0 7px;
  }
}

.indexType__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 94%;
  margin: calc(2vw + 22px) auto 0;
}
.indexType .indexItem {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 33.33%;
          flex: 0 0 33.33%;
}
@media print, (min-width: 960px) {
  .indexType__list {
    -ms-flex-wrap: nowrap;
        flex-wrap: nowrap;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    width: 91%;
    margin-top: 0;
  }
  .indexType .indexItem {
    -webkit-box-flex: 0;
        -ms-flex: 0 0 19%;
            flex: 0 0 19%;
    margin: 0 0.5%;
  }
}
@media (min-width: 1540px) {
  .indexType .indexItem {
    -webkit-box-flex: 0;
        -ms-flex: 0 0 270px;
            flex: 0 0 270px;
    margin: 0 7px;
  }
}

.indexCategory__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  width: 90%;
  margin: calc(2vw + 22px) auto 0;
}
.indexCategory .indexItem {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 47.5%;
          flex: 0 0 47.5%;
}
.indexCategory .indexItem:nth-child(2n) {
  margin-left: 5%;
}
.indexCategory .indexItem:nth-child(n+3) {
  margin-top: 5%;
}
@media print, (min-width: 960px) {
  .indexCategory__list {
    -ms-flex-wrap: nowrap;
        flex-wrap: nowrap;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    width: 91%;
  }
  .indexCategory .indexItem {
    -webkit-box-flex: 0;
        -ms-flex: 0 0 19%;
            flex: 0 0 19%;
    margin: 0 0.5%;
  }
  .indexCategory .indexItem:nth-child(2n) {
    margin-left: 0.5%;
  }
  .indexCategory .indexItem:nth-child(n+3) {
    margin-top: 0;
  }
}
@media print, (min-width: 1400px) {
  .indexCategory__list {
    margin-top: 50px;
  }
}
@media (min-width: 1540px) {
  .indexCategory .indexItem {
    -webkit-box-flex: 0;
        -ms-flex: 0 0 270px;
            flex: 0 0 270px;
    margin: 0 7px;
  }
  .indexCategory .indexItem:nth-child(2n) {
    margin-left: 7px;
  }
}

.indexSpecial {
  overflow: hidden;
}
.indexSpecial img {
  width: 100%;
  -webkit-transition: translate 0.7s ease, opacity 0.7s ease;
  transition: translate 0.7s ease, opacity 0.7s ease;
}
.indexSpecial.js-scr-wait img {
  opacity: 0;
  translate: -10%;
}

.indexJournal {
  overflow: hidden;
}
.indexJournal__list {
  position: relative;
  padding-bottom: 40px;
}
.indexJournal a {
  display: block;
  color: #222;
  text-decoration: none;
}
.indexJournal .swiper {
  overflow: visible;
  margin-left: 5%;
  margin-right: 5%;
}
.indexJournal .swiper-pagination {
  --swiper-pagination-color: #222;
  --swiper-pagination-bullet-size: 10px;
  --swiper-pagination-bullet-horizontal-gap: 6px;
  bottom: 0;
}
.indexJournal__img {
  width: 100%;
  margin-bottom: 20px;
}
.indexJournal__img img {
  width: 100%;
}
.indexJournal__category {
  margin-bottom: 11px;
  font-size: 0.625rem;
}
.indexJournal__category span {
  display: inline-block;
  padding: 0.66em 1em;
  background: #000;
  color: #FFF;
}
.indexJournal__title {
  margin-bottom: 5px;
  font-size: 0.875rem;
  font-weight: bold;
  line-height: 1.66;
}
.indexJournal__description {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
  line-clamp: 3;
  overflow: hidden;
  height: 5em;
  font-size: 0.75rem;
  line-height: 1.66;
}
.indexJournal__next, .indexJournal__prev {
  display: none;
}
@media print, (min-width: 600px) {
  .indexJournal__list {
    padding-bottom: 50px;
  }
  .indexJournal__img {
    width: 100%;
    margin-bottom: 30px;
  }
  .indexJournal__category {
    font-size: 0.75rem;
  }
  .indexJournal__title {
    font-size: 1rem;
  }
  .indexJournal__description {
    font-size: 0.875rem;
  }
}
@media print, (min-width: 960px) {
  .indexJournal .swiper {
    overflow: hidden;
    margin-right: 0;
  }
  .indexJournal__prev, .indexJournal__next {
    visibility: hidden;
    display: block;
    position: absolute;
    z-index: 2;
    top: calc(50% - 20px - 25px);
    width: 40px;
    height: 40px;
    border-radius: 100%;
    background: rgba(0, 0, 0, 0.5);
    opacity: 0;
    -webkit-transition: opacity 0.3s;
    transition: opacity 0.3s;
  }
  .indexJournal__prev {
    left: 2%;
  }
  .indexJournal__next {
    right: 2%;
  }
  .indexJournal__list:hover .indexJournal__prev, .indexJournal__list:hover .indexJournal__next {
    visibility: visible;
    opacity: 1;
  }
  .indexJournal__list:hover .indexJournal__prev.swiper-button-disabled, .indexJournal__list:hover .indexJournal__next.swiper-button-disabled {
    opacity: 0.3;
  }
  .indexJournal__prev::before, .indexJournal__next::before {
    position: absolute;
    top: calc(50% - 3px);
    left: calc(50% - 2px);
    content: "";
    display: block;
    width: 6px;
    height: 6px;
    border-left: 1px solid #FFF;
    border-top: 1px solid #FFF;
  }
  .indexJournal__prev::before {
    rotate: -45deg;
  }
  .indexJournal__next::before {
    left: calc(50% - 3px);
    rotate: 135deg;
  }
  .indexJournal__img {
    -webkit-transition: opacity 0.3s ease;
    transition: opacity 0.3s ease;
  }
  a:hover .indexJournal__img {
    opacity: 0.7;
  }
}
@media (min-width: 1500px) {
  .indexJournal .swiper {
    margin-left: calc(50% - 650px);
  }
  .indexJournal__prev {
    left: calc(50% - 650px - 40px - 2%);
  }
}

.indexRanking__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  margin-top: calc(2vw + 22px - 10px);
}
.indexRanking__item {
  position: relative;
  -webkit-box-flex: 0;
      -ms-flex: 0 0 47.5%;
          flex: 0 0 47.5%;
  text-align: center;
}
.indexRanking__item a {
  display: block;
  color: #222;
  text-decoration: none;
}
.indexRanking__item:nth-child(2) {
  margin-left: 5%;
}
.indexRanking__item:nth-child(n+3) {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 33.33%;
          flex: 0 0 33.33%;
  margin-top: 5%;
}
.indexRanking__num {
  display: block;
  position: absolute;
  z-index: 2;
  top: 0;
  left: 0;
  width: 30px;
  height: 30px;
  border-radius: 100%;
  background: #000;
  color: #FFF;
  font-size: 0.75rem;
  font-weight: bold;
  line-height: 30px;
  text-align: center;
}
.indexRanking__item:nth-child(n+3) .indexRanking__num {
  width: 24px;
  height: 24px;
  line-height: 24px;
}
.indexRanking__img {
  display: block;
  margin: 10px;
}
.indexRanking__img img {
  width: 100%;
}
.indexRanking__name {
  display: block;
  font-size: 0.625rem;
  line-height: 1.66;
}
@media print, (min-width: 600px) {
  .indexRanking__name {
    font-size: 0.875rem;
  }
  .indexRanking__item:nth-child(n+3) .indexRanking__num {
    width: 30px;
    height: 30px;
    line-height: 30px;
  }
}
@media print, (min-width: 960px) {
  .indexRanking__list {
    margin-top: calc(2vw + 22px - 15px);
  }
  .indexRanking__item {
    -webkit-box-flex: 0;
        -ms-flex: 0 0 18.5%;
            flex: 0 0 18.5%;
    max-width: 240px;
  }
  .indexRanking__item:nth-child(2) {
    margin-left: 0;
  }
  .indexRanking__item:nth-child(n+3) {
    -webkit-box-flex: 0;
        -ms-flex: 0 0 18.5%;
            flex: 0 0 18.5%;
    margin-top: 0;
  }
  .indexRanking__item:not(:first-child) {
    margin-left: 1.875%;
  }
  .indexRanking__img {
    margin: 15px;
  }
}
@media print, (min-width: 1400px) {
  .indexRanking__list {
    margin-top: 35px;
  }
}

@media print, (min-width: 960px) {
  .indexBottom {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
}

.indexColumn {
  position: relative;
}
.indexColumn a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  color: #222;
  text-decoration: none;
}
.indexColumn .title6 {
  text-align: left;
}
.indexColumn .title6::after {
  left: 0;
}
.indexColumn__viewmore {
  position: absolute;
  top: 4px;
  right: 0;
}
.indexColumn__viewmore a {
  position: relative;
  padding-right: 20px;
}
.indexColumn__viewmore a::after {
  content: "";
  display: block;
  position: absolute;
  top: 2px;
  right: 5px;
  width: 5px;
  height: 5px;
  border-left: 1px solid #000;
  border-top: 1px solid #000;
  rotate: 135deg;
}
.indexColumn__viewmore img {
  width: 90px;
}
.indexColumn__list li {
  font-size: 0.75rem;
  line-height: 1.66;
}
.indexColumn__list li:not(:first-child) {
  margin-top: 1em;
}
.indexColumn__date {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 8.5em;
          flex: 0 0 8.5em;
  font-weight: bold;
}
.indexColumn__txt {
  -webkit-box-flex: 1;
      -ms-flex: 1 1 calc(100% - 8.5em);
          flex: 1 1 calc(100% - 8.5em);
}
@media print, (min-width: 600px) {
  .indexColumn__viewmore {
    top: 3px;
  }
  .indexColumn__viewmore a {
    padding-right: 24px;
  }
  .indexColumn__viewmore a::after {
    top: 4px;
  }
  .indexColumn__viewmore img {
    width: 105px;
  }
  .indexColumn__list li {
    font-size: 0.875rem;
  }
}
@media print, (min-width: 960px) {
  .indexColumn {
    -webkit-box-flex: 0;
        -ms-flex: 0 0 48.1%;
            flex: 0 0 48.1%;
    max-width: 625px;
  }
  .indexColumn a {
    -webkit-transition: opacity 0.3s ease;
    transition: opacity 0.3s ease;
  }
  .indexColumn a:hover {
    opacity: 0.6;
  }
  .indexColumn__viewmore a::after {
    -webkit-transition: right 0.3s ease;
    transition: right 0.3s ease;
  }
  .indexColumn__viewmore a:hover::after {
    right: 2px;
  }
}

.indexBanner {
  margin-top: calc(5vw + 30px);
}
.indexBanner img {
  width: 100%;
}
@media print, (min-width: 960px) {
  .indexBanner {
    -webkit-box-flex: 0;
        -ms-flex: 0 0 48.1%;
            flex: 0 0 48.1%;
    max-width: 625px;
    margin-top: 0;
  }
}

.indexAbout {
  margin: calc(7vw + 130px) auto;
  text-align: center;
}
.indexAbout__logoimg {
  width: 50%;
  height: auto;
}
.indexAbout__catch {
  margin-top: calc(1vw + 22px);
  font-size: 3.6vw;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  letter-spacing: 0.3em;
  text-align: center;
  line-height: 2.5;
}
.indexAbout__btn {
  margin-top: calc(2vw + 22px);
}
.indexAbout__btn a {
  position: relative;
  display: inline-block;
  padding-right: 25px;
}
.indexAbout__btn a::after {
  content: "";
  display: block;
  position: absolute;
  top: 6px;
  right: 5px;
  width: 5px;
  height: 5px;
  border-left: 1px solid #000;
  border-top: 1px solid #000;
  rotate: 135deg;
}
.indexAbout__btn img {
  height: 16px;
}
@media print, (min-width: 600px) {
  .indexAbout__logoimg {
    width: 240px;
  }
  .indexAbout__catch {
    font-size: 1.125rem;
  }
}
@media print, (min-width: 960px) {
  .indexAbout__btn a {
    -webkit-transition: opacity 0.3s ease;
    transition: opacity 0.3s ease;
  }
  .indexAbout__btn a:hover {
    opacity: 0.6;
  }
  .indexAbout__btn a::after {
    -webkit-transition: right 0.3s ease;
    transition: right 0.3s ease;
  }
  .indexAbout__btn a:hover::after {
    right: 2px;
  }
}
@media print, (min-width: 1400px) {
  .indexAbout {
    margin: 230px auto;
  }
}

/* indexPage hover */
@media print, (min-width: 960px) {
  .indexItem__img,
  .indexRanking__img,
  .indexColor__img {
    overflow: hidden;
  }
  .indexItem__img img,
  .indexRanking__img img,
  .indexColor__img img {
    overflow: hidden;
    -webkit-transition: -webkit-transform 0.3s ease;
    transition: -webkit-transform 0.3s ease;
    transition: transform 0.3s ease;
    transition: transform 0.3s ease, -webkit-transform 0.3s ease;
  }
  a:hover .indexItem__img img,
  a:hover .indexRanking__img img,
  a:hover .indexColor__img img {
    -webkit-transform: scale(1.03, 1.03);
            transform: scale(1.03, 1.03);
  }
}
/* scroll effect */
.js-scr-stepview .js-scr-el {
  -webkit-transition: translate 0.8s, opacity 0.8s;
  transition: translate 0.8s, opacity 0.8s;
}

.js-scr-stepview :nth-child(2 of .js-scr-el) {
  -webkit-transition-delay: 0.12s;
  transition-delay: 0.12s;
}

.js-scr-stepview :nth-child(3 of .js-scr-el) {
  -webkit-transition-delay: 0.24s;
  transition-delay: 0.24s;
}

.js-scr-stepview :nth-child(4 of .js-scr-el) {
  -webkit-transition-delay: 0.36s;
  transition-delay: 0.36s;
}

.js-scr-stepview :nth-child(5 of .js-scr-el) {
  -webkit-transition-delay: 0.48s;
  transition-delay: 0.48s;
}

.js-scr-stepview.js-scr-wait .js-scr-el {
  opacity: 0;
  translate: 0 30%;
  -webkit-transition: none;
  transition: none;
}