@charset "UTF-8";

.js_errorCode {
  color: #999;
  font-size: 1rem;
  text-align: center;
  position: absolute;
  top: 84px;
  left: 388px;
  z-index: 10;
}

/* 共通 */
.comn_swiper_hidden { display: none; }

/* コンテンツ幅の一括設定 */
.headerBnr_exc,
.product_wrap,
.description_wrap,
.review_wrap,
.variation_wrap {
  max-width: var(--maxWidth);
  margin: var(--maxWidthMargin);
  padding: var(--maxWidthPadding);
}

/* 上部バナー */
.headerBnr_exc { display: block; }

/* 上部定期便注意文：カートに商品が入っている時
------------------------------------------------------------------------------------*/
.upperCaution_cart_p {
  color: #ff0000;
  --fs: 2rem;
  --fh: 2.8rem;
  font-size: var(--fs);
  line-height: var(--fh);
  font-weight: bold;
  text-align: center;
  display: none;
  margin-bottom: 16px;
}

/* 上部注意文
------------------------------------------------------------------------------------*/
.upperCaution_cart_p,
.upperCaution_p {
  color: #ff0000;
  --fs: 2rem;
  --fh: 2.8rem;
  font-size: var(--fs);
  line-height: var(--fh);
  font-weight: bold;
  text-align: center;
  margin-bottom: 16px;
}

/* 上部注意文：黒文字
------------------------------------------------------------------------------------*/
.upperCaution_black_p {
  color: #000;
  --fs: 2rem;
  --fh: 2.8rem;
  font-size: var(--fs);
  line-height: var(--fh);
  font-weight: bold;
  text-align: center;
  margin-bottom: 8px;
}

/* 上部バナー（共通）
------------------------------------------------------------------------------------*/
.upperBnr_cmn {
  display: block;
  max-width: var(--maxWidth);
  margin: var(--maxWidthMargin);
  padding: var(--maxWidthPadding);
  margin-bottom: 12px;
}

/* 商品
------------------------------------------------------------------------------------*/
.product_wrap {
  display: flex;
  margin-top: 32px;
}

/* 左側
-----------------------*/
.product_L {
  flex: 1;
  padding-right: 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 6px;
}

