@charset "UTF-8";


/* 共通 */
.comn_swiper_hidden { display: none; }

/* 上部バナー */
.headerBnr_exc {
  display: block;
  margin: 0 16px 24px;
}


/* 商品
------------------------------------------------------------------------------------*/
.product_img_wrap {
  position: relative;
  padding-top: 100%;
}

.product_img {
  position: absolute;
  top: 0;
  left: 0;
  opacity: 0;
  transition: opacity 500ms;
}
.product_video {
  left: -9999px;
}

.product_img_current {
  opacity: 1;
  z-index: 1;
}

.product_tmb_wrap {
  display: flex;
  flex-wrap: wrap;
  margin: 0 16px;
}

.product_tmb {
  width: 14.6%;
  cursor: pointer;
  margin: 2.48% 2.48% 0 0;
  /* topを2.48にするとなぞのスペースがフッターに現れる */
}
.product_tmb:nth-of-type(6n) { margin-right: 0; }
.product_tmb_current { outline: 4px solid #a0b4d7; }

.product_tit {
  --fs: 1.6rem;
  --fh: 1.8rem;
  font-size: var(--fs);
  line-height: var(--fh);
  margin: calc(8px + ((var(--fs) - var(--fh)) / 2)) 16px calc(0px + ((var(--fs) - var(--fh)) / 2));
}

.product_tit_sub {
  --fs: 1.2rem;
  --fh: 1.4rem;
  font-size: var(--fs);
  line-height: var(--fh);
  margin: calc(8px + ((var(--fs) - var(--fh)) / 2)) 16px calc(0px + ((var(--fs) - var(--fh)) / 2));
}

.product_label1_wrap {
  display: flex;
  flex-wrap: wrap;
  margin: calc(24px - 4px) 16px 0;
}

.product_label2_wrap {
  display: flex;
  flex-wrap: wrap;
  margin: calc(8px - 4px) 16px 0;
}

.productList_label_1day,
.productList_label_1month,
.productList_label_clear,
.productList_label_limit,
.productList_label_new,
.productList_label_npw,
.productList_label_nsale,
.productList_label_pw,
.productList_label_reco,
.productList_label_sale,
.productList_label_ship,
.productList_label_stock,
.productList_label_web,
.productList_label_ship_m,
.productList_label_sale_m,
.productList_label_reco_m,
.productList_label_new_m,
.productList_label_limit_m {
  width: auto;
  height: 12px;
  margin: 4px 4px 0 0;
}

.product_form {
  padding-top: 8px;
}

.product_paramList_wrap {
  border-bottom: #ddd solid 1px;
  display: flex;
  flex-wrap: wrap;
  margin: 0 16px;
  padding: 16px 8px 12px;
}
.product_paramList_wrap:nth-of-type(2n) {
  background: #f0f0f0;
}

.product_paramList_tit,
.product_paramList_tit_price {
  width: 104px;
  font-size: 1.6rem;
  display: grid;
  align-items: center;
}

.product_paramList_value,
.product_paramList_value_price,
.product_paramList_value_priceFree {
  width: calc(100% - 104px);
  font-size: 1.6rem;
}

.product_paramList_tit_price,
.product_paramList_value_price,
.product_paramList_value_priceFree {
  margin-bottom: 4px;
}

.product_paramList_value_priceFree {
  color: #d5155b;
  font-weight: bold;
}

.product_paramList_value_price_sale {
  color: #e40c66;
  font-weight: bold;
  display: inline-block;
  margin-top: 4px;
}

.product_paramList_value_price_strikethrough {
  font-size: 1.4rem;
  text-decoration-line: line-through;
}

.product_paramList_value_price_off {
  background-color: #e40c66;
  border-radius: 2px;
  color: #fff;
  font-size: 1rem;
  font-weight: bold;
  white-space: nowrap;
  display: inline-block;
  position: relative;
  margin-top: 2px;
  padding: 1px 11px 1px 2px;
}
.product_paramList_value_price_off::after {
  content: "";
  width: 8px;
  height: 8px;
  background: url(/images/sp/label/label_arrow_m_sp.webp);
  background-size: 8px;
  display: block;
  position: absolute;
  top: 2.5px;
  right: 1.5px;
}

.product_paramList_select,
.product_paramList_selectDisabled { 
  width: 100%;
  height: 30px;
  background: url(/images/sp/common/pulldown_arrow_sp.svg) #fff right center no-repeat;
  background-size: 27px;
  border: 1px solid #ddd;
  border-radius: 4px;
  color: #353535;
  font-size: 1.4rem;
  margin: 4px 0;
  padding: 0 27px 0 8px;
  -webkit-appearance: none;
}
.product_paramList_selectDisabled {
  background: none;
  border: none;
  font-size: 1.6rem;
  pointer-events: none;
  padding-left: 0;
}
.product_paramList_value:nth-of-type(2) .product_paramList_select { margin-top: 8px; }

.product_paramList_value_price_off_wrap {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
}

.product_paramList_value_price_off_text {
  color: #a6a6a6;
  font-size: 1.2rem;
  display: inline-block;
  text-decoration: line-through;
  margin-right: 4px;
  margin-bottom: 4px;
}

.product_paramList_value_price_off_icon {
  background-color: #e40c66;
  border-radius: 2px;
  color: #fff;
  font-size: 1rem;
  font-weight: bold;
  white-space: nowrap;
  display: inline-block;
  position: relative;
  padding: 1px 11px 1px 2px;
}
.product_paramList_value_price_off_icon::after {
  content: "";
  width: 8px;
  height: 8px;
  background: url(/images/sp/label/label_arrow_m_sp.webp);
  background-size: 8px;
  display: block;
  position: absolute;
  top: 2.5px;
  right: 1.5px;
}

.product_paramList_select_alert {
  background-color: #fae6ed;
  border: #d5155b solid 1px;
}

/* 商品合計 */
.product_total_wrap {
  background: #fdf5f8;
  display: flex;
  flex-wrap: wrap;
  margin: 12px 16px 0;
  padding: 8px 8px 12px;
}

.product_total_tit_quantity,
.product_total_tit_point,
.product_total_tit_price {
  width: 104px;
  font-size: 1.6rem;
  display: grid;
  align-items: center;
}

.product_total_value_quantity_wrap,
.product_total_value_point,
.product_total_value_price {
  width: calc(100% - 104px);
  font-size: 1.6rem;
  text-align: right;
}

.product_total_tit_point,
.product_total_value_point {  
  margin-top: 16px;
}

.product_total_tit_price,
.product_total_value_price {
  font-weight: bold;
  margin-top: 20px;
}

/* セット数 */
.product_total_value_quantity_wrap {
  display: flex;
  align-items: center;
  justify-content: flex-end;
}

.product_total_value_quantity {
  width: 1em;
  background: none;
  border: none;
  color: #353535;
  font-size: 1.6rem;
  text-align: center;
  margin-left: 12px;
  padding: 0;
  -webkit-appearance: none;
}

.product_total_value_quantityBtn_plus,
.product_total_value_quantityBtn_minus {
  width: 40px;
  height: 22px;
  background: #e5e5e6;
  border: #fff solid 1px;
  border-radius: 11px;
  color: #007aff;
  font-size: 1.6rem;
  text-align: center;
  cursor: pointer;
  margin: 0px 0 0 4px;
}
.product_total_value_quantityBtn_plus { padding-top: 1px; }

.product_total_value_quantityBtn_off {
  opacity: 0.3;
  cursor: default;
}

@media (max-width: 339px) {
  .product_total_value_priceBlock {
    display: block;
    margin-top: 4px;
  }
}


/* 2SETまとめ買いバナー
------------------------------------------------------------------------------------*/
.btn_exc {
  display: block;
  margin: 32px 16px 0;
}


/* カートに入れるボタン
------------------------------------------------------------------------------------*/
.btn_cart {
  height: 52px;
  background: #d5155b;
  border: 1px solid #a21046;
  border-radius: 8px;
  box-shadow: 0 4px 0 #a21046, inset 0 1px 0 rgba(255, 255, 255, .3), inset 0 0 3px rgba(255, 255, 255, .5);
  color: #fff;
  font-size: 2rem;
  font-weight: bold;
  display: flex;
  justify-content: center;
  place-items: center;
  cursor: pointer;
  margin: 32px 16px 0;
}
.btn_cart::before {
  content: "";
  width: 21px;
  height: 20px;
  background: url(/images/sp/product/cart_icon_sp.svg) no-repeat;
  display: block;
  margin-right: 4px;
}
.btn_exc + .btn_cart { margin-top: 24px; }

.btn_cart_off {
  height: 52px;
  background: #d7d7d7;
  border-radius: 8px;
  color: #a3a3a3;
  font-size: 2rem;
  font-weight: bold;
  display: grid;
  place-items: center;
  pointer-events: none;
  margin: 24px 16px 0;
}

.btn_cart_off_inner {
  background: url(/images/sp/product/cart_icon_off_sp.svg) no-repeat;
  background-size: 20px;
  padding-left: 24px;
}

.cart_period {
  font-size: 1.2rem;
  margin: 4px 16px 0;
}


/* お気に入りに追加ボタン
------------------------------------------------------------------------------------*/
.btn_fav,
.btn_fav_off {
  height: 36px;
  border: #d5155b solid 1px;
  border-radius: 8px;
  color: #d5155b;
  font-size: 1.6rem;
  font-weight: bold;
  text-align: center;
  display: flex;
  justify-content: center;
  align-items: center;
  cursor: pointer;
  margin: 16px 16px 0;
}
.btn_fav::before,
.btn_fav_off::before {
  content: "";
  width: 18px;
  height: 16px;
  background: url(/images/sp/product/fav_icon_sp.svg) no-repeat;
  display: block;
  margin: 1px 4px 0 0;
}

.btn_fav_off {
  border: #d7d7d7 solid 1px;
  color: #a3a3a3;
}
.btn_fav_off::before { background: url(/images/sp/product/fav_gray_icon_sp.svg) no-repeat; }


/* シェアボタン
------------------------------------------------------------------------------------*/
.shareBtn_wrap {
  height: 30px;
  display: flex;
  justify-content: space-between;
  margin: 24px 16px 0;
}

.shareBtn_line,
.shareBtn_twitter,
.shareBtn_link {
  width: 31.77%;
  border: #ddd solid 1px;
  border-radius: 8px;
  display: grid;
  place-items: center;
}
.shareBtn_img { max-height: 28px; }


/* クーポン
------------------------------------------------------------------------------------*/
.coupon_wrap {
  background: #f0f0f0;
  margin-top: 40px;
}

.coupon {
  border-top: #aaa solid 1px;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  margin: 0 16px;
  padding: 20px 8px;
  padding: 16px 8px;
}
.coupon:first-of-type { border-top: none; }

.coupon_l {
  width: calc(100% - 104px);
  flex: 1;
  text-align: left;
  margin-right: 16px;
}

.coupon_tit {
  --fs: 1.2rem;
  --fh: 1.4rem;
  font-size: var(--fs);
  font-weight: normal;
  line-height: var(--fh);
  margin: calc(0px + ((var(--fs) - var(--fh)) / 2)) 0 calc(0px + ((var(--fs) - var(--fh)) / 2));
}

.coupon_detailLink {
  --fs: 1.6rem;
  --fh: 2.2rem;
  color: #1c70b5;
  font-size: var(--fs);
  font-weight: bold;
  line-height: var(--fh);
  /* text-decoration: underline; */
  display: inline-block;
  cursor: pointer;
  margin: calc(6px + ((var(--fs) - var(--fh)) / 2)) 0 calc(0px + ((var(--fs) - var(--fh)) / 2));
}
/*
.coupon_detailLink::after {
  content: "";
  width: 8px;
  height: 16px;
  background: url(/images/sp/product/copon_arrow_sp.svg) bottom / 8px no-repeat;
  border-bottom: #1e77bc solid 1px;
  display: inline-block;
  margin-bottom: -2px;
  padding: 0 6px;
}
*/

.coupon_r { width: 104px; }

.coupon_getBtn {
  width: 104px;
  height: 32px;
  background: #134b8e;
  border-radius: 6px;
  color: #fff;
  font-weight: bold;
  display: grid;
  place-items: center;
  cursor: pointer;
  margin: 0 auto;
  transition: background 200ms, color 200ms;
}

.coupon_getBtn_off {
  background: #d7d7d7;
  color: #a3a3a3;
  cursor: default;
}

.coupon_Deadline {
  --fs: 1rem;
  --fh: 1.2rem;
  font-size: var(--fs);
  text-align: center;
  line-height: var(--fh);
  margin: calc(6px + ((var(--fs) - var(--fh)) / 2)) 0 calc(0px + ((var(--fs) - var(--fh)) / 2));
}

.coupon_addBtn_wrap {
  border-top: #aaa solid 1px;
  margin: 0 16px;
  padding: 12px 0;
}

.coupon_addBtn_link {
  color: #1c70b5;
  font-size: 1.2rem;
  font-weight: bold;
  display: inline-block;
  cursor: pointer;
}

.coupon_ball {
  width: 32px;
  height: 32px;
  background: #134b8e;
  border-radius: 50%;
  box-shadow: 2px 2px 4px rgba(27, 104, 198, 0.5);
  position: fixed;
  left: -100px;
  opacity: 0;
  z-index: 9999;
  transition: opacity 150ms, background 750ms, box-shadow 750ms;
}
/*
.cart_ball::before {
  content: "★";
  color: #dd2f69;
  font-size: 3rem;  
}
@keyframes rotate {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}
*/

.coupon_ball_on {
  /*
  background: #d5155b;
  box-shadow: 2px 2px 4px rgba(213, 21, 91, 0.5);
  */
  opacity: 1;
}


/* 商品説明
------------------------------------------------------------------------------------*/
.description_wrap {
  height: 100%;
  max-height: 178px;
  position: relative;
  overflow-y: hidden;
  margin: 24px 16px 0;
  transition: max-height 250ms;
}

.description_wrap_more::before {
  content: "";
  width: 100%;
  height: 80px;
  background: linear-gradient(180deg, transparent 0 0%, #fff 40px);
  display: block;
  position: absolute;
  bottom: 0;
}

.description_tit {
  font-size: 1.6rem;
  margin-bottom: -4px;
}

.description_p {
  --fs: 1.4rem;
  --fh: 2rem;
  font-size: var(--fs);
  line-height: var(--fh);
  margin: calc(16px + ((var(--fs) - var(--fh)) / 2)) 0 calc(0px + ((var(--fs) - var(--fh)) / 2));
}

.description_moreBtn {
  width: 160px;
  height: 26px;
  background: #fff;
  border: #3e3e3e solid 1px;
  border-radius: 9999px;
  font-size: 1.4rem;
  display: none;
  position: absolute;
  justify-content: center;
  place-items: center;
  bottom: 0;
  left: 50%;
  z-index: 1;
  transform: translateX(-50%);
  cursor: pointer;
}

.description_moreBtn::before {
  content: "";
  width: 14px;
  height: 8px;
  background: url(/images/sp/common/more_icon_sp.svg) no-repeat;
  display: block;
  margin: 1px 4px 0 -8px;
}


/* レビュー
------------------------------------------------------------------------------------*/
.review_wrap {
  margin: 32px 16px 0;
  overflow-x: hidden;
}

.description_wrap + .review_wrap {
  margin-top: 40px;
}

.review_tit {
  font-size: 1.6rem;
  font-weight: normal;
  margin-bottom: -4px;
}

.review_number {
  color: #d5155b;
  font-size: 1.2rem;
  padding-left: 4px;
}

.review,
.review_pin {
  border: #ddd solid 1px;
  border-radius: 8px;
  position: relative;
  margin-top: 16px;
  padding: 12px 8px 64px;
}
.review_pin {
  background: #fdf5f8;
  border: #d5155b solid 1px;
}
.review_pin::before {
  content: "";
  width: 12px;
  height: 18px;
  background: url(/images/sp/product/review_icon_pin_sp.svg) no-repeat;
  background-size: contain;
  display: block;
  position: absolute;
  top: 4px;
  right: 4px;
}

.review_name {
  color: #707070;
  font-size: 1.2rem;
}

.review_star {
  color: #f5b51a;
  letter-spacing: 2px;
  padding-left: 4px;
}

.review_date,
.review_user,
.review_buyItem_wrap {
  color: #707070;
  font-size: 1.2rem;
  margin-top: 4px;
}

.review_buyItem_wrap { margin: 2px 0 -4px; }

.review_buyItem {
  background: #efefef;
  border-radius: 100px;
  display: inline-block;
  margin: 0 4px 4px 0;
  padding: 2px 4px;
}

.review_pin .review_buyItem { background: #fff; }

.review_txt {
  --fs: 1.4rem;
  --fh: 2rem;
  font-size: var(--fs);
  font-weight: bold;
  line-height: var(--fh);
  margin: calc(16px + ((var(--fs) - var(--fh)) / 2)) 0 calc(0px + ((var(--fs) - var(--fh)) / 2));
}

.review_img_wrap {
  width: 132px;
  display: flex;
  justify-content: space-between;
  margin: 12px 0 -52px;
}

.review_img {
  width: 60px;
  height: 60px;
  background: #bcb1b3;
  cursor: pointer;
  object-fit: contain;
}

@media (max-width: 349px) {
  .review_number {
    display: block;
    margin-top: 6px;
    padding-left: 0;
  }
}


/*-------------------------------------------------------------------------------------------------------------------*/
/*
Copyright (c) 2023 by Akiho (https://codepen.io/wcaotdaenpaebne/pen/JjpNJpb)

Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:

The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.

THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
*/

.review_goodBtn {
  height: 28px;
  background: url(/images/sp/product/review_icon_good_sp.svg) 8px 4px / 16px #fff no-repeat;
  border: #707070 solid 1px;
  border-radius: 8px;
  font-size: 1.2rem;
  display: inline-block;
  position: absolute;
  bottom: 12px;
  right: 12px;
  cursor: pointer;
  padding: 7px 8px 0 30px;
}

.review_pin .review_goodBtn {
  background: url(/images/sp/product/review_icon_good_pin_sp.svg) 8px 4px / 16px #fff no-repeat;
  border: #d5155b solid 1px;
  color: #d5155b;
}

.review_goodBtn:before,
.review_goodBtn:after {
  content: "";
  width: 160%;
  height: 100%;
  background-repeat: no-repeat;
  display: block;
  position: absolute;  
  left: -20%;
  /* z-index: -1000; */
}
.review_goodBtn:before {
  background-image: radial-gradient(circle, #d53fff 10%, transparent 20%), radial-gradient(circle, transparent 10%, #d53fff 20%, transparent 30%), radial-gradient(circle, #d53fff 10%, transparent 20%), radial-gradient(circle, #d53fff 10%, transparent 20%), radial-gradient(circle, transparent 5%, #d53fff 15%, transparent 20%), radial-gradient(circle, #ffd635 10%, transparent 20%), radial-gradient(circle, #ffd635 10%, transparent 20%), radial-gradient(circle, #ffd635 10%, transparent 20%), radial-gradient(circle, #ffd635 10%, transparent 20%);
  background-size: 25% 25%, 35% 35%, 30% 30%, 35% 35%, 33% 33%, 25% 25%, 30% 30%, 25% 25%, 33% 33%;
  display: none;
  top: -100%;  
}
.review_goodBtn:after {
  background-image: radial-gradient(circle, #56adff 10%, transparent 20%), radial-gradient(circle, #56adff 10%, transparent 20%), radial-gradient(circle, transparent 5%, #56adff 15%, transparent 20%), radial-gradient(circle, #56adff 10%, transparent 20%), radial-gradient(circle, #79ff4c 10%, transparent 20%), radial-gradient(circle, #79ff4c 10%, transparent 20%), radial-gradient(circle, #79ff4c 10%, transparent 20%);
  background-size: 30% 30%, 35% 35%, 33% 33%, 35% 35%, 30% 30%, 25% 25%, 35% 35%;
  display: none;
  bottom: -100%;
}
.review_goodBtn.animate:before {
  display: block;
  animation: topBubbles 900ms forwards;
}
.review_goodBtn.animate:after {
  display: block;
  animation: bottomBubbles 900ms forwards;
}

@keyframes topBubbles {
  0%   { background-position: 5% 90%, 10% 90%, 10% 90%, 15% 90%, 25% 90%, 25% 90%, 40% 90%, 55% 90%, 70% 90%; }
  50%  { background-position: 0% 80%, 0% 20%, 10% 40%, 20% 0%, 30% 30%, 22% 50%, 50% 50%, 65% 20%, 90% 30%; }
  100% { background-position: 0% 70%, 0% 10%, 10% 30%, 20% -10%, 30% 20%, 22% 40%, 50% 40%, 65% 10%, 90% 20%;
         background-size: 0% 0%, 0% 0%, 0% 0%, 0% 0%, 0% 0%, 0% 0%; }
}
@keyframes bottomBubbles {
  0%   { background-position: 10% -10%, 30% 10%, 55% -10%, 70% -10%, 85% -10%, 70% -10%, 70% 0%; }
  50%  { background-position: 0% 80%, 20% 80%, 45% 60%, 60% 100%, 75% 70%, 95% 60%, 105% 0%; }
  100% { background-position: 0% 90%, 20% 90%, 45% 70%, 60% 110%, 75% 80%, 95% 70%, 110% 10%;
         background-size: 0% 0%, 0% 0%, 0% 0%, 0% 0%, 0% 0%, 0% 0%; }
}
/*-------------------------------------------------------------------------------------------------------------------*/

.review_moreBtn {
  width: 54.66%;
  height: 30px;
  border: #3e3e3e solid 1px;
  border-radius: 15px;
  font-size: 1.6rem;
  font-weight: bold;
  display: flex;
  justify-content: center;
  align-items: center;
  cursor: pointer;
  margin: 24px auto 0;
}

.review_moreBtn::before {
  content: "";
  width: 17px;
  height: 10px;
  background: url(/images/sp/common/more_icon_sp.svg) no-repeat;
  display: block;
  margin: 2px 4px 0 -6px;
}

.product_contact {
  text-align: center;
  margin-top: 32px;
}

#js_reviewModal_wrap {
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.3);
  display: grid;
  place-items: center;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 9999;
  overflow: hidden;
  opacity: 0;
  transition: opacity 250ms;
  pointer-events: none;
}

#js_reviewModal_wrap.js_reviewModal_wrap_open {
  opacity: 1;
  pointer-events: auto;
}

#js_reviewModal_inner {
  width: calc(100% - 32px);
  background: #fff;
  border-radius: 16px;
  box-shadow: 0 0 5px rgba(0, 0, 0, 0.3);
  position: relative;
  padding-bottom: 24px;
}

#js_reviewModal_close {
  width: 20px;
  position: absolute;
  top: 24px;
  right: 16px;
  cursor: pointer;
}

