@charset "utf-8";

/*--------------------------------------------
shop.common.css
--------------------------------------------*/

/*--------------------------------------------
Index

1. $ベース
	1_1 $リセット
	1_2 $フォント

2. $レイアウト
	2_ $基本コンテナ

3. $コンポーネント
	3_1 $header
	3_2 $footer
	3_3 $Topへ戻る
	3_4 $オフキャンバスメニュー用閉じるボタン・オーバーレイ

4. $汎用
--------------------------------------------*/


/* ***************************************************************************************************** */
/* ** $ベース ******************************************************************************************* */
/* ***************************************************************************************************** */
/*--------------------------------------------
	$リセット
--------------------------------------------*/
html,body{
 width: 100%;
 position: relative;
}
button,
input[type='search']{
	background-color: transparent;
	border: none;
	cursor: pointer;
	outline: none;
	padding: 0;
	appearance: none;
}



/*--------------------------------------------
	$フォント
--------------------------------------------*/
body{
 font: 16px/1.5 "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	color: #333333;
}
a:link{
	text-decoration: none;
	color: #333333;
}
a:visited{
	text-decoration: none;
	color: #333333;
}
a:hover{
	text-decoration: underline;
}
.mincho{
	 font-family: "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "游明朝", YuMincho, "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
}



/* ***************************************************************************************************** */
/* ** $レイアウト ******************************************************************************************* */
/* ***************************************************************************************************** */

/*--------------------------------------------
 $コンテナ
--------------------------------------------*/

/* 基本のコンテナ このコンテナにサイドナビ・メインコンテンツを内包 */
.container{
 max-width: 1000px;
 width: 100%;
 margin: 0 auto;
}
@media all and (-ms-high-contrast:none){
  *::-ms-backdrop, ul.container { z-index: 10000; } /* IE11のグローバルナビゲーション対策 */
}

@media only screen and (max-width: 1000px){
	.container{
		max-width: 100%;
		padding: 0 2.13%;
	}
}
@media only screen and (max-width: 768px){
	.container{
		/*max-width: 100%;*/
		/*padding: 0 2.13%;*/
	}
}
.container_full{ /* マージン・パディングなし */
	max-width: initial;
}

/* サイドナビ用*/
/* スマホ時は非表示 */
.container-sideNav{ /* container に container_flex-fd-rr 付与して並び替え*/
	/*max-width: 236px;*/
	width: 236px;
	margin: 0;
	padding: 0;
}
.container-sideNav_right{
	margin-right: 0;
}

@media only screen and (max-width: 1000px) {
	.container-sideNav,
	.container-sideNav_right{
		max-width: 100%;
		width: 100%;
		margin: 0;
	}
}
@media only screen and (max-width: 768px){
	.container-sideNav,
	.container-sideNav_right{
		display: none;
		max-width: 100%;
		width: 100%;
		margin: 0;
	}
}

/* サイドナビがある場合のメインコンテナ*/
.container-isSideNav{
	width: 728px;
	margin: 0;
	padding: 0;
}

@media only screen and (max-width: 1000px) {
	.container-isSideNav{
		max-width: 100%;
		width: 100%;
	}
}
@media only screen and (max-width: 768px){
	.container-isSideNav{
	}
}

/* Flexbox */
.container_flex{
	display:-webkit-box;
	display:-ms-flexbox;
	display:flex;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
}
.container_flex-jc-sb{
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
}
.container_flex-jc-sa{
	-ms-flex-pack: distribute;
	justify-content: space-around;
}
.container_flex-jc-c{
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
}
.container_flex-jc-fs{
	-webkit-box-pack: start;
	-ms-flex-pack: start;
	justify-content: flex-start;
}
.container_flex-ai-c{
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
}
.container_flex-ai-fe{
	-webkit-box-align: end;
	-ms-flex-align: end;
	align-items: flex-end;
}
.container_flex-ai-s{ /* 初期値 */
	-webkit-box-align: stretch;
	-ms-flex-align: stretch;
	align-items: stretch;
}
.container_flex-fd-rr{
	-webkit-box-orient: horizontal;
	-webkit-box-direction: reverse;
	-ms-flex-direction: row-reverse;
	flex-direction: row-reverse;
}
.container_flex-fd-c{
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-ms-flex-direction: column;
	flex-direction: column;
}

/* パーセンテージ分割 */
.container-item-10pct{	width: 10%;}
.container-item-15pct{	width: 15%;}
.container-item-20pct{	width: 20%;}
.container-item-25pct{	width: 25%;}
.container-item-30pct{	width: 30%;}
.container-item-35pct{	width: 35%;}
.container-item-38pct{	width: 38%;}
.container-item-40pct{	width: 40%;}
.container-item-48pct{	width: 48%;}
.container-item-50pct{	width: 50%;}
.container-item-58pct{	width: 58%;}
.container-item-60pct{	width: 60%;}
.container-item-65pct{	width: 65%;}
.container-item-70pct{	width: 70%;}
.container-item-80pct{	width: 80%;}
.container-item-90pct{	width: 90%;}
		@media only screen and (max-width: 768px){
			/* SPでコンテナを全幅に spFull を付与*/
			*[class*=" container-item-"].spFull{
				width: 100%;
			}
			*[class^="container-item-"].spFull{
				width: 100%;
			}
		}

/*--------------------------------------------
 $2カラム用
--------------------------------------------*/


/* ***************************************************************************************************** */
/* ** $コンポーネント ******************************************************************************************* */
/* ***************************************************************************************************** */

/* パンくず */
.breadcrumbs{
	margin-top: 20px;
	margin-bottom: 30px;
	font-size: 0;
}
.breadcrumbs,
.breadcrumbs a{
}
.breadcrumbs li{
	display: inline;
	margin-right: 6px;
	font-size: 12px;
}
.breadcrumbs li:not(:last-child)::after{
	content: "\03e";
	display: inline-block;
	margin-left: 6px;
}


