@charset "UTF-8";
.template1-japaneseTitle::before {
  top: -20px !important;
}
@media screen and (max-width: 767px) {
  .template1-japaneseTitle::before {
    top: -10px !important;
  }
}

.lp-video_wrap {
  width: 632px;
  margin: 0 auto;
}
@media screen and (max-width: 767px) {
  .lp-video_wrap {
    width: 89.7360703812%;
  }
}
.lp-video_wrap .caption {
  color: #717576;
  text-align: right;
  font-family: YuGothic, "Yu Gothic", sans-serif;
  font-size: 10px;
  font-style: normal;
  font-weight: 500;
  line-height: 20px; /* 200% */
  letter-spacing: 0.25px;
  margin-top: 5px;
}

/* --------------------------------------------------
   動画コンテナ（可変幅・16:9固定）
-------------------------------------------------- */
.lp-video {
  position: relative;
  width: 100%;
  aspect-ratio: 16/9; /* 16:9 を常にキープ */
  overflow: hidden; /* はみ出した部分を隠す */
  margin: 0 auto;
}

.lp-video2 {
  position: relative;
  width: 100%;
  aspect-ratio: 1389/983; /* 16:9 を常にキープ */
  overflow: hidden; /* はみ出した部分を隠す */
  margin: 0 auto;
}

/* --------------------------------------------------
   プレースホルダー（サムネイル＋再生ボタン）
-------------------------------------------------- */
.lp-video__placeholder {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  cursor: pointer;
  background: #000; /* サムネイル読み込み前の背景色 */
}

.lp-video__thumbnail-image {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover; /* 中央クロップ */
}

/* --------------------------------------------------
   再生ボタン
-------------------------------------------------- */
.lp-video__play-button {
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  width: 60px;
  height: 60px;
  padding: 0;
  background: rgba(0, 0, 0, 0.6);
  border: none;
  border-radius: 50%;
  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;
  cursor: pointer;
}

.lp-video__play-button svg {
  width: 30px;
  height: 30px;
  fill: #fff;
}

/* --------------------------------------------------
   埋め込み後の iframe（中央クロップ＆レスポンシブ）
-------------------------------------------------- */
.lp-video iframe {
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  min-width: 100%; /* 親要素を完全に覆う */
  min-height: 100%; /* 親要素を完全に覆う */
  width: auto; /* アスペクト比を保持 */
  height: auto; /* アスペクト比を保持 */
}

