@charset "UTF-8";

/* header
--------------------------------*/
#header {
	padding: 20px;
	background: url(../img/bg_wh.png);
}

#header .logo_main {
	width: 518px;
	margin-top: 12px;
	margin-left: auto;
	margin-right: auto;
}

@media screen and (max-width: 768px) {
	#header {
		padding: 10% 0 4.8%;
	}

	#header .logo_main {
		width: 86.67%;
		margin: 0 auto;
	}
}

/* mv
--------------------------------*/
#sec_mv {
	position: relative;
}

#sec_mv .mv_wrap {
	display: flex;
	height: 37.8vw;
}

#sec_mv .mv_wrap .img {
	width: 25%;
}

#sec_mv .mv_wrap .img img {
	width: 100%;
}

@media screen and (max-width: 768px) {
	.swiper-container-horizontal > .swiper-pagination-bullets {
		bottom: 4%;
	}

	.swiper-pagination-bullet {
		opacity: .4;
		background: #fff;
	}

	.swiper-pagination-bullet-active {
		opacity: 1;
		background: #ffc11d;
	}
}

/* lead
--------------------------------*/
#sec_lead {
	padding: 50px 0;
}

#sec_lead .txt {
	color: #231815;
	font-size: 17px;
	line-height: 2.3;
	text-align: center;
}

@media screen and (max-width: 768px) {
	#sec_lead {
		padding: 9.33% 0;
	}

	#sec_lead .wrap {
		width: 90%;
		margin: 0 auto;
	}

	#sec_lead .txt {
		font-size: 3.73vw;
		line-height: 2.1;
	}
}


/* recipe
--------------------------------*/
#sec_recipe {
	padding: 50px 0 0;
	border-bottom: solid 10px #00693e;
}

#sec_recipe .recipe_category_tab {
	width: 100%;
	max-width: 1150px;
	margin: 0 auto 50px;
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-start;
	gap: 20px calc(16% / 7);
	padding: 0;
}

#sec_recipe .recipe_category_tab li {
	list-style-type: none;
	width: 10.5%;
}

#sec_recipe .recipe_category_tab li a {
	display: block;
	padding-bottom: 18px;
	position: relative;
}

#sec_recipe .recipe_category_tab li a::before {
	content: "";
	width: 17px;
	height: 17px;
	border-right: 1px solid #231815;
	border-bottom: 1px solid #231815;
	position: absolute;
	left: 50%;
	bottom: 0;
	transform: rotate(45deg) translateX(-50%);
}

#sec_recipe .recipe_category_tab li .img {
	width: 100%;
	max-width: 114px;
	height: 112px;
	display: flex;
	align-items: flex-end;
	justify-content: center;
	margin: 0 auto 12px;
}

#sec_recipe .recipe_category_tab li .img img{
	width: 100%;
	height: 100%;
	object-fit: contain;
}

#sec_recipe .recipe_category_tab li .txt {
	color: #231815;
	font-size: 15px;
	text-align: center;
}

#sec_recipe .content_wrap {
	/*	padding: 100px 0 120px;*/
	background: url(../img/bg_wh.png);
}

#sec_recipe .recipe_category_content {
	width: 100%;
	max-width: 1168px;
	margin: 0 auto;
	padding: 100px 0 120px;
}

#sec_recipe .recipe_category_content .category_list {
	display: flex;
	justify-content: flex-start;
/*	align-items: flex-start;*/
	flex-wrap: wrap;
	padding: 0;
	margin-top: 45px;
	margin-bottom: 50px;
}

#sec_recipe .recipe_category_content .category_list .item {
	width: 23.8%;
	max-width: 276px;
	background-color: #fff;
	border-radius: 20px;
	padding: 20px;
	list-style-type: none;
	margin: 0 1.6% 1.6% 0;
}

#sec_recipe .recipe_category_content .category_list .item a{
	width: 100%;
	height: 100%;
	display: flex;
	flex-direction: column;
}

#sec_recipe .recipe_category_content .category_list .item:nth-child(4n) {
	margin-right: 0;
}

#sec_recipe .recipe_category_content .category_list .item > * {
	color: #231815;
}

#sec_recipe .recipe_category_content .category_list .item .img {
	width: 100%;
	aspect-ratio: 1/1;
	margin-bottom: 10px;
}

#sec_recipe .recipe_category_content .category_list .item .img img{
	width: 100%;
	height: 100%;
	object-fit: cover;
}

#sec_recipe .recipe_category_content .category_list .item .ttlbox {
	padding: 5px 0;
	border-bottom: 1px solid #231815;
	margin-bottom: 5px;
	flex: 1;
}

