@charset "utf-8";
/* CSS関数設定 */
:root{
	/* カラーパレット */
	--WHITE: #fff;
	--WHITE_OP70: rgba(255, 255, 255, 0.7);
	--WHITE_OP50: rgba(255, 255, 255, 0.5);
	--BLACK: #000;
	--BLACK02: #212121;
	--BLACK02_OP20: rgba(33, 33, 33, 0.2);
	--BLACK_OP30: rgba(0, 0, 0, 0.3);
	--BLACK_OP50: rgba(0, 0, 0, 0.5);
	--BLACK_OP60: rgba(0, 0, 0, 0.6);
	--GRAY01: #F0F0F0;
	--GRAY02: #D1D1D1;
	--GRAY03: #A5A5A5;
	--GRAY03_OP15: rgba(165, 165, 165, 0.15);
	--GRAY04: #707070;
	--GRAY05: #D1D1D1;
	--GRAY06: #B9B9B9;
	--GRAY07: #FBFBFB;
	--DARK01: #212121;
	--DARK01_OP20: rgba(33, 33, 33, 0.2);
	--DARK01_OP50: rgba(33, 33, 33, 0.5);
	--DARK01_OP60: rgba(33, 33, 33, 0.6);
	--DARK01_OP70: rgba(33, 33, 33, 0.7);
	--DARK01_OP80: rgba(33, 33, 33, 0.8);
	--DARK02: #474645;
	--GOLD01: #A39C88;
	--GOLD01_OP15: rgba(163, 156, 136, 0.15);
	--GOLD02: #B4A582;
	--RED01: #B80033;
	--RED02: #67001D;
	/* ランキングカラー */
	--RANKING_1ST: #be9640;
	--RANKING_2ND: #949393;
	--RANKING_3RD: #bf804c;
	--RANKING_OTHER: #4d4c4b;
	/* テキストベースカラー */
	--TXT_COLOR: var(--DARK01);
	/* 共通角丸 */
	--COMMON_BDRS: 5px;
	/* 共通ボックス影 */
	--COMMON_BXSD: 0px 0px 15px -5px #919191;
  /* ベースフォント */
  --FF_BASE: 'Noto Sans JP',"游ゴシック", YuGothic, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, sans-serif;
  /* Montserrat */
  --FF_MONT: 'Montserrat', sans-serif;
	/* 明朝体 */
	--FF_MINCHO: 'Noto Serif JP', serif;
	/* 英数字フォント */
	--FF_NUM: 'Noto Sans JP', serif;
	--FF_EN: 'Noto Sans JP', serif;
	/* アニメーション */
	--ANIME_FADEIN: fadeIn .5s ease-in-out .6s forwards;
}
@media screen and (min-width: 768px){
	:root{
		/* フォトサイズ */
		--FZ_SS: 12px;
		--FZ_S: 14px;
		--FZ_M: 16px;
		--FZ_L: 18px;
		/* セクション余白 */
		--GENERALSEC: 100px;
		/* マージン */
		--MG_S: 20px;
		--MG_MM: 50px;
		--MG_M: 60px;
		--MG_L: 100px;
		/* インナー幅 */
		--INNER_WIDTH: 95%;
		--MAX_WIDTH: 1200px;
	}
}
@media screen and (max-width: 767px){
	:root{
		/* フォトサイズ */
		--FZ_SS: 12px;
		--FZ_S: 14px;
		--FZ_M: 16px;
		--FZ_L: 18px;
		/* セクション余白 */
		--GENERALSEC: 60px;
		/* マージン */
		--MG_SS: 10px;
		--MG_S: 20px;
		--MG_MM: 30px;
		--MG_M: 50px;
		--MG_L: 100px;
		/* インナー幅 */
		--INNER_WIDTH: 93%;
	}
}
/* リセットCSS */
*{margin:0;padding:0;min-height: 0;min-width: 0;-webkit-box-sizing: border-box;-moz-box-sizing: border-box;box-sizing: border-box;}
html {
	height:100%;
	scroll-behavior: smooth;
}
html.no-smooth-scroll {
	scroll-behavior: auto;
}
ul li ,ol li{list-style:none;}
h1,h2,h3,h4,h5,h6{font-weight: normal;font-size: 100%;margin: 0;}
p{margin: 0;}
a:focus, *:focus{ outline:none; }
article, header, footer, aside, figure, figcaption, nav, section,main{ 
  display:block;
}
body{
	font-family: var(--FF_BASE);
	font-weight: 400;
	font-feature-settings: "palt" 1;
	letter-spacing: 0.06em;
	width:100%;
	color: var(--TXT_COLOR);
	position:relative;
	z-index: 0;
}
a{
	text-decoration: none;
	outline: none;
	word-wrap: break-word;
	color: var(--TXT_COLOR);
}
a img,a{
	-webkit-transition: all 0.5s ease;
	-moz-transition: all 0.5s ease;
	-o-transition: all 0.5s ease;
	transition: all  0.5s;
}
img{
	height: auto;
	max-width: 100%;
	box-sizing: unset;
	vertical-align: bottom;
}
iframe{
	vertical-align: bottom;
}
.form-reset button,
.form-reset input[type="button"],
.form-reset input[type="submit"],
.form-reset input[type="text"],
.form-reset input[type="image"],
.form-reset input[type="checkbox"],
.form-reset select{
	background-color: unset;
	color: var(--TXT_COLOR);
	-webkit-appearance: none;
	border-radius: 0;
	border: none;
}
input[type="text"],
input[type="text"]::placeholder{
	font-family: var(--FF_BASE);
}
/* フォントCSS */
.mincho{
	font-family: 'Yu Mincho Light','YuMincho','Yu Mincho','游明朝体','ヒラギノ明朝 ProN','Hiragino Mincho ProN','ヒラギノ明朝 ProN','Hiragino Mincho ProN',sans-serif;
}
.soure_sans{
	font-family: 'Source Sans 3', sans-serif;
}
time{
	font-family: var(--FF_NUM);
}
/* imgリセット */
.imgauto{
	height: auto;
	width: 100%;
	box-sizing: unset;
	line-height: 1rem;
	display: block;
}
/* セクション間隔*/
.generalmg{
	margin-bottom: var(--GENERALSEC);
}
.generalpd{
	padding: var(--GENERALSEC) 0;
}
/* グリッド、フレックス */
.grid{
	display: grid;
}
.flex{
	display: flex;
}
.fxw{
	display: flex;
	flex-wrap: wrap;
}
.jcsb{
	display: flex;
	justify-content: space-between;
}
/* スライダー読み込みまで非表示 */
.slick{
	opacity: 0;
	transition: opacity .3s linear;
}
.slick.slick-initialized{
	opacity: 1;
}
.swiper{
	overflow: hidden;
  opacity: 0;
	transition: opacity .3s linear;
}
.swiper.swiper-initialized{
	opacity: 1;
}
/* 縦書き */
.tategaki{
	writing-mode: vertical-rl;
}
/* タイトルの文字間 */
[class*="ttl"]{
  letter-spacing: 0.1em;
}
/* テキスト行間 */
[class*="txt"],
[class*="excerpt"]{
  line-height: 2;
}
/* フェードインアニメーション */
@keyframes fadeIn {
	0% {
		opacity: 0;
	}
	100% {
		opacity: 1;
	}
}
.display-none{
	display: none;
}
@media screen and (min-width: 1001px){
	.media1000{
		display: none;
	}
}
@media screen and (min-width: 768px){
	html{
		scroll-padding-top: 200px;
	}
	body{
		font-size: 15px;
		line-height: 1.7;
		-ms-text-size-adjust: 100%;
		-webkit-text-size-adjust: 100%;
	}
	.form-reset button:hover,
	.form-reset input[type="button"]:hover,
	.form-reset input[type="submit"]:hover,
	.form-reset input[type="image"]:hover,
  .form-reset input[type="checkbox"]:hover,
	.form-reset select:hover{
		cursor: pointer;
	}
	a:hover{
		opacity: 0.7;
		text-decoration: none;
	}
	a:hover img{
		opacity:0.9 !important;
	}
	a[href^="tel:"] {
		pointer-events: none;
	}
	.max-wrapper{
		max-width: 1440px;
		margin-left: auto;
		margin-right: auto;
	}
	.inner,
	.pc-inner{
		width: var(--INNER_WIDTH);
		max-width: var(--MAX_WIDTH);
		margin-left: auto;
		margin-right: auto;
	}
	.sp{
		display: none !important;
	}
	.hamburger{
		display: none !important;
	}
	.pc-tategaki{
		writing-mode: vertical-rl;
	}
	/* pc順番付与 */
	.pc-order-1st { order: 1; }
	.pc-order-2nd { order: 2; }
	.pc-order-3rd { order: 3; }
	.pc-order-4th { order: 4; }
	.pc-order-5th { order: 5; }
	.pc-order-6th { order: 6; }
	.pc-order-7th { order: 7; }
	.pc-order-8th { order: 8; }
	.pc-order-9th { order: 9; }
	.pc-order-10th { order: 10; }
}
@media screen and (max-width: 767px){
	html{
		scroll-padding-top: 20px;
	}
	body{
		font-size: 14px;
		line-height: 1.6;
	}
	.inner,
	.sp-inner{
		width: var(--INNER_WIDTH);
		margin-left: auto;
		margin-right: auto;
	}
	.pc{
		display: none !important;
	}
	.sp-y-scroll{
		overflow-y: scroll;
		overflow-x: auto;
	}
	.sp-x-scroll{
		overflow-x: scroll;
		overflow-y: auto;
		padding-left: calc((100% - var(--INNER_WIDTH)) / 2);
		padding-right: calc((100% - var(--INNER_WIDTH)) / 2);
	}
	.sp-y-scroll.noscrollbar,
	.sp-x-scroll.noscrollbar{
		-ms-overflow-style: none;/* IE, Edge 対応 */
		scrollbar-width: none;/* Firefox 対応 */
	}
	.sp-y-scroll.noscrollbar::-webkit-scrollbar,
	.sp-x-scroll.noscrollbar::-webkit-scrollbar{/* Chrome, Safari 対応 */
		display: none;
	}
	.sp-pc-tategaki{
		writing-mode: vertical-rl;
	}
}
/* ■■■■■■■■■■■■■■■■■■■■■■header■■■■■■■■■■■■■■■■■■■■■■ */
body.scroll #headerarea{
	min-height: unset;
}
/* ヘッダー導入 */
.h-notice,
.h-notice a{
	color: var(--WHITE);
	letter-spacing: 0.1em;
}
.h-member-area{
	color: var(--WHITE);
}
@media screen and (min-width: 768px){
	.h-inner{
		width: 95%;
		max-width: 1440px;
		margin-left: auto;
		margin-right: auto;
	}
	.h-label-area{
		background: linear-gradient(to right, var(--DARK01) 50%, var(--GRAY03) 50%);
	}
	.h-label-area .h-inner{
		display: flex;
		align-items: center;
		height: 45px;
	}
	.wp-h-hotice{
		background-color: var(--DARK01);
		height: 100%;
		display: flex;
		align-items: center;
		flex: 1;
	}
	.h-notice,
	.h-notice a{
		font-size: 16px;
	}
	.h-member-area{
		padding: var(--H_LABEL_PADDING);
		width: fit-content;
		padding-left: 8%;
		font-size: 14px;
		height: 100%;
		display: flex;
		align-items: center;
	}
	.h-guide{
		display: flex;
		justify-content: flex-end;
		gap: 40px;
	}
	.h-guide li a{
		display: block;
		font-size: 12px;
		padding: 8px 0;
	}
}
@media screen and (max-width: 767px){
	.h-notice{
		background-color: var(--DARK01);
		text-align: center;
		padding: 5px 8px;
	}
	.h-notice,
	.h-notice a{
		font-size: 14px;
	}
}
/* ヘッダー上部 */
.h-logo-area .position{
	text-align: center;
	font-family: var(--FF_MONT);
	color: var(--DARK02);
	letter-spacing: 0.1em;
}
.h-logo-area .position .current{
	color: var(--RED01);
	display: inline-block;
}
.h-logo-area .position .current::before{
	content: "/";
	font-weight: 100;
	font-style: italic;
	display: inline-block;
	color: var(--DARK02);
	margin: 0 5px;
}
.fs-search-form{
	position: relative;
}
.fs-search-form input[type="text"]{
	color: var(--DARK01_OP60);
	letter-spacing: 0.1em;
	background-color: var(--GRAY01);
	border-radius: 70px;
	display: block;
	width: 100%;
}
.fs-search-form input[type="text"]::placeholder{
	color: var(--DARK01_OP60);
	letter-spacing: 0.1em;
}
.fs-search-form button{
	mask: url(../images/common/ks_top_menu_search.svg) no-repeat center center / 100%;
	-webkit-mask: url(../images/common/ks_top_menu_search.svg) no-repeat center center / 100%;
	aspect-ratio: 1/1;
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
}
@media screen and (min-width: 1201px){
	.h-top-area{
		position: relative;
	}
	.h-logo-area{
		width: 280px;
		position: absolute;
		top: 27%;
		left: 50%;
		transform: translate(-50%, -50%);
		transition: .3s;
	}
	body.scroll .h-logo-area{
		width: 250px;
		top: 50%;
	}
}
@media screen and (min-width: 768px) and (max-width: 1200px){
	.h-logo-area{
		width: 230px;
	}
	body.scroll .h-logo-area{
		width: 180px;
	}
	.h-search-form{
		margin-left: auto;
	}
}
@media screen and (min-width: 768px){
	#headerarea{
		width: 100%;
		background-color: var(--WHITE);
		position: sticky;
		top: 0;
		left: 0;
		z-index: 99;
	}
	body.scroll #headerarea{
		box-shadow: var(--COMMON_BXSD);
	}
	.h-top-area{
		height: 90px;
		display: flex;
		justify-content: flex-end;
		align-items: center;
	}
	body.scroll .h-top-area{
		height: 77px;
	}
	.h-logo-area{
		transition: .3s;
	}
	.h-logo-area .logo{
		margin-bottom: 8px;
	}
	.h-logo-area .position{
		font-size: 12px;
		transition: .3s;
	}
	body.scroll .h-logo-area .position{
		font-size: 10px;
	}
	.h-search-form{
		width: 262px;
	}
	.h-search-form input[type="text"]{
		padding: 12px 40px 12px 20px;
	}
	.h-search-form button{
		width: 18px;
		background-color: var(--DARK01);
		right: 15px;
	}
	.h-user{
		display: flex;
		width: fit-content;
		margin-left: 30px;
		gap: 16px;
	}
	.h-user li a{
		display: block;
		background: no-repeat top center / 20px;
		padding-top: 25px;
		font-size: 12px;
	}
	.h-user li.cart a{
		position: relative;
	}
	.h-user li.cart a .fs-client-cart-count{
		top: -10px;
		right: -5px;
	}
}
@media screen and (max-width: 767px){
	.h-logo-area{
		width: 285px;
		margin: 10px auto;
	}
	.h-search-form input[type="text"]{
		padding: 15px 40px 15px 20px;
	}
	.h-search-form button{
		width: 18px;
		background-color: var(--DARK01);
		right: 15px;
	}
}
/* グローバルナビ */
.gnav{
	background-color: var(--GRAY01);
}
.gnav > .h-inner{
	display: flex;
}
.h-nav{
	display: flex;
	width: fit-content;
}
.h-nav > li > a{
	display: block;
	color: var(--WHITE);
	background-color: var(--GOLD01);
	text-align: center;
}
.h-hot-word{
	flex: 1;
	display: flex;
	align-items: center;
}
.h-hot-word li{
	min-width: fit-content;
}
.h-hot-word li a::before{
	content: '#';
	color: var(--RED01);
}
@media screen and (min-width: 1201px){
	.h-nav > li > a{
		width: 180px;
	}
}
@media screen and (min-width: 768px) and (max-width: 1200px){
	.gnav .h-inner{
		width: 100%;
	}
	.h-nav > li > a{
		width: 140px;
	}
}
@media screen and (min-width: 768px){
	.gnav{
		position: relative;
	}
	.gnav > .h-inner{
		position: relative;
	}
	.gnav > .h-inner::after{
		content: "";
		right: 0;
		width: 6.25rem;
		height: 100%;
		position: absolute;
		background: linear-gradient(270deg,var(--GRAY01) 21.11%,hsla(0,0%,100%,0) 107.22%);
		z-index: 10;
		top: 0;
	}
	.gnav > .h-inner::before{
		content: "";
		display: inline-block;
		mask: url(../images/common/ks_arrow.svg) no-repeat center center / 100%;
		-webkit-mask: url(../images/common/ks_arrow.svg) no-repeat center center / 100%;
		aspect-ratio: 1/1;
		background-color: var(--DARK01);
		position: absolute;
		top: 50%;
		transform: translateY(-50%);
		width: 12px;
		right: 0px;
		z-index: 11;
	}
	.h-nav{
		gap: 2px;
	}
	.h-nav > li > a{
		padding: 10px 0;
	}
	.h-nav > li[ontouchstart] > a{
		display: flex;
		align-items: center;
		justify-content: center;
		gap: 5px;
	}
	.h-nav > li[ontouchstart] > a span{
		display: inline-block;
		width: 15px;
		aspect-ratio: 1/1;
		background-color: var(--WHITE);
		border-radius: 50%;
		margin-top: 2px;
		position: relative;
	}
	.h-nav > li[ontouchstart] > a span::after{
		content: "";
		display: inline-block;
		mask: url(../images/common/ks_top_menu_arrow.svg) no-repeat center center / 100%;
		-webkit-mask: url(../images/common/ks_top_menu_arrow.svg) no-repeat center center / 100%;
		background-color: var(--GOLD01);
		width: 12px;
		aspect-ratio: 1/1;
		position: absolute;
		top: 50%;
		left: 50%;
		transform: translate(-50%, -50%);
	}
	.h-hot-word{
		gap: 30px;
		overflow-x: scroll;
		padding-left: 30px;
		position: relative;
		padding-right: 50px;
	}
	.h-hot-word::-webkit-scrollbar{/* Chrome, Safari 対応 */
		height: 5px;
	}
	.h-hot-word::-webkit-scrollbar:hover{
		cursor: pointer;
	 }
	.h-hot-word::-webkit-scrollbar-thumb{
		background-color: #ccc;
 	}
	.hvr-show{
		pointer-events: none;
		visibility: hidden;
		opacity: 0;
		z-index: -1;
		transition: .3s;
		padding-top: 9px;
		position: absolute;
		z-index: 1;
		width: 100%;
		top: calc(100% - 9px);
		left: 0;
	}
	.h-nav > li:hover .hvr-show{
		pointer-events: auto;
		visibility: visible;
		opacity: 1;
		z-index: 99;
	}
	.hvr-contents{
		background-color: var(--GRAY01);
		box-shadow: 0px 11px 15px -10px #a3a2a2;
		padding: 50px;
	}
	.hvr-box{
		max-height: calc(100vh - 350px);
		overflow-y: scroll;
	}
	.brand-link{
		display: grid;
	}
	.hvr-box .brand-link{
		grid-template-columns: repeat(3,1fr);
	}
	.hvr-link{
		gap: 10px;
	}
	.hvr-link li a{
		display: flex;
		align-items: center;
		justify-content: center;
		height: 100%;
		text-align: center;
		border: 1px solid var(--GRAY05);
		background-color: var(--WHITE);
		padding: 12px 5px;
		font-size: clamp( 11px, 1vw, 13px);
	}
	.hvr-link li a:hover{
		opacity: 1;
		background-color: var(--GOLD01);
		color: var(--WHITE);
	}
	.scene-link{
		display: grid;
	}
	.hvr-box .scene-link{
		grid-template-columns: repeat(6,1fr);
		gap: 40px 20px;
	}
	.hvr-box .scene-link li a{
		display: flex;
		flex-direction: column;
		justify-content: center;
		text-align: center;
		font-size: 13px;
	}
	.hvr-box .scene-link li a span{
		display: inline-block;
		aspect-ratio: 1/1;
		width: 100%;
		max-width: 80px;
		margin: 0 auto 10px;
		border-radius: 50%;
		background: no-repeat center center / 100%;
	}
	.hvr-gift-bnr{
		width: 100%;
		max-width: 900px;
		margin: 0 auto 30px;
		grid-template-columns: repeat(2,1fr);
		gap: 20px;
	}
	.gift-link-area{
		gap: 40px;
	}
	.hvr-gift-ttl{
		font-size: 18px;
		line-height: 1;
		padding: 5px 0 5px 15px;
		border-left: 5px solid var(--RED02);
		margin-bottom: 10px;
	}
	.gift-link{
		grid-template-columns: repeat(5,1fr);
	}
}
@media screen and (max-width: 767px){
	.gnav{
		margin-top: 20px;
		position: relative;
	}
	.gnav::after{
		content: "";
		right: 0;
		width: 6.25rem;
		height: 100%;
		position: absolute;
		background: linear-gradient(270deg,var(--GRAY01) 21.11%,hsla(0,0%,100%,0) 107.22%);
		z-index: 10;
		top: 0;
	}
	.gnav::before{
		content: "";
		display: inline-block;
		mask: url(../images/common/ks_arrow.svg) no-repeat center center / 100%;
		-webkit-mask: url(../images/common/ks_arrow.svg) no-repeat center center / 100%;
		aspect-ratio: 1/1;
		background-color: var(--DARK01);
		position: absolute;
		top: 50%;
		transform: translateY(-50%);
		width: 13px;
		right: 2px;
		z-index: 11;
	}
	.gnav > .h-inner{
		overflow-x: scroll;
	}
	.gnav > .h-inner::before{
		width: 13px;
		right: 3px;
	}
	.h-nav{
		gap: 2px;
	}
	.h-nav > li > a{
		width: 80px;
		padding: 8px 0;
		font-size: 13px;
	}
	.h-hot-word{
		padding: 0 50px 0 20px;
		font-size: 13px;
	}
	.h-hot-word li{
		padding-right: 15px;
	}
	.h-hot-word li:last-child{
		padding-right: 50px;
	}
}
/* ■■■■■■■■■■■■■■■■■■■■■■footer■■■■■■■■■■■■■■■■■■■■■■ */
.f-btn{
	display: grid;
}
.f-btn li a{
	background-color: var(--WHITE);
	font-family: var(--FF_MINCHO);
	display: block;
	text-align: center;
}
.f-btn li.cart a{
	position: relative;
}
.f-btn li.showroom a{
	background-color: var(--DARK01);
	color: var(--WHITE);
}
.f-btn li.contact a{
	background-color: var(--GOLD01);
	color: var(--WHITE);
}
.f-bottom-area{
	background-color: var(--DARK01);
}
.f-end-link li a{
	color: var(--WHITE);
}
.f-sns{
	display: flex;
}
.f-sns li a{
	mask: no-repeat center center / 100%;
	-webkit-mask: no-repeat center center / 100%;
	display: block;
	aspect-ratio: 1/1;
	background-color: var(--WHITE);
}
.f-copy{
	text-align: center;
	color: var(--WHITE);
}
.f-logo .position{
	color: var(--WHITE);
	text-align: center;
	font-family: var(--FF_MONT);
	letter-spacing: 0.1em;
}
@media screen and (min-width: 1201px){
	.f-btn{
		width: 90%;
	}
}
@media screen and (min-width: 768px) and (max-width: 1200px){
	.f-cat-link-area{
		display: none;
	}
	.f-page-link-area{
		grid-column: 1/3;
		margin: 0 auto;
	}
}
@media screen and (min-width: 768px){
	.f-top-area{
		background-color: var(--GRAY01);
	}
	.f-top-area .inner{
		display: grid;
		grid-template-columns: repeat(2,1fr);
		gap: 80px 40px;
	}
	.f-nav-ttl{
		font-size: 14px;
		font-weight: 500;
		border-bottom: 1px solid var(--GRAY02);
		padding: 10px 0;
	}
	.f-cat-link{
		margin-top: 20px;
	}
	.f-cat-link li{
		display: grid;
		gap: 8px;
		grid-template-columns: repeat(3,auto);
		align-items: flex-start;
	}
	.f-cat-link li a{
		display: block;
		font-size: 12px;
	}
	.f-page-link-top{
		display: grid;
		grid-template-columns: repeat(2,1fr);
		column-gap: 35px;
	}
	.f-page-link-bottom{
		display: grid;
		grid-template-columns: repeat(2,1fr);
		column-gap: 35px;
		margin-top: 60px;
	}
	.f-page-link-bottom li{
		display: grid;
		grid-template-columns: repeat(2,1fr);
	}
	.f-btn{
		grid-column: 1/3;
		grid-template-columns: repeat(5,1fr);
		gap: var(--MG_S);
		margin: 0 auto;
	}
	.f-btn li a{
		padding: 10px 0;
	}
	.f-btn li.cart a .fs-client-cart-count{
		top: 50%;
		transform: translateY(-50%);
		right: 10px;
	}
	#footerarea .f-btn li a{
		border: 1px solid var(--WHITE);
	}
	.f-btn li a:hover{
		opacity: 1;
		background-color: var(--DARK01);
		color: var(--WHITE);
	}
	.f-btn li.contact a:hover{
		background-color: var(--GOLD01);
    filter: brightness(0.8);
	}
	.f-bottom-flex{
		display: flex;
		align-items: center;
		padding: 20px 0;
	}
	.f-logo{
		width: 200px;
	}
	.f-bottom-right{
		margin-left: auto;
		display: grid;
		gap: 30px;
	}
	.f-end-link{
		display: flex;
		gap: 30px;
	}
	.f-end-link li a{
		font-size: 12px;
	}
	.f-sns{
		justify-content: flex-end;
		gap: var(--MG_S);
	}
	.f-sns li{
		width: 26px;
	}
	.f-sns li a:hover{
		opacity: 1;
		background-color: var(--GOLD01);
	}
	.f-copy{
		font-size: 12px;
		padding: 50px 0 20px;
	}
}
@media screen and (max-width: 767px){
	.f-bottom-area{
		padding: var(--GENERALSEC) 0 100px;
	}
	.f-logo{
		width: 200px;
		margin: 0 auto;
	}
	.f-btn{
		width: 200px;
		margin: var(--MG_M) auto;
		gap: var(--MG_S);
	}
	.f-btn li a{
		padding: 10px 0;
	}
	.f-end-link{
		display: flex;
		justify-content: center;
		flex-direction: column;
		gap: 10px;
		margin-bottom: 30px;
	}
	.f-end-link li{
		text-align: center;
	}
	.f-sns{
		justify-content: center;
		gap: var(--MG_S);
	}
	.f-sns li{
		width: 26px;
	}
	.f-sns li a:hover{
		opacity: 1;
		background-color: var(--GOLD01);
	}
	.f-copy{
		font-size: 12px;
		padding: 50px 0 20px;
	}
}
/* トップに戻る */
.to-top{
	position: fixed;
	aspect-ratio: 1/1;
}
.to-top a{
	display: block;
	height: 100%;
	background: url(../images/common/ks_upmark.svg) no-repeat center center / 100%;
	border: 1px solid var(--WHITE);
	border-radius: 50%;
}
@media screen and (min-width: 768px){
	.to-top{
		width: 50px;
		bottom: 30px;
		right: 30px;
		z-index: 99;
	}
}
@media screen and (min-width: 768px) and (max-width: 1000px){
	body{
		--SP_FIXED_BTN_SIZE: 50px;
		--SP_FIXED_BTN_PS_X: calc((100% - var(--INNER_WIDTH)) / 2);
		--SP_FIXED_ICON_HEIGHT: 10px;
		--SP_FIXED_BTN_PS_Y: calc(var(--SP_FIXED_ICON_HEIGHT) + 10px);
		--SP_FIXED_SEARCH_PS_Y: calc(var(--SP_FIXED_BTN_PS_Y) + var(--SP_FIXED_BTN_SIZE) + 10px);
	}
	.to-top{
		width: var(--SP_FIXED_BTN_SIZE);
		bottom: var(--SP_FIXED_BTN_PS_Y);
		right: var(--SP_FIXED_BTN_PS_X);
		z-index: 99;
	}
}
@media screen and (max-width: 767px){
	body{
		--SP_FIXED_BTN_SIZE: 40px;
		--SP_FIXED_BTN_PS_X: calc((100% - var(--INNER_WIDTH)) / 2);
		--SP_FIXED_ICON_HEIGHT: 65px;
		--SP_FIXED_BTN_PS_Y: calc(var(--SP_FIXED_ICON_HEIGHT) + 10px);
		--SP_FIXED_SEARCH_PS_Y: calc(var(--SP_FIXED_BTN_PS_Y) + var(--SP_FIXED_BTN_SIZE) + 10px);
	}
	.to-top{
		width: var(--SP_FIXED_BTN_SIZE);
		bottom: var(--SP_FIXED_BTN_PS_Y);
		right: var(--SP_FIXED_BTN_PS_X);
		z-index: 99;
	}
}
/* sp検索 */
@media screen and (max-width: 1000px){
	.sp-fixed-search-trigger{
		position: fixed;
		bottom: var(--SP_FIXED_BTN_PS_Y);
		left: var(--SP_FIXED_BTN_PS_X);
		border: 1px solid var(--WHITE);
		border-radius: 50%;
		z-index: 99;
	}
	.sp-fixed-search-trigger{
		aspect-ratio: 1/1;
		background: url(../images/common/ks_sp_search.svg) no-repeat left center / calc((var(--SP_FIXED_BTN_SIZE)*2) - 4px);
		width: var(--SP_FIXED_BTN_SIZE);
	}
	.sp-fixed-search-trigger.active{
		background-position: right center;
	}
	.sp-fixed-search-form{
		display: none;
		position: fixed;
		bottom: var(--SP_FIXED_SEARCH_PS_Y);
		left: 50%;
		transform: translateX(-50%);
	}
	.sp-fixed-search-form input[type="text"]{
		background-color: var(--WHITE);
		box-shadow: var(--COMMON_BXSD);
	}
	.sp-fixed-search-form.active{
		display: block;
	}
}
/* spフッター固定 */
@media screen and (max-width: 767px){
	.sp-fixed-icon{
		background-color: var(--WHITE);
		width: 100%;
		position: fixed;
		bottom: 0;
		left: 0;
		z-index: 999;
		display: grid;
		grid-template-columns: repeat(5,1fr);
	}
	.sp-fixed-icon li a{
		display: block;
		height: var(--SP_FIXED_ICON_HEIGHT);
		background: no-repeat top 15px center / 20px;
		position: relative;
	}
	.sp-fixed-icon li a::after{
		content: attr(data-txt);
		display: block;
		width: 100%;
		text-align: center;
		font-size: 10px;
		position: absolute;
		left: 0;
		bottom: 10px;
	}
	.sp-fixed-icon .fs-client-cart-count{
		top: 5px;
		left: 55%;
	}
}
/* ■■■■■■■■■■■■■■■■■■■■■■side■■■■■■■■■■■■■■■■■■■■■■ */
@media screen and (min-width: 768px){
	.side-search-form{
		width: 100%;
		margin-bottom: 30px;
	}
	.side-search-form input[type="text"]{
		padding: 12px 36px 12px 13px;
		background-color: var(--WHITE);
		border-radius: 0;
		border: 1px solid var(--RED02);
		font-size: 13px;
	}
	.side-search-form button{
		width: 18px;
		background-color: var(--DARK01);
		right: 15px;
	}
	.side-bnr{
		display: grid;
		gap: 10px;
		margin-bottom: 30px;
	}
	.side-sec-area{
		display: grid;
		gap: 30px;
	}
	.side-ttl{
		background-color: var(--GOLD01);
		color: var(--WHITE);
		letter-spacing: 0.1em;
		padding: 8px 12px;
		margin-bottom: 10px;
	}
	.side-menu .img,
	.side-menu span{
		display: none !important;
	}
	.side-menu > ul,
	.side-menu .cat-list-thumb .name{
		display: contents;
		font-size: unset;
	}
	.itemList li:nth-of-type(n+10){
		display: none;
	}
	.side-menu li a{
		font-size: 13px;
		display: block;
		padding: 10px 0 10px 25px;
		position: relative;
		border-bottom: 1px solid var(--GRAY01);
	}
	.side-menu li a:hover{
		opacity: 1;
		background-color: var(--GOLD01_OP15);

	}
	.side-menu li a::before{
		font-family: 'Font Awesome 5 Pro';
		font-weight: 500;
		content: '\f105';
		font-size: 16px;
		position: absolute;
		left: 6px;
		top: 50%;
		transform: translateY(-50%);
		color: var(--GRAY03);
	}
	.form-reset button.toggleList{
		width: 100%;
		text-align: center;
		padding: 15px 0 5px 0;
		position: relative;
	}
	.form-reset button.toggleList span{
		position: relative;
		display: inline-block;
		padding-right: 20px;
	}
	.form-reset button.toggleList span::before{
		content: 'もっと見る';
		display: block;
		letter-spacing: 0.1em;
		font-size: 14px;
		color: var(--RED02);
	}
	.form-reset button.toggleList.active span::before{
		content: '閉じる';
	}
	.form-reset button.toggleList span::after{
		content: "";
		display: inline-block;
		mask: url(../images/common/ks_top_menu_arrow.svg) no-repeat center center / 100%;
		-webkit-mask: url(../images/common/ks_top_menu_arrow.svg) no-repeat center center / 100%;
		aspect-ratio: 1/1;
		background-color: var(--RED02);
		width: 20px;
		position: absolute;
		top: 50%;
		transform: translateY(-50%);
		right: 0;
	}
	.form-reset button.toggleList.active span::after{
		transform: translateY(-50%) rotate(180deg);
	}
	#sidearea .f-btn{
		grid-template-columns: repeat(1,1fr);
		gap: 10px;
		margin-top: 30px;
	}
	#sidearea .f-btn li a{
		border: 1px solid var(--DARK01);
	}

	#sidearea .f-btn li.contact a{
		border: 1px solid var(--GOLD01);
	}
}