#js_reviewModal_tit {
  font-size: 1.8rem;
  font-weight: bold;
  text-align: center;
  padding-top: 32px;
}

#js_reviewModal_img_wrap {
  position: relative;
  margin: 24px 32px 0;
  padding-top: calc(100% - 64px);
}

.js_reviewModal_img {
  height: 100%;
  background: #bcb1b3;
  object-fit: contain;
  position: absolute;
  opacity: 0;
  top: 0;
  transition: opacity 250ms;
}
.js_reviewModal_img_on { opacity: 1; }

#js_reviewModal_btns {
  display: flex;
  justify-content: space-between;
  margin: 16px 32px 0;
}

#js_reviewModal_prevBtn,
#js_reviewModal_nextBtn {
  width: 46.66%;
  height: 30px;
  background: #d5155b;
  border-radius: 6px;
  color: #fff;
  font-weight: bold;
  display: grid;
  place-items: center;
  cursor: pointer;
}

#js_reviewModal_prevBtn.js_reviewModal_btn_off,
#js_reviewModal_nextBtn.js_reviewModal_btn_off {
  background: #d7d7d7;
  color: #a3a3a3;
  cursor: default;
}


/* フッター カートに入れるボタン
------------------------------------------------------------------------------------*/
#js_footerBtn_cart_wrap {
  width: 100%;
  height: 78px;
  background: #f0f0f0;
  border-top: #d6d6d6 solid 1px;
  position: fixed;
  z-index: 9200;
  bottom: 0;
  opacity: 0;
  pointer-events: none;
  transition: opacity 500ms;
}