#sec_recipe .recipe_category_content .category_list .item .ttl {
	font-weight: bold;
	font-size: 18.7px;
	line-height: 1.17;
	margin-bottom: 0;
	/*	min-height: 70px;*/
}

#sec_recipe .recipe_category_content .category_list .item .ttl.ls0 {
	letter-spacing: -0.1em;
}

#sec_recipe .recipe_category_content .category_list .item .ttl span {
	display: block;
	font-size: 12.5px;
	margin-bottom: 3px;
}

#sec_recipe .recipe_category_content .category_list .item .ttl.ls0 span {
	letter-spacing: 0;
}

_::-webkit-full-page-media,
_:future,
:root #sec_recipe .recipe_category_content .category_list .item .ttl {
	letter-spacing: -0.05em;
}

_::-webkit-full-page-media,
_:future,
:root #sec_recipe .recipe_category_content .category_list .item .ttl span {
	letter-spacing: -0.05em;
}

@media screen and (-webkit-min-device-pixel-ratio:0) {

	::i-block-chrome,
	#sec_recipe .recipe_category_content .category_list .item .ttl {
		letter-spacing: -0.05em;
	}

	::i-block-chrome,
	#sec_recipe .recipe_category_content .category_list .item .ttl span {
		letter-spacing: -0.05em;
	}
}

#sec_recipe .recipe_category_content .category_list .item .calorie {
	padding: 10px 0 5px;
	position: relative;
}

#sec_recipe .recipe_category_content .category_list .item .calorie::before {
	content: "";
	width: 158px;
	height: 1px;
	background-color: #231815;
	position: absolute;
	left: 0;
	top: 0;
}

#sec_recipe .recipe_category_content .category_list .item .calorie p {
	display: inline-block;
	margin: 0;
	line-height: 1;
	vertical-align: bottom;
}

#sec_recipe .recipe_category_content .category_list .item .calorie .per {
	font-weight: bold;
	font-size: 8px;
	letter-spacing: -0.05em;
	margin-right: .4em;
}

#sec_recipe .recipe_category_content .category_list .item .calorie .value {
	font-weight: bold;
	font-family: 'Montserrat', sans-serif;
	font-size: 17.2px;
}

#sec_recipe .recipe_category_content .category_list .item .calorie .value span {
	font-weight: bold;
	font-family: 'Montserrat', sans-serif;
	font-size: 13.6px;
}

#sec_recipe .recipe_category_content .btn_more button img {
	width: 15px !important;
	margin: 0 11px 0 -20px !important;
}

#sec_recipe .recipe_category_content .btn_more button:hover .u-hover-no {
	display: block;
}

#sec_recipe .recipe_category_content .btn_more button:hover .u-hover {
	display: none;
}

@media screen and (max-width: 768px) {
	#sec_recipe {
		padding: 3% 0 0;
		border-bottom: solid 8px #00693e;
	}

	#sec_recipe .recipe_category_tab {
		width: 90%;
		margin: 0 auto 8%;
		flex-wrap: wrap;
		justify-content: flex-start;
		gap: 3vw 4%;
	}

	#sec_recipe .recipe_category_tab li {
		width: calc(92% / 3);
	}

	#sec_recipe .recipe_category_tab li a {
		padding-bottom: 3vw;
	}

	#sec_recipe .recipe_category_tab li a::before {
		width: 3vw;
		height: 3vw;
	}

	#sec_recipe .recipe_category_tab li .img {
		width: 100%;
		max-width: inherit;
		height: 19vw;
		margin-bottom: 1vw;
	}

	#sec_recipe .recipe_category_tab li .txt {
		font-size: 3.3vw;
		margin-bottom: 1vw;
	}

	#sec_recipe .content_wrap {
		/*		padding: 16% 0 20%;*/
	}

	#sec_recipe .content_wrap .p-title-box__title {
		font-size: 7vw;
	}

	#sec_recipe .recipe_category_content {
		width: 90%;
		padding: 16% 0 20%;
	}

	#sec_recipe .recipe_category_content .category_list {
		margin-top: 9%;
		margin-bottom: 12%;
	}

	#sec_recipe .recipe_category_content .category_list .item {
		width: 48.5%;
		border-radius: 3vw;
		padding: 3vw;
		margin: 0 0 4% 0;
	}

	#sec_recipe .recipe_category_content .category_list .item:nth-child(odd) {
		margin-right: 3% !important;
	}

	#sec_recipe .recipe_category_content .category_list .item .img {
		margin-bottom: 1vw;
	}

	#sec_recipe .recipe_category_content .category_list .item .ttlbox {
		padding: 1vw 0;
		margin-bottom: 1.2vw;
	}

	#sec_recipe .recipe_category_content .category_list .item .ttl {
		font-size: 4.27vw;
		letter-spacing: -0.04em;
	}

	#sec_recipe .recipe_category_content .category_list .item .ttl span {
		font-size: 3.2vw;
		margin-bottom: 1vw;
	}

	#sec_recipe .recipe_category_content .category_list .item .calorie {
		padding: 2vw 1vw 1vw;
	}

	#sec_recipe .recipe_category_content .category_list .item .calorie::before {
		width: 20vw;
	}

	#sec_recipe .recipe_category_content .category_list .item .calorie .per {
		font-size: 2.67vw;
	}

	#sec_recipe .recipe_category_content .category_list .item .calorie .value {
		font-size: 4.4vw;
	}

	#sec_recipe .recipe_category_content .category_list .item .calorie .value span {
		font-size: 3.47vw;
	}

	#sec_recipe .recipe_category_content .btn_more button img {
		width: 15px !important;
		margin: 0 11px 0 -20px !important;
	}

	#sec_recipe .recipe_category_content .btn_more button .u-hover-no {
		display: block;
		left: 36%;
		top: 50%;
		margin-top: -4px !important
	}
}


