@charset "UTF-8";
.wrap_type {
  background-color: rgba(113, 117, 118, 0.08);
  padding: 28px;
  margin-bottom: 176px;
}
@media screen and (max-width: 767px) {
  .wrap_type {
    padding: 17px;
    width: calc(100vw - 17px - 17px);
    margin-left: -4.5333333333%;
    margin-right: -4.5333333333%;
    margin-bottom: 126px;
  }
}

.type_inner {
  background-color: #fff;
  padding: 56px 0;
}
@media screen and (max-width: 767px) {
  .type_inner {
    padding: 53px 0 28px 0;
  }
}

.type__title {
  color: #282929;
  text-align: center;
  font-family: kepler-std, serif;
  font-size: 24px;
  font-style: italic;
  font-weight: 400;
  line-height: 28px; /* 116.667% */
  letter-spacing: 0.6px;
  margin-bottom: 5px;
}
@media screen and (max-width: 767px) {
  .type__title {
    font-size: 20px;
    line-height: 24px; /* 120% */
    letter-spacing: 0.5px;
  }
}

.type__lead {
  color: #282929;
  text-align: center;
  font-family: YuGothic, "Yu Gothic", sans-serif;
  font-size: 14px;
  font-style: normal;
  font-weight: 500;
  line-height: 28px; /* 200% */
  letter-spacing: 0.35px;
  margin-bottom: 46px;
}
@media screen and (max-width: 767px) {
  .type__lead {
    line-height: 24px; /* 171.429% */
    margin-bottom: 55px;
  }
}

.type_item_wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 56px 60px;
}
@media screen and (max-width: 767px) {
  .type_item_wrap {
    width: 83.284457478%;
    margin: 0 auto;
  }
}
.type_item_wrap .type_item {
  width: 284px;
}
.type_item_wrap .type_item img {
  width: 100%;
  margin-bottom: 13px;
}
.type_item_wrap .type_item_text {
  color: #717576;
  text-align: center;
  font-family: YuGothic, "Yu Gothic", sans-serif;
  font-size: 12px;
  font-style: normal;
  font-weight: 700;
  line-height: 28px; /* 233.333% */
  letter-spacing: 0.3px;
  margin-bottom: 13px;
}
.type_item_wrap .type_item_button a {
  padding: 16px 0 12px 0;
  border: 1px solid #d5d5d5;
  display: block;
  color: var(--text-boulder, #717576);
  font-family: YuGothic, "Yu Gothic", sans-serif;
  font-size: 14px;
  font-style: normal;
  font-weight: 700;
  line-height: 28px;
  letter-spacing: 0.35px;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .type_item_wrap {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 56px 0;
  }
  .type_item_wrap .type_item {
    width: 100%;
  }
}

.product-series-mv {
  margin-bottom: 69px;
  max-width: 812px;
}
.product-series-mv img {
  width: 100%;
}

.product-series-title span {
  display: block;
}

.product-series-title-en {
  color: #282929;
  text-align: center;
  font-family: kepler-std, serif;
  font-size: 24px;
  font-style: italic;
  font-weight: 400;
  line-height: 28px; /* 116.667% */
  letter-spacing: 0.6px;
}
@media screen and (max-width: 767px) {
  .product-series-title-en {
    font-size: 20px;
    letter-spacing: 0.5px;
  }
}

.product-series-title-jp {
  color: #282929;
  text-align: center;
  font-family: YuGothic, "Yu Gothic", sans-serif;
  font-size: 14px;
  font-style: normal;
  font-weight: 500;
  line-height: 28px; /* 200% */
  letter-spacing: 0.35px;
  margin-bottom: 32px;
}

.product-series-lead {
  margin-bottom: 62px;
  max-width: 628px;
  margin-left: auto;
  margin-right: auto;
}
@media screen and (max-width: 767px) {
  .product-series-lead {
    width: 90.0293255132%;
    margin-bottom: 55px;
  }
}
.product-series-lead p {
  color: #717576;
  text-align: center;
  font-family: YuGothic, "Yu Gothic", sans-serif;
  font-size: 14px;
  font-style: normal;
  font-weight: 700;
  line-height: 32px; /* 228.571% */
  letter-spacing: 0.35px;
}
@media screen and (max-width: 767px) {
  .product-series-lead p {
    font-size: 12px;
    line-height: 22px; /* 183.333% */
    letter-spacing: 0.3px;
  }
}

.product-series-imgs {
  max-width: 628px;
  margin-left: auto;
  margin-right: auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 8px;
  margin-bottom: 66px;
}
@media screen and (max-width: 767px) {
  .product-series-imgs {
    width: 90.0293255132%;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 43px;
  }
}
.product-series-imgs .product-series-img {
  width: calc(50% - 4px);
}
.product-series-imgs .product-series-img img {
  width: 100%;
}
@media screen and (max-width: 767px) {
  .product-series-imgs {
    gap: 7px;
  }
  .product-series-imgs .product-series-img {
    width: calc(50% - 3.5px);
  }
}

.product-series-details {
  max-width: 628px;
  position: relative;
  padding-bottom: 117px;
  margin-bottom: 117px;
  margin-left: auto;
  margin-right: auto;
}
@media screen and (max-width: 767px) {
  .product-series-details {
    width: 90.0293255132%;
    margin-left: auto;
    margin-right: auto;
    padding-bottom: 76px;
    margin-bottom: 76px;
  }
}
.product-series-details:after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: 0;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  width: 35px;
  height: 1px;
  background-color: #afafaf;
}