#js_footerBtn_cart_wrap.js_footerBtn_cart_wrap_on {
  opacity: 1;
  pointer-events: auto;
}

#js_footerBtn_cart {
  width: 91.46%;
  height: 52px;
  background: #d5155b;
  border: 1px solid #a21046;
  border-radius: 8px;
  box-shadow: 0 4px 0 #a21046, inset 0 1px 0 rgba(255, 255, 255, .3), inset 0 0 3px rgba(255, 255, 255, .5);
  color: #fff;
  font-size: 2rem;
  font-weight: bold;
  display: flex;
  justify-content: center;
  place-items: center;
  cursor: pointer;
  margin: 12px auto 0;
}
#js_footerBtn_cart::before {
  content: "";
  width: 21px;
  height: 20px;
  background: url(/images/sp/product/cart_icon_sp.svg) no-repeat;
  display: block;
  margin-right: 4px;
}

#js_footerCart_wrap {
  width: 100%;
  height: calc(100% - 78px);
  background: #f0f0f0;
  position: fixed;
  top: 100%;
  z-index: 9100;
  transition: top 500ms;
}
#js_footerCart_wrap.js_footerCart_wrap_on { top: 0; }

#js_footerCart_header {
  width: 100%;
  height: 68px;
  position: fixed;
  top: 100%;
  padding-top: 25px;
  transition: top 500ms;
}
#js_footerCart_header.js_footerCart_header_on { top: 0; }