.product_tmb {
  width: 14.6%;
  cursor: pointer;
  margin: 2.48% 2.48% 0 0;
  transition: opacity 300ms;
}
.product_tmb:hover { opacity: 0.5; }
.product_tmb:nth-of-type(6n) { margin-right: 0; }
.product_tmb_current { outline: 6px solid #a0b4d7; }

/* 右側
-----------------------*/
.product_R { width: 326px; }

.product_tit {
  --fs: 2.2rem;
  --fh: 2.4rem;
  font-size: var(--fs);
  line-height: var(--fh);
  margin: calc(8px + ((var(--fs) - var(--fh)) / 2)) 0 calc(0px + ((var(--fs) - var(--fh)) / 2));
  margin: calc(16px + ((var(--fs) - var(--fh)) / 2)) 0 calc(0px + ((var(--fs) - var(--fh)) / 2));
}

.product_tit .product_tit_brand {
  border-bottom: #222 solid 1px;
  font-size: 1.8rem;
  display: block;
  margin-bottom: 4px;
  padding-bottom: 4px;
}

/* 定期用 */
.teiki_specificPage_hide { display: none; }

.product_tit_sub {
  --fs: 1.6rem;
  --fh: 1.8rem;
  font-size: var(--fs);
  line-height: var(--fh);
  margin: calc(8px + ((var(--fs) - var(--fh)) / 2)) 0 calc(0px + ((var(--fs) - var(--fh)) / 2));
}

.product_label1_wrap {
  display: flex;
  flex-wrap: wrap;
  margin-top: -4px;
}

.product_label2_wrap {
  display: flex;
  flex-wrap: wrap;
  margin: calc(8px - 4px) 0 0;
}

.productList_label_js_judge { display: none; }

/* 上段 */
.productList_label_new,
.productList_label_limit,
.productList_label_stock,
.productList_label_renewal,
.productList_label_sale,
.productList_label_reco,
.productList_label_ship {
  width: auto;
  height: 19px;
  margin: 4px 4px 0 0;
}

/* 下段 */
.productList_label_1day,
.productList_label_1month,
.productList_label_2week,
.productList_label_pw,
.productList_label_npw,
.productList_label_toric,
.productList_label_lowWater,
.productList_label_highWater,
.productList_label_uv,
.productList_label_moist,
.productList_label_silicone,
.productList_label_blueLight,
.productList_label_vitamin,
.productList_label_produce,
.productList_label_web,
.productList_label_nsale {
  width: auto;
  height: 18px;
  margin: 4px 4px 0 0;
}

.product_form { padding-top: 12px; }

.product_paramList_wrap {
  border-bottom: #ddd solid 1px;
  display: flex;
  flex-wrap: wrap;
  padding: 16px 8px 12px;
  /* padding: 20px 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_price { position: relative; }

.product_paramList_value,
.product_paramList_value_price,
.product_paramList_value_priceFree {
  --width: 104px;
  width: calc(100% - var(--width));
  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_toric_item,
.product_paramList_toric_cyl,
.product_paramList_toric_ax { 
  width: 100%;
  height: 34px;
  background: url(/images/pc/common/pulldown_arrow_pc.svg) #fff right center no-repeat;
  background-size: 34px;
  border: 1px solid #ddd;
  border-radius: 0;
  color: #353535;
  font-size: 1.6rem;
  position: relative;
  z-index: 1;
  margin: 4px 0;
  padding: 0 34px 0 12px;
  -webkit-appearance: none;
}
.product_paramList_value:nth-of-type(2) .product_paramList_select,
.product_paramList_value:nth-of-type(2) .product_paramList_toric_item:not(.product_form_selectDisabled) { margin-top: 8px; }

.product_form_selectDisabled {
  height: auto;
  min-height: 34px;
  background: none;
  border: none;
  font-size: 1.6rem;
  line-height: 2rem;
  position: relative;
  pointer-events: none;
  top: -1px;
  padding-left: 0;
  padding-right: 0;
  text-wrap: wrap;
}

/*
.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_form_selectDisabled.product_paramList_select_alert { padding: 0 34px 0 12px; }

/* 商品合計 */
.product_total_wrap {
  background: #fdf5f8;
  display: flex;
  flex-wrap: wrap;
  margin-top: 12px;
  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: 2em;
  background: none;
  border: none;
  border-radius: 4px;
  color: #353535;
  font-size: 1.6rem;
  text-align: right;
  margin-left: 8px;
  padding-right: 4px;
  -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: 0 0 0 8px;
  transition: opacity 300ms;
}
.product_total_value_quantityBtn_plus:hover,
.product_total_value_quantityBtn_minus:hover { opacity: 0.5; }
.product_total_value_quantityBtn_plus { padding-top: 1px; }

.product_total_value_quantityBtn_off {
  opacity: 0.3;
  cursor: default;
}
.product_total_value_quantityBtn_off:hover { opacity: 0.3; }

.product_total_plice {
  width: 130px;
  font-size: 1.5rem;
  font-weight: bold;
  text-align: right;
}

/* 一括反映 */
.js_allset_btn {
  width: 104px;
  height: 24px;
  background: #fff2f7;
  border: #d5155b solid 1px;
  border-radius: 8px;
  color: #d5155b;
  font-size: 1.4rem;
  font-weight:bold;
  text-align: center;
  display: grid;
  place-items: center;
  position: absolute;
  top: -38px;
  right: 34px;
  cursor: pointer;
  transition: background 300ms, color 300ms;
}
.js_allset_btn_off {
  background: #fff;
  border: #b6b6b6 solid 1px;
  color: #b6b6b6;
  cursor: default;
}

.js_allset_help_btn {
  width: 22px;
  height: 22px;
  background: #f3f3f3;
  border: #5a5a5a solid 1px;
  border-radius: 18px;
  color: #434343;
  font-size: 1.2rem;
  font-weight:bold;
  text-align: center;
  display: grid;
  place-items: center;
  position: absolute;
  top: -37px;
  right: 0;
  z-index: 10;
  cursor: pointer;
}

.js_allset_help_txt {
  width: 220px;
  background: #e8f4ff;
  border: #000 solid 1px;
  box-shadow: 3px 3px 3px #ccc;
  font-size: 1.4rem;
  line-height: 2rem;
  position: absolute;
  top: -124px;
  right: -8px;
  opacity: 0;
  pointer-events: none;
  padding: 7px 10px;
  transition: top 300ms, opacity 300ms;
}
.js_allset_help_txt_on {
  top: -134px;
  opacity: 1;
  pointer-events: auto;
}

.js_allset_help_txt:before{
  content: "";
  border: 10px solid transparent;
  border-top: 14px solid #e8f4ff;  
  position: absolute;
  bottom: -22px;
  right: 8px;
  z-index: 2;
}
.js_allset_help_txt:after{
  content: "";
  border: 10px solid transparent;
  border-top: 14px solid #000;
  filter: drop-shadow(3px 3px 3px rgba(204, 204, 204, 1));
  position: absolute;
  bottom: -24px;
  right: 8px;  
  z-index: 1;
}


/* 2SETまとめ買いバナー
------------------------------------------------------------------------------------*/
.btn_exc {
  display: block;
  margin-top: 32px;
}


/* カートに入れるボタン
------------------------------------------------------------------------------------*/
.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-top: 24px;
}
.btn_cart:hover { text-decoration: none; }

.btn_cart::before {
  content: "";
  width: 21px;
  height: 20px;
  background: url(/images/pc/product/cart_icon_pc.svg) no-repeat;
  display: block;
  margin-right: 4px;
}

.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-top: 24px;
}
.btn_cart_off:hover { opacity: 1; }

