/* CSS Document */


/*- menu -*

変更領域, fv

* filetop *
------------------------------------------------------------------------------------------------------------------------------------------*/

/*- File name [ style.css ] -*/

/*------------------------------------------------------------------------------------------------------------------------------------------

* 変更領域

------------------------------------------------------------------------------------------------------------------------------------------*/

/* screen width 768px未満
---------------------------------------------------------------------*/

.m-plus-rounded-1c {
	font-family: "M PLUS Rounded 1c", sans-serif;
	font-style: normal;
}

.noto-sans-jp {
	font-family: "Noto Sans JP", sans-serif;
	font-optical-sizing: auto;
	font-style: normal;
}

.shippori-mincho {
	font-family: "Shippori Mincho", serif;
	font-style: normal;
}

.m-plus-1p {
	font-family: "M PLUS 1p", sans-serif;
	font-style: normal;
}



/*- body -*/
body,
body * {
	color: #333;
}

/*- footer -*/
footer .inner {
	background: #ae0048;
}

footer .inner p {
	color: #FFFFFF;
}

/*- main -*/
main {
	background: url("../img/index/bg.jpg") repeat center;
}

main * {
	font-family: "Shippori Mincho", serif;
	font-style: normal;
}

/*- title -*/
h3.title span {
	border-color: #000000;
	font-weight: 700;
}

/*- box_center -*/
.box_center {
	padding-inline: clamp(12px, 3.125vw, 24px);
}

.box_center>* {}

/*- top -*/
#top {}

/*- btm -*/
#btm {}

/*- rule_mv -*/

/*- method_mv -*/




/* 横向き用
---------------------------------------------------------------------*/

@media (orientation: landscape) {}




/* TAB用768px～（TAB）
---------------------------------------------------------------------*/

@media print,
screen and (min-width: 768px) {

	/*- rule -*/

	/*- method -*/

}




/* iPad pro・ノートPC用1024px～（NPC）
---------------------------------------------------------------------*/

@media print,
screen and (min-width: 1024px) {}




/* PC用1280px～（PC）
---------------------------------------------------------------------*/

@media print,
screen and (min-width: 1280px) {}







/*------------------------------------------------------------------------------------------------------------------------------------------

* fv

------------------------------------------------------------------------------------------------------------------------------------------*/

/* screen width 768px未満
---------------------------------------------------------------------*/
.fv .fv_box {
	background: url("../img/index/fv/pc_bg.png") no-repeat center;
	background-size: auto 100%;
}

.fv .fv_box img {
	margin-right: auto;
	margin-left: auto;
	width: 100%;
}




/* 横向き用
---------------------------------------------------------------------*/

@media (orientation: landscape) {}




/* TAB用768px～（TAB）
---------------------------------------------------------------------*/

@media print,
screen and (min-width: 768px) {

	.fv .fv_box img {
		width: auto;
	}

}




/* iPad pro・ノートPC用1024px～（NPC）
---------------------------------------------------------------------*/

@media print,
screen and (min-width: 1024px) {}




/* PC用1280px～（PC）
---------------------------------------------------------------------*/

@media print,
screen and (min-width: 1280px) {}







/*------------------------------------------------------------------------------------------------------------------------------------------

* class, id

------------------------------------------------------------------------------------------------------------------------------------------*/

/* screen width 768px未満
---------------------------------------------------------------------*/
.title01,
.title02,
.title03 {
	text-align: center;
	font-weight: 600;
}

.title01::after,
.title02::after {
	content: "";
	display: block;
	background-position: center !important;
	background-repeat: no-repeat !important;
	background-size: contain !important;
}

.title01 {
	font-size: clamp(2rem, 2.1875vw, 2.8rem);
	color: #546164;
}

/*.title01::after{
	background-image: url("../img/index/title_line01.png");
	margin: clamp(20px, 2.1875vw, 28px) auto 0;
	aspect-ratio: 1 / 0.059;
	width: clamp(170px, 18.75vw, 240px);
}*/