/* 見出し */
.title-level-01{ /* カテゴリページ等に使用 */
 font: 2.25rem /1.5 "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "游明朝", YuMincho, "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
	display: inline-block;
	margin-bottom: 2.75rem;
	border-bottom: 3px solid #bfa77a;
	padding-bottom: 1.0625rem;
}
		@media only screen and (max-width: 768px) {
			.title-level-01{
				font-size: 1.875rem;
				padding-bottom: 0.75rem;
				margin-bottom: 2.0rem;
			}
		}

.title-level-02{
	font-size: 1.25rem;
	line-height: 1.625;
	font-weight: 700;
}
@media only screen and (max-width: 768px) {
 .title-level-02{
 	font-size: 0.9375rem;
 }
}

.subTitle-level-01{
	font-size: 0.875rem;
}
		@media only screen and (max-width: 768px) {
			.subTitle-level-01{
				font-size: 0.75rem;
			}
		}

/* 段落 */
.paragraph-lead-01{
	font: 1.25rem /2.125 "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "游明朝", YuMincho, "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
	text-align: center;
}
		@media only screen and (max-width: 768px) {
			.paragraph-lead-01{
				font-size: 0.875rem;
				line-height: 1.4375;
				max-width: 95%;
			}
		}


	.paragraph-note-01{
		font-size: 0.6875rem;
		line-height: 1.125;

	}

/* ボタン */
.btn_ghost01,
.btn_ghost01 a{
	font-size: 1rem;
	color: #644c1f;
}
.btn_ghost01{
	display: inline-block;
	min-width: 156px;
	padding: 0.50rem 2.50rem 0.50rem 2.00rem;
	background-color: transparent;
	border: 1px solid #644c1f;
	border-radius: 0.25rem;
	position: relative;
	text-align: center;
}
.btn_ghost01::after{
	content: "\03e";
		display: inline-block;
		position: absolute;
		margin-left: 4px;
}
.btn_ghost01.inactive01{
	border: none;
	padding-left: 2.50rem;
}
.btn_ghost01.inactive01::after{
	display: none;
}
.btn_ghost01.inactive01,
.btn_ghost01.inactive01 a{
	color: #333;
	background-color: #d5d4d2;
}
		@media only screen and (max-width: 768px) {
		 .btn_ghost01,
			.btn_ghost01 a{
				font-weight: 700;
			}
		}

/* ページネーション */
.pagination li{
	display: inline-block;
	min-width: 36px;
	min-height: 36px;
	padding: 5px;
	text-align: center;
	vertical-align: middle;
	background-color: transparent;
	border: 1px solid #6e6e6e;
}
.pagination,
.pagination a{
	font-size: 1.0rem;
	font-weight: 700;
}
.pagination li.active{
	border: none;
	background-color: #e6dece;
	padding: 6px;
}


/*--------------------------------------------
	$header
--------------------------------------------*/
/* header_上部 */
.gNav-shop{
 padding-top: 20px;
 padding-bottom: 12px;
}
		@media only screen and (max-width: 768px){
			.gNav-shop{
				padding-top: 7px;
				padding-bottom: 7px;
				width: 100%;
				min-height: 80px;
				box-shadow: 0 2px 6px 2px rgba(1, 1, 1, 0.2);
				background-color: #fff;
				z-index: 100;
				/*position: relative;*/
				position: fixed;
				top: 0;
				left: 0;
			}
			.gNav-shop_fixed{
				position: fixed;
				top: 0;
				left: 0;
			}
			body{
				padding-top: 80px;
			}
		} /* end media query */

/* header_サイト情報 */
.gNav-shop-siteInfo{
 text-align: left;
}
.gNav-shop-siteInfo > h1 > span{
	max-width: 254px;
	display: block;
	font-size: 0.72rem;
	padding: 8px 0;
}
.gNav-shop-siteLogo{
	display: block;
	width: 338px;
	height: 39px;
}
.gNav-shop-greeting{
	display: block;
	font-size: 0.75rem;
	padding: 18px 0;
}
		@media only screen and (max-width: 768px){
			.gNav-shop-siteInfo{
				width: 70%;
			}
			.gNav-shop-siteInfo > h1 > span{
				display: none;
			}
			.gNav-shop-greeting{
				font-size: 0.69rem;
				padding: 7px 0 0;
			}
		} /* end media query */

/* header_ショップメニュー */
.gNav-shop-shopMenu{
 text-align: right;
}
.gNav-shop-menuTrigger{
	display: none;
}
		@media only screen and (max-width: 768px){
			.gNav-shop-shopMenu{
				width: 30%;
				position: relative;
			}
			.gNav-shop-search,
			.gNav-shop-accountInfo{
				display: none;
			}
			.gNav-shop-menuTrigger{
				display: inline-block;
				position: absolute;
				top: 0;
				right: 0;
				width: 50px;
				height: 50px;
				border-radius: 4px;
				background-color: #bfa77a;
				color: #fff;
				font-size: 0.63rem;
				font-weight: 700;
				text-align: center;
			}
			.gNav-shop-menuTriggerInner:nth-child(1)::before,
			.gNav-shop-menuTriggerInner:nth-child(2)::before,
			.gNav-shop-menuTriggerInner:nth-child(3)::before{
			content: "";
			position: absolute;
			display: inline-block;
			width: 25px;
			border-top: 3px solid #fff;
		 left: 0;
		 right: 0;
		 margin: auto;
			}
			.gNav-shop-menuTriggerInner:nth-child(1)::before{
		 top: 8px;
			}
			.gNav-shop-menuTriggerInner:nth-child(2)::before{
		 top: 16px;
			}
			.gNav-shop-menuTriggerInner:nth-child(3)::before{
		 top: 24px;
			}
			.gNav-shop-menuTriggerInner:last-child{
			bottom: 4px;
			left: 0;
			position: absolute;
			right: 0;
			}
		} /* end media query */

 /* header_ショップメニュー_QA&検索 */
