	@charset "utf-8";
/* =======================================================================================



LOWER



======================================================================================= */
main > article { overflow: hidden; }
.grecaptcha-badge { z-index: 999; margin-bottom: 44px; }
.box { list-style: none; padding: 0; }
.box.col { display: flex; flex-direction: column; }

.box.row,
.box.row1,
.box.row2,
.box.row3,
.box.row4,
.box.row5,
.box.row6 { display: flex; flex-direction: row; }

.box.row2,
.box.row3,
.box.row4,
.box.row5,
.box.row6 { flex-wrap: wrap; }

.box.row1 > *,
.box.row2 > *,
.box.row3 > *,
.box.row4 > *,
.box.row5 > * { flex-basis: 100%; }

.box.row6 > * { flex-basis: 50%; }

[class*="_btn"]:not([class*="_box"]) { display: inline-block; overflow: hidden; margin: auto; line-height: 1; text-align: center; vertical-align: middle; text-decoration: none !important; cursor: pointer; transition: all .2s linear; }
a[class*="_btn"]:not([class*="_box"]):before { display: inline-block; width: 0; height: 100%; vertical-align: middle; content: ''; }


@media screen and (min-width: 370px) {
.box.row2 > *,
.box.row3 > *,
.box.row5 > * { flex-basis: 50%; }
.box.row4 > * { flex-basis: 50%; }
/*.box.row2:has(> *.row2, > *.row3, > *.row4, > *.row5, > *.row6) > * { flex-basis: 100%; }*/
}

@media screen and (min-width: 560px) {
.box.row5 > * { flex-basis: calc(100% / 3); }
}

@media screen and (min-width: 640px) {
.box.row3 > * { flex-basis: calc(100% / 3); }
}

@media screen and (min-width: 760px) {
main.flag,
footer.flag { filter: blur(2px); transform: translate3d(0,-176px,0); }

/*.box.row2:has(> *.row2, > *.row3, > *.row4, > *.row5, > *.row6) > * { flex-basis: 50%; }*/
.box.row4 > * { flex-basis: 25%; }
}
@media screen and (min-width: 880px) {
.box.row5 > * { flex-basis: 20%; }
.box.row6 > * { flex-basis: calc(100% / 3);}
}
@media screen and (min-width: 1152px) {
.inner { padding: 0; }
.box.row6 > * { flex-basis: calc(100% / 6); }
}

/* =======================================================================================



FONT



======================================================================================= */

.zen-kaku-gothic-new-light {
  font-family: "Zen Kaku Gothic New", serif;
  font-weight: 300;
  font-style: normal;
}


.lineup_ttl h2,
.lineup_lead h2,
.lineup_lead p,
.item_card h2,
.item_txt,
.item_shop_btn,
.item_cart_btn,
.cart_del_btn,
.cart_btn,
.item_spec,
.item_return_btn,
.item_choice,
.item_cart,
.item_shop,
.item_outline h2,
.cart_ttl,
.item_ol_01,
.item_ol_02,
.item_ol_03,
.item_ol_04,
.item_ol_05,
.cart_header_flow,
.cart_box2 dd,
.cart_user_table,
.cart_add_tel,
.cart_add_box02 address,
.cart_add_table,
.cart_add_table input,
.cart_add_table select,
.cart_add_table textarea,
.cart_add_table:placeholder,
.cart_pay_txt,
.cart_pay_credit_table,
.cart_thankyou_block p,
.oh_1st_table,
.oh_2nd_detail_inner,
.favorite_item,
.zen-kaku-gothic-new-regular {
  font-family: "Zen Kaku Gothic New", serif;
  font-weight: 400;
  font-style: normal;
}

.item_detail h1,
.item_price,
.item_buy_btn,
.item_card.mk3 h3,
.cart_box2 dt strong,
.cart_calc_table th,
.cart_calc_table .right,
.cart_add_name,
.cart_thankyou_block h2,
.oh_2nd_box dt,
.zen-kaku-gothic-new-medium {
  font-family: "Zen Kaku Gothic New", serif;
  font-weight: 500;
  font-style: normal;
}

.lineup_unit h1,
.lineup_ttl h3,
.poppins-regular {
  font-family: "Poppins", serif;
  font-weight: 400;
  font-style: normal;
}

.breadcrumb_box li  {
  font-family: "Poppins", "Zen Kaku Gothic New", serif;
  font-weight: 400;
  font-style: normal;
}

