/* ===============================================================================
Category
=============================================================================== */
/* category-section
========================= */
/* category-section-01 */
.category-section-01 .blocks-01 .main-visual img {
  display: block;
}

.category-section-01 .blocks-02__inner {
  max-width: 1280px;
  box-sizing: border-box;
  padding: 17px 17px 26px;
  margin: -30px auto 0;
  background: #fff;
  position: relative;
}

.category-section-01 .blocks-02 .dirpath {
  margin-bottom: 20px;
  font-size: 0;
}

.category-section-01 .blocks-02 .dirpath__list {
  display: inline;
}

.category-section-01 .blocks-02 .dirpath__list__item {
  display: inline;
  color: #5f5f5f;
  font-size: 0.75rem;
}

.category-section-01 .blocks-02 .dirpath__list__item::after {
  content: "";
  display: inline-block;
  top: 0;
  left: 0;
  width: 5px;
  height: 8px;
  background: url(../img/common/common_arrow01.png) no-repeat 0 0;
  background-size: 100% auto;
  margin: 0 13px;
}

.category-section-01 .blocks-02 .dirpath__list__item:last-child::after {
  content: none;
}

.category-section-01 .blocks-02 .dirpath__list__item a {
  color: inherit;
}

.category-section-01 .blocks-02 .column2 {
  display: table;
  width: 100%;
}

.category-section-01 .blocks-02 .column2__item {
  display: table-cell;
  table-layout: fixed;
  vertical-align: top;
}

.category-section-01 .blocks-02 .column2__item:first-child {
  width: 337px;
}

.category-section-01 .blocks-02 .heading {
  font-size: 3rem;
  line-height: 1.04;
  font-weight: 700;
  color: #000;
}

.category-section-01 .blocks-02 .text {
  font-size: 0.875rem;
  line-height: 1.43;
  margin-top: 5px;
}

.category-section-01 .blocks-02 .text p {
  margin-bottom: 10px;
}

.category-section-01 .blocks-02 .text p:last-of-type {
  margin-bottom: 0;
}

.category-section-01 .blocks-03 {
  background: #f2f2f2;
  padding: 80px 0 60px;
}

.category-section-01 .blocks-03__inner {
  max-width: 1280px;
  margin: 0 auto;
}

.category-section-01 .blocks-03 .list::after {
  content: "";
  display: block;
  clear: both;
}

.category-section-01 .blocks-03 .list__item {
  width: 305px;
  float: left;
  background: #fff;
  margin: 20px 20px 0 0;
}

.category-section-01 .blocks-03 .list__item:nth-child(4n) {
  margin-right: 0;
}

.category-section-01 .blocks-03 .list__item:nth-child(4n+1) {
  clear: left;
}

.category-section-01 .blocks-03 .list__item:nth-child(-n+4) {
  margin-top: 0;
}

.category-section-01 .blocks-03 .list__item a {
  display: block;
}

.category-section-01 .blocks-03 .list__item a:hover {
  text-decoration: none;
}

.category-section-01 .blocks-03 .product {
  padding: 40px 33px;
}

.category-section-01 .blocks-03 .product__image {
  margin-bottom: 67px;
}

.category-section-01 .blocks-03 .product__title {
  text-align: center;
  font-size: 1.125rem;
  margin: 0 -25px 33px;
}

.category-section-01 .blocks-03 .product__btn {
  background: #0055b8;
  text-align: center;
  color: #fff;
  padding: 8px;
  font-size: 1rem;
}

@media screen and (max-width: 1295px) {
  .category-section-01 .blocks-03 {
    background: #f2f2f2;
    padding: 80px 0 60px;
  }
  .category-section-01 .blocks-03__inner {
    padding: 0 10px;
  }
  .category-section-01 .blocks-03 .list__item {
    width: 32%;
    margin-right: 2%;
  }
  .category-section-01 .blocks-03 .list__item:nth-child(4n) {
    margin-right: 2%;
  }
  .category-section-01 .blocks-03 .list__item:nth-child(4n+1) {
    clear: none;
  }
  .category-section-01 .blocks-03 .list__item:nth-child(3n) {
    margin-right: 0;
  }
  .category-section-01 .blocks-03 .list__item:nth-child(3n+1) {
    clear: left;
  }
  .category-section-01 .blocks-03 .list__item:nth-child(-n+4) {
    margin-top: 20px;
  }
  .category-section-01 .blocks-03 .list__item:nth-child(-n+3) {
    margin-top: 0;
  }
}

@media screen and (max-width: 767px) {
  .category-section-01 .blocks-02__inner {
    padding: 10px 8px 20px;
    margin: 0 auto;
  }
  .category-section-01 .blocks-02 .dirpath {
    margin-bottom: 25px;
  }
  .category-section-01 .blocks-02 .dirpath__list__item {
    font-size: 0.857rem;
  }
  .category-section-01 .blocks-02 .column2 {
    display: block;
  }
  .category-section-01 .blocks-02 .column2__item {
    display: block;
  }
  .category-section-01 .blocks-02 .column2__item:first-child {
    width: auto;
  }
  .category-section-01 .blocks-02 .heading {
    font-size: 3.429rem;
    text-align: center;
    margin-bottom: 15px;
  }
  .category-section-01 .blocks-02 .text {
    font-size: 1rem;
    text-align: center;
    margin-top: 0;
  }
  .category-section-01 .blocks-02 .text__sp-toggle {
    display: none;
  }
  .category-section-01 .blocks-02 .text__sp-toggle.show {
    display: block;
  }
  .category-section-01 .blocks-02 .text__more-btn {
    font-weight: 600;
  }
  .category-section-01 .blocks-02 .text__more-btn.hide {
    display: none;
  }
  .category-section-01 .blocks-02 .text__less-btn {
    font-weight: 600;
  }
  .category-section-01 .blocks-03 {
    padding: 40px 0 90px;
  }
  .category-section-01 .blocks-03__inner {
    padding: 0 8px;
  }
  .category-section-01 .blocks-03 .list__item {
    width: auto;
    float: none;
    margin: 0 0 20px 0;
  }
  .category-section-01 .blocks-03 .list__item:last-child {
    margin-bottom: 0;
  }
  .category-section-01 .blocks-03 .product {
    padding: 10px 33px 40px;
  }
  .category-section-01 .blocks-03 .product__image {
    margin: 0 -35px 22px;
  }
  .category-section-01 .blocks-03 .product__image img {
    display: block;
    max-width: 454px;
    width: 100%;
    margin: 0 auto;
  }
  .category-section-01 .blocks-03 .product__title {
    font-size: 1.286rem;
    margin: 0 -20px 30px;
  }
  .category-section-01 .blocks-03 .product__btn {
    background: #0055b8;
    text-align: center;
    color: #fff;
    padding: 8px;
    font-size: 1.143rem;
  }
}