.gNav-shop-search{
}
.gNav-shop-search li{
	display: inline-block;
}
.gNav-shop-search li a{
	font-size: 0.75rem;
}
.gNav-shop-searchQA{
	vertical-align: top;
}
.gNav-shop-searchQA li{
	margin-left: 20px;
}
.gNav-shop-searchQA li::before{
	content: "";
	display: inline-block;
	position: relative;
	border-top: 4px solid transparent;
	border-right: 4px solid transparent;
	border-bottom: 4px solid transparent;
	margin-right: 6px;
	border-left: 4px solid #000;
}
.gNav-shop-searchForm{
	background-color: #f3f3f4;
	text-align: left;
	padding: 10px 20px;
	margin-left: 34px;
	max-width: 265px;
	width: 100%;
}
.gNav-shop-searchForm form{
	/*width: 100%;*/
}
.gNav-shop-searchForm input{
	border: none;
	width: 86%;
	font-size: 0.88rem;
	color: #454545;
	padding: 0;
}
.gNav-shop-searchForm input,
.gNav-shop-searchForm button{
	line-height: 1.5;
}

/* header_アカウント情報 */
.gNav-shop-accountInfo{
	margin: 12px 0 0;
}
.gNav-shop-accountInfo li{
	display: inline-block;
	vertical-align: bottom;
}
.gNav-shop-cartInfo{
	border-bottom: 1px dashed #000;
	margin-bottom: 12px;
	padding: 0 4px 2px;
}
.gNav-shop-cart{
}
.gNav-shop-cart a{
	position: relative;
	display: block;
	margin-right: 22px;
}
.gNav-shop-cartImage{
	width: 39px;
}
.gNav-shop-cartNum{
	display: block;
	position: absolute;
	top: -0.63rem;
	right: -1.25rem;
	background-color: #f03f75;
	color: #fff;
	font-size: 0.81rem;
	line-height: normal;
	text-align: center;
	padding: 0.31rem 0.44rem;
	border-radius: 50%;
	min-width: 30px;
	min-height: 30px;
}
.gNav-shop-cartPrice{
	margin-right: 18px;
	text-align: left;
}
.gNav-shop-cartPriceHeading,
.gNav-shop-cartPriceYen{
	font-size: 0.63rem;
}
.gNav-shop-cartPriceHeading{
	display: block;
}
.gNav-shop-cartPriceTotal{
	font-size: 1.25rem;
	font-weight: 700;
}
.gNav-shop-cartCheck a{
	font-weight: 700;
}
.gNav-shop-cartCheck::after{
	content: "";
	display: inline-block;
	position: relative;
	border-top: 6px solid transparent;
	border-right: 6px solid transparent;
	border-bottom: 6px solid transparent;
	margin-left: 7px;
	border-left: 6px solid #333;
}

.gNav-shop-accountMenu{
	vertical-align: bottom;
	margin: 0 0 12px 20px;
}
.gNav-shop-myPage,
.gNav-shop-register{
	width: 129px;
	height: 58px;
	border-radius: 4px;
	text-align: center;
	padding: 7px;
}
.gNav-shop-myPage a,
.gNav-shop-register a,
.gNav-shop-myPage span,
.gNav-shop-register span{
	font-size: 1.13rem;
	font-weight: 700;
}
.gNav-shop-myPage:hover,
.gNav-shop-register:hover{
opacity: 0.8;
}
.gNav-shop-myPage a{
	color: #fff;
}
.login .gNav-shop-myPage:first-of-type a{
	color: #705a30;
}
.gNav-shop-register a{
	color: #705a30;
}
.gNav-shop-myPage img,
.gNav-shop-register img{
	display: block;
	margin: 0 auto 1px;
}
.gNav-shop-myPage{
	background-color: #bfa77a;
}
.login .gNav-shop-myPage:first-of-type{
	background-color: #f5eee0;
	border: 1px solid #a27f37;
}
.gNav-shop-register{
	background-color: #f5eee0;
	border: 1px solid #a27f37;
}

/* header_アカウント情報_sp */
.gNav-shop-accountInfo_sp{
	display: none;
}
		@media only screen and (max-width: 768px){
			.gNav-shop-accountInfo_sp{
				display: flex;
				justify-content: flex-start;
				position: relative;
				text-align: center;
				border-bottom: 1px solid #949393;
			}
			.gNav-shop-accountInfo_sp a{
				display: inline-block;
				font-size: 0.75rem;
				font-weight: 700;
				min-height: 60px;
				padding: 36px 10px 0;
				width: 100%;
			}
			.gNav-shop-accountInfo_sp li {
				border-right: 1px solid #949393;
			}
			.gNav-shop-accountInfo_sp li:nth-child(4):last-of-type {
				border-right: none;
			}
			.gNav-shop-accountInfo_sp a{
				background-repeat: no-repeat;
				background-position: center 12px;
				background-size: auto 20px;
			}
			.gNav-shop-accountInfo_sp .search{
				background-image: url(../images/common/icon_gnav-search-sp01.png);
			}
			.gNav-shop-accountInfo_sp .login{
				background-image: url(../images/common/icon_gnav-mypage-sp01.svg);
			}
			.gNav-shop-accountInfo_sp .logout{
				background-image: url(../images/common/icon_gnav-logout-sp01.png);
			}
			.gNav-shop-accountInfo_sp .mypage{
				background-image: url(../images/common/icon_gnav-mypage-sp01.svg);
			}
			.gNav-shop-accountInfo_sp .register{
				background-image: url(../images/common/icon_gnav-register-sp01.png);
			}
			.gNav-shop-accountInfo_sp .cart{
				background-image: url(../images/common/icon_gnav-cart-sp01.png);
			}
			.gNav-shop-cartNum{
				top: 10%;
				right: 4%;
				font-size: 0.5625rem;
				padding: 3px 5px;
				min-width: 20px;
				min-height: 20px;
			}
		} /* end media query */