/* =======================================================================================



Breadcrumb



======================================================================================= */
.breadcrumb_unit { background-color: #f5f5f5; padding: 1em; line-height: 1; }
.breadcrumb_unit .inner { margin-bottom: 0!important; }
.breadcrumb_box li { overflow: hidden; position: relative; font-size: 12px; font-weight: 500; letter-spacing: .12em; }
.breadcrumb_box li a { position: relative; }
.breadcrumb_box li a:after { opacity: 0; position: absolute; left: 0; bottom: -4px; width: 100%; height: 1px; background-color: rgba(255,255,255,.6); content: '';  transition: all .2s linear !important; }
.breadcrumb_box li a:hover:after { opacity: 1; bottom: -2px; }
.breadcrumb_box li a:hover { background-color: transparent !important;  }
.breadcrumb_box222 li:nth-child(n+2) { padding-left: 1.5em; }
.breadcrumb_box222 li:nth-child(n+2):before { position: absolute; top: 12px; left: 5px; display: block; width: 5.5px; height: 5.5px; margin: auto; border: 1px solid currentColor; border-bottom: 0; border-left: 0; color: rgba(255,255,255,.4); line-height: 1; vertical-align: middle;  transform: rotate(45deg); content: '' }

/* =======================================================================================
ページャー
======================================================================================= */
.pagination {display: flex; list-style: none; margin: 0; padding: 0 0 32px; gap: 8px; justify-content: center;}
.pagination .page-item {display: inline-block;}
.pagination .page-link,
.pagination .dots {display: inline-block; padding: 6px 10px; text-align: center; min-width: 40px; font-size: 14px; color: #545454; border: 1px solid #eeece8; text-decoration: none;}
.pagination .page-item a:hover{color: #545454; background: #f5f5f5; border-color: #eeece8;}
.pagination .page-item.active .page-link {color: #545454; background: #f5f5f5; border-color: #eeece8; pointer-events: none; font-weight: 600;}
.pagination .dots{border: none; padding: 6px 4px; cursor: default;}
@media screen and (min-width: 960px) {
.pagination {padding: 0 0 64px; }
}

/* =======================================================================================
ぱんくず
======================================================================================= */
nav[aria-label="Breadcrumb"] ol{list-style: none;padding: 0;display: flex; flex-wrap: wrap; gap: 0.5rem;}
nav[aria-label="Breadcrumb"] li { padding-right: .5rem;}
nav[aria-label="Breadcrumb"] li + li::before { content: ">"; margin-right: .5rem;}
nav[aria-label="Breadcrumb"] li:last-child{ padding-right: 0;}
/* =======================================================================================



SENDEING



======================================================================================= */
.sendeing_dsp { display: block; z-index: 99; position: fixed; top: 0; left: 0; width: 100%; height: 100%; background-color: rgba(255,255,255,.5); text-align: center; }
.sendeing_dsp b { display: block; color: #314457; }
.sendeing_dsp i,
.sendeing_dsp i:after { border-radius: 50%; width: 4em; height: 4em; }
.sendeing_dsp i { display: block; margin: 10% auto 1em; font-style: normal; font-size: 13px; transform: translateZ(0); animation: sendeingrotate 1.1s infinite linear;
     border-top: .5em solid rgba(55,55,55,.2);
   border-right: .5em solid rgba(55,55,55,.2);
  border-bottom: .5em solid rgba(55,55,55,.2);
    border-left: .5em solid #181818;
}
@keyframes sendeingrotate {
  0% { transform: rotate(0deg); }
  100% { transform: rotate(360deg); }
}
.tac.mk1 { margin-top: 40px; }
/* =======================================================================================



Category


======================================================================================= */

.low_unit { padding-bottom: 32px; }
/* 親要素：はみ出た分を隠す */
.product_first_unit {
  width: 100%;
  padding: 16px 0 32px;
  overflow: hidden;
  text-align: center;
}

.product_first_unit:has(.cate_mv_box) { padding-top: 4px; }

.product_first_unit:empty { padding: 0; height: 24px; }

/* 中身のコンテナ：常に中央配置 */
.cate_mv_box {
  display: flex;
  justify-content: center;
  list-style: none;
  padding: 0;
  margin: 0 0 32px;
  width: 100%;
  gap: 3px;
}

/* 画像を包む li */
.cate_mv_box li {
  flex: 1; /* 通常時は均等 */
  min-width: 0;
}

.cate_mv_box li img {
  width: 100%;
  height: auto;
  display: block;
}

/* 画面幅が 640px 以下のとき、縮小させない設定 */
@media screen and (max-width: 640px) {
.product_first_unit { padding: 4px 0 64px; }
  .cate_mv_box {
    /* 画面が 640px より小さくなっても、中身は 640px を維持 */
    width: 640px;
    flex-shrink: 0;
    /* 親要素の真ん中に持ってくる */
    position: relative;
    left: 50%;
    transform: translateX(-50%);
  }

  .cate_mv_box li {
    /* 640px を 3分割したサイズで固定 (隙間3px×2を考慮) */
    flex: 0 0 calc((640px - 6px) / 3);
  }
}

.lower_page .ttl { font-size: clamp(1.625rem, 1.034rem + 2.95vw, 2rem); font-family: "Poppins", sans-serif;  font-weight: 600; margin-bottom: 8px; }

.cate_2nd_box:empty { padding: 0; }
.cate_2nd_box { display: flex; flex-wrap: wrap; gap: 8px; }
.cate_2nd_box > * { flex-basis: calc(100% / 2 - 8px);}
.cate_2nd_box figcaption { padding: 12px 6px; text-align: center; font-weight: 500; font-size: 12px; }
.cate_2nd_box .item_card a { display: block; aspect-ratio: 1 / 1; overflow: hidden; }
.cate_2nd_box .item_card a img { width: 100%; height: 100%; object-fit: cover; transition: all .2s linear; }
.cate_2nd_box .item_card a:hover { border: none; }
.cate_2nd_box .item_card a:hover img { width: 102%; height: 102%; }

.wtag_unit { padding: 32px 0;}
.wtag_list { list-style: none; padding: 0; display: flex; flex-wrap: wrap; gap: 6px; }
.wtag { display: block; padding: 7px 15px; border-radius: 18px; border: 1px solid #eeece8; background-color: #fff; font-size: 12px; font-weight: 700; line-height: 1; transition: all .2s linear; }
.wtag:hover,.wtag.active { text-decoration: none; background-color: #f5f5f5; border: 1px solid #eeece8; }

.cate_main_box { display: flex; flex-wrap: wrap; gap: 8px; border-top: solid 1px #eeece8; padding-top: 40px; }
.cate_main_box > * { flex-basis: calc(100% / 2 - 8px);}
.cate_main_box figcaption { padding: 8px 0 20px; }
.cate_main_box .item_card h2 { margin-bottom: 8px; font-size: 13px; font-weight: 700; }
.cate_main_box .item_card h3 { font-size: 12px; font-weight: 500; }
.cate_main_box .item_card a { aspect-ratio: 1 / 1; overflow: hidden; }
.cate_main_box .item_card a:hover{ border-bottom: none; }
.cate_main_box .item_card a img { width: 100%; height: 100%; object-fit: cover; transition: all .2s linear;}
.cate_main_box .item_card a:hover img { width: 102%; height: 102%; opacity: 0.6; }

.choose_unit:has(.item_card.pt2) { padding-bottom: 0; }
.choose_unit:has(.item_card.pt2) .inner { padding: 0; }
.choose_box.row2:has(.item_card.pt2) { gap: 8px; margin: auto; }
.choose_box.row2 .item_card.pt2 { position: relative; padding: 0; flex-basis: calc(50% - 8px); }
.choose_box.row2 .item_card.pt2 a:before { position: absolute; display: block; top: 0; left: 0; width: 100%; height: 100%; content: ''; background-color: rgba(99,99,99,.23); }
.choose_box.row2 .item_card.pt2 a{border: none; transition: all .2s linear; }
.choose_box.row2 .item_card.pt2 a:hover{border: none; opacity: 0.6; }
.choose_box.row2 .item_card.pt2 figcaption { position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); padding: 0; width: 100%; text-align: center; }
.choose_box.row2 .item_card.pt2 h2 { color: #fff; font-weight: 700; font-size: 14px; }
	
@media screen and (min-width: 720px) {
.cate_2nd_box > * { flex-basis: calc(100% / 4 - 8px);}
.cate_main_box > * { flex-basis: calc(100% / 4 - 8px);}
.cate_main_box figcaption { padding: 12px 0 40px; }
}

@media screen and (min-width: 960px) {
.low_unit { padding-bottom: 64px; }
.product_first_unit { padding: 32px 0 64px; }
.product_first_unit:empty { height: 40px; }
}
/* =======================================================================================



Products



======================================================================================= */
article:has(.breadcrumb_unit, .lineup_unit) .lineup_unit h1:first-child { margin-top: 42px; }
.lineup_ttl_box { align-items: flex-end; flex-wrap: wrap; padding: 28px 0; justify-content: center; }
.lineup_ttl_box > * { padding-top: 8px; flex-grow: 1; }
.lineup_ttl_box > *:first-child { padding-right: 24px; flex-grow: 0; }
.lineup_ttl_box.pt2 > *:first-child { padding-right: 0; flex-grow: 0; }


.lineup_ttl h2 { font-size: 12px; letter-spacing: .12em; }
.lineup_ttl_box.pt2 .lineup_ttl h2 { font-size: 16px; letter-spacing: .12em; font-weight: 700; }
.lineup_ttl h3 { color: rgba(255,255,255,.75); font-size: 36px; line-height: 40px; letter-spacing: .08em; }
.lineup_ttl.mk2 h3 { font-size: 26px; line-height: normal; }

.mv_unit,
.mv_box,
.mv_img { height: 64vh; }
.mv_box { position: fixed; top: 70px; width: 100%; }

.mv_img { background-position: center center; background-repeat: no-repeat; background-size: cover; }
.mv_img.no1 { background-image: url( "/assets/img/product/mv01_01m.jpg"); }
.mv_img img { width: 100%; }

.mv_img .oth { display: none; }
.mv_img .mobile { display: block; }

.choose_unit { padding-bottom: 64px; }
.choose_unit .solid { margin-bottom: 48px; }

.lineup_unit h1 { margin-bottom: 64px; color: rgba(255,255,255,.75); font-size: clamp(1.25rem, 0.45rem + 4vw, 3.25rem); letter-spacing: .08em; }

.lineup_unit .box.row2 figcaption { padding-bottom: 56px; }
.lineup_unit .box.row3 figcaption { padding-bottom: 64px; }
.lineup_unit .box.row5 figcaption { padding-bottom: 56px; }

.lineup_box.row2 { margin: 0 -15px; }
.lineup_box.row2 > * { padding: 0 15px; }
.lineup_box.row3 { margin: 0 -15px; }
.lineup_box.row3 > * { padding: 0 15px; }

.lineup_lead_box { flex-wrap: wrap; padding: 64px 0 80px; }
.lineup_lead { flex-basis: 100%; }
.lineup_lead h2 { margin-bottom: 1em; font-size: clamp(1rem, 0.775rem + 1.13vw, 1.563rem); letter-spacing: .155em; color: #fff; }
.lineup_lead p { font-size: 13px; line-height: 2; letter-spacing: .145em; color: #545454; }
.lineup_lead img { margin-bottom: 16px; }

.choose_box.row2 { margin: 0 -15px; }
.choose_box.row2 > * { padding: 0 15px; }
.choose_box.row3 { margin: 0 -15px; }
.choose_box.row3 > * { padding: 0 15px; }

.lineup_box.row5 { margin: 0 -15px; }
.lineup_box.row5 > * { padding: 0 15px; }

.lineup_box .item_card figcaption { padding: 8px 0 16px; }
.choose_box .item_card figcaption { padding: 8px 0 24px; }
.item_img_box{display: block; overflow: hidden; aspect-ratio: 1 / 1;}
.item_card img { object-fit: cover; width: 100%; height: 100%; }
.lineup_box.row2 .item_card a:first-child { display: block; overflow: hidden; max-width: 545px; aspect-ratio: 1 / 1; }
.lineup_box.row2 .item_card img { height: 100%; object-fit: cover; }
.item_card h2 { font-size: 12px; font-weight: 600; line-height: 1.6; letter-spacing: .11em; }
.item_card.mk2 h2 { font-size: 15px; }
.item_card.mk3 h2 { font-size: 15px; }
.item_card h3 { font-size: 16px; letter-spacing: .11em; line-height: 1.4; }
.item_card.mk3 h3 { font-size: 13px; text-align: right; }
.item_card.mk3 a { display: block; overflow: hidden; aspect-ratio: 1 / 1; }

.item_box { padding-top: 24px; flex-wrap: wrap; }
.item_img { width: 100%; position: relative; }
.item_img:before { position: absolute; content: ''; top: 0; right: 0; height: 100%; display: block; border-right: 5px solid #fff; z-index: 2; }
.item_img > .box { max-width: 400px; margin: auto; }
.item_img dt { overflow: hidden; aspect-ratio: 1 / 1; padding: 0; }
.item_img dd { padding: 8px 0 32px; }
.item_photo { overflow: hidden; aspect-ratio: 1 / 1; }
/* 2025/10/1修正① ここから */
.item_thumb_slick .item_photo { /*max-width: 95px;*/ }
/* 2025/10/1修正① ここまで */
.item_photo img { object-fit: cover; width: 100%; height: 100%; }
.item_thumb_slick .item_photo img { border: 1px solid #eaeaea; }
.item_thumb_slick .item_photo.slick-current img { border: 1px solid rgba(255,255,255,.4); }

.item_thumb_slick:not(.slick-slider) { display: flex; }
.item_thumb_slick:not(.slick-slider) .item_photo { flex-basis: calc(100% / 6); }

.item_thumb_slick{transform: unset !important;}
.item_thumb_slick .item_photo { flex-basis: calc(100% / 10); }

.item_img.same .item_thumb_slick .slick-track { transform: unset !important; }
.item_img.few .item_thumb_slick .slick-track { width: auto!important; transform: unset !important; }


.item_detail { width: 100%; }
.item_detail h1 { font-size: 20px; letter-spacing: .245em; font-weight: 600;}
.item_price { padding: 0 0 32px; font-size: 16px; letter-spacing: .11em; /*text-align: right;*/ }
.item_tag_assemble{width: 50px; height: 50px; margin: -1.0em 0 1em;}
.item_txt { padding-bottom: 16px; font-size: 15px; line-height: 2; letter-spacing: .115em; }
/*.item_txt * { color: #545454; }*/
.item_txt a { border-bottom: solid 1px #545454;}
.item_txt a:hover { border-bottom: none;}
.item_contact { padding-bottom: 30px; }
.item_contact > .box { flex-wrap: wrap; }
.item_contact > .box > * { padding: 4px 0; width: 100%; }
.item_buy_btn,
.item_shop_btn { width: 100%; height: 54px; padding: 16px 8px; border: 1px solid #545454; font-size: 14px; }
.item_buy_btn { background-color: rgba(255,255,255,1); color: rgba(120,146,173,.7); }
.item_buy_btn:hover { background-color: rgba(255,255,255,.3); }
.item_shop_btn { background-color: rgba(255,255,255,.1); color: #545454;}
.item_shop_btn:hover { background-color: rgba(255,255,255,.3); }
.item_loading { margin: 40px auto; width: 40px; height: 40px; border: 4px solid rgba(255,255,255,.4); border-top-color: #8DA0B5; border-radius: 50%; animation: loading-spinner 1s linear infinite; }
@keyframes loading-spinner { to { transform: rotate(360deg); } }

#cta_soldout .item_shop_btn { background-color: rgba(255,255,255,.1); color: #545454; cursor: default;}
#cta_soldout .item_shop_btn:hover { background-color: rgba(255,255,255,.1); }

.item_bnr { margin-bottom: 24px; }
.item_bnr a{ transition: all .2s linear; }
.item_bnr a:hover{ border-bottom: none; opacity: 0.8; }

.item_spec { padding-bottom: 1rem; }
.item_spec * { position: relative; font-size: 14px; letter-spacing: .115em; }
.item_spec h2 { position: relative; padding-right: 1rem; cursor: pointer; padding: 16px 16px 0 16px;}
.item_spec h2:before { position: absolute; top: 20px; right: 20px; display: block; width: 8px; height: 8px; margin: auto; border: 1px solid #4b4b4b; border-bottom: 0; border-left: 0; color: rgba(255,255,255,.4); line-height: 1; vertical-align: middle; cursor: pointer; transform: rotate(135deg); transition: all .3s linear; content: ''
}
.item_spec h2.flag:before { top: 20px; transform: rotate(315deg); }
.item_spec .jq_toggle_dsp { display: none;  padding: 0 16px;}

.item_spec p a { display: inline; transition: all .2s linear; border-bottom: solid 1px #545454; }
.item_spec p a:hover { border-bottom: none; }
.item_spec .jq_dsp { padding-bottom: 16px; border: 1px solid #eaeaea; }
.item_spec table { margin-top: 20px; }
.item_spec table tr { padding-bottom: 20px; }
.item_spec table th,
.item_spec table td { padding-bottom: 20px; }
.item_spec table th { padding-right: 1.0rem; font-weight: 500; text-align: left; vertical-align: top; white-space: nowrap; letter-spacing: 0; }
/*.item_spec table th:after { position: absolute; right: -.5rem; content: '：'; }*/
.item_spec table td {font-size: 13px; font-weight: 500; padding-left: .5rem;}
.item_spec .fc{font-size: 12px; margin: 1.0em 0 0 0.5em;}
.item_spec #size_w:not(:empty)::before{content: "幅"; padding-right: 0.4em;}
.item_spec #size_d:not(:empty)::before{content: "奥行"; padding-right: 0.4em;}
.item_spec #size_h:not(:empty)::before{content: "高さ"; padding-right: 0.4em;}
.item_spec #size_sh:not(:empty)::before{content: "座高"; padding-right: 0.4em;}
.item_spec #size_t:not(:empty)::before{content: "厚さ"; padding-right: 0.4em;}

.item_spec #size_w:not(:empty)::after{content: "mm"; padding-right: 0.5rem;}
.item_spec #size_d:not(:empty)::after{content: "mm"; padding-right: 0.5rem;}
.item_spec #size_h:not(:empty)::after{content: "mm"; padding-right: 0.5rem;}
.item_spec #size_sh:not(:empty)::after{content: "mm"; padding-right: 0.5rem;}
.item_spec #size_t:not(:empty)::after{content: "mm"; padding-right: 0.5rem;}

.item_spec #finishing_name:not(:empty)::before{content: "・";}

.item_spec table.item_shop_tbl { border-collapse: collapse; font-size: 12px !important; }
.item_spec table.item_shop_tbl th,
.item_spec table.item_shop_tbl td { display: block; }
.item_spec table.item_shop_tbl tr { border-top: 1px solid #eaeaea; }
.item_spec table.item_shop_tbl tr:first-child { /*border-top-color: #fff;*/ }
.item_spec table.item_shop_tbl tr th { padding: 12px 8px 0 1em; text-indent: -1em; white-space: normal; line-height: 1.2; vertical-align: middle; }
.item_spec table.item_shop_tbl tr td { padding: 4px 0 12px; text-align: right; }
.item_return_btn { position: relative; width: 100%; padding: 16px; background: #eaeaea; border: none; color: #545454; font-size: 14px; letter-spacing: .165em; }
.item_return_btn:hover { background: #f5f5f5; border: none; }

.item_return_btn .arrow { display: none;
  width: 20px;
  height: 1px;
  margin: 6.4px 0;
  border-radius: 9999px;
  background-color: #545454;
  position: absolute;
  left: 16px;
}

.item_return_btn .arrow::before,
.item_return_btn .arrow::after {
  content: "";
  position: absolute;
  top: calc(50% - 0.5px);
  left: 0;
  width: 8px;
  height: 1px;
  border-radius: 9999px;
  background-color: #545454;
  transform-origin: 0.5px 50%;
}
.item_return_btn .arrow::before { transform: rotate(45deg); }
.item_return_btn .arrow::after { transform: rotate(-45deg); }

.item_unit .btn_box { padding: 80px 0; }

.item_txtlink { border-bottom: 1px solid #545454; transition: all .2s linear; }
.item_txtlink:hover { border-bottom: none; }

.item_choice {}
.item_choice dt,
.item_choice dd { padding-bottom: .5em; font-size: 13px; line-height: 2; letter-spacing: .115em; }
.item_choice dd:last-child { padding-bottom: 28px; }
.item_select { display: inline-block; position: relative; }
.item_select::after {
content: "";
    position: absolute;
    top: 18px;
    right: 16px;
    width: 12px;
    height: 12px;
    margin: auto;
    border: 1px solid currentColor;
    border-bottom: 0;
    border-left: 0;
    color: rgba(255, 255, 255, .4);
    line-height: 1;
    vertical-align: middle;
    transform: rotate(135deg);
    transition: all .3s linear;
    cursor: pointer;
    pointer-events: none;
}
.item_select:has(select:disabled)::after { cursor: default; }
.item_select select { min-width: 260px; height: 52px; padding-right: 1em; padding-left: 12px; appearance: none; cursor: pointer; border: 1px solid #eaeaea; }
.item_select select:disabled{ cursor: default;}

.item_select:has(option:only-child){ pointer-events: none; }
.item_select:has(option:only-child)::after { display: none; }

.item_cart { padding: 12px 0 40px; }
.item_cart_parts { flex-wrap: wrap; gap: 8px; }
.item_cart_parts_01 { flex-basis: calc(100% - 8px); /*order: 3;*/ }
.item_cart_parts_02 { flex-grow: 1; /*order: 1;*/ }
.item_cart_parts_03 { /*order: 2;*/ }
.item_plusminus_btn {}

.item_cart_parts_02 .error{text-align: center; color: #E86868; font-size: 12px; font-weight: 600; padding-top: 8px;}


.favNone button,
.fav input{width: 100%; }
.favNone button,
.fav input{ width: 32px; display: block; padding: 48px 20px 0; border: none; background: url("/assets/img/ic_fav.png") no-repeat center center; cursor: pointer; transition: .3s; }
.favNone button:hover,.fav input:hover{background:  url("/assets/img/ic_fav_darker.png") no-repeat center center; }
.fav a{background: url("/assets/img/ic_fav.png") no-repeat center center; }


.fav a span{font-weight: bold;}
.fav a:hover{border: 4px solid #FF7373; color: #FF7373;}
.ttNone{display: none;}
.toolTip{z-index: 10;position: absolute; display: inline; padding: 15px; background: #fff; border: solid 1px #eeece8;; box-shadow: 1px 1px 3px rgba(69,69,69,.8); font-size: 12px; line-height: 1.4; left: -226px; top: 125%; margin-bottom: 12px; text-align: center; width: 278px;}
.toolTip strong{line-height: 2; font-size: 14px; font-weight: 500;}
.toolTip span {display: block; margin-top: 8px;}
.toolTip a{font-size: 13px;line-height: 2; color: #545454; border-bottom: solid 1px #545454; background: none; padding: 0;}
.toolTip a:hover{ text-decoration: none;}


.item_cart_btn { width: 100%; height: 48px; padding: 12px 8px; border: none; background-color: #333; color: #fff; font-size: 15px; }
.item_cart_btn:hover { background-color: #000; }

.item_favorite_btn {width: 100%; max-width: 52px; display: block; border: none; background: url("/assets/img/ic_fav_new.png") no-repeat center center; background-size: 50%; padding: 26px; cursor: pointer; transition: .3s;}
.item_favorite_btn.active,
.item_favorite_btn:hover {background:  url("/assets/img/ic_fav_gray.png") no-repeat center center; background-size: 50%; padding: 24px 26px;}





/* WebKit ブラウザで、input type="number" のスピンボタンを非表示にする。 */
.item_cart input[type="number"]::-webkit-outer-spin-button,
.item_cart input[type="number"]::-webkit-inner-spin-button {
  -webkit-appearance: none;
  appearance: none;
  margin: 0;
}

/* Firefox で、input type="number" のスピンボタンを非表示にする。また、入力欄の値表示を中央寄せにし、高さをボタンのサイズに合わせる。 */
.item_cart input[type="number"] {
  -moz-appearance: textfield;
  text-align: center;
  width: 56px;
  height: 48px;
  margin: 0 4px;
  padding: 0;
  border: 1px solid #eaeaea;
}

.item_cart button.btn-number {
  width: 48px;
  height: 48px;
  border-radius: 4px;
  border: none;
  background-color: #f5f5f5;
  font-size: 16px;
}
.item_cart button.btn-number[data-type="minus"] { padding-bottom: 4px; }

/* ステッパーコンポーネントの横幅を指定する。 */
.item_cart div.input-group {
  border: 1px solid rgba(255, 255, 255, .8);
}



.item_shop {}
.item_shop_visit_btn { font-size: 12px; padding: 6px 10px; border: none; color: #FFF; background: #474747; margin-left: -10px;}
.item_shop_visit_btn:hover { background: #000; color: #FFF;}


.item_shops { padding-bottom: 8px; }
.item_shops .item_shops_button { display: block; max-width: 260px; border: none; background-color: #474747; color: #fff; width: 100%; font-size: 13px; line-height: 40px; text-align: center; font-weight: 700; transition: all .2s linear; }
.item_shops .item_shops_button:hover{ background: #000; }
.item_choice_1maiita { padding-bottom: 32px;}
.item_choice_1maiita a { display: block; max-width: 260px; border: 1px solid #eaeaea; text-align: center; line-height: 40px; font-size: 13px; font-weight: 700; }
.item_question_unit { padding: 16px 0; }
.item_question_box { padding: 14px 10px; background-color: #f5f5f5; font-weight: 500; font-size: 13px; }
.item_question_box > * + * { padding-top: 1em; }
.item_question_box a { border-bottom: 1px solid #545454; }
.item_question_box a:hover { border: none; }


.item_outline { color: #545454; background: #f5f5f5; padding: 54px 16px; margin: 54px 0;}
.item_outline h1 { text-align: center; }
.item_outline h2{font-size: clamp(1rem, 0.85rem + 0.75vw, 1.375rem);}
.item_outline h3{font-size: 17px;}
.item_outline h4{font-size: 16px;}
.item_outline h5{font-size: 15px;}
.item_outline p{font-size: 15px;}
.item_outline b{ font-weight: 600;}
.item_outline > p { padding-bottom: 1rem; color: #545454; font-size: 14px; }
.item_outline img{padding: 20px;}

.item_hr { border: none; height: 1px; background-color: rgba(255,255,255,.4); }

.item_ol_01 { padding-bottom: 1em; }
.item_ol_01 .box { align-items: center; }
.item_ol_01 .box > * { flex-basis: 50%; padding: 2em 0; }
.item_ol_01 .box > * p { padding: 0 2em; font-size: 14px; }

.item_ol_02 { margin-bottom: 1em; padding: 2em 2em; background-color: rgba(255,255,255,.2);}
.item_ol_02 h3 { padding-bottom: 2em; font-size: 19px; }
.item_ol_02 .box.row { justify-content: space-between; }
.item_ol_02 .box.row > * { flex-basis: calc(100% / 3); max-width: 280px; }
.item_ol_02 .box.col dd { font-size: 13px; }

.item_ol_03,
.item_ol_04,
.item_ol_05 { padding-bottom: 120px; }

.item_ol_03 .box dd,
.item_ol_04 .box.col p { padding-top: 1em; }

.item_ol_03 .box.col p,
.item_ol_04 .box.col p,
.item_ol_05 figcaption { font-size: 15px; line-height: 2; letter-spacing: .115em; }

.item_ol_04 {  }
.item_ol_04 .box.row { justify-content: space-between; }
.item_ol_04 .box.row > * { flex-basis: calc(100% / 3); max-width: 280px; }

.item_ol_05 figure { padding: 1em 0; text-align: center; }
.item_ol_05 figure div img { margin: auto; }
.item_ol_05 figcaption { padding-top: 2em; }

[class*="item_ol_"] + h2 { padding-top: 2em; }

.item_thumb_slick { margin: 0 -4px; }
/* 2025/10/1修正② ここから */
.item_thumb_slick .slick-track { display: flex; flex-wrap: wrap; }
.item_thumb_slick .slick-track > * { flex-basis: calc(100% / 4); }
.item_thumb_slick .item_photo { padding: 0 4px 8px; }
/* 2025/10/1修正②　ここまで */
.item_thumb_slick .slick-prev:before,
.item_thumb_slick .slick-next:before { display: block; width: 14px; height: 14px; margin: auto; border: 1px solid currentColor; border-bottom: 0; border-left: 0; color: rgba(255,255,255,.4); line-height: 1; vertical-align: middle; cursor: pointer; transition: all .3s linear; content: '' }
.item_thumb_slick .slick-prev:before { transform: rotate(225deg); }
.item_thumb_slick .slick-next:before { transform: rotate(45deg); }


.viewed_items_box,
.pickup_box { display: flex; flex-wrap: wrap; gap: 8px; }
.viewed_items_box > *,
.pickup_box > * { flex-basis: calc(100% / 3 - 8px);}
.viewed_items_box .item_card a,
.pickup_box .item_card a { display: block; aspect-ratio: 1 / 1; overflow: hidden; }
.viewed_items_box .item_card a img,
.pickup_box .item_card a img { width: 100%; height: 100%; object-fit: cover; transition: all .3s linear;}
.viewed_items_box .item_card h2,
.pickup_box .item_card h2 { font-size: 13px; font-weight: 700; letter-spacing: .120em; margin-bottom: 8px; }
.viewed_items_box .item_card h3,
.pickup_box .item_card h3 { font-size: 12px; font-weight: 500; letter-spacing: .120em; }
.viewed_items_box .item_card figcaption,
.pickup_box .item_card figcaption { padding: 12px 0 32px;}
.viewed_items_box .item_card a:hover,
.pickup_box .item_card a:hover{border: none;}
.viewed_items_box .item_card a:hover img,
.pickup_box .item_card a:hover img{ width: 102%; height: 102%; opacity: 0.6;}


@media screen and (min-width: 320px) {
.item_contact > .box { flex-wrap: nowrap; }
.item_contact > .box > * { width: 42%; padding: 0; }
.item_contact > .box > *:first-child { width: 200%; }
.item_contact > .box > *:nth-child(odd) { padding-right: 4px; }
.item_contact > .box > *:nth-child(even) { padding-left: 4px; }
}
@media screen and (min-width: 540px) {
.item_detail { padding: 0 40px; }
.item_return_btn { width: auto; padding: 22px 56px; }
.item_return_btn .arrow { display: inline-block; }
}

@media screen and (min-width: 640px) {
.mv_img.no1 { background-image: url("/assets/img/product/mv01_01.jpg"); }
.mv_img .oth { display: block; }
.mv_img .mobile { display: none; }
.lineup_ttl_box > *:first-child { padding-right: 64px; }
.lineup_ttl_box.pt2 > *:first-child { padding-right: 0; }
.lineup_box.row2 .item_card a:first-child { aspect-ratio: 109 / 70; }
}

@media screen and (min-width: 720px) {
.lineup_ttl h3 { font-size: 42px; line-height: 42px; }
.lineup_lead_box.box.row { flex-direction: row-reverse; }
.lineup_lead01 { flex-basis: 35%; }
.lineup_lead02 { flex-basis: 65%; }
.lineup_lead h2 { width: 96%; }
.lineup_lead p { width: 96%; font-size: 15px; }
}

@media screen and (min-width: 760px) {
.mv_unit,
.mv_box,
.mv_img { height: 72vh; }
.mv_box { top: 176px; }

.lineup_box .item_card figcaption { padding: 16px 0; }
.choose_box .item_card figcaption { padding: 18px 0 24px; }
.item_card.mk2 h2 { font-size: 16px; }
.item_card.mk3 h2 { font-size: 16px; }
.item_card.mk3 h3 { font-size: 14px; }

.item_box { padding-top: 54px; flex-wrap: nowrap; }
.item_img { max-width: 560px; width: 56%; }
.item_img dd { padding: 32px 0; }
.item_img > .box { max-width: none; }
.item_detail { padding: 0; }
.item_txt { padding-bottom: 24px; font-size: 13px; }
.item_detail { max-width: 440px; width: 44%; margin: 32px 0 0 32px; }
.item_contact > .box > * { width: 50%; }
.item_contact > .box > *:first-child { width: 200%; flex-grow: 1; }
.item_price {  }
.item_buy_btn,
.item_shop_btn { padding: 18px 8px; font-size: 15px; }
.item_return_btn { width: auto; padding: 14px 80px; }
.item_shop_btn.mk2{ font-size: 14px; }

/* 2025/10/1修正③ ここから */
.item_thumb_slick .slick-track > * { flex-basis: calc(100% / 5); }
.item_thumb_slick .slick-track > *:nth-child(n + 6) { flex-basis: calc(100% / 10); }
/* 2025/10/1修正③　ここまで */
}

@media screen and (min-width: 960px) {
.viewed_items_box > *,
.pickup_box > * { flex-basis: calc(100% / 5 - 8px);}

.item_cart_parts { flex-wrap: nowrap; }
.item_cart_parts_01 { flex-basis: auto; }

.item_choice_1maiita { padding-bottom: 56px;}
.item_question_unit { padding: 24px 0;}

.item_outline { padding: 54px 80px; }
}

@media screen and (min-width: 1080px) {

.lineup_lead h2 { width: 90%; }
.lineup_lead p { width: 80%; }
.item_card h3 { font-size: 20px; }
.item_detail { margin-left: 64px; }
.item_txt { font-size: 15px; padding-bottom: 32px; }
.item_buy_btn,
.item_shop_btn { font-size: 16px; }
.item_shop_btn.mk2{ font-size: 14px; }
.item_unit .btn_box { padding: 40px 0; }
}

@media screen and (min-width: 1120px) {
.item_spec table.item_shop_tbl th,
.item_spec table.item_shop_tbl td { display: table-cell; }
.item_spec table.item_shop_tbl tr { border-top-color: #fff; }
.item_spec table.item_shop_tbl tr th { padding: 8px 8px 8px 1em;  }
.item_spec table.item_shop_tbl tr td { padding: 8px 0; text-align: center; }
}
/* =======================================================================================



CART



======================================================================================= */
.lower_page main .cart_header .inner { margin-bottom: 24px; }
.cart_header_flow { margin: 0 -6px; }
.cart_header_flow div { display: flex; flex-direction: column; justify-content: center; height: 44px; border: 1px solid #eeece8; line-height: 1.3; letter-spacing: .115em;  text-align: center; font-size: clamp(0.75rem, 0.675rem + 0.38vw, 0.938rem); }
.cart_header_flow div.current { background-color: #f5f5f5; }

.cart_header_flow li {
    position: relative;
    padding: 0 6px;
    flex-basis: calc(100% / 4);
}
.cart_header_flow li:nth-child(n+2):before {
    position: absolute;
    top: 19px;
    left: -5px;
    display: block;
    width: 5.5px;
    height: 5.5px;
    margin: auto;
    border: 1px solid currentColor;
    border-bottom: 0;
    border-left: 0;
    color: rgba(255, 255, 255, .4);
    line-height: 1;
    vertical-align: middle;
    transform: rotate(45deg);
    content: '';
}

.cart_body {}

.cart_list { }
.cart_list p.tac{text-align: center;}
.cart_list > li { padding-bottom: 16px; }
.cart_box { display: flex; flex-direction: column; align-items: center; flex-wrap: wrap; padding: 20px 16px 16px; border: 1px solid #eeece8; }
.cart_box1 { width: 100%; }
.cart_box1 span { display: block; max-width: 48%; text-align: center; }
.cart_box1 span img { width: 100%; height: 100%; margin: auto; object-fit: contain; }
.cart_box1 span a:hover{border: none;}
.cart_box2 { padding-top: 8px; }
.cart_box2 dt,
.cart_delivery {  }
.cart_box2 dt strong a{ font-size: clamp(0.875rem, 0.825rem + 0.25vw, 1rem); font-weight: 600; }
.cart_box2 dt strong a:hover{ }
.cart_box2 dd { font-size: clamp(0.875rem, 0.825rem + 0.25vw, 1rem); }
.cart_box2 dt .cart_price,
.cart_delivery .cart_price { font-size: clamp(0.875rem, 0.825rem + 0.25vw, 1rem); font-weight: 500; margin-left: auto; }
.cart_price:empty { display: none; }
.cart_detail {line-height: 1.4;}
.cart_detail_table th,
.cart_detail_table td { vertical-align: top; }
.cart_detail_table th { text-align: left; font-weight: 500; padding-right: 2em; white-space: nowrap; }
.cart_quantity { padding: 16px 0 8px; }
.cart_quantity_box01 .error{color: #E86868; padding-top: 8px;}
.cart_quantity_box02 { padding-left: 8px; }
.cart_del_btn { width: 100%; height: 34px; padding: 8px; border: 1px solid #eeece8; background-color: rgba(255,255,255,.1); font-size: 12px; color: #545454;}
.cart_del_btn:hover { background-color: #f5f5f5; }

.cart_detail_table tr td span.size_w:not(:empty)::before{content: "幅"; padding-right: 0.4em;}
.cart_detail_table tr td span.size_d:not(:empty)::before{content: "/ 奥行"; padding-right: 0.4em;}
.cart_detail_table tr td span.size_h:not(:empty)::before{content: "/ 高さ"; padding-right: 0.4em;}
.cart_detail_table tr td span.size_sh:not(:empty)::before{content: "/ 座高"; padding-right: 0.4em;}
.cart_detail_table tr td span.size_t:not(:empty)::before{content: "/ 厚さ"; padding-right: 0.4em;}
.cart_detail_table tr td span:not(:empty)::after{content: "mm";}


.cart_delivery {}

.cart_calc { padding: 16px 0; margin-bottom: 40px; border-bottom: 1px solid #eeece8; }
.cart_calc_table { margin: 0 0 0 auto;}
.cart_calc_table th,
.cart_calc_table td { padding: 0 0 0 1em; }
.cart_calc_table th { text-align: left; padding-right: 3em; }

.cart_btn_box.box.col { text-align: center; }
.cart_btn_box.box.col span { display: inline-block; width: 272px; max-width: 100%; padding-bottom: 16px; }
.cart_btn_box.box.col form + form,
.cart_btn_box.box.col div + form,
.cart_btn_box.box.col div + div { margin-top: 32px; }

.cart_btn { width: 100%; height: 54px; padding: 16px 8px; border: none; background-color: #333; font-size: 14px; color: #fff!important; }
.cart_btn:hover { background-color: #000; }

/* WebKit ブラウザで、input type="number" のスピンボタンを非表示にする。 */
.cart_quantity input[type="number"]::-webkit-outer-spin-button,
.cart_quantity input[type="number"]::-webkit-inner-spin-button {
  -webkit-appearance: none;
  appearance: none;
  margin: 0;
}

/* Firefox で、input type="number" のスピンボタンを非表示にする。また、入力欄の値表示を中央寄せにし、高さをボタンのサイズに合わせる。 */
.cart_quantity input[type="number"] {
  -moz-appearance: textfield;
  text-align: center;
  width: 2.5em;
  height: 32px;
  margin: 0 4px;
  border: 1px solid #eaeaea;
  padding: 0;
}

/*ボタンのサイズを 44 × 44 CSS ピクセルにする。*/
.cart_quantity button.btn-number {
  width: 32px;
  height: 32px;
  border: none;
}

/* ステッパーコンポーネントの横幅を指定する。 */
.cart_quantity div.input-group {
  border: 1px solid rgba(255, 255, 255, .8);
}

.cart_ttl { position: relative; margin-bottom: 1.5em; padding-bottom: .8em; border-bottom: 1px solid #eeece8; font-size: 19px; letter-spacing: .165em; line-height: 1.9; text-align: center; }
.cart_ttl::after { position: absolute; right: 0; bottom: -1px; left: 0; width: 32px; height: 1px; margin: 0 auto; background-color: rgba(255,255,255,.0); content: ''; }

.cart_sub_ttl{border-bottom: 1px solid rgba(255, 255, 255, .2); text-align: center; padding-bottom: 0.5em; margin: 2.0em 0 1.0em;}
.cxl_ul{margin: 1.0em 0 0 0;}
.cxl_ul li{font-size: 14px; list-style: disc; margin: 0 0 0 1.5em;}


.cart_user_table { width: 100%; margin: 56px auto; font-size: 15px; word-break: break-word; }
.cart_user_table th { width: 3%; white-space: nowrap; text-align: left; }
.cart_user_table th,
.cart_user_table td { padding: 4px; border-bottom: 1px solid #eeece8; vertical-align: top; }

.cart_add_list { flex-wrap: wrap; margin: 0 -8px 72px; }
.cart_add_list > * { flex: 1; flex-basis: 100%; padding: 8px; }
.cart_add_list label { flex-basis: 25%; align-items: center; display: block; height: 100%; border: 1px solid rgba(255,255,255,.4); }
.cart_add_list .cart_add_box{position: relative;}
.cart_add_list .cart_add_box .cart_add_del_btn { height: 24px; padding: 3px 8px 4px; border: 1px solid #545454; background-color: rgba(255,255,255,.1); font-size: 11px; vertical-align: middle; line-height: 1; color:#545454; position: absolute; top: 10px; right: 10px;}
.cart_add_list .cart_add_box .cart_add_del_btn:hover{ background-color: rgba(255,255,255,.3);}
.favorite_del_btn:hover { background-color: rgba(255,255,255,.3); }
.cart_add_box { align-content: center; }
.cart_add_box input[type="radio"] { width: 16px; height: 16px;  border: 1px solid #545454; vertical-align: text-bottom; }
.cart_add_box01 { padding: 8px; }
.cart_add_box02 { padding: 16px 16px 8px 8px; }

.cart_add_name { padding-bottom: 8px; }
.cart_add_tel { font-size: 13px; }
.cart_add_box02 address { font-size: 13px; }

.cart_add_table { width: 100%; margin-bottom: 88px; }
.cart_add_table th,
.cart_add_table td { display: block; vertical-align: top; }
.cart_add_table th { position: relative; white-space: nowrap; padding: 16px 8px 0; font-weight: 500; font-size: 15px; text-align: left; }
.cart_add_table th span { margin-left: 1em; padding: .5em 1em; background-color: #545454; color: #fff; font-weight: 500; font-size: 10px; line-height: 1; }
.cart_add_table th:empty { padding: 0; height: 0; }

.cart_add_table td { padding: 0 0 8px; }

.cart_add_table input,
.cart_add_table textarea {
width: 100%;
border: solid 1px #eeece8;;
font-size: 13px;
padding: 12px 8px
}
.cart_add_table select {
width: 100%;

    font-family: "Zen Kaku Gothic New", serif;
    font-weight: 400;
    font-style: normal;
    font-size: 14px;
    position: relative;
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    padding: 10px 16px 10px 8px;
    border: 1px solid #eeece8;;
}

.cart_add_table:placeholder {}
.cart_add_input01 { flex-wrap: wrap; }
[class*="cart_add_input"] > *,
[class*="cart_add_select"] > * { flex-grow: 1; padding: 8px; }
.cart_add_table td .atn { margin: -8px 0 0 8px; }

.cart_option_block { padding: 40px 0 80px; }
.cart_option_box { flex-wrap: wrap; }
.cart_option_box dt { width: 240px; padding-bottom: 16px; }
.cart_option_box dd input[type="radio"] { width: 16px; height: 16px; border: 1px solid #545454; vertical-align: middle; margin-top: -4px; }
.cart_option_box dd p { padding: 1em 8px; }
.cart_option_box label { font-weight: 500; display: block; }
.cart_option_box label input[type="radio"] { margin-right: .5em; }
.cart_option_box label + label { padding: 1em 16px 1em 0; }

.cart_pay_block { margin-bottom: 32px; }
.cart_pay_select { margin: 40px -16px 24px; flex-wrap: wrap; }
.cart_pay_select > * { margin: 0 16px 24px; }
.cart_pay_select label:not(:last-of-type) {margin-right: 16px;}
.cart_pay_select input[type="radio"] {appearance: none; position: relative; width: 16px; height: 16px; border: 1px solid #545454; border-radius: 9999px; cursor: pointer; top: 2px;}
.cart_pay_select input[type="radio"]:checked::after { content: ""; position: absolute; inset: 0; width: 10px; height: 10px; margin: auto; border: 1px solid #545454; border-radius: 9999px; background-color: #555;}
.cart_pay_txt { margin-bottom: 32px; padding: 16px; border: 1px solid #eeece8; }
.cart_pay_txt h3 { font-size: 15px; }
.cart_pay_txt p { padding: 24px 0; font-size: 13px; line-height: 1.8; }
.cart_pay_txt aside { margin-bottom: 16px; padding: 0 16px; background-color: rgba(255,255,255,.2); }
.cart_pay_txt aside:has(> dl) { padding: 12px 16px 16px; }
.cart_pay_txt.mk2 dl dt{margin-right: 2.0em;}
.cart_pay_chk div { text-align: center; }
.cart_pay_chk input[type="checkbox"] { vertical-align: middle; width: 19px; height: 19px;}
.cart_pay_chk label { display: flex; align-items: center;column-gap: 6px; width: fit-content; line-height: 1; cursor: pointer; text-align: center; margin: 0 auto;}
.cart_pay_chk label:not(:last-of-type) { margin-bottom: 16px;}
.cart_pay_chk label input { appearance: none; position: relative; width: 20px; height: 20px; border: 1px solid #eeece8; cursor: pointer;}
.cart_pay_chk label input:checked {  }
.cart_pay_chk label input:checked::after { content: ""; position: absolute; top: 3px; left: 3px; width: 12px; height: 6px; border-bottom: 2px solid #6b6b6b; border-left: 2px solid #6b6b6b; transform: rotate(-45deg);}

.cart_btn.mk3,
.cart_btn.mk6 { /*background-color: #fff; color: #7892ad;*/ font-weight: 500; }
.cart_btn.mk3:hover,
.cart_btn.mk6:hover { /*color: #FFF; background-color: rgba(255, 255, 255, .3);*/ }

.cart_pay_credit_group { flex-wrap: wrap; }
.cart_pay_credit_box { flex-grow: 1; flex-basis: 100%; overflow: hidden; }

.cart_pay_credit_table { width: 100%; margin: 24px 0 40px; }
.cart_pay_credit_table th,
.cart_pay_credit_table td { padding: 4px 16px 4px 8px; }
.cart_pay_credit_table th { text-align: left; background-color: rgba(255,255,255,.2); font-size: 14px; font-weight: normal;}
.cart_pay_credit_table td { font-size: 15px; color: #545454; }
.cart_pay_credit_table td:last-child { padding-right: 0; padding-left: 0; text-align: right; }
.cart_pay_credit_table input[type="radio"] { width: 16px; height: 16px; margin-right: 1.2em; border: 1px solid #eeece8; vertical-align: text-bottom; }

.cart_pay_credit_del_btn { height: 24px; margin-right: 4px; padding: 2px 14px 0; border: 1px solid #eeece8; font-size: 12px; vertical-align: text-top; }
.cart_pay_credit_del_btn:hover { background-color: #545454; color: #fff; }

.cart_pay_credit_plus { text-align: right; }

.cart_pay_credit_group{margin: 16px 0;}
.cart_btn.mk5 { display: inline-block; width: auto; height: 48px; padding: 8px 16px 4px; font-size: 14px; }

.cart_pay_credit_ttl{text-align: center;}
.payMsg{margin-bottom: 1.0em;}
.cart_btn.mk8{max-width: 272px!important; margin: 0 auto;}
.frmTb.mk8{margin: 48px 0;}
.frmTb.mk8 tr th,.frmTb.mk8 tr td{padding: 4px;}
.frmTb.mk8 tr{max-width: none; border-bottom: 1px solid #eeece8; padding: 12px 0; margin: 0;}
.frmTb.mk8 td .input{width: 100%; border: solid 1px #eeece8; font-size: 13px; padding: 12px 8px; }

#cardEntryBox{width: 100%; max-width:520px; text-align: center; margin: 0 auto;}
#cardEntryBox .cart_btn.mk8{max-width: 272px!important; font-size: 13px; margin: 8px auto ;}
#checkCardBtn { cursor: pointer; text-align: center; font-size: 13px; border: solid 1px #eeece8;; text-decoration: none; width: 100%; max-width: 272px; display: block; transition: .6s;  padding: 8px 0; margin: 8px auto 64px;}
#checkCardBtn:hover{background: #000;}
.msgResult{text-align: center;}

#cardWin #contents{height: 100vh; padding: 20px;}
#cardWin h1{text-align: center; font-size: 15px;}
#cardWin h2{text-align: center; font-size: 12px; margin-bottom: 1.0em;}

#cardWin dl{margin-bottom: 25px;text-align: center;}
#cardWin dl dt{font-weight: 400; line-height: 1.8;font-size: 14px; margin-bottom: 10px;}
#cardWin dl dd{line-height: 1.8;font-size: 14px; margin-bottom: 10px;}
#cardWin dl dd.card,
#cardWin dl dd.limit{margin-bottom: 15px;}
#cardWin dl dd.limit{font-size: 13px; font-weight: bold;}
#cardWin dl dd.limit select{font-size: 14px; padding: 4px;}
#cardWin dl dd.card span{border: 1px solid rgb(255,255,255, .4); font-family: "Poppins", "Zen Kaku Gothic New", serif; display: inline-block; padding: 4px 8px; margin-right: 8px; font-size: 11px; font-weight: 400;}
#cardWin input.closeBtn{cursor: pointer; border: solid 1px rgb(255,255,255, .4); font-weight: 400; padding: 5px 15px; font-size: 12px; text-align: center; display: block; margin: 20px auto;}
#cardWin input.closeBtn:hover{ }
#cardWin .caution{font-size: 13px;line-height: 1.6;}
#cardWin .caution p{text-align: center;}

.cart_thankyou_block { padding: 32px 16px; }
.cart_thankyou_block h2 { margin-bottom: 1em; font-size: 18px; }
.cart_thankyou_block p { font-size: 15px; }
.cart_thankyou_block p br { display: none; }
.errDl{border: 1px solid rgba(255,255,255,.4); width: 100%; max-width: 400px; padding: 16px 8px; margin: 40px auto;}
.errDl dt{text-align: center; margin-bottom: 8px;}
.errList01{ font-size: 13px; max-width: 350px; margin: 0 auto;}
.errList01 li{line-height: 1.4;}
.errList01 li:first-child{ margin-bottom: 8px;}


@media screen and (max-width: 800px) {
.x_scroll { margin-bottom: 1rem; overflow-x: auto; white-space: nowrap; animation-fill-mode: both; }
.x_scroll::-webkit-scrollbar { height: 24px;/* tableにスクロールバーを追加 */ }
.x_scroll:-webkit-scrollbar-track { background: #f1f1f1;/* tableにスクロールバーを追加 */ }
.x_scroll:-webkit-scrollbar-thumb { background-color: #bcbcbc;/* tableにスクロールバーを追加 */ }
}

@media screen and (min-width: 340px) {
.cart_box1 span { display: block; max-width: 100%; }
.cart_box2 dt { padding-bottom: 1em; }
.cart_detail_table th,
.cart_detail_table td { display: block; }
.cart_detail_table td { padding-bottom: 1em; }
}

@media screen and (min-width: 400px) {
.cart_box { flex-direction: row; }
.cart_box1 { flex-basis: 36%; }
.cart_box2 { flex-basis: 64%; padding: 0 0 0 16px; }
}

@media screen and (min-width: 560px) {
.cart_header_flow div { height: 52px; }
.cart_header_flow li:nth-child(n+2):before { top: 23px; }
.cart_header_flow { margin: 0 -15px; }
.cart_header_flow li { padding: 0 15px; }

.cart_box2 dt { padding-bottom: 0.5em; }
.cart_detail_table th,
.cart_detail_table td { display: table-cell; }
.cart_detail_table td { padding-bottom: 0; }

.cart_calc { padding: 40px 0 16px; margin-bottom: 80px; }
.frmTb.mk8 tr th,.cart_user_table td{ padding: 12px 12px 12px 44px; }
.cart_add_list > * { flex-basis: 50%; }
.cart_add_input01 { flex-wrap: nowrap; }
[class*="cart_add_input"],
[class*="cart_add_select"] { max-width: 552px; }
.cart_add_input02,
.cart_add_select { max-width: 280px }
.cart_thankyou_block p br { display: inline; }
	
.cart_user_table th,
.cart_user_table td { padding: 12px 12px 12px 44px; }
}

@media screen and (min-width: 640px) {
.cart_box { padding-top: 16px; }
.cart_box1 { max-width: 240px;}
.cart_box2 { flex-grow: 1; padding-left: 24px; }
}

@media screen and (min-width: 760px) {
.lower_page main .cart_header .inner { margin-bottom: 64px; }
.cart_box2 dt,
.cart_delivery { display: flex; flex-direction: row; }
.cart_option_box { flex-wrap: nowrap; }
.cart_option_box dd { width: calc(100% - 240px); }
.cart_option_box dd p { padding: 1em 16px; }
}
@media screen and (min-width: 840px) {
.cart_box { padding: 24px; }
.cart_box2 { padding: 0 0 0 24px; }
.cart_user_table th,
.cart_user_table td { padding-right: 44px; }
.cart_add_list > * { flex-basis: 25%; }
.cart_add_table th,
.cart_add_table td { display: table-cell; }
.cart_add_table th { width: 3%; padding-bottom: 8px; padding: 16px 144px 8px 16px; }
.cart_add_table th span { position: absolute; top: 24px; right: 0; }
.cart_add_table td { padding: 4px 16px; }
.cart_pay_txt { padding: 32px; }
.cart_pay_txt p { line-height: 2; }
.cart_pay_txt aside:has(> dl) { padding: 24px 32px; }
.cart_pay_txt aside { margin-bottom: 32px; padding: 0 24px; }
.cart_pay_block { margin-bottom: 80px; }
.frmTb.mk8 tr th,.cart_user_table td { padding-right: 44px; }
}

@media screen and (min-width: 1024px) {
.cart_pay_credit_group { flex-wrap: nowrap; }
.cart_pay_credit_table { margin: 0 0 40px auto; }
.cart_pay_credit_box { flex-basis: auto; }
.cart_pay_credit_ttl { white-space: nowrap; width: 240px; text-align: left; padding-right: 2em; }
.cart_pay_credit_table { width: 100%; }
.cart_pay_credit_table th,
.cart_pay_credit_table td { padding: 4px 64px 4px 8px; }
}
/* =======================================================================================



MY PAGE 購入履歴



======================================================================================= */
.order_history_unit { }
.oh_summary_panel { padding: 16px; border: 1px solid #eeece8; }
.oh_summary_panel + .oh_summary_panel { margin-top: 16px; }
.oh_1st_unit { }
.oh_1st_table { font-size: 13px; letter-spacing: .245em; }
.oh_1st_table th { text-align: left; font-weight: 500; white-space: nowrap; padding-right: 1em; }
.oh_1st_table.mk2 { margin: 16px 0 16px; text-align: right;}
.oh_1st_sum_item td { font-size: 16px; font-weight: 600;}

.oh_2nd_unit { border-top: 1px solid #eeece8; padding-top: 8px; }
.oh_2nd_ttl { text-align: right; padding-right: 1.5em; }
.oh_2nd_ttl::after {
    position: absolute;
    top: 8px;
    right: 8px;
    display: block;
    width: 6px;
    height: 6px;
    margin: auto;
    border: 1px solid currentColor;
    border-bottom: 0;
    border-left: 0;
    color: #4f4f4f;
    line-height: 1;
    vertical-align: middle;
    transform: rotate(135deg); 
    transition: all .2s linear;
    content: '';
}
.oh_2nd_ttl.flag::after { top: 14px; transform: rotate(-45deg);}
.oh_2nd_box { padding: 16px; background-color: rgba(255,255,255,.1); }
.oh_2nd_box + .oh_2nd_box { margin-top: 16px; }
.oh_2nd_box dt { font-size: 13px; font-weight: 600;}
.oh_2nd_detail_box.box.row { flex-wrap: wrap; }
.oh_2nd_detail_inner { flex-basis: 100%; font-size: 13px; color: #545454; }
.oh_2nd_detail_inner.mk2 { flex-grow: 1; }

.oh_2nd_ttl,jq_swicth:hover{cursor: pointer;}

.oh_2nd_detail_table { }
.oh_2nd_detail_table th { white-space: nowrap; padding-right: 1em; font-weight: 400; text-align: left; }
.oh_2nd_detail_table tr td span:not(:empty)::before{content: "×"; padding-right: 0.4em;}
.oh_2nd_detail_table tr td span:not(:empty)::after{content: "mm";}
.oh_2nd_detail_table tr td span:first-child::before{content: ""; padding: 0;}

@media screen and (min-width: 560px) {
.oh_summary_panel { padding: 24px; }
.oh_2nd_box { padding: 24px; }
.oh_2nd_detail_table th { padding-right: 2em; }
}

@media screen and (min-width: 880px) {
.oh_summary_panel { padding: 32px; }
.oh_1st_table th { padding-right: 2em; }
.oh_1st_table.mk2 { margin: 16px 0 16px auto; }
.oh_2nd_detail_table th { padding-right: 3em; }
.oh_2nd_detail_box.box.row { flex-wrap: nowrap; flex-direction: row-reverse; align-items: flex-end; }
.oh_2nd_detail_inner { flex-basis: auto; }
}

/* =======================================================================================



MY PAGE お気に入り



======================================================================================= */
.favorite_card_box { flex-wrap: wrap; margin: 0 -4px; }
.favorite_card { font-size: 12px; padding: 8px 4px 16px; flex-basis: calc(100% / 3); }
.favorite_box { padding-top: 8px; }
.favorite_img { overflow: hidden; max-width: 268px; aspect-ratio: 1 / 1; }
.favorite_img img { width: 100%; height: 100%; margin: auto; object-fit: contain; }
.favorite_box dt,
.favorite_box dd { padding: 4px 0; line-height: 1.2; }
.favorite_box dt a{font-weight: 600;}
.favorite_del_btn { height: 24px; padding: 3px 8px 4px; border: 1px solid #eeece8; background: #FFF; font-size: 11px; vertical-align: middle; line-height: 1; color: #545454; }
.favorite_del_btn:hover { background-color: #f5f5f5; }
@media screen and (min-width: 640px) {
.favorite_card_box { margin: 0 -8px; }
.favorite_card { font-size: 13px; padding: 8px 8px 16px; flex-basis: calc(100% / 4); }
}
/* =======================================================================================



サイドバナー



======================================================================================= */
.aside_contact_box { display: none; }
.side_banner{width: 100%; list-style: none; background: #dce3e8; padding: 0; position: fixed; display: flex; right: 0; bottom: 0; z-index: 999;}
.side_banner li{width: 50%; margin: 0 1%; text-align: center;}
.side_banner li a{display: block; font-size: 13px; padding: 12px; border: solid 1px rgba(255,255,255,.9); position: relative; margin: 12px 3px; transition: all .2s linear;}
.side_banner li a:hover { text-decoration: none; background-color: aliceblue; }

@media screen and (min-width: 480px) {
	.side_banner{list-style: none; padding: 0; position: fixed; right: 0; top: 50vh; width: inherit; height: 214px; display: block;}
	.side_banner li{width: 100%; margin: 0;}
	.side_banner li a{display: block; writing-mode: vertical-rl; font-size: 13px; padding: 16px; border: none; margin: 0;}
	
	.side_banner li:first-child a{padding-top: 20px; margin: 0; border: none;}
	.side_banner li:first-child a::after{content:""; border-bottom: solid 1px rgba(255,255,255, .4); position: absolute; right: 1px; bottom: 0; width: 50px;}

}