.title02 {
	font-size: clamp(2.1rem, 2.65625vw, 3.4rem);
	line-height: 1.6;
	color: #ae0048;
}

.title02 img {
	margin: 0 auto;
}

/*.title02::after{
	background-image: url("../img/index/title_line02.png");
	margin: clamp(12px, 1.5625vw, 20px) auto 0;
	aspect-ratio: 1 / 0.16;
	width: clamp(36px, 3.90625vw, 50px);
}*/

.title03 {
	font-size: clamp(2.6rem, 3.4375vw, 4.4rem);
	color: #546164;
}

.title03 small {
	font-size: clamp(1.8rem, 2.5vw, 3.2rem);
	font-weight: 600;
}

*[id^="contents_"]>*>*+*,
*[id^="contents_"]>* section>*+* {
	margin-top: clamp(36px, 5vw, 64px);
}

*[id^="contents_"] a:hover {
	opacity: 0.7;
}

*[id^="contents_"] .banners {
	margin-inline: auto;
	position: relative;
	/*max-width: 860px;
	width: 100%;*/
}

*[id^="contents_"] .banners img {
	margin: 0 auto;
}

*[id^="contents_"] .banners ul {
	width: 100%;
	display: flex;
	padding: 0 7.5px 9px;
	gap: 0 9px;
	position: absolute;
	bottom: 0;
}

*[id^="contents_"] .banners ul li {
	width: 50%;
	display: flex;
}

*[id^="contents_"] .banners ul li a {
	width: 100%;
	text-align: center;
	font-family: "M PLUS 1p", sans-serif;
	font-style: normal;
	/*font-size: 14px;*/
	font-size: clamp(1.4rem, 0.8360902256rem + 1.5037593985vw, 2.4rem);
	font-weight: 700;
	text-decoration: none;
	border-radius: 9px;
	background: #ffee00;
	border: 1px solid #FFF;
	position: relative;
	padding: 1vw 0;
}

*[id^="contents_"] .banners ul li a::after {
	content: "";
	width: 6px;
	height: 6px;
	border-top: 1px solid #d51358;
	border-right: 1px solid #d51358;
	display: block;
	rotate: 45deg;
	position: absolute;
	right: 10px;
	top: 50%;
	translate: 0 -50%;
}





/* 横向き用
---------------------------------------------------------------------*/

@media (orientation: landscape) {}




/* TAB用768px～（TAB）
---------------------------------------------------------------------*/

@media print,
screen and (min-width: 768px) {

	/*	*[id^="contents_"] .banners{
	margin-inline: auto;
	position: relative;
}

*[id^="contents_"] .banners img{
	margin: 0 auto;
}*/

	*[id^="contents_"] .banners ul {
		width: 50%;
		flex-direction: column;
		padding: 0 3vw 2vw 5vw;
		gap: 15px 0;
		right: 0;
	}

	*[id^="contents_"] .banners ul li {
		width: 100%;
		max-width: 380px;
	}

	*[id^="contents_"] .banners ul li a {
		/*font-size: 18px;*/
		border-radius: 20px;
		padding: 15px 0;
		max-height: 80px;
	}

	*[id^="contents_"] .banners ul li a::after {
		width: 14px;
		height: 14px;
		border-top: 2px solid #d51358;
		border-right: 2px solid #d51358;
		right: 2vw;
	}

}




/* iPad pro・ノートPC用1024px～（NPC）
---------------------------------------------------------------------*/

@media print,
screen and (min-width: 1024px) {

	*[id^="contents_"] .banners ul li a {
		/*font-size: 24px;*/
	}

}




/* PC用1280px～（PC）
---------------------------------------------------------------------*/

@media print,
screen and (min-width: 1280px) {}







/*------------------------------------------------------------------------------------------------------------------------------------------

* category_list

------------------------------------------------------------------------------------------------------------------------------------------*/