#js_footerCart_header_tlt {
  font-size: 1.8rem;
  font-weight: bold;
  text-align: center;
}

#js_footerCart_header_close {
  width: 18px;
  position: absolute;
  top: 25px;
  right: 3.8vw;
  cursor: pointer;
}

#js_footerCart_inner {
  height: calc(100% - 68px);
  background: #fff;
  overflow-y: scroll;
  margin-top: 68px;
  padding: 8px 0;
}

#js_footerCart_inner .product_label1_wrap {
  margin-top: 0;
}


/* 類似商品
------------------------------------------------------------------------------------*/
.variation_wrap {
  position: relative;
  margin-top: 56px;
  padding-bottom: 24px;
}

.variation_mainTit {
  border-top: #ddd solid 1px;
  font-size: 1.6rem;
  font-weight: normal;
  margin: 0 16px;
  padding-top: 12px;
}

.variation_slider_wrap {
  overflow: hidden;
  margin: 12px 16px 0;
}

.variation_link {
  color: #222;
  display: block;
}

.variation_label1_wrap {
  display: flex;
  flex-wrap: wrap;
  margin-top: -2px;
}

.variation_label2_wrap {
  display: flex;
  flex-wrap: wrap;
  margin-top: 0px;
}

.variation_label_1day,
.variation_label_1month,
.variation_label_clear,
.variation_label_limit,
.variation_label_new,
.variation_label_npw,
.variation_label_nsale,
.variation_label_pw,
.variation_label_reco,
.variation_label_sale,
.variation_label_ship,
.variation_label_stock,
.variation_label_web,
.variation_label_ship_m,
.variation_label_sale_m,
.variation_label_reco_m,
.variation_label_new_m,
.variation_label_limit_m {
  width: auto;
  height: 12px;
  margin: 4px 4px 0 0;
}