/* header_カテゴリメニュー */
.gNav-productCate{
	border-top: 1px solid #c6b188;
}
.gNav-productCate{ /* トップページは非表示 */
  border-bottom: 1px solid #c6b188;
}

.gNav-productCate > ul{
	position: relative;
	height: 92px;
	/*min-height: 92px;*/
}
.gNav-productCate > ul > li{
	text-align: center;
	z-index: 100;
}
.gNav-productCate .opener{width: 100%;}
.gNav-productCate .opener > a.gNav-productCate_hover{ /* jsで追加するためのクラス */
	background-color: rgba(84,69,42,0.97);
	color: #fff;
	font-weight: 700;
	border-radius: 8px 8px 0 0;
}
.gNav-productCate .opener > a{
 font-family: "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "游明朝", YuMincho, "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
	font-weight: 700;
	color: #644c1f;
	display: inline-block;
	width: 100%;
	height: 100%;
	padding: 22px 0;
	position: relative;
	transition: initial;
}
.gNav-productCate li.banner,
.gNav-productCate li.search,
.gNav-productCate li.series,
.gNav-productCate li.home,
.gNav-productCate li.close{ /* SP用メニュー */
	display: none;
}
.gNav-productCate .opener .cateName{
 position: absolute;
 top: 50%;
 transform: translateY(-50%);
 left: 0;
 right: 0;
}
.gNav-productCate .opener > a::before{
	content: "";
	position: absolute;
	display: block;
	height: 25px;
	top: 0;
	bottom: 0;
	margin: auto;
}
.gNav-productCate .opener > a::before{
	border-left: 1px solid #d6d6d9;
}
.gNav-productCate > ul > li:last-child .opener > a::after{
	border-right: 1px solid #d6d6d9;
	right: 0;
}
.gNav-productCate .opener > a:hover::before,
.gNav-productCate .opener > a:hover::after{
	border: none;
}

		@media only screen and (max-width: 768px){
			/* SPオフキャンバス */
			/* アコーディオンのスタイル「メガメニュー」セクションに記述 */
			.gNav-productCate{
				border-top: none;
				width: 88%;
				position: fixed;
				overflow: scroll;
				-webkit-overflow-scrolling: touch;
				top: 0;
				bottom: 0;
				right: -88%;
				/*right: 0;*/
				background: #fff;
				z-index: 1000;
				transition: all 0.5s;
			}
			.gNav-productCate > ul.container_flex{
				flex-wrap: nowrap;
				flex-direction: column;
				padding: 0;
			}
			.gNav-productCate > ul > li{
				/*padding: 16px 23px;*/
				border-bottom: 1px solid #ccc;
				text-align: left;
				flex-shrink: 0;
			}
			.gNav-productCate .close .cateName{
				font: 15px/1.5 "ヒラギノ角ゴ ProN W3","Hiragino Kaku Gothic ProN", "メイリオ","Meiryo", "ＭＳ Ｐゴシック","MS PGothic",Sans-Serif;
				font-weight: 700;
				padding: 15px 28px;
				width: 100%;
				height: 100%;
				color: #fff;
				background-color: #b3914d;
				border-radius: 4px;
				display: inline-block;
				position: relative;
			}
			.gNav-productCate .close .cateName::before,
			.gNav-productCate .close .cateName::after{  /* 閉じるアイコン */
				content: "";
				position: absolute;
				display: inline-block;
				width: 16px;
				height: 16px;
				top: 0;
				bottom: 0;
				right: 0;
				left: 0;
				margin: auto;
			}
			.gNav-productCate .close .cateName::before{ /* 閉じるアイコン */
				border-top: 2px solid #fff;
				top: 10px;
				left: 1px;
				margin: 12px 0 0 75%;
				transform: rotate(45deg);
			}
			.gNav-productCate .close .cateName::after{ /* 閉じるアイコン */
				border-right: 2px solid #fff;
				margin: 12px 0 0 75%;
				transform: rotate(45deg);
			}
			.gNav-productCate .opener{
				display: inline-block;
				padding: 16px 23px;
			}
			.gNav-productCate .opener.gNav-productCate_hover{
				background-color: #eee;
				color: unset;
			}
			.gNav-productCate .opener a{
				text-align: left;
				font-family: "ヒラギノ角ゴ ProN W3","Hiragino Kaku Gothic ProN", "メイリオ","Meiryo", "ＭＳ Ｐゴシック","MS PGothic",Sans-Serif;
				font-weight: 700;
				color: #333;
				padding: 0;
				width: 80%;
				height: initial;
			}
			.gNav-productCate .banner a{
				width: 100%;
			}
			.gNav-productCate .opener a#cateDummyLink {
				pointer-events: none;
			}
			.gNav-productCate > ul > li:last-child .opener > a::after /* PCのスタイルを上書き */ ,
			.gNav-productCate .opener > a::after{/* プラスアイコン */
				content: "";
				position: absolute;
				display: block;
				height: 15px;
				width: 15px;
				top: 0;
				bottom: 0;
				right: -32%;
				margin: auto;
				border-right: 2px solid #333;
				margin-right: 30px;
				pointer-events: none;
			}
			.gNav-productCate .opener > a::before{ /* プラスアイコン */
				width: 16px;
				height: 16px;
				border-top: 2px solid #333;
				border-left: none;
				right: -32%;
				top: 16px;
				margin-right: 23px;
				pointer-events: none;
			}
			.gNav-productCate .container .opener > a.active::after{ /* アクティブ時に縦棒を消す */
				display: none;
			}
			/*ホームへ*/
			.gNav-productCate .home .opener > a::before,/* 「ホームへ」には+-アイコンを出さない */
			.gNav-productCate .home .opener > a::after {
				display: none;
			}
			.gNav-productCate .home > span {
				padding: 0;
			}
			.gNav-productCate .home > span > a {
				display: block;
				padding: 16px 23px;
				width: 100%;
			}
			.gNav-productCate .opener .cateName{
			    position: relative;
			    top: auto;
			    transform: none;
			    left: auto;
			    right: auto;
			    font :inherit;
			}
			/* バナーと検索フォーム */
			.gNav-productCate .banner img{
				width: 100%;
			}
			.gNav-productCate .banner a::before,
			.gNav-productCate .banner a::after{
				display: none;
			}
			.gNav-productCate .search{
				padding: 16px 23px;
				border-bottom: 1px solid #ccc;
			}
			.gNav-productCate .search form{
    border: 1px solid #d8d8d8;
    padding: 10px 6px;
			}
			.gNav-productCate .search form,
			.gNav-productCate .search input{
				width: 100%;
				position: relative;
				background-color: #f3f3f4;
			}
			.gNav-productCate .search input{
				padding-right: 42px;
			}
			.gNav-productCate .search button{
    position: absolute;
    top: 0;
    bottom: 0;
    right: 15px;
			}
			.gNav-productCate .search img{
				width: 20px;
			}
			/* SPオフキャンバス_SP専用メニュー表示 */
			.gNav-productCate ul > li.banner,
			.gNav-productCate ul > li.search,
			.gNav-productCate ul > li.series,
			.gNav-productCate ul > li.home,
			.gNav-productCate ul > li.close{
				display: block;
			}
			 /* SPオフキャンバス_順序 */
			.gNav-productCate .banner{
				order: 1;
				padding: 23px;
			}
			.gNav-productCate .search{
				order: 2;
			}
			.gNav-productCate .about{
				order: 3;
			}
			.gNav-productCate .skincare{
				order: 4;
			}
			.gNav-productCate .makeup{
				order: 5;
			}
			.gNav-productCate .hair-body{
				order: 6;
			}
			.gNav-productCate .food-other{
				order: 7;
			}
			.gNav-productCate .series{
				order: 8;
				display: block!important;
			}
			.gNav-productCate .home{
				order: 9;
			}
			.gNav-productCate .close{
				order: 10;
				padding: 16px 23px;
				text-align: center;
				border-bottom: none;
				margin-top: 32px;
			}
			.gNav-productCate-detail{
				position: relative;
				top: 0;
			}

		} /* end media query */

