@charset "UTF-8";
:root {
    /* --- Spacing (clamp) --- */
  /* 最小(スマホ想定) 〜 最大(PC想定) */
  
  /* --space-xs: clamp(0.25rem, 0.2rem + 0.2vw, 0.5rem);   4px〜8px (微調整用) */
  --space-sm: clamp(1rem, calc(0.667rem + 0.833vw), 1.333rem); /* min: 15px, max: 20px */
  --space-ms:clamp(1rem, calc(0.333rem + 1.667vw), 1.667rem); /* min: 15px, max: 25px */
  --space-md: clamp(1rem, calc(0rem + 2.5vw), 2rem); /* min: 15px, max: 30px */ 
  /* --space-lg: clamp(2rem, 1.5rem + 2vw, 4rem);         32px〜64px (セクション間の余白) */
  /* --space-xl: clamp(4rem, 3rem + 4vw, 8rem);           64px〜128px (大きなセクション間) */
}
/* common---------------- */
*:hover { box-sizing: border-box; }
html, body { overflow-x: clip; color: var(--text-main); font-family: var(--font-jp); letter-spacing: 0.05em; font-weight: 400; }
a { color: inherit; transition: all .3s; }
a:hover { text-decoration: none; opacity: 0.75; }
.p-product-block ul.__product li.__item a:hover > .__title { text-decoration: none; opacity: 0.8; }
::placeholder { color: var(--text-muted); font-weight: 500; font-family: var(--font-jp); }
img { vertical-align: top; }
h1,h2,h3 { font-weight: 400; }
.wrapper { overflow: hidden; }
.c-button:active, .c-button-submit:active { box-shadow:none; }
ul li::marker { color: var(--accent-blue); }
.__en { font-family: var(--font-en); }
.red { color: var(--status-danger); }
.blue { color: var(--primary-color); }
.bg-skygray { background-color: var(--accent-blue); }
.small { font-size: 0.8666em; }
.big { font-size: 1.3rem; }
.__pc-none { display: none!important; }
.__sp-none { display: block; }

/* button -----------------*/
.button-arrow a { max-width: 230px; display: block; margin: auto; font-size: 1.06rem; background-color: var(--primary-color); color: var(--white); line-height: 50px; text-align: center; }
.button-arrow a span { position: relative; }
.button-arrow a span::after { content: '\e5cc'; display: inline-block; font-family: var(--font-icon); font-size: 1.333em; line-height: 1; vertical-align: text-bottom; width: 1rem; }

/* __block--recommend ----------------*/
.p-product-block ul.__product { padding: 0; }
.p-product-block ul.__product li.__item a { letter-spacing: 0.05em; }
/* __photo */
.p-product-block ul.__product li.__item a .__photo { margin-bottom: 1rem; aspect-ratio: 1 / 1; border: 1px solid var(--border-color); }
.p-product-block ul.__product li.__item a .__photo img { object-fit: contain; aspect-ratio: 1; max-height: unset; width: 100%; }
.p-product-block .c-more { display: none; }
/* __title */
.p-product-block ul.__product li.__item a .__title { margin-bottom: 0; font-size: 1rem; }
/* __description */
.p-product-block ul.__product li.__item a .__description dl.__price,
.main.main--product-list section.__list.__list--row ul.__product > li.__item a table tr td.__detail .__description dl.__price { text-align: left; font-size: 1rem; }
.p-product-block ul.__product li.__item a .__description dl.__price dd,
.main.main--product-list section.__list.__list--row ul.__product > li.__item a table tr td.__detail .__description dl.__price dd { margin-left: 0; color: var(--status-danger); font-weight: 600; }

/* __block--search --------------------------- */
.__block--search .__body { display: flex; justify-content: space-between; padding: 0 0.4em 0 1em; box-shadow: none;border: 1px solid var(--primary-color); background-color: var(--white); }
.c-form label:active { box-shadow: none; }
.__block--search .c-form input[type="text"] { width: 100%; padding: 0; box-shadow: none; border: none; line-height: 51px; letter-spacing: 0.05em; }
.__block--search .c-form .c-button { padding: 0; background: unset; line-height: 1; }
.__block--search .material-symbols-outlined { color: var(--primary-color); font-family: var(--font-icon); font-weight: 500; }
.__block--search .__body ::placeholder { font-weight: 400; }

