@charset "UTF-8";


/* 共通 */
.comn_swiper_hidden { display: none; }

/* コンテンツ幅の一括設定 */
.cart_wrap,
.coupon_wrap,
.variation_wrap {
  max-width: var(--maxWidth);
  margin: var(--maxWidthMargin);
  padding: var(--maxWidthPadding);
}


/* カートアラート
------------------------------------------------------------------------------------*/
.cartAlert_wrap {
  width: 520px;
  background: rgb(248 89 147 / .05);
  border: #f85993 solid 1px;
  border-radius: 5px;
  color: #f85993;
  margin: 32px auto 0;
  padding: 10px 16px 18px 40px;
}

.cartAlert_ul {
  font-size: 1.6rem;
  font-weight: bold;
  line-height: 2rem;
  display: inline-block;
  position: relative;
  left: 50%;
  transform: translateX(-50%);
}
.cartAlert_li { margin-top: 8px; }


/* カートの中身
------------------------------------------------------------------------------------*/
.cart_wrap { margin-top: 32px; }

.cart_mainTit {
  height: 60px;
  background: #eee;
  border: #ccc solid 1px;  
  font-size: 2rem;
  padding: 20px 16px;
}

.cart_item_warp {
  border: #ccc solid 1px;
  border-top: none;
}

.cart_item {
  border-bottom: #ccc solid 1px;
  display: flex;
  flex-wrap: wrap;
  position: relative;
  margin: 0 16px;
  padding: 16px 0;
}
.cart_item:last-of-type { border-bottom: none; }

.cart_item_detail_tmb {
  width: 160px;
  height: 100%;
  border: #ececec solid 1px;
}

.cart_item_detail_txt_wrap {
  flex: 1;
  margin-left: 16px;
  padding-right: 130px;
}

.cart_item_detail_txt_tit {
  --fs: 1.6rem;
  --fh: 1.8rem;
  font-size: var(--fs);
  line-height: var(--fh);
  margin: calc(0px + ((var(--fs) - var(--fh)) / 2)) 0 calc(0px + ((var(--fs) - var(--fh)) / 2));
  padding-bottom: 4px;
}

.cart_item_detail_txt_pwr {
  color: #707070;
  --fs: 1.4rem;
  --fh: 1.6rem;
  font-size: var(--fs);
  line-height: var(--fh);
  letter-spacing: -0.04rem;
  word-break: break-all;
  margin: calc(8px + ((var(--fs) - var(--fh)) / 2)) 0 calc(0px + ((var(--fs) - var(--fh)) / 2));
}

.cart_item_detail_txt_price {
  font-size: 1.4rem;
  margin-top: 16px;
}

.cart_item_btns {
  width: 120px;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  position: absolute;
  top: 16px;
  right: 0;
}

.cart_item_btns_quantity_tit { font-size: 1.4rem; }

.cart_item_btns_quantity {
  width: calc(100% - 3em);
  height: 32px;
  background: url(/images/pc/common/pulldown_arrow_pc.svg) #fff right 6px center no-repeat;
  background-size: 16px;
  border: 1px solid #cccr;
  border-radius: 4px;
  color: #353535;
  font-size: 1.4rem;
  text-align-last: center;
  position: relative;
  margin: 0;
  padding-right: 24px;
  -webkit-appearance: none;
}

.cart_del_form { width: 100%; }

.cart_item_btns_delete,
.cart_item_btns_buyLater {
  width: 100%;
  height: 32px;
  border: #ccc solid 1px;
  border-radius: 4px;
  color: #222;
  font-size: 1.4rem;
  display: grid;
  place-items: center;
  margin-top: 8px;
  padding: 0 16px;
}
.cart_item_btns_delete:hover,
.cart_item_btns_buyLater:hover { text-decoration: none; }

.cart_total {
  width: 100%;
  background: rgb(248 89 147 / .05);
  display: flex;
  flex-wrap: wrap;
}

.cart_total_tit,
.cart_total_tit_w {
  width: 120px;
  border-top: #ccc solid 1px;
  font-size: 1.6rem;
  padding: 16px 0 16px 24px;
}