.variation_tit {
  --fs: 1.1rem;
  --fh: 1.3rem;
  font-size: var(--fs);
  font-weight: normal;
  line-height: var(--fh);
  margin: calc(4px + ((var(--fs) - var(--fh)) / 2)) 0 calc(0px + ((var(--fs) - var(--fh)) / 2));
}

.variation_tit_sub {
  --fs: 1.1rem;
  --fh: 1.3rem;
  font-size: var(--fs);
  line-height: var(--fh);
  margin: calc(0px + ((var(--fs) - var(--fh)) / 2)) 0 calc(0px + ((var(--fs) - var(--fh)) / 2));
}

.variation_titBlock { display: block; }

.variation_priceBlock {
  display: inline-block;
  margin-top: 2px;
}

.variation_price,
.variation_price_strikethrough {
  color: #000;
  font-size: 1.1rem;
  margin-top: 6px;
}
.variation_price_strikethrough,
.variation_price_strikethrough > .variation_priceBlock { text-decoration-line: line-through; }

.variation_price_sale {
  color: #e40c66;
  font-size: 1.1rem;
  font-weight: bold;
  display: inline-block;
  margin-top: 2px;
}

.variation_off {
  background-color: #e40c66;
  border-radius: 2px;
  color: #fff;
  font-size: 1rem;
  font-weight: bold;
  white-space: nowrap;
  display: inline-block;
  position: relative;
  margin-top: 2px;
  padding: 1px 11px 1px 2px;
}
.variation_off::after {
  content: "";
  width: 8px;
  height: 8px;
  background: url(/images/sp/label/label_arrow_m_sp.webp);
  background-size: 8px;
  display: block;
  position: absolute;
  top: 2.5px;
  right: 1.5px;
}