/* __menu --------------------------------*/
.__menu .__custom .__item a { position: relative; display: block; padding-top: 2em; font-size: 0.9333em; }
.__menu .__custom .__item a::before { position: absolute; left: 50%; transform: translateX(-50%); top: 0; }
/* login button */
.__menu .__custom .__item.__item--login a::before { content: ''; background: url(../img/common/icon-login.svg) no-repeat; width: 2.214rem; height: 2.214rem; }
/* mypage button */
.__menu .__custom .__item.__item--mypage a::before { content: ''; background: url(../img/common/icon-mypage.svg) no-repeat; width: 2.214rem; height: 2.214rem;}
/* cart button */
.__menu .__custom .__item.__item--cart a::before { content: ''; background: url(../img/common/icon-cart.svg) no-repeat; width: 2rem;  height: 2rem; }
/* history button */
.__menu .__custom .__item.__item--history a::before { content: ''; background: url(../img/common/icon-notes.svg) no-repeat; width: 2rem; height: 2rem; }
/* regist button */
.header .__menu .__item--regist a,
.aside .__menu .__item--regist a { display: block; font-size: 1.0666em !important;  background-color: var(--primary-color);  color: var(--white); padding-top: 0 !important; line-height: 60px;  text-align: center; border-left: none !important; }
.header .__menu .__item--regist a span,
.aside .__menu .__item--regist a span { padding-left: 1.85rem; position: relative; }
.header .__menu .__item--regist a span::before,
.aside .__menu .__item--regist a span::before { content: ''; background: url(../img/common/icon-regist.svg) no-repeat; width: 16px; height: 25px; top: 50%; transform: translateY(-50%); left: 0; position: absolute; }

/* header -------------------------------------------*/
.header { display: flex; justify-content: space-between; flex-wrap: wrap; align-items: center; flex-wrap: wrap; z-index: 9; position: sticky; top: 0; height: 60px; border-bottom: 1px solid var(--border-color); }
.header { align-items: center; display: flex; max-width: 1280px; margin: auto; }
/* logo */
.header .__banner .__wrap a.__logo { display: block; width: 16vw; min-width: 160px; max-width: 233px; }
/* search */
.gnav-pc .__menu .__custom .__block--search { width: 33vw; max-width: 445px; }
.gnav-pc .__menu .__custom .__block--search .__body input { line-height: 60px; }
/* gnav-pc */
.gnav-pc { border-bottom: none; background-color: unset; flex: 1; }
.gnav-pc .__menu .__custom { display: flex; align-items: center; justify-content: space-between; gap: 0.5vw; text-align: center; }
.__is-member .gnav-pc .__menu .__custom { justify-content: space-around; }
/* pc regist button */
.header .gnav-pc .__menu .__custom .__item.__item--regist { width: 20vw; max-width: 240px; }
.aside .gnav-pc .__menu .__custom .__item.__item--regist { width: 100%; max-width: 260px; }

/* footer -------------------------------------------*/
.c-pagetop span::before { background-color: var(--primary-color); border: 1px solid var(--white); }
.footer { margin-top: 5rem; background: var(--white); overflow: hidden; border-top: 2px solid var(--primary-color); }
.footer .footer--guide { background: var(--white); padding: 4em 0 3em; border-bottom: 1px solid var(--border-color); }
.footer .footer--guide .__inner { max-width: 1280px; margin: auto; }
.footer .footer--guide .__inner .footer--guide-title { margin-top: 0; margin-bottom: 1.34em; font-size: 1.2em; color: var(--primary-color); font-weight: 700; }
.footer .footer--guide .__inner .footer--guide-sub { font-size: 1.06em; font-weight: 500; margin-bottom: 0.6667em; }
.footer .footer--guide .__inner .footer--guide-txt { margin-top: 0.6667em; color: var(--text-sub); }
/* nav */
.footer nav.__nav ul { padding: 1.7em 0 0; }
.footer nav.__nav ul li a { border-right: none; }
.footer .__copyright { padding-top: 0.666rem; }