/* lineup
--------------------------------*/
#sec_lineup {
	padding: 100px 0 130px;
	background: url(../img/shadedbg.png);
}

#sec_lineup .lineup_list {
	width: 100%;
	max-width: 914px;
	margin: 0 auto;
	display: flex;
	flex-wrap: wrap;
}

#sec_lineup .lineup_list .item {
	width: 31.8%;
	max-width: 290px;
	margin-right: 2.3%;
}

#sec_lineup .lineup_list .item:nth-of-type(3n) {
	margin-right: 0;
}

#sec_lineup .lineup_list .item:nth-child(n + 4) {
	margin-top: 60px;
}

#sec_lineup .lineup_list .item .img {
	width: 88%;
	max-width: 255px;
	margin: 0 auto 10px;
}

#sec_lineup .lineup_list .item .ttl {
	color: #00693e;
	font-weight: bold;
	font-size: 25px;
	line-height: 1.4;
	text-align: center;
}

#sec_lineup .lineup_list .item .ttl span {
	display: block;
	font-size: 18px;
}

#sec_lineup .lineup_list .item .txt {
	color: #000;
	font-size: 10px;
	line-height: 2;
	letter-spacing: 0.05em;
}

@media screen and (max-width: 768px) {
	#sec_lineup {
		padding: 17% 0 16%;
	}

	#sec_lineup .p-title-box__title {
		font-size: 7vw;
	}

	#sec_lineup .lineup_list {
		width: 100%;
		display: block;
	}

	#sec_lineup .lineup_list .item {
		width: 100%;
		max-width: inherit;
		display: flex;
		justify-content: center;
		margin-right: 0;
	}

	#sec_lineup .lineup_list .item:nth-child(even) {
		flex-direction: row-reverse;
	}

	#sec_lineup .lineup_list .item + .item {
		margin-top: 6% !important;
	}

	#sec_lineup .lineup_list .item .img {
		width: 43.2%;
		max-width: inherit;
		margin: 0
	}

	#sec_lineup .lineup_list .item .txtwrap {
		width: 54%;
		padding: 0 3%;
	}

	#sec_lineup .lineup_list .item .ttl {
		font-size: 5.2vw;
		line-height: 1.4;
		text-align: left;
	}

	#sec_lineup .lineup_list .item .txt span {
		display: block;
	}

	#sec_lineup .lineup_list .item:nth-child(even) .ttl,
	#sec_lineup .lineup_list .item:nth-child(even) .txt span {
		text-align: right;
	}

	#sec_lineup .lineup_list .item .ttl span {
		font-size: 4vw;
	}

	#sec_lineup .lineup_list .item .txt {
		color: #000;
		font-size: 3.47vw;
		line-height: 1.53;
		letter-spacing: -0.01em;
	}

	#sec_lineup .lineup_list .item:nth-child(2) .txt,
	#sec_lineup .lineup_list .item:nth-child(5) .txt {
		letter-spacing: -0.02em;
	}
}

/* scroll
--------------------------------*/
@media screen and (min-width: 769px) {
	.scroll {
		position: fixed;
		bottom: 30px;
		left: 30px;
		z-index: 999;
	}
}

/* footer
--------------------------------*/
footer {
	width: 100%;
	background-color: #fff;
}

footer .footer_img img {
	width: 100%;
}

footer .wrap {
	width: 100%;
	max-width: 1090px;
	margin: 0 auto;
	display: flex;
	justify-content: space-between;
	align-items: center;
}

footer .f_main {
	padding: 25px 0;
}