.variation_star_wrap {
  margin-top: 4px;
}

.variation_star {
  color: #ccc;
  font-size: 1.5rem;
  white-space: nowrap;
  display: inline-block;
  position: relative;
  z-index: 0; 
}
.variation_star_none { display: none; }
.variation_star::before,
.variation_star::after { content: '★★★★★'; }
.variation_star::after {
  color: #f5b51a;
  white-space: nowrap;
  position: absolute;
  z-index: 1;
  top: 0;
  left: 0;
  overflow: hidden;
}

.variation_star_txt {
  color: #696969;
  font-size: 1.1rem;
  display: inline-block;
  padding: 0 4px;
}

.variation_star_linkTxt {
  color: #1c70b5;
  font-size: 1.1rem;
  display: inline-block;
  margin-top: 2px;
}

/* 星5 */
.variation_star5::after { width: 100%; }
/* 星4.5 */
.variation_star4_5::after { width: 90%; }
/* 星4 */
.variation_star4::after { width: 80%; }
/* 星3.5 */
.variation_star3_5::after { width: 70%; }
/* 星3 */
.variation_star3::after { width: 60%; }
/* 星2.5 */
.variation_star2_5::after { width: 50%; }
/* 星2 */
.variation_star2::after { width: 40%; }
/* 星1.5 */
.variation_star1_5::after { width: 30%; }
/* 星1 */
.variation_star1::after { width: 20%; }
/* 星0.5 */
.variation_star0_5::after { width: 10%; }
/* 星0 */
.variation_star0::after { width: 0%; }

