/******************************/
/* SLIDER */
/******************************/
@media screen and (max-width: 1030px) {
  .slider { margin-left: -20px; margin-right: -20px; position: relative; }
}
#slider div { width: 100%; max-width: 100%; height: auto; }
#slider > div { display: none; }
.bx-viewport #slider > div { display: block; }
.bx-wrapper { z-index: 0; }
.bx-wrapper img { width: 100%; height: auto; }
.bx-wrapper .bx-viewport { box-shadow: none !important; border: 0 !important; left: 0 !important; }
.bx-wrapper .bx-pager { bottom: -27px !important; }
.bx-wrapper .bx-pager.bx-default-pager a {
  margin: 0 3px !important; padding-top: 15px; width: 25px !important; height: 1px !important;
  background: transparent !important; border-bottom: 1px solid #cccccc; border-radius: 0 !important;
}
.bx-wrapper .bx-pager.bx-default-pager a:hover, .bx-wrapper .bx-pager.bx-default-pager a.active {
  background: transparent !important; border-bottom: 1px solid #000000;
}
/******************************/
/* NEWS */
/******************************/
.p-line-informaiton { display: flex; flex-wrap: wrap; margin-top: 75px; width: 760px; }
@media screen and (max-width: 767px) { .p-line-informaiton { display: block; width: auto; } }
.p-line-informaiton ul { flex: 1; font-size: 13px; }
@media screen and (max-width: 767px) { .p-line-informaiton ul { font-size: 12px; } }
.p-line-informaiton li { margin-bottom: 15px; }
.p-line-informaiton__ttl { position: relative; margin: 0 40px 0 0; font-size: 14px; font-weight: bold; }
@media screen and (max-width: 767px) { .p-line-informaiton__ttl { margin: 0; } }
.p-line-informaiton__ttl:before { content: ""; position: absolute; top: 7px; right: -20px; width: 1px; height: 10px; background: #d2d2d2; }
@media screen and (max-width: 767px) { .p-line-informaiton__ttl:before { content: none; } }
/***** お知らせ *****/
.p-top-news { display: flex; flex-wrap: wrap; align-items: center; margin-bottom: 50px; }
@media screen and (max-width: 767px) { .p-top-news { display: block; margin-bottom: 45px; } }
.p-top-news__ttl {
  box-sizing: border-box; margin-right: 25px; padding: 10px; width: 110px; border: 1px solid #b2b2b2;
  font-size: 18px; font-family: "游明朝体","Yu Mincho",YuMincho,"Noto Serif JP",serif; text-align: center;
}
@media screen and (max-width: 767px) { .p-top-news__ttl { margin-right: 0; margin-bottom: 10px; padding: 5px; width: 70px; border: 1px solid #b2b2b2; font-size: 12px; } }
.p-top-news__body { flex: 1; margin-bottom: 0; }
/******************************/
/* TOP RECOMMEND */
/******************************/
.p-recommend.u-container { padding-bottom: 0; }
/******************************/
/* NEW　ARRIVAL */
/******************************/
.p-new-item.u-container { padding-bottom: 0; }
/******************************/
/* TOP RANKING */
/******************************/
.p-ranking-list .slick-track { margin-left: 0; margin-right: 0; }
.p-ranking-list .slick-prev, .p-ranking-list .slick-next {
  top: 80px; width: 30px; height: 30px; transition: all 0.4s ease; z-index: 1; background: rgba(255,255,255,0.4);
}
@media screen and (max-width: 767px) { .p-ranking-list .slick-prev, .p-ranking-list .slick-next { top: 110px; width: 45px; height: 45px; } }
.p-ranking-list .slick-prev:before, .p-ranking-list .slick-next:before {
  content: ""; position: absolute; top: 7px; left: 10px; width: 15px; height: 15px; border-left: 1px solid #000; border-top: 1px solid #000;
  transition: all 0.4s ease;
}
@media screen and (max-width: 767px) { .p-ranking-list .slick-prev:before, .p-ranking-list .slick-next:before { top: 15px; } }
.p-ranking-list .slick-prev { left: 20px; }
@media screen and (max-width: 767px) { .p-ranking-list .slick-prev { left: 0; } }
.p-ranking-list .slick-prev:before { transform: rotate(-45deg); }
@media screen and (max-width: 767px) { .p-ranking-list .slick-prev:before { left: 17px; } }
.p-ranking-list .slick-next { right: 20px; }
@media screen and (max-width: 767px) { .p-ranking-list .slick-next { right: 0; } }
.p-ranking-list .slick-next:before { left: 4px; transform: rotate(135deg); }
@media screen and (max-width: 767px) { .p-ranking-list .slick-next:before { left: 13px; } }
.p-ranking-list__item { position: relative; box-sizing: border-box; margin-right: 20px; margin-left: 20px; padding-bottom: 25px; word-break: break-all; }
@media screen and (max-width: 1030px) { .p-ranking-list__item { margin-right: 5px; margin-left: 5px; } }
.p-ranking-list__img { position: relative; margin-bottom: 35px; text-align: center; }
@media screen and (max-width: 767px) { .p-ranking-list__img { text-align: center; } }
.p-ranking-list__img:before { content: ""; display: block; padding-top: 100%; }
.p-ranking-list__img a { display: block; position: absolute; top: 0; left: 0; width: 100%; height: 100%; }
.p-ranking-list__img img {
  display: inline-block !important; position: absolute; top: 0; right: 0; bottom: 0; left: 0; margin: auto;
  max-width: 100%; max-height: 100%; width: auto !important; text-align: center;
}
.p-ranking-list__num { position: absolute; top: 0; left: 1px; width: 24px; line-height: 24px; font-size: 12px; font-weight: bold; background: #000; color: #fff; text-align: center; }
.p-ranking-list__ttl img { vertical-align: middle; }
.p-ranking-list__price { color: #909090; margin-top: 20px; }
.p-ranking-list__btn { display: block; position: absolute; right: 0; bottom: 0; padding: 0; border: 0; background: transparent; color: #d8d8d8; cursor: pointer; text-align: center; transition: all .3s cubic-bezier(.25,.46,.45,.94); }
.p-ranking-list__btn.is-added { color: #000; }
.p-ranking-list__btn svg { width: 20px; height: 20px; fill: currentColor; }
/******************************/
/* TOP INFORMATION */
/******************************/
.p-information { padding-bottom: 0; }
@media screen and (max-width: 1030px) { .p-information { padding-bottom: 45px; } }
.p-information__body { margin-left: 60px; margin-right: 60px; line-height: 2; }
@media screen and (max-width: 1030px) { .p-information__body { margin-left: 0; margin-right: 0; } }
/******************************/
/* TOP FREE */
/******************************/
.p-free__body { margin-left: 60px; margin-right: 60px; line-height: 2; }
@media screen and (max-width: 1030px) { .p-free__body { margin-left: 0; margin-right: 0; } }
/******************************/
/* TOP BANNER */
/******************************/
.p-bnr { box-sizing: border-box; padding-left: 20px; padding-right: 20px; }
@media screen and (max-width: 1030px) { .p-bnr { padding-left: 20px; padding-right: 20px; } }
.p-bnr-list { box-sizing: border-box; display: flex; flex-wrap: wrap; justify-content: center; }
@media screen and (max-width: 767px) { .p-bnr-list { display: block; } }
.p-bnr-list__item { box-sizing: border-box; padding-left: 20px; padding-right: 20px; width: 33.3333%; }
@media screen and (max-width: 1030px) { .p-bnr-list__item { padding-left: 10px; padding-right: 10px; } }
@media screen and (max-width: 767px) {
  .p-bnr-list__item { padding-left: 0; padding-right: 0; margin-bottom: 10px; width: auto; text-align: center; }
}

/* =======================================================
   価格表示（RECOMMENDEDの2商品だけに適用）
   ======================================================= */
.cm-hide-original { display: none !important; }

/* 価格ブロック */
.cm-price-block { margin-top: 8px; }

/* 上段：販売価格（税抜）&#8212; 折り返し防止＆少し大きめ */
.cm-sale {
  color: #000;
  font-weight: 900;
  line-height: 1.1;
  letter-spacing: .02em;
  font-size: clamp(22px, 2.2vw, 26px);
  white-space: nowrap;
}
/* 直下：販売価格（税込）&#8212; 少し小さめ */
.cm-sale__taxline {
  margin-top: 2px;
  font-size: clamp(13px, 1.6vw, 15px);
  font-weight: 700;
  color: #222;
  white-space: nowrap;
}

/* 下段：定価（税抜）＋（税込） */
.cm-list { margin-top: 6px; }
.cm-strike-line,
.cm-strike-sub {
  position: relative;
  display: inline-block;
  color: #555;
  white-space: nowrap;
  text-decoration: none; /* ← text-decorationの線は使わない（3本化防止） */
}

/* メイン（税抜）サイズ */
.cm-strike-line {
  font-weight: 800;
  font-size: clamp(18px, 2vw, 22px);
  letter-spacing: .01em;
  padding: 2px 0;
}

/* サブ（税込）サイズ */
.cm-strike-sub {
  margin-top: 2px;
  font-weight: 700;
  font-size: clamp(13px, 1.6vw, 15px);
}

/* 二重線（iPhone対策：少し細く＋全体を少し上へ、間隔は維持） */
.cm-strike-line::before,
.cm-strike-line::after,
.cm-strike-sub::before,
.cm-strike-sub::after {
  content: "";
  position: absolute;
  left: 0; right: 0;
  height: 1.6px;                 /* ← 既存より“ほんの少し”細く */
  background: rgba(0,0,0,.45);
  pointer-events: none;
}

/* 上下ライン位置：従来45%/55% → 43%/53%（“少しだけ上”に） */
.cm-strike-line::before,
.cm-strike-sub::before { top: 43%; }  /* 上線：わずかに上へ */
.cm-strike-line::after,
.cm-strike-sub::after  { top: 53%; }  /* 下線：同じだけ上へ */

/* モバイル微調整 */
@media screen and (max-width: 767px) {
  .cm-sale { font-size: 24px; }
  .cm-sale__taxline { font-size: 14px; }
  .cm-strike-line { font-size: 20px; }
  .cm-strike-sub  { font-size: 14px; }
}
/******************************/
/* SLIDER */
/******************************/
@media screen and (max-width: 1030px) {
  .slider { margin-left: -20px; margin-right: -20px; position: relative; }
}
#slider div { width: 100%; max-width: 100%; height: auto; }
#slider > div { display: none; }
.bx-viewport #slider > div { display: block; }
.bx-wrapper { z-index: 0; }
.bx-wrapper img { width: 100%; height: auto; }
.bx-wrapper .bx-viewport { box-shadow: none !important; border: 0 !important; left: 0 !important; }

/* ★ 追加：Android/iPhone 両対応ピンチズーム許可 */
.bx-viewport { touch-action: pan-y pinch-zoom; }
.bx-viewport img { -webkit-user-drag: none; user-select: none; }
/* 端末差が出る場合の保険（任意） */
#slider { touch-action: pan-y pinch-zoom; }

.bx-wrapper .bx-pager { bottom: -27px !important; }
.bx-wrapper .bx-pager.bx-default-pager a {
  margin: 0 3px !important; padding-top: 15px; width: 25px !important; height: 1px !important;
  background: transparent !important; border-bottom: 1px solid #cccccc; border-radius: 0 !important;
}
.bx-wrapper .bx-pager.bx-default-pager a:hover, .bx-wrapper .bx-pager.bx-default-pager a.active {
  background: transparent !important; border-bottom: 1px solid #000000;
}
/******************************/
/* NEWS */
/******************************/
.p-line-informaiton { display: flex; flex-wrap: wrap; margin-top: 75px; width: 760px; }
@media screen and (max-width: 767px) { .p-line-informaiton { display: block; width: auto; } }
.p-line-informaiton ul { flex: 1; font-size: 13px; }
@media screen and (max-width: 767px) { .p-line-informaiton ul { font-size: 12px; } }
.p-line-informaiton li { margin-bottom: 15px; }
.p-line-informaiton__ttl { position: relative; margin: 0 40px 0 0; font-size: 14px; font-weight: bold; }
@media screen and (max-width: 767px) { .p-line-informaiton__ttl { margin: 0; } }
.p-line-informaiton__ttl:before { content: ""; position: absolute; top: 7px; right: -20px; width: 1px; height: 10px; background: #d2d2d2; }
@media screen and (max-width: 767px) { .p-line-informaiton__ttl:before { content: none; } }
/***** お知らせ *****/
.p-top-news { display: flex; flex-wrap: wrap; align-items: center; margin-bottom: 50px; }
@media screen and (max-width: 767px) { .p-top-news { display: block; margin-bottom: 45px; } }
.p-top-news__ttl {
  box-sizing: border-box; margin-right: 25px; padding: 10px; width: 110px; border: 1px solid #b2b2b2;
  font-size: 18px; font-family: "游明朝体","Yu Mincho",YuMincho,"Noto Serif JP",serif; text-align: center;
}
@media screen and (max-width: 767px) { .p-top-news__ttl { margin-right: 0; margin-bottom: 10px; padding: 5px; width: 70px; border: 1px solid #b2b2b2; font-size: 12px; } }
.p-top-news__body { flex: 1; margin-bottom: 0; }
/******************************/
/* TOP RECOMMEND */
/******************************/
.p-recommend.u-container { padding-bottom: 0; }
/******************************/
/* NEW　ARRIVAL */
/******************************/
.p-new-item.u-container { padding-bottom: 0; }
/******************************/
/* TOP RANKING */
/******************************/
.p-ranking-list .slick-track { margin-left: 0; margin-right: 0; }
.p-ranking-list .slick-prev, .p-ranking-list .slick-next {
  top: 80px; width: 30px; height: 30px; transition: all 0.4s ease; z-index: 1; background: rgba(255,255,255,0.4);
}
@media screen and (max-width: 767px) { .p-ranking-list .slick-prev, .p-ranking-list .slick-next { top: 110px; width: 45px; height: 45px; } }
.p-ranking-list .slick-prev:before, .p-ranking-list .slick-next:before {
  content: ""; position: absolute; top: 7px; left: 10px; width: 15px; height: 15px; border-left: 1px solid #000; border-top: 1px solid #000;
  transition: all 0.4s ease;
}
@media screen and (max-width: 767px) { .p-ranking-list .slick-prev:before, .p-ranking-list .slick-next:before { top: 15px; } }
.p-ranking-list .slick-prev { left: 20px; }
@media screen and (max-width: 767px) { .p-ranking-list .slick-prev { left: 0; } }
.p-ranking-list .slick-prev:before { transform: rotate(-45deg); }
@media screen and (max-width: 767px) { .p-ranking-list .slick-prev:before { left: 17px; } }
.p-ranking-list .slick-next { right: 20px; }
@media screen and (max-width: 767px) { .p-ranking-list .slick-next { right: 0; } }
.p-ranking-list .slick-next:before { left: 4px; transform: rotate(135deg); }
@media screen and (max-width: 767px) { .p-ranking-list .slick-next:before { left: 13px; } }
.p-ranking-list__item { position: relative; box-sizing: border-box; margin-right: 20px; margin-left: 20px; padding-bottom: 25px; word-break: break-all; }
@media screen and (max-width: 1030px) { .p-ranking-list__item { margin-right: 5px; margin-left: 5px; } }
.p-ranking-list__img { position: relative; margin-bottom: 35px; text-align: center; }
@media screen and (max-width: 767px) { .p-ranking-list__img { text-align: center; } }
.p-ranking-list__img:before { content: ""; display: block; padding-top: 100%; }
.p-ranking-list__img a { display: block; position: absolute; top: 0; left: 0; width: 100%; height: 100%; }
.p-ranking-list__img img {
  display: inline-block !important; position: absolute; top: 0; right: 0; bottom: 0; left: 0; margin: auto;
  max-width: 100%; max-height: 100%; width: auto !important; text-align: center;
}
.p-ranking-list__num { position: absolute; top: 0; left: 1px; width: 24px; line-height: 24px; font-size: 12px; font-weight: bold; background: #000; color: #fff; text-align: center; }
.p-ranking-list__ttl img { vertical-align: middle; }
.p-ranking-list__price { color: #909090; margin-top: 20px; }
.p-ranking-list__btn { display: block; position: absolute; right: 0; bottom: 0; padding: 0; border: 0; background: transparent; color: #d8d8d8; cursor: pointer; text-align: center; transition: all .3s cubic-bezier(.25,.46,.45,.94); }
.p-ranking-list__btn.is-added { color: #000; }
.p-ranking-list__btn svg { width: 20px; height: 20px; fill: currentColor; }
/******************************/
/* TOP INFORMATION */
/******************************/
.p-information { padding-bottom: 0; }
@media screen and (max-width: 1030px) { .p-information { padding-bottom: 45px; } }
.p-information__body { margin-left: 60px; margin-right: 60px; line-height: 2; }
@media screen and (max-width: 1030px) { .p-information__body { margin-left: 0; margin-right: 0; } }
/******************************/
/* TOP FREE */
/******************************/
.p-free__body { margin-left: 60px; margin-right: 60px; line-height: 2; }
@media screen and (max-width: 1030px) { .p-free__body { margin-left: 0; margin-right: 0; } }
/******************************/
/* TOP BANNER */
/******************************/
.p-bnr { box-sizing: border-box; padding-left: 20px; padding-right: 20px; }
@media screen and (max-width: 1030px) { .p-bnr { padding-left: 20px; padding-right: 20px; } }
.p-bnr-list { box-sizing: border-box; display: flex; flex-wrap: wrap; justify-content: center; }
@media screen and (max-width: 767px) { .p-bnr-list { display: block; } }
.p-bnr-list__item { box-sizing: border-box; padding-left: 20px; padding-right: 20px; width: 33.3333%; }
@media screen and (max-width: 1030px) { .p-bnr-list__item { padding-left: 10px; padding-right: 10px; } }
@media screen and (max-width: 767px) {
  .p-bnr-list__item { padding-left: 0; padding-right: 0; margin-bottom: 10px; width: auto; text-align: center; }
}

/* =======================================================
   価格表示（RECOMMENDEDの2商品だけに適用）
   ======================================================= */
.cm-hide-original { display: none !important; }
.cm-price-block { margin-top: 8px; }
.cm-sale { color: #000; font-weight: 900; line-height: 1.1; letter-spacing: .02em; font-size: clamp(22px, 2.2vw, 26px); white-space: nowrap; }
.cm-sale__taxline { margin-top: 2px; font-size: clamp(13px, 1.6vw, 15px); font-weight: 700; color: #222; white-space: nowrap; }
.cm-list { margin-top: 6px; }
.cm-strike-line, .cm-strike-sub {
  position: relative; display: inline-block; color: #555; white-space: nowrap; text-decoration: none;
}
.cm-strike-line { font-weight: 800; font-size: clamp(18px, 2vw, 22px); letter-spacing: .01em; padding: 2px 0; }
.cm-strike-sub  { margin-top: 2px; font-weight: 700; font-size: clamp(13px, 1.6vw, 15px); }
.cm-strike-line::before, .cm-strike-line::after,
.cm-strike-sub::before, .cm-strike-sub::after {
  content: ""; position: absolute; left: 0; right: 0; height: 1.6px; background: rgba(0,0,0,.45); pointer-events: none;
}
.cm-strike-line::before, .cm-strike-sub::before { top: 43%; }
.cm-strike-line::after,  .cm-strike-sub::after  { top: 53%; }

@media screen and (max-width: 767px) {
  .cm-sale { font-size: 24px; }
  .cm-sale__taxline { font-size: 14px; }
  .cm-strike-line { font-size: 20px; }
  .cm-strike-sub  { font-size: 14px; }
}