.point_phlist {
  width: 628px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: nowrap;
      flex-wrap: nowrap;
  margin: 0 auto 56px auto;
}
@media screen and (max-width: 479px) {
  .point_phlist {
    margin-bottom: 48px;
  }
}
.point_phlist:last-child {
  margin-bottom: 0;
}
.point_phlist .phlist_ph {
  max-width: 314px;
  -webkit-box-flex: 0;
      -ms-flex: 0 0 auto;
          flex: 0 0 auto;
}
.point_phlist .phlist_ph img {
  display: block;
  max-width: 100%;
  height: auto;
}
.point_phlist .phlist_text {
  max-width: 314px;
  background-color: #fff;
  padding: 13px 24px 19px 24px;
  -webkit-box-flex: 1;
      -ms-flex: 1 1 auto;
          flex: 1 1 auto;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  /* ここを追加 */
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
.point_phlist .phlist_text h3 {
  color: #282929;
  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: 0 0 10px 0;
}
@media screen and (max-width: 479px) {
  .point_phlist .phlist_text h3 {
    font-size: 12px;
    line-height: 22px;
    margin-bottom: 3px;
  }
}
.point_phlist .phlist_text p {
  color: #717576;
  font-family: YuGothic, "Yu Gothic", sans-serif;
  font-size: 12px;
  font-style: normal;
  font-weight: 500;
  line-height: 28px; /* 233.333% */
  letter-spacing: 0.3px;
  margin: 0 0 10px 0;
}
@media screen and (max-width: 479px) {
  .point_phlist .phlist_text p {
    line-height: 22px;
  }
}
.point_phlist .phlist_text dl {
  background: #fff;
  margin: 0;
  padding: 0;
  margin-top: auto; /* 下揃えにするため追加 */
}
.point_phlist .phlist_text dl dt {
  color: #282929;
  font-family: YuGothic, "Yu Gothic", sans-serif;
  font-size: 12px;
  font-style: normal;
  font-weight: 500;
  line-height: 28px; /* 233.333% */
  letter-spacing: 0.3px;
  padding-left: 0;
  margin: 0 0 9px 0;
}
@media screen and (max-width: 479px) {
  .point_phlist .phlist_text dl dt {
    margin-bottom: 0;
  }
}
.point_phlist .phlist_text dl dd {
  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: 0 0 8px;
  padding: 4px 0;
  border: 1px solid #d5d5d5;
}
.point_phlist .phlist_text dl dd:last-child {
  margin-bottom: 0;
}

/* スマホ対応（768px以下） */
@media screen and (max-width: 768px) {
  .point_phlist {
    width: 83.284457478%;
    display: block;
  }
  .point_phlist .phlist_ph,
  .point_phlist .phlist_text {
    width: 100%;
    max-width: 100%;
    -webkit-box-flex: 0;
        -ms-flex: none;
            flex: none;
  }
  .point_phlist .phlist_ph img {
    width: 100%;
  }
}
.bg-glay {
  background-color: #f4f4f4;
}
.bg-glay .point_inner {
  padding: 0 0 34px 0;
}
.bg-glay .point_inner.pb-long {
  padding-bottom: 72px;
}
@media screen and (max-width: 767px) {
  .bg-glay .point_inner {
    padding-bottom: 10px;
  }
}

.point_wrap {
  margin-bottom: 92px;
}
@media screen and (max-width: 767px) {
  .point_wrap {
    margin-bottom: 56px;
  }
}

.point_mv {
  max-width: 812px;
  padding: 0 0 68px 0;
}
@media screen and (max-width: 767px) {
  .point_mv {
    padding-bottom: 49px;
  }
}
.point_mv img {
  width: 100%;
}

.line {
  padding-bottom: 80px;
  margin-bottom: 140px;
  border-bottom: solid 1px #afafaf;
}
@media screen and (max-width: 479px) {
  .line {
    margin-bottom: 74px;
    padding-bottom: 0;
  }
}

.ph_list {
  width: 644px;
  list-style: none;
  padding: 0;
  margin: 0 auto 64px auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
.ph_list li {
  background-color: #fafafa;
  position: relative;
  /* li間の左右上下の隙間を4pxにするためmarginを2pxずつ */
  margin: 2px;
  width: calc(50% - 4px); /* 余白分を引いて2カラム幅調整 */
  /* li全体を縦方向flexboxにして、中身を上下に分散 */
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
.ph_list li .ph_list_circle_wrap {
  position: absolute;
  top: -45px;
  left: -45px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row; /* ← ここをcolumn→rowに */
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center; /* 縦中央揃え */
  gap: 0px; /* 丸同士の間隔 */
}
.ph_list li .ph_list_circle {
  width: 90px;
  height: 90px;
  border: 1px solid #dadada;
  background-color: #fff;
  color: var(--text-boulder, #717576);
  text-align: center;
  font-family: YuGothic, "Yu Gothic", sans-serif;
  font-size: 12px;
  font-style: normal;
  font-weight: 700;
  line-height: 18px; /* 150% */
  letter-spacing: 0.3px;
  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;
  white-space: pre-line; /* <br>で改行 */
  border-radius: 50%; /* ここで円形 */
}
.ph_list li img {
  display: block;
  max-width: 100%;
  height: auto;
}
.ph_list li .phlist_text {
  padding: 13px 24px 19px 24px;
  -webkit-box-flex: 1;
      -ms-flex: 1 1 auto;
          flex: 1 1 auto;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
.ph_list li .phlist_text h3 {
  color: #282929;
  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: 0 0 7px 0;
}
@media screen and (max-width: 479px) {
  .ph_list li .phlist_text h3 {
    font-size: 12px;
  }
}
.ph_list li .phlist_text p {
  color: #717576;
  font-family: YuGothic, "Yu Gothic", sans-serif;
  font-size: 12px;
  font-style: normal;
  font-weight: 500;
  line-height: 28px; /* 233.333% */
  letter-spacing: 0.3px;
  margin: 0 0 9px 0;
}
.ph_list li .phlist_text dl {
  margin: 0;
  padding: 0;
  margin-top: auto; /* ここでdlを下に押し出す */
}
.ph_list li .phlist_text dl dt {
  color: #282929;
  font-family: YuGothic, "Yu Gothic", sans-serif;
  font-size: 12px;
  font-style: normal;
  font-weight: 500;
  line-height: 28px; /* 233.333% */
  letter-spacing: 0.3px;
  margin: 0 0 3px 0;
}
.ph_list li .phlist_text dl dd {
  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: 0 0 8px;
  background: #fff;
  border: 1px solid #d5d5d5;
  padding: 4px;
}
.ph_list li .phlist_text dl dd span {
  color: #717576;
  font-family: YuGothic, "Yu Gothic", sans-serif;
  font-size: 12px;
  font-style: normal;
  font-weight: 500;
  line-height: 20px;
  letter-spacing: 0.3px;
}
.ph_list li .phlist_text dl dd:last-child {
  margin-bottom: 0;
}

/* SP対応：1カラム */
@media screen and (max-width: 768px) {
  .ph_list {
    width: 83.284457478%;
    -ms-flex-wrap: nowrap;
        flex-wrap: nowrap;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  .ph_list li {
    width: 100%;
    margin: 4px 0;
  }
  .ph_list li .ph_list_circle_wrap {
    top: -45px;
    left: -25px;
  }
}
.point_title {
  max-width: 628px;
  margin: 0 auto 18px auto;
}
@media screen and (max-width: 767px) {
  .point_title {
    padding: 0 17px;
  }
}
.point_title span {
  display: block;
  text-align: center;
}
.point_title.mb-middle {
  margin-bottom: 60px;
}
.point_title.mb-long {
  margin-bottom: 80px;
}
.point_title .point_title__title.fs14 {
  font-size: 14px;
}
@media screen and (max-width: 479px) {
  .point_title .point_title__title.fs14 {
    width: 92.5081433225%;
    margin: 0 auto;
  }
}

.point_title__num {
  color: #282929;
  text-align: center;
  font-family: "Kepler Std";
  font-size: 24px;
  font-style: italic;
  font-weight: 400;
  line-height: 28px; /* 116.667% */
  letter-spacing: 0.6px;
  margin-bottom: 3px;
}
@media screen and (max-width: 767px) {
  .point_title__num {
    margin-bottom: 0px;
    font-size: 20px;
  }
}

.point_title__title {
  color: #717576;
  text-align: center;
  font-family: YuGothic, "Yu Gothic", sans-serif;
  font-size: 16px;
  font-style: normal;
  font-weight: 700;
  line-height: 28px; /* 200% */
  letter-spacing: 0.35px;
  margin-bottom: 19px;
}
@media screen and (max-width: 767px) {
  .point_title__title {
    margin-bottom: 18px;
    font-size: 14px;
    line-height: 26px; /* 185.714% */
    letter-spacing: 0.35px;
  }
}

.point_text {
  max-width: 628px;
  margin: 0 auto 62px auto;
}
@media screen and (max-width: 767px) {
  .point_text {
    padding: 0 17px;
    margin-bottom: 50px;
  }
}
.point_text p {
  color: #717576;
  font-size: 12px;
  font-style: normal;
  font-weight: 500;
  line-height: 28px; /* 233.333% */
  letter-spacing: 0.3px;
}
@media screen and (max-width: 767px) {
  .point_text p {
    line-height: 22px; /* 183.333% */
  }
}

.cartframe {
  margin-top: 165px;
  /* SP対応 */
}
@media screen and (max-width: 479px) {
  .cartframe {
    margin-top: 0;
  }
}
.cartframe .bg-glay {
  padding-bottom: 72px;
  margin-bottom: 176px;
}
@media screen and (max-width: 479px) {
  .cartframe .bg-glay {
    padding-bottom: 16px;
    margin-bottom: 80px;
  }
}
.cartframe .ph_list {
  margin-bottom: 4px;
}
@media screen and (max-width: 479px) {
  .cartframe .ph_list {
    margin-bottom: 2px;
  }
}
.cartframe .ph_list_text {
  width: 644px;
  margin: 0 auto 55px auto;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}
.cartframe .ph_list_text .caption {
  text-align: right;
  font-size: 12px;
}
@media screen and (max-width: 767px) {
  .cartframe .ph_list_text .caption {
    text-align: left;
  }
}
@media screen and (max-width: 479px) {
  .cartframe .point_title__title {
    width: 92.5081433225%;
    margin: 0 auto;
  }
}
.cartframe .phlist_text {
  padding: 17px 24px 0 24px;
  margin-bottom: 16px;
  -webkit-box-flex: 1;
      -ms-flex: 1 1 auto;
          flex: 1 1 auto;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  background-color: #fff;
  /* 2カラム切替部分ここから */
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 30px;
  /* 2カラム切替部分ここまで */
}
@media screen and (max-width: 479px) {
  .cartframe .phlist_text {
    width: 83.284457478%;
    margin: 0 auto;
  }
}
.cartframe .phlist_text .phlist_text_wrap {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  width: 294px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
.cartframe .phlist_text dl {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  width: 266px;
  margin: 0;
  padding: 0;
}
.cartframe .phlist_text dl dt {
  color: #282929;
  font-family: YuGothic, "Yu Gothic", sans-serif;
  font-size: 12px;
  font-style: normal;
  font-weight: 500;
  line-height: 28px; /* 233.333% */
  letter-spacing: 0.3px;
  margin: 0 0 3px 0;
}
.cartframe .phlist_text dl dd {
  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: 0 0 8px;
  background: #fff;
  border: 1px solid #d5d5d5;
  padding: 4px;
}
.cartframe .phlist_text dl dd span {
  color: #717576;
  font-family: YuGothic, "Yu Gothic", sans-serif;
  font-size: 12px;
  font-style: normal;
  font-weight: 500;
  line-height: 20px;
  letter-spacing: 0.3px;
}
.cartframe .phlist_text dl dd:last-child {
  margin-bottom: 0;
}
.cartframe .phlist_text h3 {
  color: #282929;
  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: 0;
  width: 100%;
}
.cartframe .phlist_text p {
  color: #717576;
  font-family: YuGothic, "Yu Gothic", sans-serif;
  font-size: 12px;
  font-style: normal;
  font-weight: 500;
  line-height: 28px; /* 233.333% */
  letter-spacing: 0.3px;
  margin: 0 0 9px 0;
  width: 100%;
}
@media screen and (max-width: 768px) {
  .cartframe .phlist_text {
    display: block;
    padding: 17px 24px 19px 32px;
    margin-bottom: 6px;
  }
  .cartframe .phlist_text .phlist_text_wrap,
  .cartframe .phlist_text dl {
    width: 100%;
    margin-top: 0;
    margin-bottom: 0;
  }
  .cartframe .phlist_text h3,
  .cartframe .phlist_text p {
    width: 100%;
  }
  .cartframe .ph_list_text {
    width: 100%;
    margin: 0 auto 40px auto;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
  }
  .cartframe .ph_list_text .caption {
    text-align: left !important;
  }
}
@media screen and (max-width: 768px) and (max-width: 479px) {
  .cartframe .ph_list_text .caption {
    text-align: center !important;
    font-size: 10px;
  }
}

.point_text {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 16px; /* カラム間の隙間 */
}
.point_text.mb-long {
  margin-bottom: 176px;
}
@media screen and (max-width: 479px) {
  .point_text.mb-long {
    margin-bottom: 64px;
  }
}
.point_text .point_list {
  width: 306px;
  border: 1px solid #d5d5d5;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  text-align: center;
  padding: 15px 22px; /* お好みで内側の余白調整してください */
}
.point_text .point_list dt {
  color: var(--text-boulder, #717576);
  font-family: YuGothic, "Yu Gothic", sans-serif;
  font-size: 14px;
  font-style: normal;
  font-weight: 700;
  line-height: 28px; /* 200% */
  letter-spacing: 0.35px;
  margin: 0 0 8px 0;
  width: 100%;
}
.point_text .point_list dt:only-child {
  margin-bottom: 0;
  padding: 7px 0;
}
.point_text .point_list dd {
  color: var(--text-boulder, #717576);
  font-family: YuGothic, "Yu Gothic", sans-serif;
  font-size: 12px;
  font-style: normal;
  font-weight: 500;
  line-height: 24px; /* 200% */
  letter-spacing: 0.3px;
  margin: 0;
  width: 100%;
  text-align: left;
}

/* SP対応 */
@media screen and (max-width: 768px) {
  .point_text {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 0;
  }
  .point_text .point_list {
    width: 100%;
    margin-bottom: 16px;
  }
}
.point_ph {
  max-width: 628px;
  margin: 0 auto;
}
@media screen and (max-width: 767px) {
  .point_ph {
    padding: 0 17px;
  }
}
.point_ph img {
  width: 100%;
  margin-bottom: 32px;
}
@media screen and (max-width: 767px) {
  .point_ph img {
    margin-bottom: 17px;
  }
}
.point_ph img:last-of-type {
  margin-bottom: 0;
}

.point_ph_caption {
  max-width: 628px;
  margin: 0 auto;
  padding-top: 20px;
}
@media screen and (max-width: 767px) {
  .point_ph_caption {
    padding: 12px 0 0 0;
  }
}
.point_ph_caption p {
  color: #717576;
  font-size: 12px;
  font-style: normal;
  font-weight: 500;
  line-height: 22px; /* 183.333% */
  letter-spacing: 0.3px;
}

.last-contents {
  margin-bottom: 120px;
}

.other_items {
  border: solid 1px #dadada;
  padding: 61px 26px 64px 26px;
}
@media screen and (max-width: 767px) {
  .other_items {
    padding: 46px 25px 48px 25px;
  }
}
.other_items img {
  width: 100%;
}
.other_items p {
  color: #717576;
  text-align: center;
  font-size: 12px;
  font-style: normal;
  font-weight: 500;
  line-height: 28px; /* 233.333% */
  letter-spacing: 0.3px;
  margin-bottom: 31px;
}

.other_items__title {
  text-align: center;
  color: #282929;
  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: 14px;
}

.other_items__link {
  text-align: center;
  margin-top: 40px;
}
.other_items__link a {
  display: inline-block;
  color: var(--text-boulder, #717576);
  text-align: center;
  font-size: 14px;
  font-style: normal;
  font-weight: 600;
  line-height: 28px; /* 200% */
  letter-spacing: 0.35px;
  padding: 14px 68px;
  border: solid 1px #dadada;
}

.recommended_wrap {
  padding-top: 96px;
  margin-top: 96px;
  margin-bottom: 64px;
  position: relative;
}
.recommended_wrap::after {
  content: "";
  width: 35px;
  height: 1px;
  background-color: #afafaf;
  position: absolute;
  top: 0;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
}

.recommended_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: 12px;
}

.recommended_text {
  color: #717576;
  text-align: center;
  font-size: 12px;
  font-style: normal;
  font-weight: 500;
  line-height: 28px; /* 233.333% */
  letter-spacing: 0.3px;
}

.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: 52px;
  color: #717576;
}
@media screen and (min-width: 768px) {
  .f15-lede {
    margin-top: 56px;
    margin-inline: auto;
    width: 77.3399014778%;
    line-height: 28px;
    margin-bottom: 52px;
  }
}

.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%;
  }
}

.product {
  margin-bottom: 80px;
}
@media screen and (min-width: 768px) {
  .product {
    margin-inline: auto;
    margin-bottom: 176px;
  }
}

.product__inner {
  max-width: 628px;
  margin-left: auto;
  margin-right: auto;
  background-color: #fafafa;
  margin-bottom: 56px;
}
@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__icon {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 81.5249266862%;
  margin: 0 auto 11px auto;
}
.product-desc__icon li {
  width: 84px;
  border: 1px solid var(--rgb-157158158, #9d9e9e);
  background: var(--ffffff, #fff);
  color: #282929;
  text-align: center;
  font-family: YuGothic, "Yu Gothic", sans-serif;
  font-size: 12px;
  font-style: normal;
  font-weight: 500;
  line-height: 28px; /* 233.333% */
  letter-spacing: 0.3px;
  margin-right: 7px;
}

.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: 58px 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時も均等 */
  }
}