@charset "utf-8";
/* CSS関数設定 */
:root {
	/* カラーパレット */
	--WHITE: #FFFFFF;
	--WHITE_OP95: rgba(255, 255, 255, 0.95);
	--BLACK: #000000;

	--DARK01: #3E3E3E;

	--GRAY01: #F0F0F0;
	--GRAY01_OP95: rgba(240, 240, 240, 0.95);
	--GRAY01_OP90: rgba(240, 240, 240, 0.9);
	--GRAY02: #D1D1D1;
	--GRAY03: #A7A7A7;
	--GRAY04: #F8F8F8;
	--GRAY05: #646464;

	--GREEN01: #167276;
	--GREEN02: #123D4B;
	--GREEN02_OP50: rgba(18, 61, 75, 0.5);

	--BLUE01: #9196FF;
	--BLUE02: #4ED3FE;
	--BLUE03: #343579;
	--BLUE04: #DADCFF;

	--YELLOW01: #F0FF96;

	--ORANGE01: #FF8F60;

	--RED01: #FF0000;

	--BEIGE01: #F2E9D8;

	/* テキストカラー */
	--TXT_COLOR_BASE: var(--BLACK);
	--TXT_COLOR_WHITE: var(--WHITE);
	--TXT_COLOR_BEIGE_1: var(--BEIGE01);
	--TXT_BGCOLOR_GRAY_1: var(--GRAY03);

	/* ボーダーカラー */
	--BDCOLOR_GRAY_1: var(--GRAY02);
	--BDCOLOR_GRAY_2: var(--GRAY03);
	--BGCOLOR_BEIGE_1: var(--BEIGE01);

	/* 背景カラー */
	--BGCOLOR_GRAY_1: var(--GRAY01);
	--BGCOLOR_GRAY_1_OP95: var(--GRAY01_OP95);
	--BGCOLOR_GRAY_1_OP90: var(--GRAY01_OP90);
	--BGCOLOR_BODY_GRAY: var(--GRAY04);
	--BDCOLOR_GREEN_1: var(--GREEN02);

	/* ランキングカラー */
	--RANKING_1ST: #B7A900;
	--RANKING_2ND: #A7A7A7;
	--RANKING_3RD: #B57146;
	--RANKING_OTHER: #002C1B;

	/* 共通角丸 */
	--COMMON_BDRS_S: 5px;
	--COMMON_BDRS_M: 10px;
	--COMMON_BDRS_L: 20px;

	/* 共通ボックス影 */
	--COMMON_BXSD: 0px 0px 15px -5px var(--GRAY02);
	--COMMON_BXSD_BTM: 0px 5px 15px -5px var(--GRAY02);

	/* ベースフォント */
	--FF_BASE: 'Noto Sans JP', "游ゴシック", YuGothic, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, sans-serif;
	/* 英数字フォント */
	--FF_EN: "Archivo Narrow", sans-serif;
	--FF_NUM: "Archivo Narrow", sans-serif;

	/* フォントウェイト */
	--FF_WEIGHT_BASE: var(--FF_W_R);
	--FF_W_R: 400;
	--FF_W_M: 500;
	--FF_W_B: 700;
	
	/* アニメーション */
	--ANIME_FADEIN: fadeIn .5s ease-in-out 0s forwards;
	--ANIME_FADEOUT: fadeOut .5s ease-in-out 0s forwards;

	/* フォトサイズ */
	--FZ_11: clamp(10px, 1vw, 11px);
	--FZ_12: clamp(10px, 1vw, 12px);
	--FZ_13: clamp(11px, 1vw, 13px);
	--FZ_14: clamp(12px, 1.2vw, 14px);
	--FZ_15: clamp(13px, 1.4vw, 15px);
	--FZ_16: clamp(14px, 1.5vw, 16px);
	--FZ_18: clamp(15px, 1.6vw, 18px);
	--FZ_19: clamp(16px, 1.7vw, 19px);
	--FZ_20: clamp(16px, 1.8vw, 20px);
	--FZ_22: clamp(18px, 2vw, 22px);
	--FZ_25: clamp(20px, 2vw, 25px);
	--FZ_28: clamp(22px, 2.5vw, 28px);
	--FZ_30: clamp(25px, 3vw, 30px);
	--FZ_35: clamp(25px, 3vw, 35px);
	--FZ_40: clamp(30px, 3.5vw, 40px);
	--FZ_43: clamp(30px, 4vw, 43px);
	--FZ_50: clamp(30px, 4vw, 50px);
	--FZ_60: clamp(40px, 5vw, 60px);
	--FZ_65: clamp(50px, 5.5vw, 65px);
	--FZ_70: clamp(50px, 6vw, 70px);
	--FZ_80: clamp(60px, 6.5vw, 80px);
	--FZ_130: clamp(80px, 8vw, 130px);
	--FZ_10_CONST: 10px;
	--FZ_11_CONST: 11px;
	--FZ_12_CONST: 12px;
	--FZ_14_CONST: 14px;
	--FZ_15_CONST: 15px;
	--FZ_16_CONST: 16px;
	--FZ_18_CONST: 18px;
	--FZ_20_CONST: 20px;

	/* 行間 */
	--LINE_HEIGHT_S: 1.5;
	--LINE_HEIGHT_M: 1.7;
	--LINE_HEIGHT_L: 2;

	/* ブロック間 */
	--GAP_10: clamp( 5px, 1.1vw, 10px);
	--GAP_15: clamp( 10px, 1.2vw, 15px);
	--GAP_20: clamp( 15px, 1.7vw, 20px);
	--GAP_25: clamp( 18px, 2vw, 25px);
	--GAP_35: clamp( 20px, 2.5vw, 35px);
	--GAP_30: clamp( 20px, 2.5vw, 30px);
	--GAP_40: clamp( 30px, 3.5vw, 40px);
	--GAP_50: clamp( 30px, 3.5vw, 50px);
	--GAP_60: clamp( 40px, 4.5vw, 60px);
	--GAP_65: clamp( 50px, 5.5vw, 65px);
	--GAP_70: clamp( 50px, 5.5vw, 70px);
	--GAP_75: clamp( 60px, 6.5vw, 75px);
	--GAP_80: clamp( 50px, 5.5vw, 80px);
	--GAP_90: clamp( 60px, 6.5vw, 90px);
	--GAP_100: clamp( 70px, 7.5vw, 100px);
	--GAP_5_CONST: 5px;
	--GAP_10_CONST: 10px;
	--GAP_15_CONST: 15px;
	--GAP_20_CONST: 20px;
	--GAP_30_CONST: 30px;
	--GAP_40_CONST: 40px;

	/* マージン */
	--MG_5: 5px;
	--MG_10: 10px;
	--MG_15: 15px;
	--MG_20: 20px;
	--MG_30: 30px;
	--MG_40: 40px;
	--MG_50: 50px;
	--MG_60: 60px;
	--MG_80: 80px;

	/* PCマックス幅 */
	--PC_MAX_WIDTH: var(--PC_MAX_WIDTH_M);
	--PC_MAX_WIDTH_SS: 800px;
	--PC_MAX_WIDTH_S: 1000px;
	--PC_MAX_WIDTH_M: 1200px;
	--PC_MAX_WIDTH_L: 1440px;

	/* 親要素を超えて幅100% */
	--FULL_WIDTH: calc(50% - 50vw);

	/* セクション間隔半分 */
	--GENERALSEC_HALF: calc(var(--GENERALSEC) / 2);
}

