﻿@charset "UTF-8";

.for-pc {
  display: none;
}

body.no-scroll {
  overflow: hidden;
}

/* --------------------------------------------------------------------
  ヘッダー
--------------------------------------------------------------------- */
.header_ {
  background: #fff;
}

.header_ .header-inner {
  padding: 0 16px;
}

.header_ .header-catch {
  margin: 0 0 -8px;
  padding: 6px 0 0;
  font-size: 12px;
  line-height: 1.333;
  color: #999999;
}

.header_ .header-main.fixed {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 99;
}

.header_ .header-main .header-inner {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 18px 16px 17px;
  background: #fff;
  border-bottom: 1px solid var(--borderColor);
}

.header_ .header-main-menu {
  display: flex;
  align-items: center;
}

.header_ .header-main-menu a,
.header_ .header-main-menu button {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 36px;
  height: 30px;
}

.header_ .header-main-menu .header-cart {
  position: relative;
}

.header_ .header-main-menu .header-cart-count {
  /* display: none; */
  position: absolute;
  top: -5px;
  right: -3px;
  width: 18px;
  height: 18px;
  font-size: 12px;
  line-height: 18px;
  text-align: center;
  color: #fff;
  background: var(--accentColor);
  border-radius: 50%;
}

.header_ .header-content .js-cart-count {
  display: none;
  position: absolute;
  min-width: 20px;
  height: 20px;
  line-height: 20px;
  font-size: 11px;
  font-weight: normal;
  background-color: #e61d50;
  color: #fff;
  border-radius: 9px;
  right: -1.2vw;
  z-index: 2;
  margin-top: -5px;
}

.header_ .search-btn {
  position: relative;
}

.header_ .search-btn::before,
.header_ .search-btn::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  width: 18px;
  height: 2px;
  margin: auto;
  background: #000;
  transition: 0.3s ease-in-out;
  opacity: 0;
}

.header_ .search-btn.active::before,
.header_ .search-btn.active::after {
  opacity: 1;
}

.header_ .search-btn.active img {
  opacity: 0;
}

.header_ .menu-btn {
  position: relative;
  margin-right: -8px;
}

.header_ .menu-btn span {
  position: absolute;
  left: 0;
  right: 0;
  display: block;
  width: 18px;
  height: 2px;
  margin: auto;
  background: #000;
  transition: 0.3s ease-in-out;
}

.header_ .search-btn::before,
.header_ .menu-btn span:nth-of-type(1) {
  top: calc(50% - 7px);
}

.header_ .menu-btn span:nth-of-type(2) {
  top: calc(50% - 1px);
}

.header_ .search-btn::after,
.header_ .menu-btn span:nth-of-type(3) {
  top: calc(50% + 5px);
}

.header_ .search-btn.active::before,
.header_ .menu-btn.active span:nth-child(1) {
  top: calc(50% - 1px);
  transform: rotate(-45deg);
}

.header_ .menu-btn.active span:nth-child(2) {
  opacity: 0;
}

.header_ .search-btn.active::after,
.header_ .menu-btn.active span:nth-child(3) {
  top: calc(50% - 1px);
  transform: rotate(45deg);
}

/* gnavi_search */

.header_ .gnavi_search {
  position: relative;
  flex: 1;
}

.header_ .gnavi_search .search_type_radio_ {
  display: none;
}

.header_ .gnavi_search .block-global-search--keyword {
  width: 100%;
  height: 54px;
  padding: 8px 52px 8px 210px;
  border-color: var(--textColor);
}

.header_ .gnavi_search .block-global-search--select-frame label{
  align-content: center;
}

/* --------------------------------------------------------------------
  グローバルナビ
--------------------------------------------------------------------- */
.gnavi__sp-style {
  position: fixed;
  left: 0;
  display: block;
  width: 100%;
  overflow: auto;
  overscroll-behavior: none;
  opacity: 0;
  transition: all 0.3s ease-in-out;
  pointer-events: none;
  z-index: 100;
}

.gnavi__sp-style.active {
  opacity: 1;
  pointer-events: all;
}

#gnavi-search {
  background: var(--bgColor);
}

#gnavi-search .block-global-search {
  position: relative;
  padding: 12px 16px 16px;
}