/* screen width 768px未満
---------------------------------------------------------------------*/
.category_list>ul {
	display: grid;
	gap: 16px;
	grid-template-columns: repeat(2, 1fr);
}

.category_list>ul>li a {
	display: block;
	position: relative;
	text-decoration: none;
}

.category_list>ul>li a img {
	object-fit: cover;
	/*aspect-ratio: 1 / 1;*/
	width: 100%;
}

.category_list>ul>li a p {
	background: rgba(0, 0, 0, 0.6);
	font-size: clamp(1.2rem, 1.09375vw, 1.4rem);
	line-height: 1.4;
	color: #ffffff;
	padding: 12px;
	min-height: clamp(56px, 5vw, 64px);
	position: absolute;
	bottom: 0;
	right: 0;
	left: 0;
}

.category_list>ul>li a p::after {
	content: "";
	display: block;
	background: url("../img/index/icon_arrow.png") no-repeat center;
	background-size: contain;
	aspect-ratio: 1 / 1;
	width: clamp(12px, 1.25vw, 16px);
	position: absolute;
	bottom: 5px;
	right: 5px;
}

.category_list .txt {
	text-align: center;
	font-weight: 700;
	font-size: clamp(1.2rem, 1.40625vw, 1.8rem);
	color: #FFF;
}

.category_list *+.txt {
	margin-top: clamp(20px, 1.5625vw, 60px);
}




/* 横向き用
---------------------------------------------------------------------*/

@media (orientation: landscape) {}




/* TAB用768px～（TAB）
---------------------------------------------------------------------*/

@media print,
screen and (min-width: 768px) {

	.category_list>ul {
		gap: 10px 12px;
		grid-template-columns: repeat(4, 1fr);
	}

}




/* iPad pro・ノートPC用1024px～（NPC）
---------------------------------------------------------------------*/

@media print,
screen and (min-width: 1024px) {

	.category_list>ul {
		grid-template-columns: repeat(5, 1fr);
	}

}




/* PC用1280px～（PC）
---------------------------------------------------------------------*/

@media print,
screen and (min-width: 1280px) {}







/*------------------------------------------------------------------------------------------------------------------------------------------

* anchor_btns

------------------------------------------------------------------------------------------------------------------------------------------*/

/* screen width 768px未満
---------------------------------------------------------------------*/
#anchor_btns {
	margin-top: clamp(40px, 4.375vw, 56px);
}

#anchor_btns ul.list {
	display: flex;
	justify-content: space-between;
}

#anchor_btns ul.list li {
	width: calc(50% - 4px);
}




/* 横向き用
---------------------------------------------------------------------*/

@media (orientation: landscape) {}




/* TAB用768px～（TAB）
---------------------------------------------------------------------*/

@media print,
screen and (min-width: 768px) {}




/* iPad pro・ノートPC用1024px～（NPC）
---------------------------------------------------------------------*/

@media print,
screen and (min-width: 1024px) {

	#anchor_btns ul.list li {
	  width: calc(50% - 13px);
  }

	#anchor_btns ul.list li a {
		transition: 0.3s;
	}

	#anchor_btns ul.list li a:hover {
		opacity: 0.7;
	}

}




/* PC用1280px～（PC）
---------------------------------------------------------------------*/

@media print,
screen and (min-width: 1280px) {}







/*------------------------------------------------------------------------------------------------------------------------------------------

* contents_mmt

------------------------------------------------------------------------------------------------------------------------------------------*/

/* screen width 768px未満
---------------------------------------------------------------------*/
#contents_mmt>* {
	padding-block: clamp(40px, 7.8125vw, 100px) clamp(40px, 6.25vw, 80px);
}

#contents_mmt #products_mmt .product_list {
	display: grid;
	row-gap: clamp(40px, 5vw, 64px);
}

#contents_mmt #products_mmt .product_list>li {
	display: flex;
	row-gap: 18px;
	flex-direction: column;
}