/* aside------------------ */
.aside .__menu .__custom li { margin-bottom: 1.33rem; }
/* heading */
.aside section.__block .__heading.__heading--default,
.aside section.__block .__heading.__heading--custom { padding: 0.8rem 1.111em; font-size: 1.2rem; color: var(--primary-color); background-color: var(--bg-light); font-weight: 600; }
/* category list toggle */
.aside section.__block.__block--category .__body ul.__tree > li.__item:last-child { border-bottom: 1px solid var(--border-color); }
.aside section.__block.__block--category .__body ul.__tree li.__item:not(.__item--has-children) > a:after { color: var(--text-main); font-family: var(--font-icon); content: '\e5cc'; font-size: 1.4666em; font-weight: 400; right: 0; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; display: inline-block; font-style: normal; font-variant: normal; line-height: 1; position: absolute; top: 50%; margin-top: -.5em; }
.aside section.__block.__block--category .__body ul.__tree > li.__item.__item--has-children > ul { display: none; }
.aside section.__block.__block--category .__body ul.__tree li.__item.__item--has-children:not(:has(a + .__js-toggle)) > a:after { content: none; }
.aside section.__block.__block--category .__body ul.__tree li.__item.__item--has-children a + .__js-toggle { display: block; height: 100%; }
.aside section.__block.__block--category .__body ul.__tree li.__item.__item--has-children a + .__js-toggle::before { content: '\e313'; position: absolute; font-family: var(--font-icon); font-size: 1.4666em; font-weight: 400; color: var(--text-main); right: 0px; top: 0.7rem; }
/* item */
.aside section.__block.__block--category .__body ul.__tree>li.__item a { padding: 0.89em 0; }
/* calendar */
.aside section.__block.__block--calendar { margin: 1rem 0 2.3333rem; }
.aside section.__block.__block--calendar ul li table.cal { font-family: var(--font-en); }
/* __youtube--list */
.aside .__youtube--list li { margin-top: 0.866rem; container-type: inline-size; }
.aside .__youtube--list li a { color: var(--white); display: block; aspect-ratio: 251 / 102; text-align: center; font-size: 6cqw; }
.aside .__youtube--list li.__youtube--bg-black a { background-color: #000; text-decoration: underline; text-underline-offset: 2px; padding-top: 12%; line-height: 2; }
.aside .__youtube--list li.__youtube--bg-line a { padding-top: 11%; line-height: 1.5; background: linear-gradient( to bottom, #000 0%, #000 25%, #7B0912 40%, #C80D0F 49%,#FFA596 50%, #C80D0F 51%, #7B0912 60%, #000 75%, #000 100% ); white-space: nowrap; }

/* title ------*/
.top-h { font-size: 1rem; text-align: center; }
.top-h .__en { display: block; font-size: clamp(1.563rem, calc(1.125rem + 1.167vw), 2.133rem); font-weight: 700; line-height: 1.28; color: var(--primary-color); }

@media screen and (max-width: 1279px) {
    .header { max-width: 1240px; padding-right: 3%; padding-left: 3%; }
    .wrapper .__inner { max-width: 1240px; width: 94%; margin-right: 3%; margin-left: 3%; }
    .footer .__inner { max-width: 1240px; width: 94%; margin-right: 3%; margin-left: 3%; }
}

@media screen and (max-width: 1023px) {
   .gnav-pc { display: none; }
   .gnav-sp { display: block !important; }
   .aside .__menu { display: none; }
   .gnav-sp .__drawer .__menu .__content .__heading { font-size: 1.15rem; background: var(--bg-light); color: var(--primary-color); font-weight: 600;}
   .gnav-sp .__menu .__custom { margin: 0 0 1em; padding: 0; display: grid; grid-template-columns: repeat(3, 1fr); }
   .gnav-sp .__menu .__custom .__item a { padding-top: 2.55em !important;  padding-bottom: 0 !important; text-align: center; }
   .gnav-sp .__menu .__custom .__item a::after { content: none !important; }
   .gnav-sp .__menu .__custom .__item.__item--login { border-bottom: none !important; }
   .gnav-sp .__menu .__custom .__item.__item--login a,
   .gnav-sp .__menu .__custom .__item.__item--mypage a { border: none; }
   .gnav-sp .__menu .__custom .__item.__item--cart { border-bottom: none !important; }
   .header .gnav-sp .__menu .__item--regist,
   .aside .gnav-sp .__menu .__item--regist { width: 96%; margin: 1em auto; }
   .header .gnav-sp .__menu .__item--regist a,
   .aside .gnav-sp .__menu .__item--regist a { font-size: 1.2em !important; }
   .header .__banner .__wrap { display: flex; justify-content: space-between; align-items: center; }
   .header .__banner .__wrap .__view-cart { display: block; position: relative; }
   .header .__banner .__wrap .__view-cart a span.__view-cart-text { display: none; }
   .header .__banner .__wrap .__view-cart a:before { font-size: 2.5em; font-family: var(--font-icon); font-weight: 400; font-style: normal; display: inline-block; line-height: 1; text-transform: none; letter-spacing: normal; word-wrap: normal; white-space: nowrap; direction: ltr; -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility; -moz-osx-font-smoothing: grayscale; font-feature-settings: 'liga'; font-variation-settings: 'FILL' 1; content: ""; color: var(--primary-color); }
   .header .__banner .__wrap .__view-cart a span.__counter { position: absolute; top: 0; right: 0; padding: 0 .4em; font-size: .85em; background-color: var(--text-main); color: var(--white); border: 1px solid; border-radius: 2em; font-family: var(--font-en); }
   /* __toggle--- */
   .header .__banner .__wrap .__toggle-open { display: table-cell; width: 3.5em; }
   .header .__banner .__wrap .__toggle-open label { display: block; text-align: center; width: 3.5em; height: 3.5em;  padding: .2em 0; }
   /* open */
   .header .__banner .__wrap .__toggle-open label span:before { content: '\e5d2'; font-family: var(--font-icon); font-weight: 300; font-size: 3rem; color: var(--text-main); line-height: 1; }
   /* close */
   .gnav-sp .__drawer .__menu .__toggle-close { border: none; }
   .gnav-sp .__drawer .__menu .__toggle-close label span:before { content: '\e5cd'; font-family: var(--font-icon); font-weight: 300; font-size: 3em; color: var(--text-main); }
   .gnav-sp .__drawer .__menu .__toggle-close label { text-align: left; }
   /* search */
   .gnav-sp .__block--search .__body { margin-top: 0; width: 96%; margin-left: 2%; margin-right: 2%; }
   .gnav-sp .__drawer .__menu .__content.__content--default .__page ul li.__block.__block--search { padding: 1em 0; background: var(--bg-light); border-bottom: unset;  }
   .gnav-sp .__drawer .__menu .__content .__search--keyword { display: none; }
   .gnav-sp .__drawer .__menu .__content .__search.__search--category .__body ul.__tree li.__item.__item--has-children ul { border-top: 1px solid var(--border-color); }
   .gnav-sp .__drawer .__menu .__content .__search.__search--category .__body ul.__tree > li.__item.__item--has-children:not(:has(a + .__js-toggle)) > a:after, 
   .gnav-sp .__drawer .__menu .__content .__member.__is-member .__body ul.__sub-menu > li.__item.__item--has-children:not(:has(a + .__js-toggle)) > a:after { content: none; }
   .gnav-sp .__drawer .__menu .__content .__search.__search--category .__body ul.__tree li.__item.__item--has-children a + .__js-toggle { right: 0.5em; }
   .gnav-sp .__drawer .__menu .__content .__search.__search--category .__body ul.__tree li.__item.__item--has-children a + .__js-toggle::before,
   .gnav-sp .__drawer .__menu .__content .__member.__is-member .__body ul.__sub-menu li.__item.__item--has-children a + .__js-toggle::before  { color: var(--text-main); font-family: var(--font-icon); content: '\e313'; font-size: 1.4666em; }
   .gnav-sp .__drawer .__menu .__content .__member.__is-member .__body ul.__sub-menu li.__item.__item--has-children ul { border-top: 1px solid var(--border-color); }
   .gnav-sp .__drawer .__menu .__content .__member.__is-member .__body ul.__sub-menu li.__item.__item--has-children ul > li:not(:last-of-type) > a { border-bottom: 1px solid var(--border-color); }
   .gnav-sp .__drawer .__menu .__content .__member.__is-guest ul li a:after, 
   .gnav-sp .__drawer .__menu .__content .__search.__search--feature ul li a:after, 
   .gnav-sp .__drawer .__menu .__content.__content--default .__page ul li a:after, 
   .gnav-sp .__drawer .__menu .__content.__content--custom .__page ul li a:after,
   .gnav-sp .__drawer .__menu .__content .__search.__search--category .__body ul.__tree li.__item:not(.__item--has-children) > a:after { color: var(--text-main); font-family: var(--font-icon); content: '\e5cc'; font-size: 1.46666rem; font-weight: 400; right: 1rem; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; display: inline-block; font-style: normal; font-variant: normal; line-height: 1; position: absolute; top: 50%; margin-top: -.5em; }

    .gnav-sp .__drawer .__menu .__content .__member.__is-guest ul li, 
    .gnav-sp .__drawer .__menu .__content .__search.__search--feature ul li, 
    .gnav-sp .__drawer .__menu .__content.__content--default .__page ul li, 
    .gnav-sp .__drawer .__menu .__content.__content--custom .__page ul li { border-color: var(--border-color); }
    .gnav-sp .__drawer .__menu .__content .__member.__is-guest ul li a, 
    .gnav-sp .__drawer .__menu .__content .__search.__search--feature ul li a, 
    .gnav-sp .__drawer .__menu .__content.__content--default .__page ul li a, 
    .gnav-sp .__drawer .__menu .__content.__content--custom .__page ul li a { color: var(--text-main); }
    .gnav-sp .__drawer .__menu .__content .__search.__search--category .__body ul.__tree li.__item a, 
    .gnav-sp .__drawer .__menu .__content .__member.__is-member .__body ul.__sub-menu li.__item a { color: var(--text-main); border: none; }
    .gnav-sp .__drawer .__menu .__content .__search.__search--category .__body ul.__tree > li.__item > ul > li + li { border-top: 1px solid var(--border-color); }
}

@media screen and (max-width: 1023px) and (min-width: 600px) {
    .header .__banner .__wrap .__view-cart { padding-top: 0.6rem; }
    .aside section.__block.__block--calendar ul li { margin: auto; float: none; }
}

@media screen and (max-width: 959px) {
    body { font-size: 14px; }
    .aside .__youtube--list { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0 0.866rem; }
    
}


@media screen and (max-width: 599px) {
    .__pc-none { display: block!important; }
    .__sp-none { display: none; }

    .header .__banner .__wrap a.__logo { height: unset; }
    
    .footer .footer--guide { padding: 0; }
    .footer .footer--guide li { padding: 3.5em 0 2.5em; }
    .footer .footer--guide li + li { border-top: 1px solid #ddd; }

    .aside .__youtube--list { grid-template-columns: repeat(2, 1fr); }
}

@media screen and (min-width: 600px) {
    .button-arrow a { max-width: 260px; line-height: 60px; }
    .top-h { margin-bottom: 2rem; }
}

@media screen and (min-width: 768px) {
    .footer .footer--guide .__inner { display: flex; justify-content: space-between; }
    .footer .footer--guide .__inner li { width: calc((100% - 6.25%) /3); }
    .footer nav.__nav ul { text-align: center; }

}

@media (min-width: 960px) {
    .__block--pro-recommend .p-product-block ul.__product li.__item,
    .__block--recommend .p-product-block ul.__product li.__item { width: 18.73%; padding: 0; }
    .__block--pro-recommend .p-product-block ul.__product li.__item + li,
    .__block--recommend .p-product-block ul.__product li.__item + li { margin-left: 1.535%; }
    .footer nav.__nav ul li { padding: 0; }
}

@media (min-width: 1024px) {
    .header { height: 100px; }
    .header::before { position: absolute; content: ''; background: var(--white); width: 100%; left: -50%; height: 100%; z-index: -1; border-bottom: 1px solid var(--border-color); }
    .header::after { position: absolute; content: ''; background: var(--white); width: 100%; right: -50%; height: 100%; z-index: -1; border-bottom: 1px solid var(--border-color); }
    .header .__banner { width: auto; max-width: 233px;  margin-left: 0; }
    .header .__banner .__wrap a.__logo { margin-right: clamp(2rem, calc(0.667rem + 3.33vw), 3.333rem); /* min: 30px, max: 50px */ }
}

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

}