footer .f_main .logo {
	margin: 0 0 0;
}

footer .f_main .f_menu {
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-start;
	width: 71%;
	max-width: 766px;
	list-style-type: none;
	margin: 0;
	padding: 0;
}

footer .f_main .f_menu li {
	width: 20%;
}

footer .f_main .f_menu li:not(:nth-child(4n + 1)) {
	margin-left: calc(19.9% / 3);
}

footer .f_main .f_menu li a {
	display: inline-block;
	color: #231815;
	font-size: 13px;
	letter-spacing: 0.05em;
	padding: .3em 0;
}

footer .f_main .f_menu li a:hover {
	text-decoration: underline;
}

footer .f_bottom {
	padding: 15px 0;
}

footer .f_bottom p {
	margin: 0;
	color: #231815;
	line-height: 1;
	font-size: .8rem;
	letter-spacing: 0.1em;
}

footer .f_bottom p a {
	color: #231815 !important;
}

footer .f_bottom p a:hover {
	text-decoration: underline;
}

footer .f_bottom .link_top {
	line-height: 1;
	display: flex;
	align-items: center;
}

footer .f_bottom .link_top span {
	margin-right: 1.2em;
}

footer .f_bottom .copyright {
	font-size: .9rem;
}

@media screen and (max-width: 768px) {
	footer {
		padding-bottom: 22vw;
	}

	footer .footer_img img {
		width: 100%;
	}

	footer .wrap {
		width: 90%;
		display: block;
	}

	footer .f_main {
		padding: 4.6vw 0;
	}

	footer .f_main .logo {
		width: 38vw;
		margin: 0 0 4vw;
	}

	footer .f_main .f_menu {
		width: 100%;
		max-width: inherit;
	}

	footer .f_main .f_menu li {
		width: 50%;
	}

	footer .f_main .f_menu li:not(:nth-child(4n + 1)) {
		margin-left: 0;
	}

	footer .f_main .f_menu li a {
		font-size: 3.2vw;
		letter-spacing: 0.01em;
		padding: .2em 0;
	}

	footer .f_bottom {
		padding: 5vw 0 3vw;
	}

	footer .f_bottom p {
		font-size: 2.4vw;
	}

	footer .f_bottom .link_top {
		margin-bottom: 3vw;
	}

	footer .f_bottom .link_top img {
		width: 41vw;
	}

	footer .f_bottom .link_top span img {
		width: 17.07vw;
	}

	footer .f_bottom .copyright {
		font-size: 2.67vw;
		margin-bottom: 1vw;
	}
}


/* bnr_mugen用
--------------------------------*/

@media screen and (min-width: 769px) {

	.fixed_bnr_mugen {
		width: 16.7%;
		max-width: 320px;
		position: absolute;
		top: 100%;
		right: 1vw;
		transform: translateY(-55%);
		z-index: 100;
	}

	.fixed_bnr_mugen a {
		display: block;
		cursor: pointer;
		position: relative;
	}

	.fixed_bnr_mugen.is-fixed {
		width: 11.2%;
		max-width: 160px;
		position: fixed;
		top: 1vw;
		right: 1vw;
		transform: translateY(0);
	}

	.fixed_bnr_mugen a:hover {
		opacity: 1;
	}

	.fixed_bnr_mugen a::before {
		content: "";
		width: 100%;
		height: 100%;
		background: url(../img/bnr_mugen_l_bg.png) no-repeat center bottom / 100% auto;
		position: absolute;
		left: 0;
		bottom: 0;
		opacity: 0;
		transition: .3s ease;
		z-index: 1;
	}

	.fixed_bnr_mugen a:hover::before {
		opacity: .5;
	}

	.fixed_bnr_mugen.is-fixed a::before {
		background: url(../img/bnr_mugen_s_bg.png) no-repeat center bottom / 100% auto;
	}
}

@media screen and (max-width: 768px) {
	.fixed_bnr_mugen {
		width: 100vw;
		max-width: inherit;
		height: 25.333vw;
		position: fixed;
		left: 0;
		right: 0;
		bottom: 0;
		transform: translateY(0);
		opacity: 1;
		visibility: visible;
		z-index: 100;
		transition: transform .6s ease, opacity .3s ease;
	}

	.fixed_bnr_mugen.is-hide {
		transform: translateY(100%);
		opacity: 0;
		visibility: hidden;
	}

	.fixed_bnr_mugen img {
		width: 100%;
	}
}

/* 印刷用
--------------------------------*/

@media print {
	#header {
		position: absolute;
	}

	a[href]:after {
		content: "" !important;
	}

	abbr[title]:after {
		content: "" !important;
	}

	.fixed_bnr_mugen {
		display: none !important;
	}
}