#contents_mmt #products_mmt .product_list>li * {
	font-weight: 600;
}

#contents_mmt #products_mmt .product_list>li .image img {
	margin-inline: auto;
	max-width: 512px;
	width: 70vw;
}

#contents_mmt #products_mmt .product_list>li .text>*+* {
	margin-top: clamp(20px, 5vw, 64px);
}

#contents_mmt #products_mmt .product_list>li .text .btn_more img {
	margin-inline: auto;
	width: clamp(216px, 7.8125vw, 270px);
}

#contents_mmt #products_mmt .product_list>li .btn_more .order_end {
	background: rgba(0, 0, 0, 0.7);
	color: #fff;
	font-weight: bold;
	font-size: 1.2em;
	text-align: center;
	padding: 10px;
	width: 70%;
	margin: 0 auto;
	border-radius: 5px;
}



/* 横向き用
---------------------------------------------------------------------*/

@media (orientation: landscape) {}




/* TAB用768px～（TAB）
---------------------------------------------------------------------*/

@media print,
screen and (min-width: 768px) {

	#contents_mmt .title02 br {
		display: contents;
	}

	#contents_mmt #products_mmt .product_list>li {
		flex-direction: row;
		justify-content: space-between;
	}

	#contents_mmt #products_mmt .product_list>li:nth-of-type(even) {
		flex-direction: row-reverse;
	}

	#contents_mmt #products_mmt .product_list>li .image {
		width: 50%;
	}

	#contents_mmt #products_mmt .product_list>li .image img {
		margin-inline: auto;
		max-width: 100%;
		width: auto;
	}

	#contents_mmt #products_mmt .product_list>li .text {
		padding-inline: clamp(20px, 3.125vw, 40px);
		width: calc(50% - clamp(16px, 2.5vw, 32px));
	}

	#contents_mmt #products_mmt .product_list>li:nth-of-type(odd) .text .btn_more img {
		margin-left: 0;
	}

	#contents_mmt #products_mmt .product_list>li:nth-of-type(even) .text .btn_more img {
		margin-right: 0;
	}

}




/* iPad pro・ノートPC用1024px～（NPC）
---------------------------------------------------------------------*/

@media print,
screen and (min-width: 1024px) {}




/* PC用1280px～（PC）
---------------------------------------------------------------------*/

@media print,
screen and (min-width: 1280px) {}







/*------------------------------------------------------------------------------------------------------------------------------------------

* contents_aeon

------------------------------------------------------------------------------------------------------------------------------------------*/

/* screen width 768px未満
---------------------------------------------------------------------*/
#contents_aeon {
	/*background-color: rgba(191, 0, 142, 0.1);*/
	background: url(../img/index/okurimono/bg02.jpg) repeat center top;
}

#contents_aeon>* {
	padding-block: clamp(40px, 6.25vw, 80px) clamp(40px, 7.8125vw, 100px);
}

#contents_aeon>*>*+* {
	margin-top: clamp(20px, 5vw, 60px);
}

#contents_aeon .title03 {
	color: #000000;
}

#contents_aeon h3 img {
	margin: 0 auto;
}




/* 横向き用
---------------------------------------------------------------------*/

@media (orientation: landscape) {}




/* TAB用768px～（TAB）
---------------------------------------------------------------------*/

@media print,
screen and (min-width: 768px) {}




/* iPad pro・ノートPC用1024px～（NPC）
---------------------------------------------------------------------*/

@media print,
screen and (min-width: 1024px) {}




/* PC用1280px～（PC）
---------------------------------------------------------------------*/

@media print,
screen and (min-width: 1280px) {}




/*------------------------------------------------------------------------------------------------------------------------------------------

* contents_eat

------------------------------------------------------------------------------------------------------------------------------------------*/

/* screen width 768px未満
---------------------------------------------------------------------*/
#contents_eat {
	background: #ca0f24;
}

#contents_eat h3 img {
	margin: 0 auto;
}