@media screen and (min-width: 768px){
	:root{
		--INNER_WIDTH: 97%;
		--GENERALSEC: clamp(70px, 8vw, 100px);
	}
}
@media screen and (max-width: 767px){
	:root{
	--INNER_WIDTH: 90%;
	--GENERALSEC: 50px;
	}
}
/* フェードインアニメーション */
@keyframes fadeIn {
	0% {
		opacity: 0;
	}
	100% {
		opacity: 1;
	}
}
@keyframes fadeOut {
	0% {
		opacity: 1;
	}
	100% {
		opacity: 0;
	}
}
/* リセット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;}
ul li ,ol li{list-style:none;}
h1,h2,h3,h4,h5,h6{font-weight: var(--FF_WEIGHT_BASE);font-size: 100%;margin: 0;}
p{margin: 0;}
strong{font-weight: inherit;}
a:focus, *:focus{ outline:none; }
article, header, footer, aside, figure, figcaption, nav, section,main{ 
  display:block;
}
body{
	font-family: var(--FF_BASE);
	font-weight: var(--FF_WEIGHT_BASE);
	font-feature-settings: "palt" 1;
	letter-spacing: 0.1em;
	width:100%;
	color: var(--TXT_COLOR_BASE);
	position:relative;
	z-index: 0;
	overflow-x: clip;
}
body > *{
	overflow-x: clip;
}
a{
	text-decoration: none;
	outline: none;
	word-wrap: break-word;
	color: var(--TXT_COLOR_BASE);
}
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;
}
.formReset button,
.formReset input[type="button"],
.formReset input[type="submit"],
.formReset input[type="text"],
.formReset input[type="image"],
.formReset select{
	background-color: unset;
	color: var(--TXT_COLOR_BASE);
	-webkit-appearance: none;
	border-radius: 0;
	border: none;
}
.formReset input[type="text"],
.formReset input[type="text"]::placeholder{
	font-family: var(--FF_BASE);
	color: var(--TXT_COLOR_BASE);
}
time{
	font-family: var(--FF_NUM);
}
/* フォントCSS */
.ff-mincho{
	font-family: 'Yu Mincho Light','YuMincho','Yu Mincho','游明朝体','ヒラギノ明朝 ProN','Hiragino Mincho ProN','ヒラギノ明朝 ProN','Hiragino Mincho ProN',sans-serif;
}
/* imgリセット */
.imgauto{
	height: auto;
	width: 100%;
	box-sizing: unset;
	line-height: 1rem;
	display: block;
}
/* セクション間隔*/
.g-mgt{
	margin-top: var(--GENERALSEC);
}
.g-mgb{
	margin-bottom: var(--GENERALSEC);
}
.g-pd{
	padding: var(--GENERALSEC) 0;
}
.g-pdt{
	padding-top: var(--GENERALSEC);
}
.g-pdb{
	padding-bottom: var(--GENERALSEC);
}
.g-mgt--half{
	margin-top: var(--GENERALSEC_HALF);
}
.g-mgb--half{
	margin-bottom: var(--GENERALSEC_HALF);
}
.g-pd--half{
	padding: var(--GENERALSEC_HALF) 0;
}
.g-pdt--half{
	padding-top: var(--GENERALSEC_HALF);
}
.g-pdb--half{
	padding-bottom: var(--GENERALSEC_HALF);
}
/* グリッド、フレックス */
.grid{
	display: grid;
}
.flex{
	display: flex;
}
.fxw{
	display: flex;
	flex-wrap: wrap;
}
.jcsb{
	display: flex;
	justify-content: space-between;
}
.aic{
	display: flex;
	align-items: center;
}
/* スライダー読み込みまで非表示 */
.slick{
	opacity: 0;
	transition: opacity .3s linear;
	line-height: 1;
}
.slick.slick-initialized{
	opacity: 1;
}
.swiper{
	overflow: hidden;
  opacity: 0;
	transition: opacity .3s linear;
}
.swiper.swiper-initialized{
	opacity: 1;
}
/* 縦書き */
.tategaki{
	writing-mode: vertical-rl;
}
/* 文字間 */
::placeholder,
input[type="text"],
[class*="ttl"],
[class*="lead"],
[class*="txt"],
[class*="heading"],
a{
  letter-spacing: 0.1em;
}
/* スクロールバー消す */
.noscrollbar,
.noscrollbar{
	-ms-overflow-style: none;/* IE, Edge 対応 */
	scrollbar-width: none;/* Firefox 対応 */
}
.noscrollbar::-webkit-scrollbar,
.noscrollbar::-webkit-scrollbar{/* Chrome, Safari 対応 */
	display: none;
}
/* youtube */
.youtubeContainer iframe {
  display: block;
  width: 100%;
	height: auto;
	aspect-ratio: 10000/5625;
}
/* 改行用 */
.dib{
	display: inline-block;
}
/* 非表示 */
.displaynone{
	display: none;
}
@media (hover: hover){
	.formReset button:hover,
	.formReset input[type="button"]:hover,
	.formReset input[type="submit"]:hover,
	.formReset input[type="image"]:hover,
	.formReset select:hover{
		cursor: pointer;
	}
	a:hover{
		opacity: 0.7;
		text-decoration: none;
	}
	a:hover img{
		opacity:0.75 !important;
	}
}
html.no-smooth-scroll {
	scroll-behavior: auto;
}
@media screen and (min-width: 1001px){
	.media1000{
		display: none;
	}
}
@media screen and (min-width: 768px){
	html{
		scroll-padding-top: 80px;
	}
	body{
		font-size: var(--FZ_15_CONST);
		line-height: 1.7;
		-ms-text-size-adjust: 100%;
		-webkit-text-size-adjust: 100%;
	}
	a[href^="tel:"] {
		pointer-events: none;
	}
	.g-inner,
	.g-inner--pc,
	.g-inner--l,
	.g-inner--lPc,
	.g-inner--m,
	.g-inner--s,
	.g-inner--ss,
	.g-inner--sPc{
		width: var(--INNER_WIDTH);
		margin-left: auto;
		margin-right: auto;
	}
	.g-inner,
	.g-inner--pc{
		max-width: var(--PC_MAX_WIDTH_M);
	}
	.g-inner--l,
	.g-inner--lPc{
		max-width: var(--PC_MAX_WIDTH_L);
	}
	.g-inner--s,
	.g-inner--sPc{
		max-width: var(--PC_MAX_WIDTH_S);
	}
	.g-inner--ss{
		max-width: var(--PC_MAX_WIDTH_SS);
	}
	.g-inner--pcHasSlickGap{
		--INNER_ADJUST: calc(var(--SLICK_GAP) * 2);
    width: calc(var(--INNER_WIDTH) + var(--INNER_ADJUST));
    max-width: calc(var(--PC_MAX_WIDTH_M) + var(--INNER_ADJUST));
		margin-left: auto;
		margin-right: auto;
	}
	.g-pd--halfPcOnly{
		padding: var(--GENERALSEC_HALF) 0;
	}
	.g-pd--pcOnly{
		padding: var(--GENERALSEC) 0;
	}
	.sp{
		display: none !important;
	}
	.hamburger{
		display: none !important;
	}
	.tategaki--pc{
		writing-mode: vertical-rl;
	}
	/* pc順番付与 */
	.orderPc-1st { order: 1; }
	.orderPc-2nd { order: 2; }
	.orderPc-3rd { order: 3; }
	.orderPc-4th { order: 4; }
	.orderPc-5th { order: 5; }
	.orderPc-6th { order: 6; }
	.orderPc-7th { order: 7; }
	.orderPc-8th { order: 8; }
	.orderPc-9th { order: 9; }
	.orderPc-10th { order: 10; }
}
@media screen and (max-width: 767px){
	html{
		scroll-padding-top: 60px;
	}
	body{
		font-size: var(--FZ_14_CONST);
		line-height: 1.6;
	}
	.g-inner,
	.g-inner--sp,
	.g-inner--l,
	.g-inner--m,
	.g-inner--s,
	.g-inner--ss{
		width: 92%;
		margin-left: auto;
		margin-right: auto;
	}
	.g-pd--halfPcOnly{
		padding: var(--GENERALSEC) 0;
	}
	.g-pd--spOnly{
		padding: var(--GENERALSEC_HALF) 0;
	}
	.pc{
		display: none !important;
	}
	.sp-scroll--y{
		overflow-y: scroll;
		overflow-x: auto;
	}
	.sp-scroll--x{
		overflow-x: scroll;
		overflow-y: clip;
		padding-left: calc((100% - var(--INNER_WIDTH)) / 2);
		padding-right: calc((100% - var(--INNER_WIDTH)) / 2);
	}
	.tategaki--sp{
		writing-mode: vertical-rl;
	}
	.formReset input[type="text"]{
		font-size: var(--FZ_16_CONST);
	}
}
/* ■■■■■■■■■■■■■■■■■■■■■■header■■■■■■■■■■■■■■■■■■■■■■ */
/* g-headMessage */
.g-headMessageContainer{
	background-color: var(--BLACK);
}
.g-headMessage{
	text-align: center;
}
.g-headMessage a{
	display: block;
	color: var(--WHITE);
}
.g-headMessage a:visited{
	color: var(--WHITE);
}
@media screen and (min-width: 768px){
	.g-headMessage a{
		font-size: var(--FZ_13);
		padding: 10px 0 11px;
	}
}
@media screen and (max-width: 767px){
	.g-headMessage a{
		font-size: var(--FZ_10_CONST);
		padding: 8px;
	}
}
/* headerarea */
.g-headMessageContainer{
	position: absolute;
	width: 100%;
	z-index: 99;
	top: 0;
	left: 0;
}
#headerarea{
	background-color: var(--WHITE_OP95);
	border-bottom: 1px solid var(--BLACK);
	position: absolute;
	width: 100%;
	z-index: 99;
	top: 0;
	left: 0;
}
.hd-container{
	display: flex;
}
@media screen and (min-width: 768px){
	body{
		padding-top: 78px;
	}
	body:has(.g-headMessageContainer){
		padding-top: 122px;
	}
	body:has(.g-headMessageContainer) #headerarea{
		top: 43px;
	}
	body.header-fixed #headerarea{
		position: fixed;
		top: 0;
	}
	.hd-container{
		padding: clamp( 12px, 1.3vw, 17px) 0;
	}
}
@media screen and (max-width: 767px){
	.hd-container{
		padding: 7px 0;
	}
	body{
		padding-top: 59px;
	}
	body:has(.g-headMessageContainer){
		padding-top: 99px;
	}
	body:has(.g-headMessageContainer) #headerarea{
		top: 50px;
	}
	body.header-fixed #headerarea{
		position: fixed;
		top: 0;
		opacity: 0;
	}
	body.header-fixed.is-scrollingTop #headerarea{
		opacity: 1;
		transition: .5s;
	}
}