.btn_cart_off_inner {
  background: url(/images/pc/product/cart_icon_off_pc.svg) no-repeat;
  background-size: 20px;
  padding-left: 24px;
}

.cart_period {
  font-size: 1.2rem;
  margin: 4px 16px 0;
}

.btn_cart_cautionText {
  color: #ff0000;
  --fs: 1.4rem;
  --fh: 1.8rem;
  font-size: var(--fs);
  line-height: var(--fh);
  text-indent: -1em;
  display: block;
  margin: 24px 0 -16px;
  padding-left: 1em;
}

.btn_cart_cautionText_link {
  color: #ff0000;
  text-decoration: underline;
  text-underline-offset: 2px;
}


/* お気に入りに追加ボタン
------------------------------------------------------------------------------------*/
.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;
  place-items: center;
  cursor: pointer;
  margin-top: 16px;
}
.btn_fav:hover { text-decoration: none; }

.btn_fav::before,
.btn_fav_off::before {
  content: "";
  width: 17px;
  height: 17px;
  background: url(/images/pc/product/fav_icon_pc.svg) no-repeat;
  display: block;
  margin: 2px 6px 0 0;
}

.btn_fav_off {
  border: #d7d7d7 solid 1px;
  color: #a3a3a3;
}
.btn_fav_off::before { background: url(/images/pc/product/fav_gray_icon_pc.svg) no-repeat; }


/* シェアボタン
------------------------------------------------------------------------------------*/
.shareBtn_wrap {
  height: 32px;
  display: flex;
  justify-content: space-between;
  margin-top: 16px;
}

.shareBtn_line,
.shareBtn_x,
.shareBtn_link {
  width: 31.77%;
  border: #ddd solid 1px;
  border-radius: 8px;
  display: grid;
  place-items: center;
}
.shareBtn_img { max-height: 30px; }


/* クーポン
------------------------------------------------------------------------------------*/
.coupon_wrap {
  max-width: calc(var(--maxWidth) - 80px);
  background: #f0f0f0;
  border-radius: 12px;
  margin: 40px auto 0;
}