#contents_eat>* {
	padding-block: clamp(40px, 6.25vw, 80px) clamp(40px, 7.8125vw, 100px);
}

#contents_eat>*>*+* {
	margin-top: clamp(40px, 5vw, 64px);
}

#contents_eat .eat_detail {}

/*#contents_eat .eat_detail .info {
	width: 90%;
	margin: 0 auto;
}*/

#contents_eat .eat_detail .info a {
	width: 80%;
	margin: 35px auto 0;
	text-align: center;
	font-family: "M PLUS 1p", sans-serif;
	font-style: normal;
	/*font-size: 14px;*/
	font-size: clamp(1.4rem, 0.8360902256rem + 1.5037593985vw, 2.4rem);
	font-weight: 700;
	text-decoration: none;
	border-radius: 9px;
	background: #eddc9f;
	border: 1px solid #13251f;
	position: relative;
	padding: 3vw 0;
	display: block;
}

#contents_eat .eat_detail .info a::after {
	content: "";
	width: 6px;
	height: 6px;
	border-top: 1px solid #13251f;
	border-right: 1px solid #13251f;
	display: block;
	rotate: 45deg;
	position: absolute;
	right: 10px;
	top: 50%;
	translate: 0 -50%;
}

#contents_eat .eat_detail .img {
	width: 80%;
	margin: 40px auto 0;
}

#contents_eat .eat_detail .img img {
	margin: 0 auto;
}

#contents_eat .txt {
	text-align: center;
	font-weight: 700;
	font-size: clamp(1.2rem, 1.40625vw, 1.8rem);
	color: #FFF;
	font-size: 2.0rem;
	width: 80%;
	margin: 0 auto;
}

#contents_eat *+.txt {
	margin-top: clamp(16px, 1.5625vw, 30px);
}



/* 横向き用
---------------------------------------------------------------------*/

@media (orientation: landscape) {}




/* TAB用768px～（TAB）
---------------------------------------------------------------------*/

@media print,
screen and (min-width: 768px) {

	#contents_eat .eat_detail {
		display: flex;
		justify-content: space-between;
		width: 100%;
	}

	#contents_eat .eat_detail .info {
		width: calc(50% - 30px);
		margin: 15px 0 0 0;
	}

	#contents_eat .eat_detail .info a {
		width: 100%;
		margin: 45px auto 0;
		/*font-size: 18px;*/
		border-radius: 20px;
		padding: 25px 0;
	}

	#contents_eat .eat_detail .info a::after {
		width: 12px;
		height: 12px;
		border-top: 2px solid #13251f;
		border-right: 2px solid #13251f;
		right: 2vw;
	}

	#contents_eat .eat_detail .img {
		width: 50%;
		margin: 0;
	}

	#contents_eat .txt {
		font-size: 3.0rem;
	}

}




/* iPad pro・ノートPC用1024px～（NPC）
---------------------------------------------------------------------*/

@media print,
screen and (min-width: 1024px) {

	#contents_eat .eat_detail .info a {
		/*font-size: 24px;*/
	}

}




/* PC用1280px～（PC）
---------------------------------------------------------------------*/

@media print,
screen and (min-width: 1280px) {}






/*------------------------------------------------------------------------------------------------------------------------------------------

* Add Sample Code

------------------------------------------------------------------------------------------------------------------------------------------*/

/* screen width 768px未満
---------------------------------------------------------------------*/




/* 横向き用
---------------------------------------------------------------------*/

@media (orientation: landscape) {}




/* TAB用768px～（TAB）
---------------------------------------------------------------------*/

@media print,
screen and (min-width: 768px) {}




/* iPad pro・ノートPC用1024px～（NPC）
---------------------------------------------------------------------*/

@media print,
screen and (min-width: 1024px) {}




/* PC用1280px～（PC）
---------------------------------------------------------------------*/

@media print,
screen and (min-width: 1280px) {}

.futan0 {
	text-align: center;
}

.futan0 img {
	display: inline-block;
}