.product__items {
  margin-bottom: 64px;
}
@media screen and (max-width: 767px) {
  .product__items {
    margin-bottom: 45px;
  }
}

.product__item-title {
  color: #282929;
  text-align: center;
  font-family: kepler-std, serif;
  font-size: 24px;
  font-style: italic;
  font-weight: 400;
  line-height: 28px; /* 116.667% */
  letter-spacing: 0.6px;
}
@media screen and (max-width: 767px) {
  .product__item-title {
    font-size: 20px;
    letter-spacing: 0.5px;
  }
}

.product__item-text {
  color: #282929;
  text-align: center;
  font-family: YuGothic, "Yu Gothic", sans-serif;
  font-size: 14px;
  font-style: normal;
  font-weight: 500;
  line-height: 28px; /* 200% */
  letter-spacing: 0.35px;
}

.product-series-detail {
  margin-bottom: 37px;
}
.product-series-detail:last-child {
  margin-bottom: 0;
}

.product-series-detail-title {
  color: var(--text-boulder, #717576);
  font-family: YuGothic, "Yu Gothic", sans-serif;
  font-size: 14px;
  font-style: normal;
  font-weight: 700;
  line-height: 28px;
  letter-spacing: 0.35px;
  margin-bottom: 4px;
}
@media screen and (max-width: 767px) {
  .product-series-detail-title {
    font-size: 12px;
    line-height: 22px; /* 183.333% */
    letter-spacing: 0.3px;
  }
}

.product-series-detail-text {
  color: #717576;
  font-family: YuGothic, "Yu Gothic", sans-serif;
  font-size: 12px;
  font-style: normal;
  font-weight: 500;
  line-height: 22px; /* 183.333% */
  letter-spacing: 0.3px;
}

.template1-japaneseTitle {
  margin-top: 44px !important;
}
@media screen and (max-width: 767px) {
  .template1-japaneseTitle {
    margin-top: 19px !important;
  }
}
.template1-japaneseTitle::before {
  top: -20px !important;
}
@media screen and (max-width: 767px) {
  .template1-japaneseTitle::before {
    top: -10px !important;
  }
}

.anc {
  display: block;
  margin-top: -86px;
  padding-top: 86px;
}

@media screen and (min-width: 768px) {
  .anc {
    display: block;
    margin-top: -104px;
    padding-top: 104px;
  }
}
.f15 {
  color: #282929;
  -webkit-font-smoothing: antialiased;
}

.f15-hero {
  margin-top: 6px;
}
.f15-hero img {
  width: 100%;
}

.f15-lede {
  margin-top: 40px;
  width: 90.0293255132%;
  font-size: 1.2rem;
  line-height: 2;
  letter-spacing: 0.025em;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 69px;
  color: #717576;
}
@media screen and (min-width: 768px) {
  .f15-lede {
    margin-top: 56px;
    margin-inline: auto;
    width: 77.3399014778%;
    line-height: 28px;
    margin-bottom: 132px;
  }
}

.image-area {
  margin-top: 97px;
  width: 100%;
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: minmax(0, 1fr);
  grid-template-columns: minmax(0, 1fr);
  row-gap: 6px;
}
@media screen and (min-width: 768px) {
  .image-area {
    margin-top: 112px;
    row-gap: 8px;
  }
}

.image-area .image {
  width: 100%;
}
.image-area .image img {
  width: 100%;
}

.point {
  padding-top: 125px;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}
@media screen and (min-width: 768px) {
  .point {
    margin-top: 136px;
    padding-top: 0;
  }
}

.point__title {
  font-size: 1.4rem;
  letter-spacing: 0.025em;
  font-weight: bold;
  line-height: 1.7142857143;
  color: #717576;
  text-align: center;
}
@media screen and (min-width: 768px) {
  .point__title {
    font-size: 1.6rem;
    line-height: 2;
  }
}

.point__lead {
  margin-top: 9px;
}
@media screen and (min-width: 768px) {
  .point__lead {
    margin-top: 11px;
    margin-inline: auto;
    width: 77.3399014778%;
  }
}
.point__lead p {
  font-size: 1.2rem;
  letter-spacing: 0.025em;
  line-height: 2;
  color: #717576;
}
@media screen and (min-width: 768px) {
  .point__lead p {
    line-height: 2.3333333333;
  }
}

.features,
.size {
  margin-top: 72px;
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: minmax(0, 1fr);
  grid-template-columns: minmax(0, 1fr);
  row-gap: 125px;
}

.feature {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: minmax(0, 1fr);
  grid-template-columns: minmax(0, 1fr);
  row-gap: 51px;
  padding-bottom: 78px;
  background-color: #fafafa;
}
@media screen and (min-width: 768px) {
  .feature {
    row-gap: 71px;
  }
}

.feature.feature--04 {
  margin: 0 -4.9853372434%;
  padding-top: 62px;
  padding-bottom: 50px;
}
@media screen and (min-width: 768px) {
  .feature.feature--04 {
    margin: 0;
    padding-top: 101px;
    padding-bottom: 50px;
  }
}

.feature.feature--05 {
  padding-top: 94px;
}
@media screen and (min-width: 768px) {
  .feature.feature--05 {
    padding-top: 101px;
  }
}

.feature.feature--gray {
  background: #f2f2f2;
}

.feature__mv {
  width: 100%;
}
.feature__mv img {
  width: 100%;
  aspect-ratio: 341/227;
  -o-object-fit: cover;
     object-fit: cover;
}
@media screen and (min-width: 768px) {
  .feature__mv img {
    aspect-ratio: 812/416;
  }
}

.size__content {
  margin-inline: auto;
  padding-top: 46px;
  width: 89.2441860465%;
}
@media screen and (min-width: 768px) {
  .size__content {
    padding-top: 82px;
    width: 77.3399014778%;
  }
}

.feature__number {
  font-size: 1.8rem;
  line-height: 1.2222222222;
  letter-spacing: 0.02em;
  text-align: center;
  font-family: "Cosmiqua W01 Italic", serif;
  color: #615c57;
}

.feature__title {
  margin-top: 18px;
  font-size: 1.4rem;
  line-height: 2;
  letter-spacing: 0.025em;
  font-weight: bold;
  text-align: center;
  color: #717576;
}
@media screen and (min-width: 768px) {
  .feature__title {
    font-size: 1.6rem;
    line-height: 1.75;
  }
}

.feature__lede {
  margin-top: 17px;
  margin-inline: auto;
  width: 90.0293255132%;
  font-size: 1.2rem;
  line-height: 2.3333333333;
  letter-spacing: 0.025em;
  text-align: center;
  color: #717576;
}
@media screen and (min-width: 768px) {
  .feature__lede {
    width: 77.3399014778%;
  }
}

.feature__blockWrapper {
  width: 100%;
}
@media screen and (min-width: 768px) {
  .feature__blockWrapper {
    margin-inline: auto;
    width: 77.3399014778%;
  }
  .feature__blockWrapper--01 {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
  .feature__blockWrapper--01 .feature__block:nth-of-type(n + 3) {
    margin: 0;
    width: auto;
    -ms-flex-preferred-size: 47.4522292994%;
        flex-basis: 47.4522292994%;
  }
  .feature__blockWrapper--01 .feature__block:nth-of-type(n + 3) .feature__images {
    width: 100%;
  }
  .feature__blockWrapper--01 .feature__block:nth-of-type(n + 3) .feature__images .feature__image {
    width: 100%;
    -ms-flex-preferred-size: 100%;
        flex-basis: 100%;
  }
  .feature__blockWrapper--02 {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
  .feature__blockWrapper--02 .feature__block:nth-of-type(n + 3) {
    margin: 0;
    width: auto;
    -ms-flex-preferred-size: 47.4522292994%;
        flex-basis: 47.4522292994%;
  }
  .feature__blockWrapper--02 .feature__images {
    width: 100%;
  }
  .feature__blockWrapper--02 .feature__images .feature__image {
    width: 100%;
    -ms-flex-preferred-size: 100%;
        flex-basis: 100%;
  }
  .feature__blockWrapper--03 {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
  .feature__blockWrapper--03 .feature__block:nth-of-type(n + 3) {
    margin: 0;
    width: auto;
    -ms-flex-preferred-size: 47.4522292994%;
        flex-basis: 47.4522292994%;
  }
  .feature__blockWrapper--03 .feature__images {
    width: 100%;
  }
  .feature__blockWrapper--03 .feature__images .feature__image {
    width: 100%;
    -ms-flex-preferred-size: 100%;
        flex-basis: 100%;
  }
}

.feature__block {
  margin-inline: auto;
  width: 90.0293255132%;
}
@media screen and (min-width: 768px) {
  .feature__block {
    width: 100%;
  }
}

.feature__images {
  position: relative;
  margin-top: 70px;
}
@media screen and (min-width: 768px) {
  .feature__images {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    margin-top: 72px;
    padding-top: 0;
  }
}

.feature__image {
  width: 100%;
}
@media screen and (min-width: 768px) {
  .feature__image {
    position: static;
    -ms-flex-preferred-size: 49.3630573248%;
        flex-basis: 49.3630573248%;
    width: auto;
  }
}
.feature__image img {
  width: 100%;
}
.feature__image + .feature__image {
  margin-top: 7px;
}
@media screen and (min-width: 768px) {
  .feature__image + .feature__image {
    margin-top: 0;
  }
}

.feature__images-texts {
  margin-top: 18px;
}
@media screen and (min-width: 768px) {
  .feature__images-texts {
    margin-top: 16px;
  }
}

.feature__images-title {
  font-size: 1.2rem;
  letter-spacing: 0.025em;
  line-height: 2.3333333333;
  text-align: center;
  color: #717576;
  font-weight: bold;
}

.feature__images-text {
  margin-top: 6px;
  font-size: 1.2rem;
  letter-spacing: 0.025em;
  line-height: 1.8333333333;
  text-align: center;
  color: #717576;
}

.feature__imagePicture {
  margin-top: 54px;
  margin-left: auto;
  margin-right: auto;
  width: 81.3333333333%;
}
@media screen and (min-width: 768px) {
  .feature__imagePicture {
    margin: 0;
    -webkit-box-flex: 0;
        -ms-flex: 0 0 50%;
            flex: 0 0 50%;
    width: auto;
  }
}
.feature__imagePicture img {
  width: 100%;
}

.how-to-use__list {
  margin-top: 45px;
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: minmax(0, 1fr);
  grid-template-columns: minmax(0, 1fr);
  row-gap: 44px;
}
@media screen and (min-width: 768px) {
  .how-to-use__list {
    margin-top: 76px;
    -ms-grid-columns: minmax(0, 1fr) 5.0955414013% minmax(0, 1fr);
    grid-template-columns: repeat(2, minmax(0, 1fr));
    -webkit-column-gap: 5.0955414013%;
       -moz-column-gap: 5.0955414013%;
            column-gap: 5.0955414013%;
    row-gap: 31px;
  }
}

.how-to-use__list-item {
  width: 100%;
}

.how-to-use-item__image {
  width: 100%;
}
.how-to-use-item__image img {
  width: 100%;
  aspect-ratio: 307/205;
  -o-object-fit: cover;
     object-fit: cover;
}

.how-to-use-item__text {
  margin-top: 9px;
}
.how-to-use-item__text p {
  font-size: 1.2rem;
  letter-spacing: 0.025em;
  line-height: 1.8333333333;
  color: #717576;
  text-align: center;
}
@media screen and (min-width: 768px) {
  .how-to-use-item__text p {
    line-height: 2.3333333333;
  }
}

.size {
  margin-top: 127px;
  padding-bottom: 75px;
  background-color: #fafafa;
}
@media screen and (min-width: 768px) {
  .size {
    margin-top: 140px;
    padding-bottom: 71px;
  }
}

.size__title {
  margin-bottom: 27px;
  font-size: 14px;
  letter-spacing: 0.025em;
  line-height: 2;
  font-weight: 700;
  text-align: center;
  position: relative;
  color: #717576;
}
@media screen and (min-width: 768px) {
  .size__title {
    font-size: 16px;
    line-height: 1.75;
  }
}
.size__title::after {
  position: absolute;
  bottom: -15px;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  display: inline-block;
  width: 35px;
  height: 1px;
  content: "";
  background-color: #acacac;
}

.size-block + .size-block {
  margin-top: 66px;
}
@media screen and (min-width: 768px) {
  .size-block + .size-block {
    margin-top: 80px;
  }
}

.size-block__head {
  text-align: center;
}

.size-block__title {
  font-size: 1.2rem;
  letter-spacing: 0.025em;
  line-height: 2.3333333333;
  color: #717576;
  font-weight: bold;
}

.size-block__lede {
  margin-top: 5px;
  font-size: 1.2rem;
  letter-spacing: 0.025em;
  line-height: 1.8333333333;
  color: #717576;
}

.part-description {
  margin-top: 104px;
  margin-left: -4.5%;
  padding: 24px 0;
  background-color: #fafafa;
  width: 109.011627907%;
}
@media screen and (min-width: 768px) {
  .part-description {
    margin-top: 140px;
    margin-left: 0;
    padding: 28px 0;
    width: 100%;
  }
}

.part-description__inner {
  margin-inline: auto;
  padding-top: 50px;
  padding-bottom: 50px;
  width: 91.7333333333%;
  background-color: #fff;
}
@media screen and (min-width: 768px) {
  .part-description__inner {
    padding-top: 93px;
    padding-bottom: 74px;
    width: 93.1034482759%;
  }
}

.part-description__title {
  font-size: 1.4rem;
  letter-spacing: 0.025em;
  line-height: 2;
  text-align: center;
  font-weight: 700;
  color: #717576;
}
@media screen and (min-width: 768px) {
  .part-description__title {
    font-size: 1.6rem;
    line-height: 1.75;
  }
}

.part-description__contens {
  margin-top: 17px;
  width: 100%;
}
@media screen and (min-width: 768px) {
  .part-description__contens {
    margin-top: 45px;
  }
}
.part-description__contens img {
  width: 100%;
  height: auto;
  display: block;
}

.part-description__note {
  margin-top: 14px;
  margin-inline: auto;
  width: 39.5894428152%;
  min-width: 215px;
}
@media screen and (min-width: 768px) {
  .part-description__note {
    width: 78.9682539683%;
  }
}

.part-description__note-list {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: minmax(0, 1fr);
  grid-template-columns: minmax(0, 1fr);
}
@media screen and (min-width: 768px) {
  .part-description__note-list {
    -ms-grid-columns: minmax(0, auto) 4.6901172529% minmax(0, auto) 4.6901172529% minmax(0, auto);
    grid-template-columns: repeat(3, minmax(0, auto));
    -webkit-column-gap: 4.6901172529%;
       -moz-column-gap: 4.6901172529%;
            column-gap: 4.6901172529%;
  }
}
.part-description__note-list li {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-column-gap: 6px;
     -moz-column-gap: 6px;
          column-gap: 6px;
}
.part-description__note-list li span {
  display: inline-block;
  font-size: 1.2rem;
  letter-spacing: 0.025em;
  line-height: 2;
  color: #717576;
}
@media screen and (min-width: 768px) {
  .part-description__note-list li span {
    line-height: 2.3333333333;
  }
}

.product {
  margin-top: 104px;
}
@media screen and (min-width: 768px) {
  .product {
    margin-top: 170px;
    margin-inline: auto;
    margin-bottom: 84px;
  }
}

.product__inner {
  max-width: 628px;
  margin-left: auto;
  margin-right: auto;
  background-color: #fafafa;
}
@media screen and (min-width: 768px) {
  .product__inner {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
  .product__inner .product-mv {
    -webkit-box-flex: 0;
        -ms-flex: 0 0 47.4522292994%;
            flex: 0 0 47.4522292994%;
  }
  .product__inner .product-desc {
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
  }
}

.product-mv {
  width: 100%;
}

.product-mv__image {
  width: 100%;
  height: auto;
  display: block;
}

@media screen and (max-width: 767px) {
  .product-desc {
    padding-top: 21px;
    padding-bottom: 28px;
  }
}

.product-desc__title {
  margin-inline: auto;
  width: 81.5249266862%;
  font-size: 1.4rem;
  letter-spacing: 0.025em;
  line-height: 2;
  color: #282929;
}
@media screen and (min-width: 768px) {
  .product-desc__title {
    width: 80.6060606061%;
  }
}

.product-desc__price {
  margin-top: 7px;
  margin-inline: auto;
  width: 81.5249266862%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: baseline;
      -ms-flex-align: baseline;
          align-items: baseline;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  font-family: kepler-std, serif;
  font-style: italic;
  -webkit-column-gap: 3px;
     -moz-column-gap: 3px;
          column-gap: 3px;
}
@media screen and (min-width: 768px) {
  .product-desc__price {
    width: 80.6060606061%;
  }
}
.product-desc__price .price {
  display: inline-block;
  font-size: 1.8rem;
  letter-spacing: 0.1em;
  line-height: 1.5555555556;
  color: #282929;
}
.product-desc__price .tax {
  display: inline-block;
  font-size: 1rem;
  letter-spacing: 0.1em;
  line-height: 2.8;
  color: #717576;
}

.product-desc__link {
  margin-top: 9px;
  margin-inline: auto;
  width: 81.2316715543%;
  height: 48px;
}
@media screen and (min-width: 768px) {
  .product-desc__link {
    height: 56px;
  }
}
.product-desc__link a {
  width: 100%;
  height: 100%;
  font-size: 1.4rem;
  letter-spacing: 0.025em;
  line-height: 2;
  font-weight: 700;
  background-color: #9d9e9e;
  display: -ms-grid;
  display: grid;
  place-items: center;
  color: #fff;
}

.item__container__spec {
  max-width: 628px;
  margin: 35px auto 72px auto !important;
  border-top: solid 1px #707070;
  border-bottom: solid 1px #dadada;
}
@media screen and (min-width: 768px) {
  .item__container__spec {
    grid-column: 1/-1;
    margin-top: 56px;
    margin-bottom: 92px !important;
    width: 100%;
  }
}

.accordion__title {
  padding: 12px 0;
  position: relative;
  cursor: pointer;
  -webkit-user-select: none;
     -moz-user-select: none;
      -ms-user-select: none;
          user-select: none;
  font-size: 1.2rem;
  line-height: 2;
  width: 100%;
  text-align: left;
  color: #717576;
}
@media screen and (min-width: 768px) {
  .accordion__title {
    line-height: 2.3333333333;
  }
}
.accordion__title::before {
  content: "";
  position: absolute;
  top: 50%;
  right: 0;
  width: 11px;
  height: 1px;
  -webkit-transform: rotate(90deg);
          transform: rotate(90deg);
  background: #282929;
  -webkit-transition: all 0.3s ease-in-out;
  transition: all 0.3s ease-in-out;
}
.accordion__title::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 0;
  width: 11px;
  height: 1px;
  background: #282929;
  opacity: 1;
  -webkit-transition: all 0.2s ease-in-out;
  transition: all 0.2s ease-in-out;
}

.accordion__title.open::before {
  -webkit-transform: rotate(180deg);
          transform: rotate(180deg);
}

.accordion__title.open::after {
  opacity: 0;
}

.accordion__content {
  border-top: 1px solid #dadada;
}

/* CSS for CodePen */
.accordion-container {
  width: 300px;
  margin: 0 auto;
}

.spec-obverse {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
@media screen and (min-width: 768px) {
  .spec-obverse {
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: 168px 1fr;
    grid-template-columns: 168px 1fr;
  }
}
.spec-obverse + .spec-obverse {
  border-top: 1px solid #dadada;
}
.spec-obverse dt {
  padding: 11px 0 0 16px;
  width: 89px;
  text-align: left;
  background-color: #fafafa;
  line-height: 2;
  color: #717576;
  font-size: 1.2rem;
  letter-spacing: 0.025em;
}
@media screen and (min-width: 768px) {
  .spec-obverse dt {
    padding-top: 14px;
    width: 100%;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    line-height: 2.3333333333;
  }
}
.spec-obverse dd {
  padding: 13px 0 13px 7px;
  width: 73.9002932551%;
  color: #717576;
  font-size: 1.2rem;
  letter-spacing: 0.025em;
}
@media screen and (min-width: 768px) {
  .spec-obverse dd {
    padding: 14px 0 14px 16px;
    width: 100%;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
  }
}
.spec-obverse dd p {
  line-height: 2;
  color: #717576;
}
@media screen and (min-width: 768px) {
  .spec-obverse dd p {
    line-height: 2.3333333333;
  }
}
.spec-obverse dd .sizeList li {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  line-height: 2;
  font-weight: normal;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
}
@media screen and (min-width: 768px) {
  .spec-obverse dd .sizeList li {
    line-height: 2.3333333333;
  }
}
.spec-obverse dd .sizeList__type {
  width: 13px;
  padding-right: 5px;
  text-align: center;
}
.spec-obverse dd .sizeList__details {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
.spec-obverse dd .sizeList__details::before {
  content: ":";
  padding-right: 5px;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}
.spec-obverse dd .note li {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  line-height: 2;
  font-weight: normal;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  color: #717576;
}
@media screen and (min-width: 768px) {
  .spec-obverse dd .note li {
    line-height: 2.3333333333;
  }
}
.spec-obverse dd .note li::before {
  padding-right: 4px;
  content: "・";
  -ms-flex-negative: 0;
      flex-shrink: 0;
}
.spec-obverse dd .note li.havenot-circle::before {
  padding-right: 1px;
  content: "＞";
}
.spec-obverse dd .note li + li.havenot-circle {
  margin-top: 10px;
}
@media screen and (min-width: 768px) {
  .spec-obverse dd .note li + li.havenot-circle {
    margin-top: 28px;
  }
}

.page-nav-wrap {
  margin: 43px 0 78px 0;
}

.page-nav-wrap__list {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex; /* 横並びに */
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 8px; /* li間の余白 */
  list-style: none; /* デフォルトのリストスタイルを削除 */
  padding: 0;
  margin: 0 auto;
  -webkit-box-align: stretch;
      -ms-flex-align: stretch;
          align-items: stretch;
}
.page-nav-wrap__list li {
  width: 108px;
  -webkit-box-flex: 1;
      -ms-flex: 1 1 calc(50% - 8px);
          flex: 1 1 calc(50% - 8px); /* 2カラム: 親の50%幅から余白を引く */
  -webkit-box-sizing: border-box;
          box-sizing: border-box; /* パディングやボーダーを含む */
}
.page-nav-wrap__list a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex; /* Flexboxを適用 */
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center; /* 縦方向に中央揃え */
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center; /* 横方向にも中央揃え（必要なら） */
  font-size: 1.2rem;
  line-height: 2;
  font-weight: normal;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  color: #282929;
  padding: 8px 15px;
  -webkit-box-sizing: border-box;
          box-sizing: border-box; /* パディングとボーダーを含めてサイズを計算 */
  border: solid 1px #dadada;
  text-align: center; /* テキストを中央揃え */
  width: 100%; /* 横幅を親要素に合わせる */
  height: 100%; /* 高さを親要素（li）に揃える */
  -webkit-transition: opacity 0.3s ease, background-color 0.3s ease;
  transition: opacity 0.3s ease, background-color 0.3s ease; /* 透明度の変化をスムーズに */
  opacity: 1; /* 初期の透明度を設定 */
}
.page-nav-wrap__list .bg-red {
  background-color: #6e1e1e; /* 背景色 */
}
.page-nav-wrap__list .bg-red a {
  border: none;
  color: #fff; /* テキスト色を白に */
  font-weight: 700;
}

@media screen and (min-width: 768px) {
  .page-nav-wrap {
    margin: 69px 0 140px 0;
  }
  .page-nav-wrap__list {
    width: 77.3399014778%;
    -ms-flex-wrap: nowrap;
        flex-wrap: nowrap; /* 折り返しなし（横並び） */
  }
  .page-nav-wrap__list a:hover {
    opacity: 0.7; /* ホバー時の透明度を変更 */
    background-color: #f0f0f0; /* 必要に応じて背景色も変更 */
  }
  .page-nav-wrap__list .bg-red a:hover {
    opacity: 0.7;
    background-color: #6e1e1e;
  }
  .page-nav-wrap__list li {
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1; /* 均等に幅を設定 */
  }
  .page-nav-wrap__list .bg-glay {
    -webkit-box-flex: 1.5;
        -ms-flex: 1.5;
            flex: 1.5; /* PC時も均等 */
  }
}