/* hd-logo */
.hd-logo a{
	display: flex;
	align-items: center;
}
.hd-logo a span{
	display: block;
}
.hd-logo__catch{
	flex: 1;
}
.hd-logo__catch strong{
	font-weight: var(--FF_W_B);
	display: block;
}
@media screen and (min-width: 768px) and (max-width: 1000px){
	.hd-logo__catch{
		line-height: 1.5;
	}
}
@media screen and (min-width: 768px){
	.hd-logo{
		width: fit-content;
	}
	.hd-logo__img{
		width: clamp( 70px, 8vw, 100px);
	}
	.hd-logo a{
		gap: var(--GAP_20);
	}
	.hd-logo__catch{
		font-size: var(--FZ_12);
	}
}
@media screen and (max-width: 767px){
	.hd-logo__img{
		width: 70px;
	}
	.hd-logo a{
		gap: 18px;
	}
	.hd-logo__catch > *{
		letter-spacing: 0.07em;
	}
	.hd-logo__catch strong{
		font-size: var(--FZ_11_CONST);
	}
	.hd-logo__catch span{
		font-size: var(--FZ_10_CONST);
	}
	.hd-logo__catch br{
		display: none;
	}
}
/* g-search */
.g-search{
	display: grid;
}
.g-search__form{
	position: relative;
}
.g-search__form.formReset input[type="text"]{
	width: 100%;
	border: 1px solid var(--BDCOLOR_GRAY_2);
	background-color: var(--WHITE);
	border-radius: 70px;
}
.g-search__form.formReset input[type="text"]::placeholder{
	color: var(--TXT_BGCOLOR_GRAY_1);
}
.g-search__form.formReset button{
	aspect-ratio: 1/1;
	mask: url(../images/common/icon_search.svg) no-repeat center center / 100%;
	-webkit-mask: url(../images/common/icon_search.svg) no-repeat center center / 100%;
	background-color: var(--BDCOLOR_GRAY_2);
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
}
.g-search__keyword{
	display: flex;
	align-items: center;
}
.g-search__keyword__ttl{
	width: fit-content;
	color: var(--WHITE);
	background-color: var(--BLACK);
}
.g-search__keyword__list{
	flex: 1;
	display: flex;
	overflow-x: auto;
	white-space: nowrap;
}
.g-search__keyword__list li{
	flex: 0 0 auto;
}
.g-search__keyword__list li a{
	display: block;
}
.g-search__keyword__list li a::before{
	content: "#";
}
@media screen and (min-width: 768px){
	.g-search{
		gap: 12px;
	}
	.g-search--hd .g-search__form.formReset input[type="text"]{
		padding: 10px 35px 10px 20px;
	}
	.g-search--hd .g-search__form.formReset button{
		width: 20px;
		right: 15px;
	}
	.g-search--top .g-search__form.formReset input[type="text"]{
		padding: 18px 35px 18px 20px;
	}
	.g-search--top .g-search__form.formReset button{
		width: 20px;
		right: 18px;
	}
	.g-search__keyword{
		gap: 10px;
	}
	.g-search__keyword__ttl{
		padding: 2px 8px 3px;
		font-size: var(--FZ_13);
	}
	.g-search__keyword__list::-webkit-scrollbar{
		height: 5px;
	}
	.g-search__keyword__list::-webkit-scrollbar-thumb{
		background-color: var(--GRAY03);
	}
	.g-search__keyword__list::-webkit-scrollbar-thumb:hover{
		cursor: grab;
	}
	.g-search__keyword__list li{
		margin-right: 15px;
	}
}
/* g-nav */
@media (hover: hover){
	.g-nav__item--txt a{
		display: block;
		position: relative;
	}
	.g-nav__item--txt a::after{
		content: "";
		display: inline-block;
		background: var(--BLACK);
		width: 100%;
		height: 1px;
		position: absolute;
		left: 50%;
		transform: translateX(-50%);
		bottom: -6px;
		opacity: 0;
		transition: .3s;
	}
	.g-nav__item--txt a:hover::after{
		opacity: 1;
	}
}
@media screen and (min-width: 768px) and (max-width: 900px){
	.g-nav__item--txt a{
		letter-spacing: 0.05em;
	}
}
@media screen and (min-width: 768px){
	.g-navContainer{
		flex: 1;
		display: flex;
		justify-content: flex-end;
		align-items: center;
	}
	.g-nav{
		display: flex;
		align-items: center;
	}
	.g-nav__item{
		position: relative;
	}
	.g-nav__item--txt{
		padding: 0 clamp( 10px, 1.3vw, 23px);
	}
	.g-nav__item--icon{
		padding: 0 clamp( 10px, 1.3vw, 20px);
	}
	.g-nav__item:not(:last-child)::after{
		content: "";
		display: inline-block;
		background: var(--BDCOLOR_GRAY_1);
		height: 20px;
		width: 1px;
		position: absolute;
		right: 0;
		top: 55%;
		transform: translateY(-50%);
	}
	.g-nav__item > a{
		display: block;
	}
	.g-nav__item--txt a{
		font-size: var(--FZ_14);
		display: inline-block;
		max-height: 14px;
	}
	.g-nav__item--txt{
		line-height: 1;
	}
	.g-nav__item--icon > a{
		width: clamp( 15px, 1.6vw, 20px);
		background: no-repeat center center / 100%;
		aspect-ratio: 1/1;
	}
	.g-nav__cart >  a{
		position: relative;
	}
	.g-nav__cart .fs-client-cart-count{
		top: -10px;
		right: -10px;
		width: clamp( 15px, 1.7vw, 20px);
	}
	.g-nav__search{
		position: relative;
	}
	.g-nav__search__contents{
		display: none;
		background-color: var(--BGCOLOR_GRAY_1);
		width: 500px;
		position: absolute;
		top: calc(100% + 10px);
		right: 0;
		border: 1px solid var(--BLACK);
		border-radius: 10px;
		padding: 20px;
	}
	.g-nav__search.is-active .g-nav__search__contents{
		display: block;
	}
}

/* ■■■■■■■■■■■■■■■■■■■■■■footer■■■■■■■■■■■■■■■■■■■■■■ */
/* ページトップ */
.pagetop{
	position: fixed;
	z-index: 99;
	border-radius: 50%;
}
.pagetop a{
	display: block;
	aspect-ratio: 1/1;
	border-radius: 50%;
	background: url(../images/common/pagetop.svg) no-repeat center center / 100%;
}
@media screen and (min-width: 768px){
	.pagetop{
		width: 50px;
		bottom: 20px;
		right: 3%;
	}
}
@media screen and (max-width: 767px){
	.pagetop{
		width: 46px;
		bottom: 80px;
		right: -7px;
	}
}
/* footerarea */
#footerarea{
	background-color: var(--BDCOLOR_GREEN_1);
}
.g-sns{
	display: flex;
}
.g-sns li a{
	display: block;
	background: no-repeat center center / 100%;
	aspect-ratio: 1/1;
}
@media screen and (min-width: 1151px){
	.ft-container{
		grid-template-columns: 69fr 64fr;
		align-items: stretch;
		column-gap: clamp( 50px, 8vw, 110px);
	}
}
@media screen and (min-width: 768px) and (max-width: 1150px){
	.ft-container {
		width: 90%;
		max-width: 800px;
		margin: 0 auto;
		row-gap: 50px;
	}
	.ft-sns{
		justify-content: center;
		margin-top: 50px;
	}
}
@media screen and (min-width: 768px){
	.ft-logo{
		width: 97px;
		margin: 0 auto;
		padding: 100px 0;
	}
	.ft-container {
		display: grid;
	}
	.ft-linkPcContainer{
		flex: 1;
		display: flex;
		justify-content: space-between;
		align-items: flex-start;
	}
	.ft-contents.orderPc-1st{
		display: flex;
		flex-direction: column;
	}
	.ft-linkPc{
		display: grid;
		gap: 30px;
	}
	.ft-linkPc li a{
		color: var(--TXT_COLOR_BEIGE_1);
	}
	.ft-linkPc li a:visited{
		color: var(--TXT_COLOR_BEIGE_1);
	}
	.ft-linkPc__lv1{
		font-size: var(--FZ_15);
		font-weight: 600;
	}
	.ft-linkPc__lv2{
		display: grid;
		gap: 3px;
		margin-top: 5px;
	}
	.ft-linkPc__lv2 li a{
		font-size: var(--FZ_14);
		font-weight: var(--FF_W_R);
	}
	.g-sns{
		gap: 30px;
	}
	.g-sns li{
		width: 43px;
	}
}
@media screen and (max-width: 767px){
	.ft-logo{
		width: 97px;
		margin: 0 auto;
		padding: 80px 0;
	}
	.ft-sns{
		margin: 50px 0;
	}
	.g-sns{
		justify-content: center;
		gap: 30px;
	}
	.g-sns li{
		width: 43px;
	}
}
/* カレンダー */
.ft-calendarContainer{
	display: grid;
}
.ft-calendar{
	width: 100%;
	color: var(--DARK01);
	--SUN_COLOR: #FF0000;
	--SAT_COLOR: #6D98DD;
}
.ft-calendar > div{
	padding-bottom: 15px;
	background-color: var(--WHITE);
}
.monthName{
	text-align: center;
	background-color: var(--GREEN02_OP50);
	color: var(--WHITE);
	padding: 10px 0;
}
.TableInner{
	padding: 16px;
}
#calendarTable{
	width: 100%;
	border-collapse: collapse;
}
#calendarTable th{
	font-weight: var(--FF_W_R);
}
#calendarTable tbody tr{
	display: flex;
}
#calendarTable tbody tr > *{
	flex: 1;
	text-align: center;
	font-size: 14px;
	padding: 3px 0;
}
#calendarTable tbody tr th{
	color: var(--DARK01);
}
#calendarTable tbody tr .youbi_0,
#calendarTable tbody tr td.public_holiday{
	color: var(--SUN_COLOR);
}
#calendarTable tbody tr .youbi_6{
	color: var(--SAT_COLOR);
}
.public_holiday,
.closed,
.kyugyobi{
	position: relative;
	z-index: 0;
}
.public_holiday::after,
.closed::after,
.kyugyobi::after{
	content: "";
	display: inline-block;
	background-color: var(--GRAY01);
	aspect-ratio: 1/1;
	width: 22px;
	position: absolute;
	z-index: -1;
}
.public_holiday::after,
.closed::after{
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
}
.kyugyobi::after{
	left: -30px;
	top: 2px;
}
.kyugyobi{
	color: var(--DARK01);
	width: fit-content;
	margin: 0 15px 0 auto;
}
.ft-calendar__note{
	color: var(--TXT_COLOR_BEIGE_1);
}
@media screen and (min-width: 768px){
	.ft-calendarContainer{
		gap: 14px;
		margin-bottom: var(--GAP_50);
	}
	.ft-calendar{
		display: grid;
		grid-template-columns: repeat(2, 1fr);
		gap: 25px;
	}
	.ft-calendar__note{
		font-size: var(--FZ_13_CONST);
	}
}
@media screen and (max-width: 767px){
	.ft-calendarContainer{
		gap: 14px;
		margin-bottom: var(--MG_50);
	}
	.ft-calendar div:last-child{
		display: none;
	}
}
/* ft-mailmag */
.ft-mailmag__heading,
.ft-mailmag__subscTtl,
.ft-mailmag__unsubscLink a{
	color: var(--TXT_COLOR_BEIGE_1);
}
.ft-mailmag__unsubscLink a:visited{
	color: var(--TXT_COLOR_BEIGE_1);
}
.ft-mailmag__body{
	border: 1px solid var(--BGCOLOR_BEIGE_1);
	border-left: none;
	border-right: none;
}
.ft-mailmag__subscTtl{
	font-weight: var(--FF_W_B);
}
.ft-mailmag__from{
	display: grid;
	align-items: stretch;
}
.ft-mailmag__from.formReset input[type="text"]{
	background-color: var(--WHITE);
}
.ft-mailmag__from.formReset input[type="text"]::placeholder{
	color: var(--TXT_BGCOLOR_GRAY_1);
}
.ft-mailmag__from.formReset input[type="submit"]{
	background-color: var(--BLUE02);
	display: flex;
	justify-content: center;
	align-items: center;
	text-align: center;
}
.ft-mailmag__unsubscLink a{
	font-size: 13px;
}
@media screen and (min-width: 768px){
	.ft-mailmag__heading{
		font-weight: var(--FF_W_B);
		font-size: var(--FZ_18);
		margin-bottom: 5px;
	}
	.ft-mailmag__body{
		padding: 20px;
	}
	.ft-mailmag__from{
		grid-template-columns: 1fr 120px;
		gap: 10px;
		margin: 10px 0;
	}
	.ft-mailmag__from.formReset input[type="text"]{
		padding: 13px 20px;
	}
}
@media screen and (max-width: 767px){
	.ft-mailmag__heading{
		font-size: var(--FZ_16_CONST);
		text-align: center;
		line-height: 2;
		margin-bottom: 10px;
	}
	.ft-mailmag__body{
		padding: 15px 0;
	}
	.ft-mailmag__subscTtl{
		text-align: center;
	}
	.ft-mailmag__from{
		grid-template-columns: 1fr 80px;
		gap: 5px;
		margin: 10px 0;
	}
	.ft-mailmag__from.formReset input[type="text"]{
		padding: 13px 20px;
	}
	.ft-mailmag__unsubscLink{
		text-align: center;
	}
}
/* ft-linkSp */
.ft-linkSp li a:visited{
	color: var(--TXT_COLOR_BEIGE_1);
}
@media screen and (max-width: 767px){
	.ft-linkSp{
		display: grid;
		grid-template-columns: repeat(2, 1fr);
	}
	.ft-linkSp li{
		border-bottom: 1px solid var(--BGCOLOR_BEIGE_1);
	}
	.ft-linkSp li:last-child{
		grid-column: span 2;
	}
	.ft-linkSp li a{
		display: flex;
		align-items: center;
		font-size: var(--FZ_12_CONST);
		color: var(--TXT_COLOR_BEIGE_1);
		height: 50px;
		line-height: 1.4;
	}
	.ft-linkSp li:nth-child(odd) a{
		padding-left: 10px;
	}
}
/* ft-copy */
.ft-copy{
	color: var(--TXT_COLOR_BEIGE_1);
}
@media screen and (min-width: 768px){
	.ft-copy{
		margin-top: var(--GAP_50);
		font-size: var(--FZ_14);
		padding-bottom: 30px;
	}
}
@media screen and (max-width: 767px){
	.ft-copy{
		font-size: var(--FZ_12_CONST);
		padding-bottom: 100px;
	}
}
/* ft-spMenuContainer */
@media screen and (max-width: 767px){
	:root{
		--SP_MENU_HEIGT: 64px;
	}
	.ft-spMenuContainer{
		position: fixed;
		bottom: 0;
		left: 0;
		z-index: 999;
		background-color: var(--WHITE);
		width: 100%;
		height: var(--SP_MENU_HEIGT);
		padding: 8px 0;
	}
	.ft-spMenu{
		display: flex;
		height: 100%;
	}
	.ft-spMenu li{
		flex: 1;
	}
	.ft-spMenu li:not(:last-child){
		border-right: 1px solid var(--BDCOLOR_GRAY_1);
	}
	.ft-spMenu li a{
		display: block;
		height: 100%;
		background-repeat: no-repeat;
		background-position: top 5px center;
		background-size: 25px;
		position: relative;
	}
	.ft-spMenu li a::after{
		content: attr(data-text);
		display: block;
		width: 100%;
		text-align: center;
		position: absolute;
		bottom: 1px;
		left: 0;
		white-space: break-spaces;
		font-size: 10px;
		letter-spacing: 0.05em;
		line-height: 1.1;
	}
	.ft-spMenu li a .fs-client-cart-count{
		top: -5px;
		left: 55%;
	}
}