#gnavi-search .block-global-search--select-frame {
  display: flex;
  width: fit-content;
  height: 36px;
  margin: 0 0 16px;
  background: #EFEFEF;
  border: 1px solid var(--borderColor);
  border-radius: 20px;
}

#gnavi-search .block-global-search--select {
  display: block;
  height: 100%;
  padding: 0 8px;
  font-size: 12px;
  border-radius: 20px;
}

#gnavi-search .block-global-search--select.active {
  color: #fff;
  background: var(--textColor);
}

#gnavi-search .block-global-search form {
  position: relative;
}

#gnavi-search .block-global-search--keyword {
  width: 100%;
  height: 54px;
  padding: 8px 50px 8px 16px;
  border-color: var(--textColor);
}

#gnavi-search .block-global-search--keyword::placeholder {
  font-size: 16px;
}

#gnavi-search .block-global-search--submit {
  position: absolute;
  top: 24px;
  right: 10px;
  width: 50px;
  height: 100%;
  background: url(../../img/usr/common/icon_search_b.png) no-repeat center / 20px;
}

#gnavi-menu {
  padding: 0 0 40px;
  background: #fff;
}

#gnavi-menu .gnavi_link ul.link_list_ {
  margin: 26px 0 0;
  padding: 0 16px;
}

#gnavi-menu .gnavi_link ul.link_list_ li a {
  display: block;
  font-size: 14px;
  line-height: 2.4;
  color: var(--themeColor);
}

#gnavi-menu .gnavi_link ul.link_list_ li a::before {
  content: "";
  display: inline-block;
  width: 4px;
  height: 8px;
  margin-right: 8px;
  background: var(--themeColor);
  clip-path: polygon(0 0, 100% 50%, 0 100%);
}

#gnavi-menu .gnavi_contact {
  margin: 32px auto 0;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

#gnavi-menu .gnavi_contact>* {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 256px;
  height: 48px;
  margin: 0 auto;
  font-weight: bold;
  font-size: 20px;
  background: var(--bgColor) no-repeat center left 14px / 24px;
  border: 1px solid var(--borderColor);
  border-radius: 4px;
}

#gnavi-menu .gnavi_contact .gnavi_contact-tel {
  background-image: url(../../img/usr/common/icon_tel.png);
}

#gnavi-menu .gnavi_contact .gnavi_contact-fax {
  background-image: url(../../img/usr/common/icon_fax.png);
}

#gnavi-menu .CategoryStyleG_ {
  margin: 0;
}

#gnavi-menu .CategoryStyleG_ ul li {
  padding: 0;
  width: 100%;
  transition: 0.4s all;
}

#gnavi-menu .block-goods-list__navi.open {
  overflow: visible;
}

#gnavi-menu .list-item__center {
  position: relative;
  display: flex;
  align-items: center;
  min-height: 42px;
  padding: 14px 0 13px 16px;
  font-weight: bold;
  font-size: 18px;
  border-bottom: 1px solid var(--borderColor);
}

#gnavi-menu .list-item__center.level1 {
  padding: 14px 0 14px 32px;
  font-weight: bold;
  font-size: 16px;
  background: var(--bgColor);
}

#gnavi-menu .list-item__center.level2,
#gnavi-menu .list-item__center.level3,
#gnavi-menu .list-item__center.level4 {
  padding: 10px 0 10px 32px;
  font-weight: 500;
  font-size: 14px;
  border: none;
}

#gnavi-menu .list-item__center span {
  position: absolute;
  top: 0;
  right: 0;
  width: 46px;
  height: 100%;
  z-index: 1;
}

#gnavi-menu .list-item--chevron>.list-item__center span::before,
#gnavi-menu .list-item--chevron>.list-item__center span::after {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  width: 14px;
  height: 2px;
  margin: auto;
  background: var(--themeColor);
  transition: all 0.4s ease;
}

#gnavi-menu .list-item--chevron>.list-item__center span::after {
  transform: rotate(90deg);
}

#gnavi-menu .list-item--chevron>.list-item__center.minus span::after {
  transform: rotate(180deg);
}