.cart_total_value,
.cart_total_value_w {
  width: calc(100% - 120px);
  border-top: #ccc solid 1px;
  font-size: 1.6rem;
  text-align: right;
  padding: 16px 24px 16px 0;
}

.cart_total_tit_w,
.cart_total_value_w {
  font-size: 1.6rem;
  font-weight: bold;
}

.cart_btn_wrap {
  width: 696px;
  height: 56px;
  display: flex;
  justify-content: center;
  margin: 32px auto 0;
}

.cart_btn_buy {
  width: 340px;
  height: 52px;
  background: #f85993;
  border-radius: 5px;
  box-shadow: 0 4px 0 #c7386c;
  text-align: center;
  color: #fff;
  font-size: 2rem;
  font-weight: bold;
  display: block;
  place-items: center;
  margin-right: 16px;
  padding-top: 16px;
}
.cart_btn_buy:hover { text-decoration: none; }

.cart_btn_buy::before {
  content: "";
  width: 18px;
  height: 18px;
  background: url(/images/sp/cart/buy_icon_sp.svg) no-repeat;
  background-size: contain;
  display: inline-block;
  position: relative;
  top: 1px;
  margin-right: 2px;
}

.cart_btn_shopping {
  width: 340px;
  background: #eee;
  border: #ccc solid 1px;
  border-radius: 5px;
  text-align: center;
  color: #222;
  font-size: 2rem;
  font-weight: bold;
  display: grid;
  place-items: center;
}
.cart_btn_shopping:hover { text-decoration: none; }


/* 対象クーポン
------------------------------------------------------------------------------------*/
.coupon_wrap {
  max-width: 1000px;
  border: #ccc solid 1px;
  margin: 64px auto 0;
  padding: 0;
}

.coupon_mainTit {
  height: 60px;
  background: #eee;
  border-bottom: #ccc solid 1px;
  font-size: 1.8rem;
  padding: 20px 16px;
}

.coupon {
  border-top: #ccc solid 1px;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  margin: 0 8px;
  padding: 20px 8px;
  padding: 16px 8px;
}
.coupon:first-of-type { border-top: none; }

.coupon_l {
  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: #f85993;
  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: #f85993;
  border-radius: 5px;
  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_getBtn_off:hover { opacity: 1; }

.coupon_Deadline {
  --fs: 1.2rem;
  --fh: 1.4rem;
  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 {
  border-top: #bcbcbc solid 1px;
  color: #f85993;
  font-size: 1.2rem;
  font-weight: bold;
  cursor: pointer;
  margin: 0 16px 12px;
  padding-top: 12px;
}

.coupon_terms {
  width: 100%;
  color: #29598f;
  font-size: 1.6rem;
  font-weight: bold;
  margin-top: 16px;
}

.coupon_addShopping {
  width: 250px;
  height: 42px;
  background: #f85993;
  border-radius: 5px;
  text-align: center;
  color: #fff;
  font-size: 1.6rem;
  font-weight: bold;
  display: grid;
  place-items: center;
  margin: 24px auto 0;
}
.coupon_addShopping:hover { text-decoration: none; }


/* amazon payボタン
------------------------------------------------------------------------------------*/
.amazonPay_btn {
  width: 200px;
  display: block;
  margin: 32px auto 0;
}


/* 類似商品
------------------------------------------------------------------------------------*/
.variation_wrap {
  position: relative;
  margin-top: 80px;
  padding-bottom: 36px;
}

.variation_mainTit {
  border-top: #ccc 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_label1_wrap img{
  width: auto;
  height: 15px;
  margin: 4px 4px 0 0;
}

.variation_label2_wrap {
  display: flex;
  flex-wrap: wrap;
  margin-top: 0px;
}


/* 上段 */
/* .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_priceBlock {
  display: block;
  margin-top: 2px;
}

.variation_price,
.variation_price_sale,
.variation_price_strikethrough {
  color: #000;
  font-size: 1.1rem;
  margin-top: 8px;
}

.variation_price_sale {
  color: #e40c66;
  font-weight: bold;
  margin-top: 4px;
}

.variation_price_strikethrough { text-decoration-line: line-through; }

.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: #f85993;
  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;
}