﻿@charset "UTF-8";

/* ヘッダ（スマートフォン） ファーストビュー用 */

/* usr/sb_layout.css のコピー ここから */

.pane-header {
  width: 100%;
  background: #fff;
  padding-top: 70px;
}

/* ここまで usr/sb_layout.css のコピー */

/* usr/sb_base_misc.css のコピー ここから */

.hidden-sb {
  display: none !important;
}

/* ここまで usr/sb_base_misc.css のコピー */

/* usr/sb_block.css のコピー ここから */

/* ----ヘッダー---- */
.block-header-fixed{
  width: 100%;
  height: 70px;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 11;
  padding: 14px 20px 8px;
  background: #FFF;
  transition: height .3s;
}
.--login .block-header-fixed{
  padding: 8px 20px 8px;
}
.pane-header.is-fixed .block-header-fixed{
  height: 64px;
}
.block-header-fixed .container{
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.pane-header.is-fixed .block-header-fixed .container{
  align-items: center;
}
.block-header-logo{
  flex-shrink: 0;
}
.block-header-logo img{
  width: clamp(6.875rem, -2.854rem + 41.51vw, 8.25rem);
  height: auto;
  transition: .3s;
}
.pane-header.is-fixed .block-header-logo img{
  width: 110px;
  height: auto;
}
.block-header-nav #header_menu {
  position: relative;
  width: 42px;
  height: 44px;
  cursor: pointer;
}
.block-header-nav #header_menu::before {
  position: absolute;
  top: 6px;
  left: 9px;
  width: 24px;
  height: 1px;
  background: #1F2123;
  transition: all 0.3s;
  content: "";
}
.block-header-nav #header_menu::after {
  position: absolute;
  top: 18px;
  left: 9px;
  width: 24px;
  height: 1px;
  background: #1F2123;
  transition: all 0.3s;
  content: "";
}
.block-header-nav #header_menu span:not(.block-headernav__item-text) {
  position: absolute;
  top: 12px;
  left: 9px;
  display: block;
  width: 24px;
  height: 1px;
  font-size: 0;
  background: #1F2123;
}
.block-header-nav #header_menu span.block-headernav__item-text {
  position: absolute;
  bottom: 0;
}
.block-header-nav #header_menu.active::before {
  top: 12px;
  transform: rotate(45deg);
}
.block-header-nav #header_menu.active::after {
  top: 12px;
  transform: rotate(-45deg);
}
.block-header-nav #header_menu.active span:not(.block-headernav__item-text)  {
  display: none;
}
.block-headernav__item-list {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: clamp(0.625rem, -1.144rem + 7.55vw, 0.875rem);
}
.block-headernav__item-list a{
  text-decoration: none;
  letter-spacing: 0;
  display: block;
}
.block-headernav__item-list .block-headernav__item-history{
  border-right: 1px solid #C9C9C9;
  padding-right: 10px;
}
.block-headernav__item-list .block-headernav__item-beginner a::before{
  content: "";
  width: 24px;
  height: 24px;
  background: url(../../img/usr/common/ico_first.png) center center / contain no-repeat;
  display: block;
  margin: 0 auto 7px;
}
.block-headernav__item-list .block-headernav__item-login a::before{
  content: "";
  width: 24px;
  height: 24px;
  background: url(../../img/usr/common/ico_login.png) center center / contain no-repeat;
  display: block;
  margin: 0 auto 7px;
}
.block-headernav__item-list .block-headernav__item-history a::before{
  content: "";
  width: 24px;
  height: 24px;
  background: url(../../img/usr/common/ico_history.png) center center / contain no-repeat;
  display: block;
  margin: 0 auto 2px;
}
.block-headernav__item-list .block-headernav__item-cart{
  position: relative;
}
.block-headernav__item-list .block-headernav__item-cart a::before{
  content: "";
  width: 28px;
  height: 28px;
  background: url(../../img/usr/common/ico_cart.png) center center / contain no-repeat;
  display: block;
  margin: 0 auto 4px;
}
.block-headernav__item-list .block-headernav__item-menu a::before{
  content: "";
  width: 24px;
  height: 24px;
  background: url(../../img/usr/common/ico_entry.png) center center / contain no-repeat;
  display: block;
  margin: 0 auto 7px;
}
.block-headernav__item-list .block-headernav__item-bookmark a::before{
  content: "";
  width: 34px;
  height: 34px;
  background: url(../../img/usr/common/ico_favorite.png) center center / contain no-repeat;
  display: block;
  margin: 0 auto 4px;
}
.block-headernav__item-list .block-headernav__item-mypage a::before{
  content: "";
  width: 34px;
  height: 34px;
  background: url(../../img/usr/common/ico_mypage.png) center center / contain no-repeat;
  display: block;
  margin: 0 auto 4px;
}
.block-headernav__cart-count{
  font-size: 9px;
  color: #FFF;
  text-align: center;
  line-height: 1;
  position: absolute;
  top: -4px;
  right: -6px;
  width: 16px;
  height: 16px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: #A80D0D;
}
.block-headernav__item-text{
  font-size: clamp(0.563rem, 0.12rem + 1.89vw, 0.625rem);
  font-family: var(--font-700);
  font-weight: bold;
  letter-spacing: 0;
  display: block;
  line-height: 1.2;
  text-align: center;
}
.block-headernav__item-history .block-headernav__item-text{
  color: var(--color01);
  text-align: center;
}
.block-header-information{
  background: #E8E8E8;
  padding: 9px 20px;
}
.block-header-information-inner {
  max-width: 800px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 16px;
  margin: 0 auto;
}
.block-header-information ul > * + *{
  margin: 5px 0 0;
}
.block-header-information li{
  font-size: 13px;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 1;
  overflow: hidden;
}
.block-header-information li a{
  text-decoration: none;
  display: block;
}
.block-header-information-more{
  flex-shrink: 0;
}
.block-header-information-more a{
  font-size: 13px;
  text-decoration: none;
  position: relative;
  padding-right: 16px;
}
.block-header-information-more a::after{
  content: "";
  width: 9px;
  height: 12px;
  clip-path: polygon(0 0, 0 100%, 100% 50%);
  position: absolute;
  top: 50%;
  right: 0;
  transform: translateY(-50%);
  background: #000;
}
.block-headernav__item-search{
  margin: 0 0 12px;
  padding: 4px 20px 0;
}
.block-global-search{
  position: relative;
}
.block-global-search .block-global-search--keyword{
  width: 100%;
  height: 46px;
  border: 1px solid #4D535D;
  border-radius: 4px;
  padding: 4px 112px 4px 16px;
}
.block-global-search .block-global-search--submit{
  height: 46px;
  font-size: 16px;
  color: #FFF;
  position: absolute;
  top: 0;
  right: 0;
  background: #1F2123;
  border: none;
  border-radius: 0 4px 4px 0;
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 4px 16px;
}
.block-global-search .block-global-search--submit::after{
  content: "";
  width: 24px;
  height: 24px;
  background: url(../../img/usr/common/ico_search.png) center center / contain no-repeat;
}