/* ■■■■■■■■■■■■■■■■■■■■■■side■■■■■■■■■■■■■■■■■■■■■■ */


/* ■■■■■■■■■■■■■■■■■■■■■■全ページ共通部分■■■■■■■■■■■■■■■■■■■■■■ */
/* -----------------dummyImg----------------- */
.dummyImg{
	position: relative;
}
.dummyImg::before{
	content: "ダミー画像";
	display: inline-block;
	background: rgba(33, 33, 33, 0.5);
	color: #e81010;
	text-shadow: 0 0 5px #fff;
	font-weight: bold;
	width: 100%;
	height: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	position: absolute;
	top: 0;
	left: 0;
	z-index: 2;
}
/* -----------------タブ切り替え共通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%;
	background: url(../images/common/sp/icon_batsu.svg) no-repeat center center / 70%;
	top: 0;
	right: 0;
}
@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 (hover: hover){
	.popup-overlay button.closePopup:hover{
		cursor: pointer;
	}
}
@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(--BLACK);
	--FS_BTN_COLOR_2: var(--BLUE03);
	--REVIEW_COLOR: #edc622;
}
/* 内部幅設定 */
#wrapper{
	margin-left: auto;
	margin-right: auto;
	width: var(--INNER_WIDTH);
	max-width: var(--PC_MAX_WIDTH_L);
	margin-bottom: var(--GENERALSEC);
}
.bgcolor--bodyGray > #wrapper{
	margin-bottom: 0;
}
#mainarea{
	flex: 1;
}
#sidearea{
	background-color: #f2f2f2;
}
@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(--ORANGE01);
	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: 7px 16px 8px;
	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{
	background-color: var(--WHITE);
}
.fs-c-breadcrumb__list{
  padding: 0;
	width: var(--INNER_WIDTH);
	max-width: var(--PC_MAX_WIDTH_L);
	margin-left: auto;
	margin-right: auto;
}
#wrapper .fs-c-breadcrumb__list{
	width: 100%;
}
.bgcolor--bodyGray #wrapper .fs-c-breadcrumb__list{
	width: var(--INNER_WIDTH);
}
.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_BASE);
}
.fs-c-breadcrumb li a{
	text-decoration: underline;
}
@media screen and (min-width: 768px) {
	.fs-c-breadcrumb {
		padding: 10px 0;
		font-size: 14px;
		margin-bottom: 30px;
	}
}
@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;
	}
}
body:has(main.bgcolor--bodyGray) .fs-c-breadcrumb{
	margin-bottom: 0;
}
.bgcolor--bodyGray .fs-c-breadcrumb{
	margin: 0 var(--FULL_WIDTH);
	border-bottom: 1px solid var(--BLACK);
	margin-bottom: 0;
}
/* レビュー */
.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;
	align-items: center;
}
#next > span.pages{
	display: block;
	text-align: center;
	margin-top: 10px;
	display: none;
}
.found-postContainer,
.fs-c-listControl__status,
#next .post_range{
	font-size: 13px;
	text-align: center;
	margin-bottom: 16px;
	color: var(--TXT_COLOR);
}
.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(--BLUE01);
	color: var(--WHITE);
}
.fs-c-pagination > *,
.wp-pagenavi > *{
	font-weight: var(--FF_W_M);
}
.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{
	background-color: var(--GRAY02);
	display: flex;
	justify-content: center;
	text-align: center;
	align-items: center;
	padding: 0;
	position: relative;
	font-weight: var(--FF_W_R);
	width: 30px;
	height: 30px;
}
#next a.previouspostslink .navi-prev,
#next a.nextpostslink .navi-next{
	position: absolute;
	top: 50%;
	left: 52%;
	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: var(--FF_W_R);
	display: inline-block;	color: var(--WHITE);
  vertical-align: text-bottom;
	position: absolute;
	top: 54%;
	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: 15px;
	}
	#next {
		margin: var(--MG_50) auto 0;
	}
	.fs-c-pagination > *,
	.wp-pagenavi > *{
		width: 45px;
	}
	.fs-c-pagination__item--next:hover{
		color: var(--WHITE);
	}
	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{
		font-size: 13px;
		width: 30px;
		height: 30px;
	}
}
@media screen and (max-width: 767px){
	.fs-c-pagination,
	.wp-pagenavi{
		font-size: 12px;
		gap: 3px;
	}
	#next {
		margin: var(--MG_30) auto 0;
	}
	.fs-c-pagination > *,
	.wp-pagenavi > *{
		width: 30px;
	}
	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{
		font-size: 10px;
		width: 25px;
		height: 25px;
	}
}
/* aiレコメンドリセット */
.fs-p-heading--lv2,
.fr3-item__rankContainer{
	display: none;
}
.fr3-productListStatic{
	padding: 0 !important;
}
.fr3-item__productPrice__price{
	font-size: unset;
}
@media (hover: hover){
	.fr3-item a:hover{
		color: var(--TXT_COLOR_BASE);
	}
}
/* 404イメージ画像 */
@media screen and (min-width: 768px){
  .fs-p-closed__image{
		width: 300px;
		padding: 30px 0;
	}
}
@media screen and (max-width: 767px){
	.fs-p-closed__image{
		width: 200px;
		padding-bottom: 15px;
	}
}
/* -------------------g-heading-------------------- */
h1.g-heading{
	padding: var(--GENERALSEC_HALF) 0;
}
.g-heading > span{
	display: block;
}
.g-heading--center > span{
	text-align: center;
}
.g-heading__en{
	font-family: var(--FF_EN);
}
.g-heading__ja{
	font-weight: 900;
	line-height: 1.7;
}
h3 .g-heading__ja{
	font-weight: 700;
}
@media screen and (min-width: 768px){
  .g-headingContainer,
	.g-heading--history{
		margin-bottom: var(--GAP_40);
	}
	.g-heading__ja{
		font-size: var(--FZ_40);
	}
	.g-heading__en{
		font-size: var(--FZ_16);
	}
	.g-headingContainer:has(h3){
		margin-bottom: var(--GAP_30);
	}
	h3 .g-heading__ja,
	.g-heading--history .g-heading__ja{
		font-size: var(--FZ_30);
	}
}
@media screen and (max-width: 767px){
	.g-headingContainer{
		margin-bottom: var(--MG_20);
	}
	.g-heading__ja{
		font-size: 28px;
	}
	.g-heading__en{
		font-size: var(--FZ_16);
	}
	.g-headingContainer:has(h3),
	.g-heading--history{
		margin-bottom: var(--GAP_30);
	}
	h3 .g-heading__ja{
		font-size: 20px;
	}
	.g-heading--centerSp > span{
		text-align: center;
	}
	.g-heading--history .g-heading__ja{
		font-size: 22px;
	}
}
/* -------------------g-btn-------------------- */
.g-btnContainer{
	display: grid;
}
.g-btnContainer--horizontal{
	display: flex;
	justify-content: center;
}
.g-btn,
.fs-c-continueShopping{
	width: 100%;
}
.g-btn--long{
	width: var(--INNER_WIDTH);
	max-width: 388px;
}
.g-btn a,
.fs-c-continueShopping a.fs-c-button--standard{
	display: block;
	text-align: center;
	letter-spacing: 0.1em;
	position: relative;
	border: 1px solid var(--BLACK);
	text-decoration: none !important;
}
.g-btn--white a,
.fs-c-continueShopping a.fs-c-button--standard{
	background-color: var(--WHITE);
	border: 1px solid var(--BLACK);
}
.g-btn--black a{
	background-color: var(--BLACK);
	color: var(--WHITE) !important;
}
.g-btn--black a:visited{
	color: var(--WHITE);
}
.g-btn--yellow a{
	background-color: var(--YELLOW01);
	border-color: var(--YELLOW01);
}
.g-btn--center,
.fs-c-continueShopping{
	margin-left: auto;
	margin-right: auto;
}
.g-btn--link a{
	position: relative;
}
.fs-c-continueShopping a.fs-c-button--standard{
	letter-spacing: 0.1em;
}
.g-btn--link a::after,
.fs-c-continueShopping a.fs-c-button--standard::after{
	/* font-family: 'Font Awesome 5 Pro';
	font-weight: 100;
	content: '\f054';
	color: var(--BDCOLOR_GRAY_2);
	position: absolute; */
}
.g-btn--anchor a::after{
	transform: rotate(90deg);
}
.g-btn--return a::after,
.fs-c-continueShopping a.fs-c-button--standard::after{
	transform: rotate(180deg) translateX(5px);
}
.g-btn--anchor a::after{
	content: "";
	display: inline-block;
	background: url(../images/common/anchor.svg) no-repeat center center / 100%;
	aspect-ratio: 1/1;
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
}
@media (hover: hover){
	.g-btn a:hover,
	.fs-c-continueShopping a.fs-c-button--standard:hover{
		opacity: 1;
	}
	.g-btn--white a:hover,
	.fs-c-continueShopping a.fs-c-button--standard:hover{
		opacity: 1;
		background-color: var(--BLACK);
		border: 1px solid var(--BLACK);
		color: var(--WHITE);
	}
	.g-btn--black a:hover{
		opacity: 1;
		background-color: var(--WHITE);
		color: var(--BLACK) !important;
	}
	.g-btn--yellow a:hover{
		opacity: 1;
		background-color: var(--BLACK);
		border-color: var(--WHITE);
		color: var(--WHITE);
	}
}
@media screen and (min-width: 768px){
	.g-btnContainer{
		margin-top: var(--MG_50);
	}
	.g-btnContainer--horizontal{
		gap: var(--GAP_30);
	}
	.g-btnContainer--horizontalPc{
		display: flex;
		justify-content: center;
		gap: var(--GAP_30);
	}
	.g-btnContainer--vertical{
		gap: var(--GAP_20);
	}
	.g-btn,
	.fs-c-continueShopping{
		max-width: 300px;
	}
	.g-btn--longPc{
		width: var(--INNER_WIDTH);
		max-width: 388px;
	}
	.g-btn--small{
		max-width: 198px;
	}
	.g-btn a{
		font-size: var(--FZ_16_CONST);
		padding: 20px 0;
	}
	.g-btn--small a{
		padding: 12px 0;
	}
	.fs-c-continueShopping a.fs-c-button--standard{
		font-size: var(--FZ_14_CONST);
		padding: 15px 0;
	}
	.g-btn--link a::after,
	.fs-c-continueShopping a.fs-c-button--standard::after{
		font-size: 12px;
		top: 28%;
		right: 5px;
	}
	.fs-c-continueShopping a.fs-c-button--standard::after{
		top: 36%;
	}
	.g-btn--anchor a::after{
		width: 30px;
		right: 10px;
	}
	.fs-c-continueShopping a.fs-c-button--standard{
		margin: 40px 0 var(--GENERALSEC);
	}
}
@media screen and (max-width: 767px){
	.g-btnContainer{
		margin-top: var(--MG_40);
	}
	.g-btnContainer--horizontal{
		gap: var(--GAP_20);
	}
	.g-btnContainer--vertical,
	.g-btnContainer--horizontalPc{
		gap: var(--GAP_20);
	}
	.g-btnContainer--vertical .g-btn,
	.g-btnContainer--horizontalPc .g-btn{
		margin-left: auto;
		margin-right: auto;
	}
	.g-btn,
	.fs-c-continueShopping{
		max-width: 260px;
	}
	.g-btn--small{
		max-width: 198px;
	}
	.g-btn a,
	.fs-c-continueShopping a.fs-c-button--standard{
		font-size: var(--FZ_14_CONST);
		padding: 20px 0;
	}
	.g-btn--small a{
		padding: 12px 0;
	}
	.fs-c-continueShopping a.fs-c-button--standard{
		font-size: var(--FZ_14_CONST);
		padding: 15px 0;
	}
	.g-btn--longPc a{
		font-size: var(--FZ_12_CONST);
		letter-spacing: 0.05em;
	}
	.g-btn--link a::after,
	.fs-c-continueShopping a.fs-c-button--standard::after{
		font-size: 12px;
		top: 28%;
		right: 5px;
	}
	.fs-c-continueShopping a.fs-c-button--standard::after{
		top: 36%;
	}
	.g-btn--anchor a::after{
		width: 25px;
		right: 10px;
	}
	.fs-c-continueShopping a.fs-c-button--standard{
		margin: 20px 0 var(--GENERALSEC);
	}
}
/* ------------------g-txt------------------ */
.g-txt{
	display: grid;
}
.g-txt mark{
	background: linear-gradient(transparent 70%, #fff799 30%);
}
.g-txt p:not(.g-btn) a{
	color: var(--BLUE03);
	text-decoration: underline;
}
.g-txt__list > li{
	position: relative;
}
.g-txt__list > li::before{
	content: '';
	display: inline-block;
	background: var(--BLACK);
	aspect-ratio: 1/1;
	border-radius: 50%;
	position: absolute;
	top: 50%;
	left: 0;
	transform: translateY(-50%);
}
.g-txt__note li{
	position: relative;
	color: var(--GRAY03);
}
.g-txt__note li::before{
	content: '※';
	position: absolute;
	top: 0;
	left: 0;
}
.g-txt__order{
	counter-reset: original-counter;
}
.g-txt__order > li::before{
	content: counter(original-counter)'.';
	counter-increment: original-counter;
}
.g-txt__note02{
	color: var(--GRAY03);
}
.g-txt__note02-red{
	color: #FF0000;
}
.g-txtBgc{
	background-color: var(--YELLOW01);
	padding: 20px 25px;
}
.g-txtPoint{
	text-align: center;
}
@media screen and (min-width: 768px){
	.g-txt *{
		font-size: var(--FZ_16);
	}
	.g-txt p:has(mark){
		line-height: 2.5;
	}
	.g-txt > p:not(:first-child){
		margin-top: var(--GAP_40);
	}
	.g-txt > *+.g-txt__list{
		margin-top: var(--GAP_20);
	}
	.g-txt mark{
		padding: 2px 5px 3px;
	}
	.g-txt__list > li{
		padding-left: 15px;
	}
	.g-txt__list > li::before{
		width: 4px;
		top: 12px;
	}
	.g-txt__note li{
		font-size: var(--FZ_12);
		padding-left: 15px;
	}
	.g-txtBgc{
		margin-top: 20px;
	}
	.g-txtPoint{
		font-size: 20px;
	}
}
@media screen and (max-width: 767px){
	.g-txt *{
		font-size: var(--FZ_14);
	}
	.g-txt p:has(mark){
		line-height: 2.5;
	}
	.g-txt > p:not(:first-child){
		margin-top: var(--GAP_20);
	}
	.g-txt > *+.g-txt__list{
		margin-top: var(--GAP_20);
	}
	.g-txt mark{
		padding: 2px 5px 3px;
	}
	.g-txt__list > li{
		padding-left: 12px;
	}
	.g-txt__list > li::before{
		width: 4px;
		top: 11px;
	}
	.g-txt__note li{
		font-size: var(--FZ_12);
		padding-left: 15px;
	}
	.g-txtBgc{
		margin-top: 12px;
	}
	.g-txtPoint{
		font-size: 17px;
	}
}
/* ------------------g-descWithImg------------------ */
.g-descWithImg{
	display: grid;
	gap: var(--GENERALSEC);
}
.g-descWithImg__desc{
	display: grid;
}
@media screen and (min-width: 768px){
	.g-descWithImg li{
		display: flex;
		gap: var(--GAP_40);
		align-items: flex-start;
	}
	.g-descWithImg--crossList li:nth-child(even){
		flex-direction: row-reverse;
	}
	.g-descWithImg li > *{
		flex: 1;
	}
	.g-descWithImg__desc{
		gap: var(--GAP_30);
	}
}
@media screen and (max-width: 767px){
	.g-descWithImg li{
		display: grid;
		gap: var(--GAP_20_CONST);
	}
	.g-descWithImg__desc{
		gap: var(--GAP_30);
	}
}
/* -------------------g-slickArrow---------------------- */
[class*="g-slickArrow--"]{
	width: var(--SLICK_ARROW_SIZE);
	background: url(../images/common/slider-part.svg) no-repeat center center / 100%;
	aspect-ratio: 1/1;
	position: absolute;
	z-index: 2;
}
.g-slickArrow--prev{
	left: var(--SLICK_ARROW_TO_BODY);
}
.g-slickArrow--next{
	right: var(--SLICK_ARROW_TO_BODY);
	transform: rotate(180deg);
}
@media (hover: hover){
	[class*="g-slickArrow--"]:hover{
		cursor: pointer;
	}
}
@media screen and (min-width: 768px){
	.g-hasSlickArrow{
		--SLICK_ARROW_SIZE: clamp( 20px, 3vw, 40px);
		--SLICK_ARROW_TO_BODY: calc(0px - var(--SLICK_ARROW_SIZE) + var(--SLICK_GAP) - 5px);
	}
}
@media screen and (max-width: 767px){
	.g-hasSlickArrow{
		--SLICK_ARROW_SIZE: 25px;
		--SLICK_ARROW_TO_BODY: 5px;
		overflow-x: clip;
	}
}
/* -------------------g-slickDots-------------------- */
.slick:has(.g-slickDots){
	line-height: 1;
	margin-bottom: 0;
}
.g-slickDots{
	display: flex;
	justify-content: center;
	gap: var(--GAP_10);
}
.g-slickDots button{
	font-size: 0;
	width: 50px;
	height: 20px;
	position: relative;
}
.g-slickDots button::before{
	content: "";
	display: inline-block;
	background: var(--GRAY02);
	width: 100%;
	height: 2px;
	position: absolute;
	left: 0;
	top: 50%;
	transform: translateY(-50%);
}
.g-slickDots .slick-active button::before{
	background: var(--BROWN01);
}
/* -------------------g-newsContainer-------------------- */
.g-newsContainer .g-news{
	display: flex;
	align-items: center;
}
.g-newsContainer .g-news__ttl{
	width: fit-content;
	font-family: var(--FF_EN);
	font-weight: var(--FF_W_B);
	letter-spacing: 0.05em;
}
.g-newsContainer .g-news__list{
	flex: 1;
}
.g-newsContainer .g-news__list .slick-slide > div{
	display: flex;
	align-items: center;
}
.g-newsContainer .g-news__list__date{
	width: fit-content;
}
.g-newsContainer .g-news__list__ttl{
	flex: 1;
}
.g-newsContainer .g-news__list__ttl a{
	overflow: hidden;
	-webkit-line-clamp: 1;
	-webkit-box-orient: vertical;
	display: -webkit-box;
}
.g-newsContainer .g-news__list__ttl .g-news__list__cat{
	display: none;
}
.g-newsContainer .g-news__list__body{
	display: none;
}
@media screen and (min-width: 768px){
	.g-newsContainer{
		background-color: var(--BGCOLOR_GRAY_1_OP95);
	}
	.g-newsContainer .g-news{
		gap: var(--GAP_20);
		padding: 15px var(--GAP_20);
	}
	.g-newsContainer .g-news__ttl{
		font-size: var(--FZ_22);
	}
  .g-newsContainer .g-news__list li a{
		font-size: var(--FZ_14);
		gap: 17px;
	}
}
@media screen and (max-width: 767px){
  .g-newsContainer{
		background-color: var(--BGCOLOR_GRAY_1_OP90);
	}
	.g-newsContainer .g-news{
		gap: var(--GAP_20);
		padding: 10px 0 10px;
	}
	.g-newsContainer .g-news__ttl{
		font-size: var(--FZ_18_CONST);
	}
	.g-newsContainer .g-news__list li a{
		font-size: 11px;
		gap: 5px;
	}
	.g-newsContainer .g-news__list__date{
		display: block;
	}
}
/* -------------------bgcolor-------------------- */
.bgcolor--gray{
	background-color: var(--BGCOLOR_GRAY_1);
}
.bgcolor--bodyGray{
	background-color: var(--BGCOLOR_BODY_GRAY);
}
.bgcolor--lightBlue{
	background-color: var(--BLUE01);
}
.bgcolor--darkBlue{
	background-color: var(--BLUE03);
}
/* ------------------- -------------------- */
.g-product__name{
	line-height: 1.3;
}
.g-product__price{
	display: flex;
	align-items: baseline;
}
.g-product__price > *{
	line-height: 1;
}
.g-product__price__addon{
	display: flex;
	align-items: baseline;
	gap: 3px;
}
.g-product__price__addon__tax{
	color: var(--TXT_BGCOLOR_GRAY_1);
}
@media screen and (min-width: 951px){
  .g-product--col5{
		grid-template-columns: repeat(5, 1fr);
	}
}
@media screen and (min-width: 768px) and (max-width: 950px){
	.g-product--col5{
		grid-template-columns: repeat(4, 1fr);
	}
	.g-product--col5 article:nth-of-type(n+5){
		display: none;
	}
}
@media screen and (min-width: 768px){
	.g-product{
		display: grid;
		gap: 40px var(--GAP_20);
	}
	.g-product--col4{
		grid-template-columns: repeat(4, 1fr);
	}
	.g-product--col3{
		grid-template-columns: repeat(3, 1fr);
	}
	.g-product__thumb{
		margin-bottom: 10px;
	}
	.g-product__name{
		font-size: var(--FZ_14);
		margin-bottom: 7px;
	}
	.g-product__price__main{
		font-size: var(--FZ_16);
	}
	.g-product__price__addon{
		font-size: var(--FZ_11);
	}
}
@media screen and (max-width: 767px){
	.g-product:not(.g-product--ranking){
		display: grid;
		grid-template-columns: repeat(2, 1fr);
		gap: 25px 15px;
	}
	.g-product__thumb{
		margin-bottom: 10px;
	}
	.g-product__name{
		font-size: var(--FZ_14);
		margin-bottom: 7px;
	}
	.g-product__price__main{
		font-size: var(--FZ_16);
	}
	.g-product__price__addon{
		font-size: var(--FZ_11);
	}
}
/* g-product--ranking */
.g-product--ranking{
	counter-reset: original-counter;
}
.g-product--ranking article{
	position: relative;
}
.g-product--ranking article::before{
	display: inline-block;
	content: ''counter(original-counter);
	counter-increment: original-counter;
	font-family: var(--FF_NUM);
	font-weight: var(--FF_W_B);
	aspect-ratio: 1/1;
	background-color: var(--WHITE);
	clip-path: polygon(0 0, 0% 100%, 100% 0);
	line-height: 1;
	position: absolute;
	top: 0;
	left: 0;
	z-index: 2;
}
.g-product--ranking article:nth-of-type(1)::before{
	color: var(--RANKING_1ST);
}
.g-product--ranking article:nth-of-type(2)::before{
	color: var(--RANKING_2ND);
}
.g-product--ranking article:nth-of-type(3)::before{
	color: var(--RANKING_3RD);
}
@media screen and (min-width: 768px){
	.g-product--ranking article::before{
		width: 50px;
		padding: 5px 0 0 8px;
		font-size: var(--FZ_20_CONST);
	}
}
@media screen and (max-width: 767px){
	.g-product.sp-scroll--x{
		display: flex;
		gap: 10px;
	}
	.g-product.sp-scroll--x article{
		flex: 0 0 auto;
		min-width: 160px;
		max-width: 160px;
	}
	.g-product.sp-scroll--x article::before{
		width: 40px;
		padding: 5px 0 0 8px;
		font-size: var(--FZ_18_CONST);
	}
}
/* -------------------containerWhite-------------------- */
.g-containerWhite{
	background-color: var(--WHITE);
}
@media screen and (min-width: 768px){
  .g-containerWhite{
		border-radius: 50px;
		padding-top: 50px;
	}
}
@media screen and (max-width: 767px){
	.g-containerWhite{
		padding-top: 30px;
		border-radius: 20px;
	}
}
/* -------------------g-linkPanel-------------------- */
.g-linkPanel{
	display: grid;
}
.g-linkPanel__item a{
	display: block;
	background-color: var(--BGCOLOR_GRAY_1);
	position: relative;
}
.g-linkPanel__item--hasIcon a{
	text-align: center;
}
.g-linkPanel__item__icon{
	aspect-ratio: 1/1;
	position: absolute;
}
.g-linkPanel__item__name{
	font-weight: var(--FF_W_B);
}
.g-linkPanel__item__arrow{
	width: 100%;
	display: block;
	position: absolute;
	bottom: 0;
	left: 0;
	background-color: var(--BLACK);
}
.g-linkPanel__item__arrow::after{
	font-family: 'Font Awesome 5 Pro';
	font-weight: 500;
	content: '\f054';
	font-size: 16px;
	position: absolute;
	color: var(--WHITE);
	top: 50%;
	transform: translateY(-50%);
}
.g-linkPanel__item--targetBlank a{
	position: relative;
}
.g-linkPanel__item--targetBlank a::after{
	content: "";
	display: inline-block;
	background: url(../images/common/logo_link.svg) no-repeat center center / 100%;
	aspect-ratio: 1/1;
	position: absolute;
	z-index: 2;
}
.g-linkPanel__item a:hover,.g-guide a:hover{
	color: var(--TXT_COLOR_BASE);
	text-decoration: none;
}
@media screen and (min-width: 768px){
  .g-linkPanel{
		gap: var(--GAP_20);
	}
	.g-linkPanel--col2{
		grid-template-columns: repeat(2, 1fr);
	}
	.g-linkPanel--col3{
		grid-template-columns: repeat(3, 1fr);
	}
	.g-linkPanel__item{
		flex: 1;
	}
	.g-linkPanel__item__icon{
		width: clamp( 65px, 7.5vw, 90px);
		left: 30px;
		top: 15%;
	}
	.g-linkPanel--col2 li a{
		padding: 40px 0 63px;
	}
	.g-linkPanel--col3 li a{
		padding: 25px clamp( 20px, 3vw, 40px) 43px;
	}
	.g-linkPanel__item--targetBlank a::after{
		width: 15px;
		top: 10px;
		right: 10px;
	}
	.g-linkPanel--col2 .g-linkPanel__item__name{
		font-size: var(--FZ_30);
	}
	.g-linkPanel--col3 .g-linkPanel__item__name{
		font-size: var(--FZ_22);
	}
	.g-linkPanel__item__arrow{
		height: 23px;
	}
	.g-linkPanel__item__arrow::after{
		right: 7px;
		font-size: 12px;
	}
}
@media screen and (max-width: 767px){
	.g-linkPanel{
		gap: var(--GAP_20_CONST);
	}
	.g-linkPanel__item--hasIcon a{
		padding: 25px 0 45px;
	}
	.g-linkPanel__item--onlyTxt a{
		padding: 20px 30px 40px;
	}
	.g-linkPanel__item--targetBlank a::after{
		width: 15px;
		top: 10px;
		right: 10px;
	}
	.g-linkPanel__item__icon{
		width: 53px;
		top: 12%;
		left: 14px;
	}
	.g-linkPanel__item__name{
		font-size: var(--FZ_20_CONST);
	}
	.g-linkPanel__item__arrow{
		height: 15px;
	}
	.g-linkPanel__item__arrow::after{
		right: 5px;
		font-size: 9px;
	}
}
/* -------------------tab-wrap--test-------------------- */
.tab-wrap--test .tab-btn{
	background-color: var(--GRAY03);
}
.tab-wrap--test .tab-btn.show{
	background-color: var(--BLACK);
}
@media screen and (min-width: 768px){
	.tab-wrap--test .tab-nav{
		align-items: flex-end;
		gap: 5px;
		margin-bottom: 20px;
	}
	.tab-wrap--test .tab-btn{
		height: clamp( 50px, 6vw, 70px);
		display: flex;
		justify-content: center;
		align-items: center;
		justify-content: center;
	}
	.tab-wrap--test .tab-btn.show{
		height: clamp( 60px, 7vw, 90px);
		width: 70%;
	}
	.tab-wrap--test .tab-btn img{
		margin-top: 10px;
		width: 40%;
	}
}
@media screen and (max-width: 767px){
	.tab-wrap--test .tab-nav{
		gap: 5px;
		margin-bottom: 15px;
	}
	.tab-wrap--test .tab-btn{
		padding: 10px 0 21px;
		display: flex;
		justify-content: center;
		align-items: center;
		justify-content: center;
		position: relative;
	}
	.tab-wrap--test .tab-btn::after{
		font-family: 'Font Awesome 5 Pro';
		font-weight: 500;
		content: '\f078';
		font-size: 12px;
		position: absolute;
		left: 50%;
		transform: translateX(-50%);
		bottom: 5px;
		color: var(--WHITE);
		line-height: 1;
	}
	.tab-wrap--test .tab-btn img{
		width: 80%;
	}
}
/* -------------------g-viewMore-------------------- */
.g-viewMore{
	width: fit-content;
	text-decoration: underline;
	font-weight: 500;
	font-size: var(--FZ_12_CONST);
	letter-spacing: 0.05em;
}
/* ------------------g-heading--------------------- */
.g-history__more{
	margin-left: auto;
}
@media screen and (min-width: 951px){
	.g-history{
		grid-template-columns: repeat(7,1fr);
	}
}
@media screen and (min-width: 768px) and (max-width: 950px){
	.g-history{
		grid-template-columns: repeat(6,1fr);
	}
	.g-history li:nth-of-type(n+7){
		display: none;
	}
}
@media screen and (min-width: 768px){
	.g-history{
		display: grid;
		gap: var(--GAP_20);
	}
	.g-history__more{
		margin-top: 20px;
	}
}
@media screen and (max-width: 767px){
	.g-history{
		display: flex;
		gap: 10px;
	}
	.g-history li{
		min-width: 100px;
		max-width: 100px;
	}
	.g-history__more{
		margin-top: 20px;
	}
}
/* ------------------g-guide--------------------- */
.g-guide__icon{
	background: var(--BLACK) no-repeat center center / 50%;
	border-radius: 50%;
	aspect-ratio: 1/1;
}
.i-registerGuidance .g-guide p{
	background-size: 70%;
}
.g-guide__ttl{
	font-weight: var(--FF_W_M);
}
@media screen and (min-width: 768px){
	.g-guideSection{
		background-color: var(--BGCOLOR_GRAY_1);
	}
	.g-guide{
		display: flex;
	}
	.g-guide li{
		flex: 1;
		padding: 0 var(--GAP_30);
	}
	.g-guide li:not(:last-child){
		border-right: 1px solid var(--BDCOLOR_GRAY_1);
	}
	.g-guide__icon{
		width: 76px;
		margin: 0 auto;
	}
	.g-guide__ttl{
		text-align: center;
		margin: 20px 0 15px;
		font-size: var(--FZ_19);
	}
	.g-guide__explainPc{
		font-size: var(--FZ_14);
	}
}
@media screen and (max-width: 767px){
	.g-guide{
		border-top: 1px solid var(--BDCOLOR_GRAY_1);
	}
	.g-guide li{
		border-bottom: 1px solid var(--BDCOLOR_GRAY_1);
	}
	.g-guide li a{
		display: grid;
		grid-template-columns: 40px 1fr;
		align-items: center;
		gap: 17px;
		padding: 15px calc((100% - var(--INNER_WIDTH)) / 2);
		position: relative;
	}
	.g-guide li a::after{
		font-family: 'Font Awesome 5 Pro';
		font-weight: 500;
		content: '\f054';
		font-size: 12px;
		position: absolute;
		top: 50%;
		transform: translateY(-50%);
		right: 5%;
		color: #646464;
	}
	.g-guide__ttl{
		font-size: var(--FZ_18_CONST);
	}
	.g-guide__ttl br{
		display: none;
	}
}
/* ------------------is-targetBlank--------------------- */
.is-targetBlank{
	display: inline-block;
	padding-right: 20px;
	position: relative;
}
.is-targetBlank::after{
	content: "";
	display: inline-block;
	background: url(../images/common/blank.svg) no-repeat center center / 100%;
	width: 15px;
	aspect-ratio: 1/1;
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	right: 0;
}
@media screen and (min-width: 768px){
	
}
@media screen and (max-width: 767px){
	
}
/* -------------------g-purpose------------------- */
.g-purpose{
  display: grid;
}
.g-purpose li a{
  display: block;
  border: 1px solid var(--BLACK);
  text-align: center;
  font-weight: var(--FF_W_M);
}
@media (hover: hover){
  .g-purpose li a:hover{
    background-color: var(--BLACK);
    color: var(--WHITE);
    opacity: 1;
  }
}
@media screen and (min-width: 768px){
  .g-purpose{
    grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
    gap: var(--GAP_20);
  }
  .g-purpose li a{
    font-size: var(--FZ_19);
    padding: 20px 0;
  }
}
@media screen and (max-width: 767px){
  .g-purpose{
    grid-template-columns: repeat(2,1fr);
    gap: 15px;
  }
  .g-purpose li a{
    font-size: var(--FZ_12_CONST);
    padding: 15px 0;
  }
}
/* -------------------お買い物ガイド------------------- */
.g-guideContents{
	--H3_BGCOLOR: #F5F5F5;
	--H2_BDCOLOR: #E5E5E5;
	margin-top: 3px;
	display: grid;
	gap: var(--GENERALSEC);
}
.g-guideColumn__heading,
.l-container h3.g-guideColumn__heading{
	font-weight: 700;
	border-left: 1px solid var(--BLUE01);
}
.g-guideColumn__ttl{
	font-weight: 700;
	border-bottom: 1px solid var(--BLACK);
}
.g-guideCredit{
	display: flex;
	align-items: center;
	gap: var(--GAP_5_CONST);
	margin: var(--GAP_20) 0;
}
.g-guideCredit li{
	flex: 1;
}
.g-guidePaymentLogo{
	margin: var(--GAP_30) 0 var(--GAP_20);
}
.g-guideTable{
	width: 100%;
	max-width: 540px;
	border-collapse: collapse;
}
.g-guideTable--bank{
	max-width: 300px;
}
.g-guideTable th,
.g-guideTable td{
	border: 1px solid var(--BLACK);
}
.g-guideTable th{
	font-weight: normal;
}
.g-guideTable thead th{
	background-color: var(--BLACK);
	color: var(--WHITE);
	font-weight: 700;
	padding: 5px 0;
}
.g-guideTable tbody th,
.g-guideTable tbody td{
	text-align: center;
}
.g-guideColumn__subttl{
	font-size: var(--FZ_14);
	font-weight: 400;
}
.g-guideColumn__subttl::before{
	content: '【';
}
.g-guideColumn__subttl::after{
	content: '】';
}
.g-guideNav__item li a{
	display: block;
	font-weight: 600;
}
.g-txt__underline{
  text-decoration: underline;
}
@media screen and (min-width: 768px){
	.g-guideContainer{
		display: grid;
		grid-template-columns: 200px 1fr;
		align-items: flex-start;
		gap: clamp( 80px, 8.5vw, 100px);
	}
	.g-guideNav{
		position: sticky;
		top: 105px;
		left: 0;
	}
	.g-guideNav__item li a{
		font-size: var(--FZ_16);
		padding: 10px 0;
	}
	.g-guideColumn__heading,
	.l-container h3.g-guideColumn__heading{
		font-size: var(--FZ_22);
		margin-bottom: var(--MG_40);
		padding-left: 12px;
		border-width: 5px;
	}
	.g-guideColumn__ttl{
		font-size: var(--FZ_20);
		padding-bottom: 12px;
		margin: var(--MG_50) 0 var(--MG_15);
	}
	.g-guideCredit{
		max-width: 240px;
	}
	.g-guidePaymentLogo--AmazonPay{
		width: 180px;
	}
	.g-guidePaymentLogo--PayPay{
		width: 130px;
	}
	.g-guidePaymentLogo--rakutenPay{
		width: 150px;
	}
	.g-guideTable{
		margin-top: var(--MG_20);
	}
	.g-guideTable tbody th,
	.g-guideTable tbody td{
		padding: 7px 20px;
	}
	.g-guideColumn__subttl{
		margin-top: var(--MG_20);
	}
}
@media screen and (max-width: 767px){
	.g-guideNav{
		--GUIDE_NAV_SP_BOX: 300px;
		--GUIDE_NAV_SP_BOX_TRIGGER: 40px;
		position: fixed;
		right: calc(0px - var(--GUIDE_NAV_SP_BOX) + var(--GUIDE_NAV_SP_BOX_TRIGGER));
		top: 150px;
		display: flex;
		width: var(--GUIDE_NAV_SP_BOX);
		transition: .5s;
		z-index: 99;
		opacity: 0;
	}
	body.scroll .g-guideNav{
		opacity: 0;
		animation: var(--ANIME_FADEIN);
	}
	body.scroll.returnTop .g-guideNav{
		opacity: 1;
		animation: var(--ANIME_FADEOUT);
	}
	.g-guideNav.active{
		right: 0;
	}
	.g-guideNav__spTrigger{
		width: var(--GUIDE_NAV_SP_BOX_TRIGGER);
		height: 200px;
		background-color: var(--GRAY01);
		display: flex;
		justify-content: center;
		align-items: center;
		border-radius: 5px 0 0 5px;
		border: 1px solid var(--GRAY03);
		border-right: none;
	}
	.g-guideNav__spTrigger::after{
		content: '目次';
		writing-mode: vertical-rl;
	}
	.g-guideNav.active .g-guideNav__spTrigger::after{
		content: '閉じる';
	}
	.g-guideNav__item{
		flex: 1;
		background-color: var(--WHITE);
		border: 1px solid var(--GRAY03);
	}
	.g-guideNav__item li a{
		padding: 8px 15px;
		font-size: 13px;
	}
	.g-guideColumn__heading,
	.l-container h3.g-guideColumn__heading{
		font-size: var(--FZ_18_CONST);
		margin-bottom: var(--MG_20);
		padding-left: 12px;
		border-width: 4px;
	}
	.g-guideColumn__ttl{
		font-size: var(--FZ_15_CONST);
		padding: 7px;
		margin: var(--MG_20) 0 var(--MG_10);
	}
	.g-guidePaymentLogo--AmazonPay{
		width: 150px;
	}
	.g-guidePaymentLogo--PayPay{
		width: 120px;
	}
	.g-guidePaymentLogo--rakutenPay{
		width: 120px;
	}
	.g-guideTable{
		margin-top: var(--MG_20);
	}
	.g-guideTable tbody th,
	.g-guideTable thead th,
	.g-guideTable tbody td{
		padding: 5px 15px;
		font-size: var(--FZ_12_CONST);
	}
	.g-guideColumn__subttl{
		margin-top: var(--MG_10);
	}
}
.g-txt__note .fontWeightBlack{
	color: var(--TXT_COLOR_BASE);
	font-weight: 700;
}
.blockMgb{
	display: block;
	margin-bottom: 10px;
}
.blockMgt{
	display: block;
	margin-top: 10px;
}
/* -------------------よくある質問------------------- */
.g-faq{
	border-bottom: 1px solid var(--GRAY01);
}
.g-faq--noBorder{
	border-bottom: none;
}
.g-faq dt,
.g-faq dd{
	position: relative;
}
.g-faq dt{
	font-weight: 700;
}
.g-faq dt::before,
.g-faq dd::before {
	font-family: var(--FF_EN);
	position: absolute;
}
.g-faq dt::before{
	content: 'Q';
  color: var(--FS_BTN_COLOR_1);
	font-weight: 700;
	line-height: 1;
}
.g-faq dd::before{
	content: 'A';
  color: var(--FS_BTN_COLOR_2);
	font-weight: 700;
	line-height: 1;
}
.g-faq .g-txt__note li{
	color: var(--TXT_COLOR_BASE);
}
@media screen and (min-width: 768px){
	.g-faq{
		margin-top: 20px;
	}
	.g-faq dd:not(:last-child){
		padding-bottom: 30px;
		margin-bottom: 30px;
	}
	.g-faq--noBorder dd:not(:last-child){
		margin-bottom: 50px;
	}
	.g-faq dt{
		font-size: var(--FZ_18);
		padding: 6px 50px 35px 59px;
	}
	.g-faq dd{
		padding: 6px 15px 40px 60px;
	}
	.g-faq dt::before {
		font-size: 49px;
	}
	.g-faq dt::before{
		left: 10px;
		top: -2px;
	}
	.g-faq dd::before {
		font-size: 49px;
	}
	.g-faq dd::before{
		left: 12px;
		top: 14px;
	}
}
@media screen and (max-width: 767px){
	.g-faq{
		margin-top: 30px;
	}
	.g-faq dd:not(:last-child){
		padding-bottom: 20px;
		margin-bottom: 40px;
	}
	.g-faq dt{
		font-size: var(--FZ_14_CONST);
		padding: 0 10px 10px 30px;
	}
	.g-faq dd{
		padding: 8px 10px 30px 30px;
	}
	.g-faq dt::before {
		font-size: 23px;
	}
	.g-faq dt::before{
		left: 2px;
		top: 2px;
	}
	.g-faq dd::before {
		font-size: 23px;
	}
	.g-faq dd::before{
		left: 3px;
		top: 17px;
	}
	.g-faq dd .g-txt{
		line-height: 1.7;
	}
}
/* アコーディオン プラスマイナス */
.g-faq--acc dt,
.l-faq .g-guideColumn__heading{
	position: relative;
}
.g-faq--acc dt span,
.l-faq .g-guideColumn__heading span{
	display: inline-block;
	position: relative;
	aspect-ratio: 1/1;
	position: absolute;
	border-radius: 50%;
}
.g-faq--acc dt span::before,
.g-faq--acc dt span::after,
.l-faq .g-guideColumn__heading span::before,
.l-faq .g-guideColumn__heading span::after{
	content: "";
	display: inline-block;
	background: var(--BLACK);
	width: 80%;
	height: 2px;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
}
.g-faq--acc dt span::after,
.l-faq .g-guideColumn__heading span::after{
	transition: .3s;
	transform: translate(-50%, -50%) rotate(90deg);
}
.g-faq--acc dt.active span::after,
.l-faq .g-guideColumn__heading.active span::after{
	transform: translate(-50%, -50%) rotate(180deg);
}
.g-faq--acc dd,
.l-faq .g-faq{
	display: none;
}
.l-container h3.g-guideColumn__heading{
	margin-bottom: 0;
}
.l-faq .g-guideContents{
	gap: var(--GENERALSEC_HALF);
}
@media (hover: hover){
	.g-faq--acc dt:hover,
	.l-faq .g-guideColumn__heading:hover{
		cursor: pointer;
	}
}
@media screen and (min-width: 768px){
	.g-faq--acc dt:not(:first-child){
		margin-top: 10px;
	}
	.l-faq .g-guideColumn__heading{
		padding-right: 50px;
	}
	.g-faq--acc dt span,
	.l-faq .g-guideColumn__heading span{
		width: 15px;
		right: 23px;
		top: 14px;
	}
	.l-faq .g-faq{
		margin-top: var(--GAP_80);
	}
}
@media screen and (max-width: 767px){
	.g-faq--acc dt:not(:first-child){
		margin-top: 10px;
	}
	.l-faq .g-guideColumn__heading{
		padding-right: 25px;
	}
	.g-faq--acc dt span,
	.l-faq .g-guideColumn__heading span{
		width: 13px;
		right: 7px;
		top: 7px;
	}
	.l-faq .g-faq{
		margin-top: var(--GAP_50);
	}
}
/* -------------------g-column-------------------- */
.g-column__thumb img{
  aspect-ratio: 285/225;
  object-fit: cover;
}
.g-column__body{
  flex: 1;
  display: flex;
  flex-direction: column;
}
.g-column__ttl{
  flex: 1;
}
.g-column__more{
  margin-left: auto;
}
@media screen and (min-width: 768px){
  .g-column{
    grid-template-columns: repeat(4,1fr);
    gap: var(--GAP_40) var(--GAP_20);
  }
  .g-column a{
    display: flex;
    flex-direction: column;
    height: 100%;
  }
  .g-column__ttl{
    margin: 20px 0;
    font-size: var(--FZ_14);
    font-weight: var(--FF_W_B);
  }
}
@media screen and (max-width: 767px){
  .g-column{
    gap: 30px;
  }
  .g-column a{
    display: grid;
    grid-template-columns: 128px 1fr;
    gap: 12px;
  }
  .g-column__ttl{
    font-size: var(--FZ_16_CONST);
    font-weight: var(--FF_W_M);
    line-height: 1.4;
    overflow: hidden;
    -webkit-line-clamp: 4;
    -webkit-box-orient: vertical;
    display: -webkit-box;
    margin-bottom: 15px;
  }
}
/* -------------------t-feature-------------------- */
.g-feature a img{
  aspect-ratio: 386/500;
  object-fit: cover;
}
@media screen and (min-width: 768px){
  .g-feature{
    display: flex;
		justify-content: center;
    gap: var(--GAP_20);
  }
	.g-feature li{
		width: calc((100% / 3) - var(--GAP_40));
	}
}
@media screen and (max-width: 767px){
  .g-featureSection{
    overflow-x: clip;
  }
  .g-feature{
    width: 87%;
  }
  .g-feature .slick-list{
    overflow: visible;
  }
  .g-feature .slick-slide{
    padding: 0 7px;
  }
}
/* -------------------s-tpoTestMode-------------------- */
.s-tpoTestMode{
	border-bottom: 1px solid var(--BDCOLOR_GRAY_1);
}
.s-tpoTestMode > li{
	background-color: var(--BGCOLOR_GRAY_1);
}
.s-tpoTestMode__heading{
	display: grid;
	align-items: center;
}
.s-tpoTestMode__heading__icon{
	display: inline-block;
	grid-row: span 2;
	background-color: var(--BLUE03);
	border-radius: 50%;
	aspect-ratio: 1/1;
	overflow: hidden;
	position: relative;
}
.s-tpoTestMode__heading__icon--noLimit::after{
	content: "";
	display: inline-block;
	background: var(--WHITE);
	width: 200%;
	height: 1px;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%) rotate(-45deg);
	transform-origin: center;
}
.s-tpoTestMode__heading__icon i{
	display: block;
	width: 100%;
	height: 100%;
	mask: url(../images/tpo/icon_timelimit.svg) no-repeat center center / 50%;
	-webkit-mask: url(../images/tpo/icon_timelimit.svg) no-repeat center center / 50%;
	background-color: var(--WHITE);
}
.s-tpoTestMode__heading__ja{
	font-weight: 500;
	display: flex;
	align-items: flex-end;
}
.s-tpoTestMode__heading__en{
	font-weight: 700;
	display: flex;
	align-items: flex-start;
	line-height: 1;
}
.s-tpoTestMode__desc li{
	position: relative;
	font-weight: 700;
}
.s-tpoTestMode__desc li::before{
	content: "・";
	display: inline-block;
	position: absolute;
	top: 0;
	left: 0;
}
.s-tpoTestMode__explain__txt{
	font-weight: 700;
}
.s-tpoTestMode__explain__txt--col2{
	display: grid;
	grid-template-columns: repeat(2,1fr);
}
.s-tpoTestMode__explain__txt--right{
	text-align: right;
}
@media screen and (min-width: 768px){
	.s-tpoTestMode{
		display: grid;
		grid-template-columns: repeat(2,1fr);
		gap: var(--GAP_40);
		padding-bottom: var(--GAP_50);
		margin: var(--GAP_20) auto var(--GAP_50);
	}
	.s-tpoTestMode > li{
		display: flex;
		flex-direction: column;
		align-items: center;
		padding: var(--GAP_35) 0 var(--GAP_60);
	}
	.s-tpoTestMode__heading{
		width: fit-content;
		margin: 0 auto;
		grid-template-columns: 76px 1fr;
		gap: 0 var(--GAP_20);
	}
	.s-tpoTestMode__heading__ja{
		font-size: var(--FZ_16);
	}
	.s-tpoTestMode__heading__en{
		font-size: var(--FZ_30);
		margin-top: -20px;
	}
	.s-tpoTestMode__desc{
		margin: var(--GAP_20) 0 var(--GAP_30);
	}
	.s-tpoTestMode__desc li{
		padding-left: 15px;
		font-size: var(--FZ_16);
	}
	.s-tpoTestMode__explain{
		display: grid;
		grid-template-columns: repeat(2,1fr);
		gap: var(--GAP_40);
	}
	.s-tpoTestMode__explain__img,
	.s-tpoTestMode__explain__txt{
		padding: 0 var(--GAP_30);
	}
	.s-tpoTestMode__explain__txt{
		gap: var(--GAP_30);
	}
}
@media screen and (max-width: 767px){
	.s-tpoTestMode{
		display: grid;
		gap: var(--GAP_30);
		padding-bottom: var(--GAP_30);
		margin: var(--GAP_20) auto var(--GAP_30);
	}
	.s-tpoTestMode > li{
		padding: var(--GAP_30) var(--GAP_20);
	}
	.s-tpoTestMode__heading{
		grid-template-columns: 46px 1fr;
		gap: var(--GAP_20);
	}
	.s-tpoTestMode__heading__ja{
		font-size: var(--FZ_12_CONST);
	}
	.s-tpoTestMode__heading__en{
		font-size: var(--FZ_25);
		margin-top: -20px;
	}
	.s-tpoTestMode__desc{
		margin: var(--GAP_20) 0 var(--GAP_30);
	}
	.s-tpoTestMode__desc li{
		padding-left: 10px;
		font-size: var(--FZ_12_CONST);
	}
	.s-tpoTestMode__explain{
		display: grid;
		gap: var(--GAP_30);
	}
	.s-tpoTestMode__explain__txt{
		gap: var(--GAP_20);
		font-size: var(--FZ_10_CONST);
	}
}