/* header_カテゴリーナビ_メガメニュー */
.gNav-productCate-detail{
	visibility: hidden;
	position: absolute;
	top: 92px;
	left: 0px;
	padding: 50px 70px;
	background-color: rgba(84,69,42,0.97);
	color: #fff;
	text-align: left;
	font-weight: 700;
}
.gNav-productCate-detail-close{
	cursor: pointer;
	width: 24px;
	height: 24px;
	position: absolute;
	top: 20px;
	right: 20px;
}
.gNav-productCate-detail-close::before,
.gNav-productCate-detail-close::after{
	content: "";
	display: block;
	position: absolute;
	transform: rotate(45deg);
}
.gNav-productCate-detail-close::before{
	border-top: 2px solid #fff;
	width: 24px;
	top: 11px;
	right: 0;
}
.gNav-productCate-detail-close::after{
	border-right: 2px solid #fff;
	height: 24px;
	top: 0;
	right: 11px;
}
/**
.gNav-productCate .skincare .gNav-productCate-detail{
	margin-left: -20%;
}
.gNav-productCate .makeup .gNav-productCate-detail{
	margin-left: -40%;
}
.gNav-productCate .hair .gNav-productCate-detail{
	margin-left: -60%;
}
.gNav-productCate .health .gNav-productCate-detail{
	margin-left: -80%;
}
*/
.gNav-productCate-detail a{
	color: #fff;
	font-weight: 700;
	display: inline-block;
	width: 100%;
	padding: 10px;
}
.gNav-productCate-detail a::before{
	content: "";
	display: inline-block;
	position: relative;
	vertical-align: middle;
	width: 5px;
	height: 5px;
	border-left: 2px solid #fff;
 border-top:  2px solid #fff;
	transform: rotate(135deg);
	margin-right: 15px;
}
		@media only screen and (max-width: 768px) {
			/* SPオフキャンバスメニュー_アコーディオン */
			.gNav-productCate-detail{
				position: relative;
				visibility: hidden;
				display: none;
				top: 0;
				flex-direction: column;
				padding: 0;
			}
			.gNav-productCate-detail li{
				padding: 0;
				flex-shrink: 0;
			}
			.gNav-productCate-detail a{
				padding: 20px 16px;
				display: block;
				width: 100%;
			}
			.gNav-productCate-detail,
			.gNav-productCate-detail a{ /* フォント */
				font-size: 0.875rem;
				font-weight: 500;
				color: #333;
				background-color: #fff;
			}
			.gNav-productCate-detail a::before{
				border-left: 1px solid #644c1f;
			 border-top:  1px solid #644c1f;
			}
			.gNav-productCate .gNav-productCate-detail{
				margin-left: 0 !important;
			}
} /* end media query */

/*--------------------------------------------
	$footer
--------------------------------------------*/
/* common.css上書き */
footer{
	background-color: transparent;
}
footer div{
	margin: 0;
}

/* footer_sns */
.footer-sns{
	padding: 22px 0 33px;
/*	border-top:1px solid #eae8e7; */
	border-bottom:1px solid #eae8e7;
	text-align: center;
}
.footer-sns-heading{
	font-weight: 700;
	margin-bottom: 24px;
}
.footer-sns li{
	width: 128px;
}
.footer-sns a{
	font-size: 0.69rem;
}
.footer-sns-icon{
	display: block;
}
@media all and (-ms-high-contrast:none){
  *::-ms-backdrop, .footer-sns-icon img { width: 48px; } /* IE11 */
}