.coupon {
  border-top: #aaa solid 1px;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  margin: 0 16px 0 24px;
  padding: 20px 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.4rem;
  --fh: 1.6rem;
  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.8rem;
  --fh: 2.4rem;
  color: #1c70b5;
  font-size: var(--fs);
  font-weight: bold;
  line-height: var(--fh);  
  display: inline-block;
  cursor: pointer;
  margin: calc(6px + ((var(--fs) - var(--fh)) / 2)) 0 calc(0px + ((var(--fs) - var(--fh)) / 2));
  transition: opacity 300ms;
}
.coupon_detailLink:hover { opacity: 0.5; }

.coupon_r { width: 250px; }

.coupon_getBtn {
  width: 100%;
  height: 36px;
  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, opacity 300ms;
}
.coupon_getBtn:hover { opacity: 0.5; }

.coupon_getBtn_off {
  background: #d7d7d7;
  color: #a3a3a3;
  cursor: default;
}

.coupon_Deadline {
  --fs: 1.2rem;
  --fh: 1.6rem;
  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.4rem;
  font-weight: bold;
  display: inline-block;
  cursor: pointer;
  transition: opacity 300ms;
}
.coupon_addBtn_link:hover { opacity: 0.5; }


/* 注意文
------------------------------------------------------------------------------------*/
.caution_wrap {
  max-width: var(--maxWidth);
  margin: var(--maxWidthMargin);
  padding: var(--maxWidthPadding);
  margin-top: 40px;
}

.caution_p {
  color: #ff0000;
  --fs: 1.6rem;
  --fh: 2.4rem;
  font-size: var(--fs);
  line-height: var(--fh);
}


/* 商品説明
------------------------------------------------------------------------------------*/
.description_wrap {
  /*
  height: 100%;
  max-height: 178px;
  position: relative;
  overflow: hidden;
  */
  margin-top: 40px;
  /* transition: max-height 250ms; */
}

.description_accordion {
  height: 100%;
  max-height: 164px;
  position: relative;
  overflow: hidden;
  transition: max-height 250ms;
}

.description_accordion_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: 2rem;
  margin-bottom: -4px;
}

.description_p {
  --fs: 1.6rem;
  --fh: 2.4rem;
  font-size: var(--fs);
  line-height: var(--fh);
  margin: calc(24px + ((var(--fs) - var(--fh)) / 2)) 0 calc(0px + ((var(--fs) - var(--fh)) / 2));
}

.description_accordionBtn {
  width: 300px;
  height: 40px;
  background: #fff;
  border: #3e3e3e solid 1px;
  border-radius: 9999px;
  font-weight: bold;
  display: none;
  position: absolute;
  justify-content: center;
  place-items: center;
  bottom: 0;
  left: 50%;
  z-index: 2;
  transform: translateX(-50%);
  cursor: pointer;
  transition: opacity 300ms;
}
.description_accordionBtn:hover { opacity: 0.5; }

.description_accordionBtn::before {
  content: "";
  width: 17px;
  height: 10px;
  background: url(/images/pc/common/more_icon_pc.svg) no-repeat;
  display: block;
  margin: 2px 8px 0 -8px;
}


/* レビュー
------------------------------------------------------------------------------------*/
.review_wrap {
  margin-top: 32px;
  scroll-margin-top: 56px;
  /* overflow-x: hidden; */  
}

.description_wrap + .review_wrap {
  margin-top: 64px;
}

.review_tit {
  font-size: 2rem;
  margin-bottom: -4px;
}

.review_number {
  color: #d5155b;
  font-size: 1.2rem;
  font-weight: normal;
  padding-left: 4px;
}

.review,
.review_pin {
  border: #ddd solid 1px;
  border-radius: 8px;
  position: relative;
  margin-top: 16px;
  padding: 16px 16px 64px;
}
.review_pin {
  background: #fdf5f8;
  border: #d5155b solid 1px;
}
.review_pin::before {
  content: "";
  width: 16px;
  height: 24px;
  background: url(/images/pc/product/review_icon_pin_pc.svg) no-repeat;
  background-size: contain;
  display: block;
  position: absolute;
  top: 4px;
  right: 4px;
}

.review_star {
  color: #f5b51a;
  font-size: 1.4rem;
  letter-spacing: 2px;
}