/* ■■■■■■■■■■■■■■■■■■■■■■全ページ共通部分■■■■■■■■■■■■■■■■■■■■■■ */
/* -----------------タブ切り替え共通css----------------- */
.tab-nav{
	display: flex;
}
.tab-btn{
	flex: 1;
}
.tab-contents {
  height: 0;
  overflow: hidden;
  opacity: 0;
}
.tab-contents.show {
	cursor: auto;
  height: auto;
  overflow: unset;
  opacity: 1;
  transition: .5s opacity;
}
@media screen and (min-width: 768px){
	.tab-btn:hover{
		cursor: pointer;
	}
	.tab-btn.show{
		cursor: auto;
	}
}
/* -----------------ポップアップ共通css----------------- */
body.fixed {
	position: fixed;
	width: 100%;
	overflow: hidden;
}
.popup-overlay {
  display: none; 
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.7);
}
.popup-overlay.fixed{
  position: fixed;
  top: 0;
  left: 0;
  z-index: 9999;
}
.popup-content {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  background-color: var(--WHITE);
  box-shadow: 0px 0px 10px rgba(0, 0, 0, 0.3);
}
.popup-overlay .popup-box{
	overflow-y: scroll;
}
.popup-overlay button.closePopup{
	position: absolute;
	aspect-ratio: 1/1;
	border-radius: 50%;
	border: 1px solid #fff;
	background-color: var(--TXT_COLOR);
	top: 0;
	right: 0;
	transform: translate(50%, -50%);
}
.popup-overlay button.closePopup::before{
	font-family: 'Font Awesome 5 Pro';
	font-weight: 500;
	content: '\f00d';
	display: block;
	line-height: 1;
	height: 1em;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	color: #fff;
}
@media screen and (min-width: 768px){
	.popup-overlay .popup-content{
		width: 95%;
		max-width: 900px;
	}
	.popup-overlay .popup-box{
		padding: 50px 30px;
		max-height: 90vh;
	}
	.popup-overlay button.closePopup{
		width: 40px;
	}
	.popup-overlay button.closePopup::before{
		font-size: 23px;
	}
}
@media screen and (max-width: 767px){
	.popup-overlay .popup-content{
		width: 90%;
	}
	.popup-overlay .popup-box{
		padding: 30px 15px;
		max-height: 80vh;
	}
	.popup-overlay button.closePopup::before{
		font-size: 23px;
	}
	.popup-overlay button.closePopup{
		width: 30px;
	}
	.popup-overlay button.closePopup::before{
		font-size: 18px;
	}
}
/* -----------------フューチャー調整CSS----------------- */
/* 内部の色設定 */
:root{
	--WISH_COLOR: #d42929;
	--FS_BTN_COLOR_1: var(--GOLD01);
	--FS_BTN_COLOR_2: var(--DARK01);
	--REVIEW_COLOR: #edc622;
}
/* 内部幅設定 */
#wrapper{
	margin-left: auto;
	margin-right: auto;
	width: var(--INNER_WIDTH);
	max-width: var(--MAX_WIDTH);
	margin-bottom: var(--GENERALSEC);
}
#mainarea{
	flex: 1;
}
@media screen and (min-width: 1100px){
  #sidearea{
    width: 240px;
    margin-right: 50px;
  }
}
@media screen and (min-width: 951px) and (max-width: 1100px){
  #sidearea{
    width: 200px;
    margin-right: 30px;
  }
}
@media screen and (max-width: 950px){
  #sidearea{
    display: none;
  }
}
@media screen and (min-width: 768px){
	#wrapper > .flex{
		align-items: flex-start;
	}
}
/* カートカウント */
.fs-client-cart-count{
	display: flex;
	justify-content: center;
	align-items: center;
	text-align: center;
	aspect-ratio: 1/1;
	width: 20px;
	font-size: 11px;
	background-color: var(--RED01);
	color: var(--WHITE);
	border-radius: 50%;
	position: absolute;
}
/* 商品マークリセット */
.fs-c-productMarks{
	display: flex;
	gap: 5px;
	flex-wrap: wrap;
	--BDRS: 70px;
}
.fs-c-productMark{
	gap: 5px;
}
.fs-c-productMark__mark{
	width: fit-content;
}
.fs-c-productMark li,
.fs-c-productMark span,
.fs-c-productMarks > .fs-c-mark .fs-c-mark__label{
	margin: 0;
	font-size: 11px;
/*
  background-color: var(--BLACK);
	color: var(--WHITE);
*/
  border-radius: var(--BDRS);
}
.fs-c-productMark__mark,
.fs-c-productMarks > .fs-c-mark .fs-c-mark__label{
	display: inline-block;
	padding: 4px 12px 6px;
	line-height: 1;
}
.fs-c-productMark img{
	width: auto;
	height: 20px;
}
.fs-c-productMarks > .fs-c-mark{
	line-height: 1;
}
/* 1回のみ・定期 */
.fs-c-mark--normalAndSubscription .fs-c-mark__label{
	background-color: var(--BROWN02);
	color: var(--WHITE);
	border-radius: var(--BDRS);
}
/* 定期販売 */
.fs-c-mark--subscription .fs-c-mark__label{
	background-color: #D21341;
	color: var(--WHITE);
	border-radius: var(--BDRS);
}
/* 初回特別価格あり */
.fs-c-mark--firstTimeSpecialPrice .fs-c-mark__label{
	background-color: #FF506F;
	color: var(--WHITE);
	border-radius: var(--BDRS);
}
/* パンくずリセット  */
.fs-c-breadcrumb__list {
  padding: 0;
	max-width: var(--MAX_WIDTH);
	margin-left: auto;
	margin-right: auto;
}
.fs-c-breadcrumb__list > li {
  box-sizing: border-box;
}
.fs-c-breadcrumb__listItem {
  display: inline-block;
  word-break: break-all;
}
.fs-c-breadcrumb__listItem + .fs-c-breadcrumb__listItem::before {
  content: " > ";
}
.fs-c-breadcrumb li,
.fs-c-breadcrumb li a {
	color: var(--TXT_COLOR);
}
.fs-c-breadcrumb li a{
	text-decoration: underline;
}
@media screen and (min-width: 768px) {
	.fs-c-breadcrumb {
		margin: 0 auto;
		padding: 10px 0;
		font-size: 14px;
    margin-bottom: 20px;
	}
}
@media screen and (max-width: 767px) {
	.fs-c-breadcrumb {
		padding: 8px 0;
		font-size: 11px;
		overflow: hidden;
		position: relative;
    margin-bottom: 20px;
	}
	.fs-c-breadcrumb::after{
		content: "";
    right: 0;
    width: 6.25rem;
    height: 100%;
    position: absolute;
    background: linear-gradient(270deg,#fff 21.11%,hsla(0,0%,100%,0) 107.22%);
    z-index: 10;
		top: 0;
	}
	.fs-c-breadcrumb__list{
		white-space: nowrap;
    overflow: scroll;
		padding-right: 40px;
	}
}
/* レビュー */
.fs-c-rating__value{
	color: var(--REVIEW_COLOR);
}
.fs-c-reviewStars::before{
	color: var(--REVIEW_COLOR);
}
/* ページャー */
.fs-c-listControl {
	display: flex;
	flex-direction: column;
	align-items: center;
	flex-grow: 2;
	padding: 6px 15px 4px;
	margin: 10px 0 40px;
}
.wp-pagenavi{
	display: flex;
	justify-content: center;
}
#next > span.pages{
	display: block;
	text-align: center;
	margin-top: 10px;
}
.found-postContainer,
.fs-c-listControl__status{
	font-size: 16px;
	text-align: center;
	margin-bottom: 30px;
	padding-top: 1em;
}
.fs-c-pagination > *,
.wp-pagenavi > *{
	aspect-ratio: 1/1;
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	font-weight: normal;
	border-radius: 50%;
}
.fs-c-pagination__item{
	padding: 0;
}
.fs-c-pagination__item.is-active,
.wp-pagenavi .current{
	background-color:var(--FS_BTN_COLOR_1);
	border: 1px solid var(--FS_BTN_COLOR_1);
	color: var(--WHITE);
}
.fs-c-pagination{
	font-weight: bold;
	align-items: center;
}
a.fs-c-pagination__item.fs-c-pagination__item--prev,
a.fs-c-pagination__item.fs-c-pagination__item--next,
#next a.previouspostslink,
#next a.nextpostslink{
	border: 1px solid var(--FS_BTN_COLOR_1);
	display: flex;
	justify-content: center;
	text-align: center;
	align-items: center;
	padding: 0;
	position: relative;
}
#next a.previouspostslink .navi-prev,
#next a.nextpostslink .navi-next{
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
}
.fs-c-pagination__item--prev::before,
.fs-c-pagination__item--next::before,
#next a.previouspostslink .navi-prev::before,
#next a.nextpostslink .navi-next::before{
	font-family: "Font Awesome 5 Pro" !important;
	font-weight: 400;
	display: inline-block;
  color: var(--BLACK);
  font-size: 16px;
  vertical-align: text-bottom;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
}
.fs-c-pagination__item--prev::before,
#next a.previouspostslink .navi-prev::before{
	content: "\f104";
}
.fs-c-pagination__item--next::before,
#next a.nextpostslink .navi-next::before{
	content: "\f105";
}
@media screen and (min-width: 768px){
	.fs-c-pagination,
	.wp-pagenavi{
		font-size: 18px;
		gap: 10px;
	}
	#next {
		margin: 70px auto 0;
	}
	.fs-c-pagination > *,
	.wp-pagenavi > *{
		width: 45px;
	}
	.fs-c-pagination__item--next:hover{
		color: var(--WHITE);
	}
}
@media screen and (max-width: 767px){
	.fs-c-pagination,
	.wp-pagenavi{
		font-size: 16px;
		gap: 10px;
	}
	#next {
		margin: 40px auto 0;
	}
	.fs-c-pagination > *,
	.wp-pagenavi > *{
		width: 34px;
	}
}
/* aiレコメンドリセット */
.fs-p-heading--lv2,
.fr3-item__rankContainer{
	display: none;
}
.fr3-productListStatic{
	padding: 0 !important;
}
.fr3-item__productPrice__price{
	font-size: unset;
}
.fr3-item__rankContainer{
	display: none !important;
}
/* -------------------もっとみるボタン-------------------- */
.more-btn-simple{
	text-align: right;
}
.more-btn-simple a{
	color: var(--RED02);
	letter-spacing: 0.3em;
}
.more-btn-simple a::before{
	content: ">";
	display: inline-block;
	margin-right: 5px;
}
.more-btn a{
	background-color: var(--WHITE);
	font-family: var(--FF_MINCHO);
	display: flex;
	justify-content: center;
	align-items: center;
	letter-spacing: 0.2em;
	border: 1px solid var(--DARK01);
	gap: 5px;
}
.more-btn a span{
	display: inline-block;
	mask: url(../images/common/ks_bottan_arrow.svg) no-repeat center center / 100%;
	-webkit-mask: url(../images/common/ks_bottan_arrow.svg) no-repeat center center / 100%;
	background-color: var(--GRAY05);
	aspect-ratio: 1/1;
}
@media screen and (min-width: 768px){
  .more-btn-simple{
		margin-top: 10px;
	}
	.more-btn{
		width: 350px;
		margin: var(--MG_M) auto 0;
	}
	.more-btn a{
		height: 50px;
	}
	.more-btn a span{
		width: 18px;
		transition: 1.5s;
	}
	.more-btn a:hover{
		opacity: 1;
		color: var(--WHITE);
		background-color: var(--GOLD01);
	}
	.more-btn a:hover span{
		background-color: var(--WHITE);
	}
}
@media screen and (max-width: 767px){
	.more-btn-simple{
		margin-top: 8px;
	}
	.more-btn{
		width: 320px;
		margin: var(--MG_M) auto 0;
	}
	.more-btn a{
		height: 50px;
	}
	.more-btn a span{
		width: 18px;
		transition: 1.5s;
	}
}
/* -------------------セクションタイトル-------------------- */
.sec-ttl span{
	display: block;
	text-align: center;
}
.sec-ttl.white span{
	color: var(--WHITE);
}
.sec-ttl .en{
	color: var(--RED01);
}
.sec-ttl .ja{
	font-weight: 300;
	letter-spacing: 0.15em;
}
@media screen and (min-width: 768px){
	.sec-ttl{
		margin-bottom: 60px;
	}
  .sec-ttl .en{
		font-size: 14px;
	}
	.sec-ttl .ja{
		font-size: 32px;
		line-height: 1.6;
	}
}
@media screen and (max-width: 767px){
	.sec-ttl{
		margin-bottom: 30px;
	}
  .sec-ttl .en{
		font-size: 14px;
	}
	.sec-ttl .ja{
		font-size: 24px;
	}
}
/* -------------------商品カテゴリから探す-------------------- */
.cat-list-area{
  overflow: hidden;
	position: relative;
}
.cat-sec .cat-list-thumb,
.hvr-box .cat-list-thumb{
	grid-template-columns: repeat(3,1fr);
}
.cat-list-thumb .name{
	font-weight: 500;
	text-align: center;
}
.cat-list-icon li a{
	display: block;
}
.cat-list-icon li a span{
	display: inline-block;
	border-radius: 50%;
	background: no-repeat left center / 100%;
	aspect-ratio: 1/1;
}
.cat-more{
	position: absolute;
	border-top: 1px solid var(--DARK01_OP20);
	bottom: 0;
	left: 0;
	text-align: center;
	width: 100%;
	background-color: var(--WHITE);
}
.cat-more span{
	display: block;
	text-align: center;
	transition: .3s;
}
.cat-more .txt::after{
	content: 'カテゴリをもっと見る';
	font-size: 12px;
	letter-spacing: 0.2em;
}
.cat-more .arrow{
	mask: url(../images/common/ks_top_menu_arrow.svg) no-repeat center center / 100%;
	-webkit-mask: url(../images/common/ks_top_menu_arrow.svg) no-repeat center center / 100%;
	aspect-ratio: 1/1;
	background-color: var(--DARK01);
	width: 15px;
	margin: 0 auto;
}
.cat-list-area.open .cat-more .txt::after{
	content: '閉じる';
}
.cat-list-area.open .cat-more .arrow{
	transform: rotate(180deg);
}
@media screen and (min-width: 1101px){
	.cat-list-icon{
		grid-template-columns: repeat(5,1fr);
	}
}
@media screen and (min-width: 768px) and (max-width: 1100px){
	.cat-list-icon{
		grid-template-columns: repeat(4,1fr);
	}
}
@media screen and (min-width: 768px){
  .cat-list-thumb{
		width: 70%;
		margin-left: auto;
		margin-right: auto;
		column-gap: var(--MG_S);
		margin-bottom: var(--MG_MM);
	}
	.cat-list-thumb .name{
		font-size: 16px;
		margin-top: 10px;
		text-align: center;
	}
	.cat-list-icon{
		gap: 30px 10px;
	}
	.cat-list-icon li a{
		display: flex;
		align-items: center;
		gap: 10px;
	}
	.cat-list-icon li a span{
		width: 60px;
	}
	.cat-more:hover{
		cursor: pointer;
	}
	.cat-list-area.open{
		padding-bottom: 80px;
	}
}
@media screen and (max-width: 767px){
	.cat-sec .cat-list-thumb{
		column-gap: var(--MG_SS);
		margin-bottom: var(--MG_S);
	}
	.cat-sec .cat-list-thumb .name{
		font-size: 12px;
		margin-top: 5px;
	}
	.cat-sec .cat-list-icon{
		grid-template-columns: repeat(4,1fr);
		gap: 20px 30px;
	}
	.cat-sec .cat-list-icon li a{
		display: block;
		font-size: 10px;
		text-align: center;
	}
	.cat-sec .cat-list-icon li a span{
		width: 100%;
		display: block;
		max-width: 100px;
		margin: 0 auto 5px;
	}
	.cat-sec .cat-list-area.open{
		padding-bottom: 70px;
	}
}
/* -------------------今のおすすめ-------------------- */
.special-list .cat{
	display: flex;
	flex-wrap: wrap;
}
.special-list .cat li a{
	display: block;
	color: var(--GRAY04);
	border: 1px solid var(--GRAY04);
}
.special-list .ttl{
	font-weight: 500;
}
.special-list .excerpt{
	overflow: hidden;
	-webkit-line-clamp: 3;
	-webkit-box-orient: vertical;
	display: -webkit-box;
}
@media screen and (min-width: 1201px){
	.special-list{
		grid-template-columns: repeat(4,1fr);
	}
}
@media screen and (min-width: 768px) and (max-width: 1200px){
	.special-list{
		grid-template-columns: repeat(3,1fr);
	}
}
@media screen and (min-width: 768px){
  .special-list{
		gap: var(--MG_MM) var(--MG_S);
	}
	.special-list .cat{
		margin: 15px 0 5px;
	}
	.special-list .cat li a{
		font-size: 14px;
		padding: 1px 8px 2px;
	}
	.special-list .excerpt{
		font-size: 14px;
	}
}
@media screen and (max-width: 767px){
	.special-list{
		grid-template-columns: repeat(2,1fr);
		gap: var(--MG_MM) var(--MG_SS);
	}
	.special-list .cat{
		margin: 10px 0 2px;
	}
	.special-list .cat li a{
		font-size: 14px;
		padding: 1px 8px 2px;
	}
	.special-list .cat li a{
		font-size: 12px;
		padding: 1px 8px 2px;
	}
	.special-list .excerpt{
		font-size: 12px;
	}
}
/* -------------------商品-------------------- */
.ranking-sec .fr3-productListStatic{
	counter-reset: original-counter;
}
.ranking-sec .fr3-productListStatic article{
	position: relative;
}
.ranking-sec .fr3-productListStatic article::before{
	content: ''counter(original-counter);
	counter-increment: original-counter;
	font-family: var(--FF_MONT);
	color: var(--WHITE);
	background-color: var(--DARK01);
	aspect-ratio: 1/1;
	display: flex;
	justify-content: center;
	align-items: center;
	position: absolute;
	top: 0;
	left: 0;
	z-index: 2;
}
.gift-bnr{
	margin: var(--MG_M) auto 0;
}
@media screen and (min-width: 1201px){
	.product-tab .tab-nav{
		width: 90%;
	}
}
@media screen and (min-width: 768px){
  .product-tab .tab-nav{
		gap: 5px;
		margin: 0 auto var(--MG_MM);
	}
	.product-tab .tab-btn{
		text-align: center;
		border-bottom: 1px solid var(--GRAY05);
		padding-bottom: 5px;
	}
	.product-tab .tab-btn.show{
		font-weight: 500;
		color: var(--RED01);
		border-bottom: 1px solid var(--RED01);
	}
	.product-tab .fr3-productListStatic{
		gap: var(--MG_M) var(--MG_S);
	}
	.product-tab .fr3-item__productName{
		font-size: 14px;
	}
	.product-tab .fr3-item__productPrice__price{
		font-size: 16px;
	}
	.product-tab .fr3-item__productPrice__addon{
		font-size: 14px;
	}
	.ranking-sec .fr3-productListStatic article::before{
		width: 40px;
		font-size: 20px;
	}
	.gift-top-txt{
		max-width: 700px;
		margin: 0 auto var(--MG_MM);
	}
	.gift-bnr{
		width: 590px;
	}
}
@media screen and (max-width: 767px){
  .product-tab .tab-nav{
		background-color: var(--GRAY01);
		margin-bottom: var(--MG_S);
		position: relative;
	}
	.product-tab.tab-wrap{
		position: relative;
	}
/*
	.product-tab.tab-wrap::after{
		content: "";
		right: 0;
		width: 6.25rem;
		height: 42px;
		position: absolute;
		background: linear-gradient(270deg,var(--GRAY01) 21.11%,hsla(0,0%,100%,0) 107.22%);
		z-index: 10;
		top: 0;
	}
*/
/*
	.product-tab.tab-wrap::before{
		content: "";
		display: inline-block;
		mask: url(../images/common/ks_arrow.svg) no-repeat center center / 100%;
		-webkit-mask: url(../images/common/ks_arrow.svg) no-repeat center center / 100%;
		aspect-ratio: 1/1;
		background-color: var(--DARK01);
		position: absolute;
		top: 14px;
		width: 13px;
		right: 4px;
		z-index: 11;
	}
*/
	.product-tab .tab-btn{
		min-width: fit-content;
		padding: 10px 20px 10px 0;
	}
	.product-tab .tab-btn:last-child{
		padding-right: 30px;
	}
	.product-tab .tab-btn.show{
		color: var(--RED02);
	}
	.product-tab .fr3-productListStatic{
		width: var(--INNER_WIDTH);
		margin: 0 auto;
		gap: var(--MG_MM) var(--MG_SS);
	}
	.product-tab .fr3-item__productName{
		font-size: 14px;
	}
	.product-tab .fr3-item__productPrice__price{
		font-size: 16px;
	}
	.product-tab .fr3-item__productPrice__addon{
		font-size: 14px;
	}
	.ranking-sec .fr3-productListStatic article::before{
		width: 30px;
		font-size: 20px;
	}
	.gift-top-txt{
		max-width: 700px;
		margin: 0 auto var(--MG_MM);
	}
}
/* -------------------ブログ-------------------- */
.blog-sec .sec-ttl .ja{
	font-family: var(--FF_MINCHO);
}
.blog-list time{
	font-size: 14px;
}
.blog-list .ttl{
	font-weight: 500;
}
.blog-list .excerpt{
	overflow: hidden;
	-webkit-box-orient: vertical;
	display: -webkit-box;
}
@media screen and (min-width: 1201px){
	.blog-list{
		width: 90%;
		margin: 0 auto;
	}
}
@media screen and (min-width: 768px){
  .blog-list{
		display: grid;
		grid-template-columns: repeat(2,1fr);
		gap: var(--MG_MM);
	}
	.blog-list .ttl{
		font-size: 20px;
		margin: 10px 0 20px;
	}
	.blog-list .desc{
		display: flex;
		gap: 15px;
	}
	.blog-list .thumb{
		width: 192px;
	}
	.blog-list .thumb img{
		width: 100%;
		height: 100%;
		object-fit: cover;
	}
	.blog-list .excerpt{
		flex: 1;
		-webkit-line-clamp: 5;
		font-size: 14px;
	}
}
@media screen and (max-width: 767px){
	.blog-list{
		width: 90%;
		margin: 0 auto;
	}
  .blog-list article:nth-of-type(n+2){
		display: none;
	}
	.blog-list .ttl{
		margin: 10px 0 20px;
	}
	.blog-list .thumb{
		width: 70%;
		margin: 0 auto 20px;
	}
}
/* -------------------今までチェックした商品-------------------- */
.history-ttl{
	text-align: center;
}
.history-sec .fr3-item__productName,
.history-sec .fr3-item__productPrice{
	display: none;
}
@media screen and (min-width: 1301px){
	.history-sec{
		width: calc(var(--INNER_WIDTH) + var(--MG_S));
		max-width: calc(var(--MAX_WIDTH) + var(--MG_S));
	}
}
@media screen and (min-width: 768px) and (max-width: 1300px){
	.history-sec{
		width: calc(var(--INNER_WIDTH) - var(--MG_S));
		max-width: calc(var(--MAX_WIDTH) - var(--MG_S));
	}
}
@media screen and (min-width: 768px){
  .history-ttl{
		font-size: 22px;
		margin-bottom: var(--MG_MM);
	}
	.flywheel-recommend__frame[data-frame-id="history"] .fr3-productListStatic{
		display: block;
		opacity: 0;
		transition: opacity .3s linear;
	}
	.flywheel-recommend__frame[data-frame-id="history"] .fr3-productListStatic.slick-initialized{
		opacity: 1;
	}
	.flywheel-recommend__frame[data-frame-id="history"] .fr3-productListStatic .slick-slide{
		margin: 0 calc(var(--MG_S) / 2);
	}
	[class^="history-arrow"]{
		width: 20px;
		aspect-ratio: 1/1;
		background: url(../images/common/ks_arrow.svg) no-repeat center center / 10px;
		position: absolute;
		top: 50%;
		transform: translateY(-50%);
	}
	[class^="history-arrow"]:hover{
		cursor: pointer;
	}
	.history-arrow-prev{
		right: 100%;
		transform: rotate(180deg);
	}
	.history-arrow-next{
		left: 100%;
	}
}
@media screen and (max-width: 767px){
	.history-ttl{
		font-size: 18px;
		margin-bottom: var(--MG_S);
	}
	.flywheel-recommend__frame[data-frame-id="history"] .fr3-productListStatic{
		display: flex;
		overflow-x: scroll;
		overflow-y: auto;
		padding-left: calc((100% - var(--INNER_WIDTH)) / 2) !important;
		padding-right: calc((100% - var(--INNER_WIDTH)) / 2) !important;
		gap: var(--MG_SS);
	}
	.flywheel-recommend__frame[data-frame-id="history"] .fr3-productListStatic article{
		min-width: 120px;
		max-width: 120px;
	}
}
/* -------------------ガイドエリア-------------------- */
.guide-area{
	background-color: var(--GRAY01);
}
.guide-area-list .img{
	border-radius: 50%;
	background: var(--WHITE) no-repeat center center / 50%;
	aspect-ratio: 1/1;
}
.guide-area-list .txt{
	text-align: center;
}
@media screen and (min-width: 1101px){
	.guide-area-list{
		width: 50%;
		margin: 0 auto;
	}
}
@media screen and (min-width: 768px){
	.guide-area{
		padding: calc(var(--GENERALSEC) / 2);
	}
  .guide-area-list{
		grid-template-columns: repeat(2,1fr);
	}
	.guide-area-list .img{
		width: 70%;
		max-width: 150px;
		margin: 0 auto var(--MG_S);
	}
}
@media screen and (max-width: 767px){
	.guide-area{
		padding: var(--GENERALSEC) 0;
	}
  .guide-area-list{
		grid-template-columns: repeat(2,1fr);
		row-gap: var(--MG_MM);
	}
	.guide-area-list .img{
		width: 70%;
		max-width: 100px;
		margin: 0 auto var(--MG_SS);
		box-shadow: var(--COMMON_BXSD);
	}
	.guide-area-list .txt{
		font-size: 13px;
	}
}
/* -------------------ショールーム-------------------- */
.show-room-sec .img{
	background: url(../images/common/ks_top_showroom.jpg) no-repeat center center / cover;
}
.show-room-txt{
	text-align: center;
}
.show-room-link li a{
	display: block;
	text-align: center;
	border: 1px solid var(--DARK01);
	font-family: var(--FF_MINCHO);
	background-color: var(--WHITE);
}
@media screen and (min-width: 768px){
	.show-room-sec{
		position: relative;
	}
  .show-room-sec .img{
		position: absolute;
		width: 50%;
		height: calc(100% - var(--GENERALSEC)*2);
		top: 50%;
		transform: translateY(-50%);
		left: 0;
	}
	.show-room-sec .txtarea{
		position: relative;
		z-index: 2;
		width: 540px;
		background-color: var(--WHITE_OP50);
		padding-left: 30px;
		margin-left: auto;
	}
	.show-room-txt{
		margin: -50px auto 30px;
	}
	.show-room-link{
		display: flex;
		flex-wrap: wrap;
		justify-content: center;
		gap: var(--MG_S);
	}
	.show-room-link li a{
		padding: 13px 20px;
	}
	.show-room-link li a:hover{
		opacity: 1;
		background-color: var(--DARK01);
		color: var(--WHITE);
	}
}
@media screen and (max-width: 767px){
  .show-room-sec .img{
		height: 170px;
		margin-bottom: var(--MG_MM);
	}
	.show-room-txt{
		margin: -20px auto 30px;
	}
	.show-room-link{
		display: grid;
		gap: var(--MG_S);
		width: 95%;
		margin: 0 auto;
	}
	.show-room-link li a{
		font-size: 16px;
		padding: 8px 0;
	}
}
/* -------------------インテリア-------------------- */
.interior-sec{
  background: no-repeat center center / cover;
  position: relative;
  z-index: 0;
  color: var(--WHITE);
}
.interior-sec::before{
  content: "";
  display: inline-block;
  background: var(--DARK01_OP50);
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
}
.interior-sec .en{
  color: var(--WHITE);
}
.interior-sec .ja{
  font-weight: 500;
}
.interior-txt{
  border-top: 1px solid var(--WHITE);
}
.interior-link li a{
  border: 1px solid var(--WHITE);
  color: var(--WHITE);
  position: relative;
  font-family: var(--FF_MINCHO);
  display: block;
  text-align: center;
}
@media screen and (min-width: 768px){
  .interior-logo{
    width: 72px;
    margin: 0 auto 20px;
  }
  .interior-txt{
    width: 600px;
    margin: -40px auto 100px;
    padding-top: 20px;
  }
	.cm-top  .interior-txt{
    width: 493px;
  }
  .interior-link{
		display: flex;
		justify-content: center;
    gap: var(--MG_S);
  }
	.interior-link li{
		flex: 1;
	}
	.cm-top .interior-link li{
		max-width: 350px;
	}
  .interior-link li a{
    padding: 20px 0;
    font-size: clamp( 13px, 1.5vw, 18px);
  }
  .interior-link li a::after{
    content: "";
    display: inline-block;
    mask: url(../../common/images/common/ks_arrow.svg) no-repeat center center / 100%;
    -webkit-mask: url(../../common/images/common/ks_arrow.svg) no-repeat center center / 100%;
    aspect-ratio: 1/1;
    background-color: var(--WHITE);
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: clamp( 5px, 1vw, 15px);
    right: 10px;
    transition: .5s;
  }
  .interior-link li a:hover{
    opacity: 1;
    filter: brightness(0.8);
  }
}
@media screen and (max-width: 767px){
  .interior-logo{
    width: 48px;
    margin: 0 auto 20px;
  }
  .interior-txt{
    margin: -20px auto 20px;
    padding-top: 10px;
  }
  .interior-link{
    gap: var(--MG_S);
  }
  .interior-link li a{
    font-size: 16px;
    padding: 10px 0;
  }
}
/* ----------------------ユーチューブ埋め込み--------------------- */
.youtube-area iframe {
  display: block;
  width: 100%;
	height: auto;
	aspect-ratio: 10000/5625;
}