@media only screen and (max-width: 768px) {
	.footer-sns{
		padding: 16px 0 20px;
	}
	.footer-sns-heading{
		font-size: 0.75rem;
	}
	.footer-sns li{
		width: initial;
	}
	.footer-sns-icon{
		padding: 0 16px;
	}
	.footer-sns-icon img{
		width: 40px;
	}
	.footer-sns-icon + span {
		display: none;
	}
} /* end media query */

/* footer_カテゴリーナビ */
.footer-productCate{
	padding: 31px 0 63px;
	font-size: 0.81rem;
}
.footer-productCate-col{
	padding: 0 10px;
}
.footer-productCate-col:first-child{
	padding-left: 0;
}
.footer-productCate-col:last-child{
	padding-right: 0;
}

.footer-productCate-heading{
	display: inline-block;
	font-size: 0.88rem;
	font-weight: 700;
	margin-bottom: 27px;
}
.footer-productCate-list > li{
	text-indent: -20px;
	padding: 0 0 0 20px;
}
.footer-productCate-list > li,
.footer-productCate-list > li > ul >li{
	margin-bottom: 8px;
}
.footer-productCate-list > li::before,
.footer-productCate-list > li > ul >li::before{
	content: "";
	display: inline-block;
	position: relative;
	vertical-align: middle;
	width: 5px;
	height: 5px;
}
.footer-productCate-list > li::before{
	border-left: 1px solid #333;
 border-top:  1px solid #333;
	transform: rotate(135deg);
	margin-right: 15px;
}
.footer-productCate-list > li > ul > li::before{
	border-top: 1px solid #333;
	margin-right: 6px;
	top: 2px;
}
.footer-productCate-list > li > ul{
	text-indent: 24px;
}
		@media only screen and (max-width: 1000px) {
	  .footer-productCate{
	  	padding-right: 2.13%;
	  	padding-left: 2.13%;
	  }
		}
		@media only screen and (max-width: 768px) {
			.footer-productCate{display: none;}
		} /* end media query */

/* footer_ショップガイド */
.footer-shopGuide{
	background-color: #f4eeea;
	padding: 0 0 20px;
}

/* footer_コンタクト */
.footer-contactInfo{
	margin-bottom: 36px;
}
.footer-telephone{
	width: 676px;
	background-color: #fff;
	border-radius: 4px;
	padding: 20px 24px;
	display: table;
	margin-top: 24px;
}
.footer-telephone > *{
	display: table-cell;
	vertical-align: middle;
	position: relative;
	top: 4px;
}
.footer-telephone-heading{
	color: #644c1f;
	font-size: 1.25rem;
	font-weight: 700;
	padding-right: 48px;
}
.footer-telephone-heading-spNote{
	display: none;
}
.footer-telephoneInfo > address{
	padding-right: 18px;
}
.footer-telephoneInfo > address,
.footer-telephoneInfo > div{
	display: table-cell;
	vertical-align: middle;
}
.footer-telephoneInfo > address *{
 vertical-align: middle;
}
.footer-telephoneInfo > address >span{
	font-size: 1.5rem;
	font-weight: 700;
}
.footer-telephoneInfo-time{
	font-size: 0.88rem;
	font-weight: 700;
}
.footer-telephoneInfo-note{
	font-size: 0.69rem;
	font-weight: 700;
}
.footer-inquiry{
	width: 306px;
	text-align: center;
	background-color: #bfa77a;
	border-radius: 4px;
	margin-top: 24px;
}
.footer-inquiry ,
.footer-inquiry a{
	color: #fff;
	font-size: 1.25rem;
	font-weight: 700;
	top: 10px;
}
.footer-inquiry a{
	display: block;
	position: relative;
	padding: 22px 0;
}
.footer-inquiry:hover ,
.footer-inquiry a:hover{
	opacity: 0.8;
}
		@media only screen and (max-width: 768px) {
			.footer-telephone{
				width: 100%;
			}
			.footer-telephone > *{
				display: inline-block;
			}
			.footer-telephone{
				margin-top: 18px;
				padding: 14px 30px;
			}
			.footer-telephone-heading{
				display: inline-block;
				position: relative;
				vertical-align: middle;
				font-size: 1.0625rem;
				padding-right: 0;
				width: 100%;
			}
			.footer-telephone-heading-spNote{
				display: inline-block;
				position: absolute;
				font-size: 0.625rem;
				font-weight: 700;
				color: #644c1f;
				margin-left: 13px;
				padding: 4px 12px;
				border-radius: 48px;
				background-color: #e2d7c2;
			}
			.footer-telephoneInfo > address{
				width: 100%;
				display: inline-block;
				padding: 6px 0 0;
				line-height: 1.2;
			}
			.footer-telephoneInfo > address > span{
				font-size: 1.88rem;
			}
			.footer-telephoneInfo-timeInfo{
				width: 100%;
			}
			.footer-telephoneInfo .footer-telephoneInfo-timeInfo,
			.footer-telephoneInfo .footer-telephoneInfo-time,
			.footer-telephoneInfo .footer-telephoneInfo-note{
				display: inline-block;
				text-align: center;
			}
			.footer-inquiry{
				width: 100%;
				margin-top: 18px;
				position: relative;
			}
			.footer-inquiry .textVisible-SP{
				padding-left: 40px;
			}
			.footer-inquiry .textVisible-SP::before{
				content: "";
				position: absolute;
				display: inline-block;
				top: 0;
				left: 0;
				width: 100%;
				height: 100%;
				background: no-repeat left center/32px auto url(../images/common/icon_footer-contact-sp01.png);
			}
			.footer-inquiry a{
				top: 0;
				font-size: 1.062rem;
				padding-left: 55px;
				padding-right: 55px;
			}
		} /* end media query */

/* footer_ショップ基本情報 */
.footer-copyright .footer-logo{
	width: 272px;
	display: block;
}
.footer-copyright .footer-copyrightText{
 font-size: 0.63rem;
}