/* swiper */
.variation_wrap .swiper-pagination-bullet {
  background: #000 !important;
  display: block;
}
.variation_wrap .swiper-pagination {
 height: 8px;
 display: flex;
 justify-content: center;
}

.variation_wrap .swiper-pagination-bullets.swiper-pagination-horizontal,
.variation_wrap .swiper-pagination-fraction {
 bottom: 0 !important;
}

.variation_wrap .swiper-button-prev,
.variation_wrap .swiper-button-next {
  background: rgba(150, 150, 150, 0.4);
  color: #fff;
  width: 3vw !important;
  height: 8vw !important;
  top: 50% !important;
  margin-top: -15px !important;
  padding-top: 2px;
}

.variation_wrap .swiper-button-prev { left: 0.5vw; }
.variation_wrap .swiper-button-next { right: 0.5vw; }


.variation_wrap .swiper-button-next:after,
.variation_wrap .swiper-button-prev:after {
  font-size: 3.5vw !important;
}


/* 最近チェックした商品
------------------------------------------------------------------------------------*/
.history_wrap {
  border: #707070 solid 1px;
  border-radius: 8px;
  position: relative;
  margin: 24px 16px;
}

.history_tit {
  background: #000;
  border-radius: 7px 7px 0 0;
  color: #fff;
  font-size: 1.2rem;
  font-weight: bold;
  text-align: center;
  padding: 5px 0 6px;
}

.history_slider_wrap {
  width: 87.25%;
  position: relative;
  overflow: hidden;
  margin: 8px auto;
}
.history_slider_wrap_noSlide { width: 94.25%; }
.history_slider_img { border-radius: 8px; }

/* swiper */
.history_wrap .swiper-button-prev,
.history_wrap .swiper-button-next {
  background: rgba(150, 150, 150, 0.4);
  color: #fff;
  width: 3vw !important;
  height: 8vw !important;
  top: 0% !important;
  margin-top: calc(29px + 8.8vw) !important;
  padding-top: 2px;
}

.history_wrap .swiper-button-prev { left: 1.6vw; }
.history_wrap .swiper-button-next { right: 1.6vw; }


.history_wrap .swiper-button-next:after,
.history_wrap .swiper-button-prev:after {
  font-size: 3.5vw !important;
}