.review_date,
.review_user,
.review_buyItem_wrap {
  color: #707070;
  font-size: 1.4rem;
  margin-top: 6px;
}

.review_buyItem_wrap { margin: 4px 0 -4px; }

.review_buyItem {
  background: #efefef;
  border-radius: 100px;
  display: inline-block;
  margin: 0 4px 4px 0;
  padding: 2px 8px;
}

.review_pin .review_buyItem { background: #fff; }

.review_txt {
  --fs: 1.6rem;
  --fh: 2.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));
}

.review_img_wrap {
  width: 172px;
  display: flex;
  justify-content: space-between;
  margin: 20px 0 -52px;
}

.review_img {
  width: 80px;
  height: 80px;
  background: #bcb1b3;
  cursor: pointer;
  object-fit: contain;
}

/*-------------------------------------------------------------------------------------------------------------------*/
/*
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/pc/product/review_icon_good_pc.svg) 8px 5px / 17px #fff no-repeat;
  border: #707070 solid 1px;
  border-radius: 8px;
  font-size: 1.4rem;
  display: inline-block;
  position: absolute;
  bottom: 12px;
  right: 12px;
  cursor: pointer;
  padding: 7px 10px 0 32px;
  transition: opacity 300ms;
}
.review_goodBtn:hover { opacity: 0.5; }

.review_pin .review_goodBtn {
  background: url(/images/pc/product/review_icon_good_pin_pc.svg) 8px 5px / 17px #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: 300px;
  height: 40px;
  border: #3e3e3e solid 1px;
  border-radius: 9999px;
  font-weight: bold;
  display: flex;
  justify-content: center;
  place-items: center;
  cursor: pointer;
  margin: 32px auto 0;
  transition: opacity 300ms;
}
.review_moreBtn:hover { opacity: 0.5; }

.review_moreBtn::before {
  content: "";
  width: 17px;
  height: 10px;
  background: url(/images/pc/common/more_icon_pc.svg) no-repeat;
  display: block;
  margin: 2px 8px 0 -12px;
}

.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: 100%;
  max-width: 520px;
  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;
}


/* 類似商品
------------------------------------------------------------------------------------*/
.variation_wrap {
  position: relative;
  margin-top: 72px;
  padding-bottom: 36px;
}

.variation_mainTit {
  border-top: #ddd solid 1px;
  font-size: 2rem;
  padding-top: 16px;
}

.variation_slider_wrap {
  overflow: hidden;
  margin: 24px 40px 0;
}
.variation_slider_wrap_noSlide { margin: 24px 0 0; }