.footer-baseNav{
	text-align: right;
}
.footer-baseNav > ul > li,
.footer-baseNav > ul > li > ul >li{
	display: inline-block;
}
.footer-baseNav-shop{
	margin-bottom: 6px;
}
.footer-baseNav-shop,
.footer-baseNav-shop a{
 font-size: 1.0rem;
 font-weight: 700;
 color: #644c1f;
}
.footer-baseNav-shop > ul > li{
	margin-left: 24px;
}
.footer-baseNav-company,
.footer-baseNav-company a{
	font-size: 0.75rem;
}
.footer-baseNav-company > ul >li{
	margin-left: 20px;
}
		@media only screen and (max-width: 768px) {
			.footer-baseInfo.container{
				padding: 0;
			}
			.footer-copyright,
			.footer-baseNav{
				width: 100%;
			}
			.footer-copyright{
				order: 2;
			}
			.footer-baseNav{
				order: 1;
				text-align: left;
			}
			.footer-baseNav-shop{
				border-top: 1px solid #ccc;
				border-bottom: 1px solid #ccc;
				background-color: #fff;
				margin-bottom: 30px;
				width: 100%;
			}
			.footer-baseNav-shop > ul > li{
				width: 50%;
				margin: 0;
			}
			.footer-baseNav-shop a{
				color: #333;
				display: inline-block;
				font-size: 0.88rem;
				font-weight: 500;
				height: 100%;
				width: 100%;
				padding: 18px 5%;
				position: relative;
			}
			.footer-baseNav-shop a::before{
				content: "";
				display: inline-block;
				width: 6px;
				height: 6px;
				position: relative;
				margin-right: 8px;
				border-top: 1px solid #644c1f;
				border-right: 1px solid #644c1f;
				transform: rotate(45deg);
			}
			.footer-baseNav-shop li:nth-child(odd) a{
				border-right: 1px solid #ccc;
			}
			.footer-baseNav-shop li:nth-child(-n+2) a{
				border-bottom: 1px solid #ccc;
			}

			.footer-baseNav-company{
				line-height: 2;
				text-align: center;
				margin-bottom: 22px;
			}
			.footer-baseNav-company > ul >li{
				margin-left: 0;
			}
			.footer-baseNav-company > ul >li > a{
				padding: 0 20px;
				text-decoration: underline;
			}

			.footer-copyright{
				text-align: center;
			}
			.footer-copyright .footer-logo{
				width: 266px;
				margin: 0 auto 10px;
			}
		} /* end media query */


/*--------------------------------------------
	$サイドナビ
--------------------------------------------*/
/* コンポーネント */
.sideNav-bnr-01{
	width: 236px;
	max-width: 100%;
}

.sideNav-list-01{

}
.sideNav-list-01 .sideNav-heading-01{
	font: 1.125rem /1.5 "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "游明朝", YuMincho, "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
	padding-bottom: 13px;
	border-bottom: 1px solid #bfa77a;
	font-weight: 700;
}
.sideNav-list-01 li,
.sideNav-list-01 a{
	font-size: 0.875rem;
}
.sideNav-list-01 .parent span,
.sideNav-list-01 .child span{
	display: block;
	width: 100%;
	border-bottom: 1px dashed #ccc;
	position: relative;
}
.sideNav-list-01 .parent span{
	padding: 18px 54px 18px 32px;
}
.sideNav-list-01 .child span{
	padding: 10px 54px 10px 32px;
	padding-left: 32px;
	font-size: 0.75rem;
}
.sideNav-list-01 a{
	display: block;
}
.sideNav-list-01 .parent span::after,
.sideNav-list-01 .child span::after{
	content: "";
	position: absolute;
	top: 0;
	bottom: 0;
	right: 12px;
	margin: auto;
	width: 6px;
	height: 6px;
	border-top: 1px solid #333;
	border-right: 1px solid #333;
	transform: rotate(45deg);
}
.sideNav-list-01.sideNav-list-01_hasAaccordion .parent > li > span::after{
		transform: rotate(135deg);
		transition: all 0.5s;
}
.sideNav-list-01.sideNav-list-01_hasAaccordion .parent > li > span.rotate::after{
		transform: rotate(45deg);
}
.sideNav-list-01 .child{
	display: none;
}
.sideNav-list-01 .parent > li > span.active{
	background-color: #eee;
}



/* レイアウト */
.sideNav-bnr-area{
	margin-bottom: 32px;
}
.sideNav-bnr-01-wrapper{
	margin-bottom: 16px;
}
.sideNav-list-01{
	margin-bottom: 54px;
}


/*--------------------------------------------
	$Topへ戻る
--------------------------------------------*/
#scrollTop{
	position: fixed;
	display: none;
	right: 14px;
	bottom: 14px;
	width: 55px;
	height: 55px;
	background-color: #c2ab81;
	color: #fff;
	border-radius: 4px;
	cursor: pointer;
	transition: initial;
}
#scrollTop::before{
	content: "";
	position: absolute;
	top: 14px;
	left: 22px;
	display: block;
	width: 8px;
	height: 8px;
	border-top: 2px solid #fff;
	border-left: 2px solid #fff;
	transform: rotate(45deg);
}
#scrollTop::after{
	content: "TOPへ";
	display: inline-block;
	position: absolute;
	left: 7px;
	bottom: 8px;
	font-size: 0.88rem;
	font-weight: 700;
	color: #fff;
}
#scrollTop:hover{
	text-decoration: none;
	opacity: 0.8;
}
		@media only screen and (max-width: 768px) {
			#scrollTop{
				background-color: #83704c;
				opacity: 0.8;
			}
		}/* end media query */