#menu_view {
  display: none;
  width: 100%;
  height: 100%;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 99990;
  background-color: #fff;
}
#menu_view .menu_inner {
  width: 100%;
  height: 100%;
  overflow-y: scroll;
  transition: all 0.3s ease;
  -webkit-overflow-scrolling: touch;
  will-change: transform;
  position: relative;
  border-top: 1px #ccc solid;
}
.block-header-menu-header{
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 12px 20px 8px;
}
.--login .block-header-menu-header{
  padding: 8px 20px;
}
.block-header-menu-header .header_menu {
  position: relative;
  width: 42px;
  height: 44px;
  cursor: pointer;
}
.block-header-menu-header .header_menu span.block-headernav__item-text {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
}
.block-header-menu-header .header_menu::before {
  position: absolute;
  top: 12px;
  transform: rotate(45deg);
  left: 9px;
  width: 24px;
  height: 1px;
  background: #1F2123;
  transition: all 0.3s;
  content: "";
}
.block-header-menu-header .header_menu::after {
  position: absolute;
  top: 12px;
  transform: rotate(-45deg);
  left: 9px;
  width: 24px;
  height: 1px;
  background: #1F2123;
  transition: all 0.3s;
  content: "";
}
.block-header-menu-btn-list{
  background: #F5F5F5;
  padding: 12px 20px 16px;
}
.block-header-menu-list__user{
  display: flex;
  flex-wrap: wrap;
  gap: 10px 20px;
  margin: 0 0 10px;
}
.--login .block-header-menu-list__user{
  margin-bottom: 20px;
}
.block-header-menu-list__user li{
  width: calc((100% - 20px) / 2);
}
.block-header-menu-list__user a{
  font-size:clamp(0.75rem, -0.134rem + 3.77vw, 0.875rem);
  background: #000;
  color: #FFF;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 8px;
  width: 100%;
  height: 50px;
  border-radius: 50px;
  text-decoration: none;
}
.--login .block-header-menu-list__user a{
  gap: 4px;
  background: #FFF;
  color: #1F2123;
  border: 1px solid #1F2123;
}
.block-header-menu-list__user .block-header-menu-list__user-history a{
  color: var(--color01);
  border-color: var(--color01);
}
.block-header-menu-list__user .block-header-menu-list__user-login a::before{
  content: "";
  width: 24px;
  height: 24px;
  background: url(../../img/usr/common/ico_login_w.png) center center / contain no-repeat;
  display: block;
}
.block-header-menu-list__user .block-header-menu-list__user-entry a::before{
  content: "";
  width: 21px;
  height: 18px;
  background: url(../../img/usr/common/ico_entry_w.png) center center / contain no-repeat;
  display: block;
}
.block-header-menu-list__user .block-header-menu-list__user-mypage a::before{
  content: "";
  width: 24px;
  height: 24px;
  background: url(../../img/usr/common/ico_mypage.png) center center / contain no-repeat;
  display: block;
}
.block-header-menu-list__user .block-header-menu-list__user-cart a::before{
  content: "";
  width: 24px;
  height: 24px;
  background: url(../../img/usr/common/ico_cart.png) center center / contain no-repeat;
  display: block;
}
.block-header-menu-list__user .block-header-menu-list__user-history a::before{
  content: "";
  width: 24px;
  height: 24px;
  background: url(../../img/usr/common/ico_history.png) center center / contain no-repeat;
  display: block;
}
.block-header-menu-list__user .block-header-menu-list__user-bookmark a::before{
  content: "";
  width: 24px;
  height: 24px;
  background: url(../../img/usr/common/ico_favorite.png) center center / contain no-repeat;
  display: block;
}
.block-header-menu-goods-list__cont{
  display: none;
}
.block-header-menu-goods-list{
  padding: 20px 20px 10px;
}
.block-header-menu-goods-list__title{
  font-size: 16px;
  font-family: var(--font-700);
  font-weight: bold;
  border-bottom: 1px solid #C9C9C9;
  position: relative;
  padding: 0 30px 6px 0;
}
.block-header-menu-goods-list__title::before,.block-header-menu-goods-list__title::after{
  content: "";
  width: 14px;
  height: 1px;
  background: #1F2123;
  position: absolute;
  top: calc(50% - 6px);
  right: 0;
}
.block-header-menu-goods-list__title::before{
  transform: translate(-50%,-50%);
}
.block-header-menu-goods-list__title::after{
  transform: translate(-50%,-50%) rotate(90deg);
  transition: transform .3s;
}
.block-header-menu-goods-list__title.is-open::after{
  transform: translate(-50%,-50%) rotate(0);
}
.block-header-menu-goods-list__title span{
  display: flex;
  align-items: center;
  gap: 6px;
  position: relative;
}
.block-header-menu-goods-list__title.--category span::before{
  content: "";
  width: 36px;
  height: 36px;
  background: url(../../img/usr/common/ico_search_cate.png) center center / contain no-repeat;
  display: block;
}
.block-header-menu-goods-list__title.--genre span::before{
  content: "";
  width: 36px;
  height: 36px;
  background: url(../../img/usr/common/ico_purpose.png) center center / contain no-repeat;
  display: block;
}
.block-header-menu-goods-list__col1,.block-header-menu-goods-list__cont .block-dynamic-category--body{
  margin: 0 0 18px;
}
.block-header-menu-goods-list__cont .block-dynamic-category--row img{
  display: none;
}
.block-header-menu-goods-list__col1 li a,.block-header-menu-goods-list__cont .block-dynamic-category--row a{
  font-size: 13px;
  font-family: var(--font-500);
  font-weight: 500;
  display: block;
  padding: 15px 30px 15px 0;
  border-bottom: 1px solid #C9C9C9;
  text-decoration: none;
  position: relative;
}
.block-header-menu-goods-list__col1 li a::after,.block-header-menu-goods-list__cont .block-dynamic-category--row a::after{
  content: "";
  width: 18px;
  height: 4px;
  background: url(../../img/usr/common/arrow_next.png) center center / contain no-repeat;
  position: absolute;
  top: 50%;
  right: 6px;
  transform: translateY(-50%);
}
.block-header-menu-goods-list__col2{
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
  padding: 30px 0 0;
}
.block-header-menu-goods-list__cont:has(.block-dynamic-category--body) .block-header-menu-goods-list__col2{
  padding-top: 0;
}
.block-header-menu-goods-list__col2 li{
  width: calc((100% - 16px) / 2);
}
.block-header-menu-goods-list__col2 li img{
  width: 100%;
  height: auto;
}
.block-header-menu-goods-list__col1 + .block-header-menu-goods-list__col2{
  padding-top: 0;
}
.block-header-menu-other-list{
  padding: 20px;
}
.block-header-menu-other-list ul{
  margin: 0 0 30px;
}
.block-header-menu-other-list li a{
  font-size: 16px;
  font-family: var(--font-700);
  font-weight: bold;
  display: flex;
  align-items: center;
  gap: 6px;
  position: relative;
  padding: 0 30px 6px 0;
  border-bottom: 1px solid #C9C9C9;
  text-decoration: none;
  position: relative;
}
.block-header-menu-other-list li a::after{
  content: "";
  width: 18px;
  height: 4px;
  background: url(../../img/usr/common/arrow_next.png) center center / contain no-repeat;
  position: absolute;
  top: 50%;
  right: 6px;
  transform: translateY(-50%);
}
.block-header-menu-other-list li a.block-header-menu-column::before{
  content: "";
  width: 36px;
  height: 36px;
  background: url(../../img/usr/common/ico_prevention.png) center center / contain no-repeat;
  display: block;
}
.block-header-menu-btn{
  font-size: 16px;
  font-family: var(--font-700);
  font-weight: bold;
  height: 60px;
  background: #F5F5F5;
  border: 1px solid #1F2123;
  border-radius: 30px;
  display: flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
}
.block-header-menu-btn-seminar::before{
  content: "";
  width: 38px;
  height: 38px;
  background: url(../../img/usr/common/ico_seminar.png) center center / contain no-repeat;
  display: block;
  margin-right: 16px;
}
.block-header-menu-btn-seminar::after{
  content: "";
  width: 17px;
  height: 17px;
  background: url(../../img/usr/common/link.png) center center / contain no-repeat;
  display: block;
  margin-left: 14px;
}
.block-header-menu-information{
  background: #F5F5F5;
  padding: 20px 20px 40px;
}
.block-header-menu-information ul{
  display: flex;
  flex-wrap: wrap;
  gap: 10px 20px;
  margin: 0 0 16px;
}
.block-header-menu-information ul li{
  width: calc((100% - 20px) / 2);
}
.block-header-menu-information ul li a{
  height: 50px;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px solid #1F2123;
  border-radius: 30px;
  background: #F5F5F5;
  text-decoration: none;
}
.block-header-menu-contact{
  text-align: center;
  background: #FFF;
  border-radius: 4px;
  margin: 0 0 30px;
  padding: 20px 20px;
}
.block-header-menu-contact__title{
  font-size: 16px;
  font-family: var(--font-700);
  font-weight: bold;
  margin: 0 0 5px;
}
.block-header-menu-contact__tel{
  font-size: 26px;
  font-family: var(--font-700);
  font-weight: bold;
  line-height: 1;
  margin: 0 0 3px;
}
.block-header-menu-contact__time{
  font-size: 14px;
  margin: 0 0 12px;
}
body:not(:has(.--login)) .block-header-menu-contact__btn{
  display: none;
}
.block-header-menu-contact__btn a{
  font-size: 16px;
  font-family: var(--font-700);
  font-weight: bold;
  color: #FFF;
  letter-spacing: 0.02em;
  display: block;
  background: var(--color01);
  border-radius: 30px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 12px;
  transition: opacity .3s;
  text-decoration: none;
}
.block-header-menu-contact__btn a:hover{
  opacity: 0.7;
}
.block-header-menu-contact__btn a::before{
  content: "";
  width: 20px;
  height: 13px;
  background: url(../../img/usr/common/ico_mail.png) center center / contain no-repeat;
  display: block;
}
.block-header-menu-close{
  text-align: center;
}
.block-header-menu-close span{
  padding-left: 20px;
  position: relative;
}
.block-header-menu-close span::before,.block-header-menu-close span::after{
  content: "";
  width: 12px;
  height: 1px;
  background: #1F2123;
  position: absolute;
  top: 50%;
  left: 0;
}
.block-header-menu-close span::before{
  transform: translateY(-50%) rotate(45deg);
}
.block-header-menu-close span::after{
  transform: translateY(-50%) rotate(-45deg);
}



/* ここまで usr/sb_block.css のコピー */


/* usr/sb_user.css のコピー ここから */

.lazyload {
  opacity: 0;
}
.lazyloading {
  opacity: 1;
}
.lazyloaded {
  opacity: 1;
  transition: opacity 200ms;
}
.js-limited-contents{
  display: none;
}

/* ここまで usr/sb_user.css のコピー */