#gnavi-menu .list-item--img_>.list-item__center::before {
  content: "";
  display: inline-block;
  width: 4px;
  height: 8px;
  margin-right: 8px;
  background: var(--themeColor);
  clip-path: polygon(0 0, 100% 50%, 0 100%);
}

#gnavi-menu .list-item--img_>.list-item__center.level0::before {
  position: absolute;
  top: 0;
  bottom: 0;
  right: 20px;
  width: 6px;
  height: 12px;
  margin: auto;
}

#gnavi-menu .block-goods-list__navi-slideside {
  display: none;
  height: auto;
  overflow: hidden;
}

#gnavi-menu .block-goods-list__navi-slideside .block-goods-list__navi-slideside>.list {
  padding: 12px 0;
  border-bottom: 1px solid var(--borderColor);
}

/* --------------------------------------------------------------------
  PC/SP切り替え
--------------------------------------------------------------------- */
div.change_mode_ {
  display: flex;
  justify-content: center;
  gap: 8px;
  width: 100%;
  padding: 24px 0;
  background: #222;
  display: none;
}

div.change_mode_ a,
div.change_mode_ span {
  display: block;
  width: calc(50% - 20px);
  padding: 11px 2px;
  border-radius: 2px;
  font-size: 14px;
  font-weight: 500;
  color: #222;
  text-align: center;
  background: #fff;
}

div.change_mode_ a {
  cursor: pointer;
}

div.change_mode_ span {
  background: #707070;
}

/* --------------------------------------------------------------------
  フッター
--------------------------------------------------------------------- */
.footer_ {
  margin: 56px 0 0;
}

.footer_ .block-page-top {
  position: fixed;
  top: auto;
  bottom: 200px;
  right: 0;
  z-index: 99;
}

.footer_ .block-page-top a {
  position: relative;
  display: block;
  width: 40px;
  height: 40px;
  font-size: 0;
  background: var(--themeColor);
  border-radius: 4px;
}

.footer_ .block-page-top a::before {
  content: "";
  position: absolute;
  top: 18px;
  left: 50%;
  width: 11px;
  height: 11px;
  border-top: 2px solid #fff;
  border-right: 2px solid #fff;
  transform: translateX(-50%) rotate(-45deg);
}

.footer_ .footer-top {
  padding: 32px 16px;
  background: var(--bgColor);
}

.footer_ .footer-bottom {
  padding: 24px 10px;
  background: var(--themeColor);
}

.footer_ .footer-btn-wrapper {
  display: flex;
  align-items: flex-end;
  gap: 16px;
}

.footer_ .footer-btn-wrapper+.footer-btn-wrapper {
  margin: 16px 0 0;
}

.footer_ .footer-about-address {
  margin: 0 16px 0 0;
  font-size: 12px;
  line-height: 1.5;
}

.footer_ .footer-btn {
  display: flex;
  justify-content: center;
  align-items: center;
  text-align: center;
  height: 42px;
  border-radius: 4px;
}

.footer_ .footer-btn.company {
  width: 104px;
  margin: 4px 0 0;
  background: #fff;
  border: 1px solid var(--borderColor);
}

.footer_ .footer-btn.issue,
.footer_ .footer-btn.contact {
  flex: 1;
}

.footer_ .footer-nav-title {
  margin: 24px 0 0;
  font-weight: bold;
  font-size: 16px;
}

.footer_ .footer-nav-list {
  display: flex;
  flex-direction: column;
  margin: 10px 0 0;
}

.footer_ .footer-nav-list a {
  position: relative;
  padding: 14px 16px 13px;
  font-size: 14px;
  color: var(--themeColor);
  background: #fff;
}

.footer_ .footer-nav-list a::before {
  content: "";
  display: inline-block;
  width: 4px;
  height: 8px;
  margin-right: 8px;
  background: var(--themeColor);
  clip-path: polygon(0 0, 100% 50%, 0 100%);
}

.footer_ .footer-nav-list a+a {
  border-top: 1px solid #F7F7F7;
}

.footer_ .footer-security {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: 10px;
}

.footer_ .footer-security li a {
  display: block;
}

.footer_ .footer-copyright {
  margin: 16px 0 0;
  font-size: 12px;
  text-align: center;
  color: #fff;
}