/*--------------------------------------------
	$オフキャンバスメニュー用閉じるボタン・オーバーレイ
--------------------------------------------*/
#closeOffcanvas{
	position: fixed;
	top: 0;
	right: -88%;
	display: block;
	background-color: #644c1f;
	width: 45px;
	height: 45px;
	z-index: 501;
	transition: all 0.7s;
}
#closeOffcanvas span{
	position: absolute;
	font-size: 11px;
	font-weight: 700;
	color: #fff;
	text-align: center;
	left: 0;
	right: 0;
	bottom: 3px;
}
#closeOffcanvas::before,
#closeOffcanvas::after{
	content: "";
	position: absolute;
	display: inline-block;
	width: 16px;
	height: 16px;
	transform: rotate(45deg);
}
#closeOffcanvas::before{
	border-top: 2px solid #fff;
	margin: 10px 0 0 9px;
}
#closeOffcanvas::after{
	border-right: 2px solid #fff;
	margin: 0 0 0 8px;
}
#overlay{
	position: absolute;
	top: 0;
	bottom: 0;
	display: none;
	width: 100%;
	height: 100%;
	background-color: rgba(0,0,0,0.5);
	z-index: 500;
	transition: all 0.5s;
}




/* ***************************************************************************************************** */
/* ** $汎用 ******************************************************************************************* */
/* ***************************************************************************************************** */
.dn{
	display: none;
}

/* スマホのみクリック可能な要素に付与 */
.spLink{
	pointer-events: none;
	display: inherit;
	position: inherit;
	color: inherit;
	font-size: inherit;
	font-weight: inherit;
	font-style: inherit;
	cursor: default;
}
		@media only screen and (max-width: 768px){
			.spLink{
				pointer-events: unset;
				cursor: unset;
			}
		}

/* PCのみ表示させるテキストに付与 */
.textVisible-PC{
	display: inherit;
	position: inherit;
	color: inherit;
	font-size: inherit;
	font-weight: inherit;
	font-style: inherit;
	cursor: inherit;
}
		@media only screen and (max-width: 768px){
			.textVisible-PC{
				display: none;
			}
		}

/* PCのみ表示させる要素に付与 */
.elemVisible-PC{
	display: unset;
}
		@media only screen and (max-width: 768px){
			.elemVisible-PC{
				display: none;
			}
		}

/* SPのみ表示させるテキストに付与 */
.textVisible-SP{
	display: none;
}
		@media only screen and (max-width: 768px){
			.textVisible-SP{
				display: inherit;
				position: inherit;
				color: inherit;
				font-size: inherit;
				font-weight: inherit;
				font-style: inherit;
				cursor: inherit;
			}
		}

/* SPのみ表示させる要素に付与 */
.elemVisible-SP{
	display: none;
}
		@media only screen and (max-width: 768px){
			.elemVisible-SP{
				display: unset;
			}
		}

/* 改行_PCのみ */
@media only screen and (max-width: 768px){
br.pc,.pcBnr{
	display: none;
}
}
@media only screen and (min-width: 767.9px){
.spBnr{
	display: none;
}
}
/* 改行_SPのみ */
br.sp{
	display: none;
}
@media only screen and (max-width: 768px){
br.sp,.spBnr{
	display: block;
}
}

/* 小さいデバイス用調整 */
@media only screen and (max-width: 370px) {
		html, body{
			font-size: 14px;
		}
}

/* Clearfix */
.clearfix::before,
.clearfix::after,
.cf::before,
.cf::after{
	content:"";
	display:table;
	clear:both;
}

/* SPのみclear fix */
@media only screen and (max-width: 768px) {
	.clearfix-sp:before,
	.cf-sp:before,
	.clearfix-sp:after,
	.cf-sp:after {
	content:"";
	display:table;
	}
	.clearfix-sp:after,
	.cf-sp:after {
	clear:both;
	}
}

/* スクロールバー非表示 */
.hideScrollbar{
	-ms-overflow-style:none;
}
.hideScrollbar::-webkit-scrollbar{
	display: none;
}

/* スライダー用クラス */
/*
.js-slide-displayArea::-webkit-scrollbar{
	display: none;
}
.js-slide-displayArea{
	-ms-overflow-style:none;
}
*/


/* ***************************************************************************************************** */
/* ** 個別ページ *************************************************************************************** */
/* ***************************************************************************************************** */

/*商品ページ販売期間*/
div.salesPeriodEndItemWrap {
    border: 1px solid;
    border-radius: 10px;
    padding: 5px 10px;
    display: inline-block;
    margin-bottom: 1em;
    background: #f5eee0;
}


/*メンテナンス*/
#systemError.maintenance .contents {
	height: calc(100vh - 310px);
}
#systemError.maintenance .errorMessage .mainText {
	font-size: 1.6em;
}
#systemError.maintenance .footer-copyright img{
	margin-top: 12px;
}
@media only screen and (max-width: 768px) {
	#systemError.maintenance .contents {
		height: calc(100vh - 100px);
		margin-bottom: 0;
	}
	#systemError.maintenance footer {
		position: absolute;
		bottom: 0;
	}
	#systemError.maintenance .footer-copyright img{
		margin: 12px auto 10px;
	}
}
@media only screen and (max-width: 641px) {
	#systemError.maintenance .contents .topGroupName {
		width: 100%;
	}
}


/* 汎用アコーディオン */
.accordionParent{
}
*[class*="accordionHeading-"]{
 position: relative;
 padding-right: 32px;
 cursor: pointer;
}
*[class*="accordionHeading-"].accordionIcon{
  padding-right: 32px!important;
  cursor: pointer;
}
*[class*="accordionHeading-"].accordionIcon::after{
 content: "";
 position: absolute;
 background: no-repeat right center/100% url(../images/common/icon-plus-dark.svg);
 opacity: 0.5;
 width: 16px;
 height: 16px;
 right: 0;
 top: 0;
 bottom: 0;
 margin: auto;
}
*[class*="accordionHeading-"].accordionIcon.accordionIcon--close::after{
  background: no-repeat right center/100% url(../images/common/icon-minus-dark.svg);
}
*[class*="accordionContent-"]{
display: none;
}