.variation_link { color: #222; }
.variation_link:hover { text-decoration: none; }

.variation_label1_wrap {
  display: flex;
  flex-wrap: wrap;
  margin-top: -2px;
}

.variation_label2_wrap {
  display: flex;
  flex-wrap: wrap;
  margin-top: 0px;
}

.variation_label_js_judge { display: none; }

/* 上段 */
.variation_label_new,
.variation_label_limit,
.variation_label_stock,
.variation_label_renewal,
.variation_label_sale,
.variation_label_reco,
.variation_label_ship {
  width: auto;
  height: 13px;
  margin: 4px 4px 0 0;
}

/* 下段 */
.variation_label_1day,
.variation_label_1month,
.variation_label_2week,
.variation_label_pw,
.variation_label_npw,
.variation_label_toric,
.variation_label_lowWater,
.variation_label_highWater,
.variation_label_uv,
.variation_label_moist,
.variation_label_silicone,
.variation_label_blueLight,
.variation_label_vitamin,
.variation_label_produce,
.variation_label_web,
.variation_label_nsale {
  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_titBlock .product_tit_brand { display: block; }

/*
.variation_priceBlock {
  display: block;
  margin-top: 2px;
}
*/

.variation_price,
.variation_price_strikethrough {
  color: #000;
  font-size: 1.1rem;
  margin-top: 8px;
}
.variation_price_strikethrough { text-decoration-line: line-through; }

.variation_price_sale {
  color: #e40c66;
  font-size: 1.1rem;
  font-weight: bold;
  display: inline-block;
  margin-top: 4px;
}

.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/pc/label/label_arrow_m_pc.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;
}
.variation_star_linkTxt:hover { text-decoration: underline; }

/* 星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-slide { transition: opacity 300ms; }
.variation_wrap .swiper-slide:hover { opacity: 0.5; }

.variation_wrap .swiper-pagination-bullet {
  background: #000 !important;
  display: block;
}
.variation_wrap .swiper-pagination {
  height: 12px;
  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 {
  width: 20px !important;
  height: 56px !important;
  background: rgba(150, 150, 150, 0.4);
  color: rgba(255, 255, 255, 0.6);
  display: grid;
  place-items: center;
  text-align: center;
  margin-top: -28px !important;
  transition: opacity 300ms;
}
.variation_wrap .swiper-button-prev:hover,
.variation_wrap .swiper-button-next:hover { opacity: 0.5; }

.variation_wrap .swiper-button-prev { left: 48px; }
.variation_wrap .swiper-button-next { right: 48px; }

.variation_wrap .swiper-pagination-bullet {
  width: 12px !important;
  height: 12px !important;
}

.variation_wrap .swiper-button-next:after,
.variation_wrap .swiper-button-prev:after {
  font-size: 1.8rem !important;
}


/* 最近チェックした商品
------------------------------------------------------------------------------------*/
.history_wrap {
  width: calc(100% - 80px);
  max-width: calc(var(--maxWidth) - 80px);
  border: #707070 solid 1px;
  border-radius: 8px;
  position: relative;
  margin: 64px auto;
}

.history_tit {
  background: #000;
  border-radius: 7px 7px 0 0;
  color: #fff;
  font-size: 2rem;
  font-weight: bold;
  text-align: center;
  padding: 6px 0 7px;
}

.history_slider_wrap {
  width: calc(100% - 68px);
  position: relative;
  overflow: hidden;
  margin: 8px auto;
}
.history_slider_wrap_noSlide { width: calc(100% - 22px); }
.history_slider_img { border-radius: 8px; }

/* swiper */
.history_wrap .swiper-slide { transition: opacity 300ms; }
.history_wrap .swiper-slide:hover { opacity: 0.5; }

.history_wrap .swiper-button-prev,
.history_wrap .swiper-button-next {
  background: rgba(150, 150, 150, 0.4);
  color: #fff;
  width: 18px !important;
  height: 46px !important;
  top: calc(50% + 41px - 23px) !important;
  display: grid;
  place-items: center;
  transition: opacity 300ms;
}
.history_wrap .swiper-button-prev:hover,
.history_wrap .swiper-button-next:hover { opacity: 0.5; }

.history_wrap .swiper-button-prev { left: 8px; }
.history_wrap .swiper-button-next { right: 8px; }


.history_wrap .swiper-button-next:after,
.history_wrap .swiper-button-prev:after {
  font-size: 1.8rem !important;
}


/* スタッフレビューボタン
------------------------------------------------------------------------------------*/
.product_staffReview_btn {
  width: 300px;
  height: 40px;
  background: #fff;
  border: #3e3e3e solid 1px;
  border-radius: 9999px;
  color: #222;
  font-weight: bold;
  display: flex;
  justify-content: center;
  place-items: center;
  margin: 64px auto 0;
  transition: opacity 300ms;
}
.product_staffReview_btn:hover {
  text-decoration: none;
  opacity: 0.5;
}

.product_staffReview_btn::before {
  content: "";
  width: 26px;
  height: 17px;
  background: url(/images/pc/product/review_icon_pc.svg) no-repeat;
  display: block;
  margin: 0 8px 0 -8px;
}


/* スペック表
------------------------------------------------------------------------------------*/
.product_spec {
  width: calc(100% - 80px);
  max-width: calc(var(--maxWidth) - 80px);
  border-collapse: collapse;
  margin: 80px auto 0;
}

.product_spec th,
.product_spec td {
  border: #ccc solid 1px;
  font-size: 1.6rem;
  line-height: 2rem;
  text-align: left;
  padding: 10px 12px;
}

.product_spec th {
  width: 30%;
  background: #f7f7f7;
}