@charset "UTF-8";

/*main
----------------------------------------*/
.food main {
	background: #fff;
}
.food .ttl_page {
	background: #f8f9f8;
}

/*intro
----------------------------------------*/
.food .intro {
	padding: 11.9rem 2rem 20rem;
	border-radius: 0 0 27rem;
	background: #f8f9f8;
}
.food .intro::after {
	content: '';
	display: block;
	width: 66.4rem;
	position: absolute;
	right: 26.4rem;
	top: 19.8rem;
	bottom: 0;
	border-radius: 33.2rem 33.2rem 0 0;
	background: #718E5E;
	opacity: .06;
}
.food .intro::before {
	content: '';
	display: block;
	width: 54.4rem;
	position: absolute;
	right: 0;
	top: 0;
	bottom: 0;
	border-radius: 0 0 27rem 27rem;
	background: #F2F2F2 url(../../img/common/intro_img_01.png) no-repeat right bottom / 30.7rem auto;
}
.food .intro_txt {
	max-width: 93rem;
	margin: 0 auto;
	z-index: 2;
}
.food .intro_txt h2 {
	font-weight: 400;
	font-size: 2.8rem;
	color: #7AA160;
	line-height: 1.4286;
	letter-spacing: .1em;
	margin-bottom: 3rem;
}
.food .intro_txt p {
	font-size: 1.5rem;
	line-height: 1.9333;
	letter-spacing: .1em;
}
.food .intro_txt p + p {
	margin-top: 1.3rem;
}
@media only screen and (max-width: 768px) {
	.food .intro {
		padding: 5.2rem 4rem 6.3rem;
		border-radius: 0 0 12rem;
	}
	.food .intro::after {
		width: 36.9rem;
		right: 12.5rem;
		height: 28.5rem;
		top: auto;
		border-radius: 18.45rem 18.45rem 0 0;
	}
	.food .intro::before {
		width: 25rem;
		border-radius: 0 0 12rem 12rem;
		background: #F2F2F2 url(../../img/common/intro_img_01-sp.png) no-repeat right bottom / 12.4rem auto;
	}
	.food .intro_txt {
		margin: 0;
	}
	.food .intro_txt h2 {
		font-size: 2.2rem;
		margin-bottom: 1.7rem;
	}
	.food .intro_txt p {
		font-size: 1.3rem;
		line-height: 1.6923;
		letter-spacing: .05em;
	}
	.food .intro_txt p + p {
		margin-top: 1.7rem;
	}
}

/*menu
----------------------------------------*/
.food .menu {
	margin: -7.9rem 0 0;
	padding: .1rem 0 0;
	z-index: 3;
}
.food .chef + .menu {
	margin-top: 0;
	padding: 0 0 12.6rem;
}
.food .menu_head {
	display: flex;
	align-items: flex-end;
	margin-bottom: 8rem;
}
.food .chef + .menu .menu_head {
	justify-content: flex-end;
}
.food .menu_head figure {
	width: calc(50% + 8.5rem);
	border-radius: 0 16rem 0 0;
	overflow: hidden;
}
.food .chef + .menu .menu_head figure {
	width: calc(50% + 10.6rem);
	order: 1;
	border-radius: 16rem 0 0;
}
.food .menu_head_txt {
	width: 45.9rem;
	padding-left: 11.1rem;
}
.food .chef + .menu .menu_head_txt {
	width: 43.7rem;
	padding: 0 0 3.8rem;
}
.food .menu_head_txt h2 {
	font-size: 1.3rem;
	letter-spacing: .15em;
	font-weight: 400;
	color: #7AA160;
	line-height: 1.39;
	margin-bottom: 2rem;
}
.food .menu_head_txt h2 .en {
	font-size: 2.8rem;
	letter-spacing: .15em;
	display: block;
}
.food .menu_head_txt h3 {
	font-size: 2.2rem;
	letter-spacing: .1em;
	font-weight: 400;
	margin-bottom: 1.7rem;
}
.food .chef + .menu .menu_head_txt h3 {
	line-height: 1.3182;
	margin-bottom: 1.4rem;
}
.food .menu_head_txt p {
	font-size: 1.3rem;
	line-height: 2.0769;
	letter-spacing: .07em;
}
.food .menu_head_txt p + p {
	margin-top: .9rem;
}
.food .menu_slider {
	width: 61.1rem;
	margin: 0 auto;
	position: static;
}
.food .menu_slider .slick-list::after,
.food .menu_slider::after {
	content: '';
	display: block;
	clear: both;
}
.food .menu_slider figure {
	float: left;
	margin: 0 .1rem;
	width: 60.9rem;
}
.food .menu_slider .slick-prev,
.food .menu_slider .slick-next {
	content: '';
	display: block;
	appearance: none;
	outline: none;
	border: 0;
	width: 3.6rem;
	height: 3.6rem;
	overflow: hidden;
	text-indent: -99rem;
	background: url(../../img/common/icon_arrow_01.svg) no-repeat left top / 100% auto;
	position: absolute;
	top: 16.6rem;
	right: 6.9rem;
	z-index: 10;
	cursor: pointer;
}
.food .menu_slider .slick-prev {
	transform: scale(-1, 1);
	left: 6.9rem;
	right: auto;
}
.food .menu_slider .slick-dots {
	display: flex;
	gap: .8rem;
	justify-content: center;
	margin-top: 4.5rem;
	z-index: 2;
}
.food .menu_slider .slick-dots li {
	width: .6rem;
	height: .6rem;
}
.food .menu_slider .slick-dots button {
	display: block;
	appearance: none;
	width: .6rem;
	height: .6rem;
	border-radius: 50%;
	background: #D9D9D9;
	overflow: hidden;
	text-indent: -99rem;
	border: 0;
}
.food .menu_slider .slick-dots .slick-active button {
	background: #7AA160;
}
@media only screen and (max-width: 768px) {
	.food .menu {
		margin: 0;
		padding: 0;
	}
	.food .chef + .menu {
		padding: 0 0 7rem;
	}
	.food .menu_head {
		display: block;
		padding-top: 14.2rem;
		margin-bottom: 3.3rem;
	}
	.food .menu_head figure {
		width: 35.5rem;
		border-radius: 0 7rem 0 0;
	}
	.food .chef + .menu .menu_head figure {
		width: 35.5rem;
		border-radius: 7rem 0 0;
		margin: 0 0 0 auto;
	}
	.food .menu_head_txt {
		position: static;
		width: 29.5rem;
		margin: 2.1rem auto 0;
		padding-left: 0;
	}
	.food .chef + .menu .menu_head_txt {
		width: 29.5rem;
		padding: 0;
	}
	.food .menu_head_txt h2 {
		position: absolute;
		top: 6.5rem;
		left: 0;
		right: 0;
		text-align: center;
		line-height: 1.38;
	}
	.food .menu_head_txt h2 .en {
		font-size: 2.4rem;
	}
	.food .menu_head_txt h3 {
		font-size: 1.8rem;
		margin-bottom: .7rem;
	}
	.food .chef + .menu .menu_head_txt h3 {
		line-height: 1.6111;
		margin-bottom: .5rem;
	}
	.food .menu_head_txt p {
		line-height: 1.6923;
		letter-spacing: .05em;
	}
	.food .menu_head_txt p + p {
		margin-top: .7rem;
	}
	.food .menu_slider {
		width: 33.7rem;
	}
	.food .menu_slider figure {
		width: 33.5rem;
	}
	.food .menu_slider figure img {
		height: 24.5rem;
		object-fit: cover;
	}
	.food .menu_slider .slick-prev,
	.food .menu_slider .slick-next {
		width: 2.8rem;
		height: 2.8rem;
		top: 10.8rem;
		right: 1.3rem;
		filter: brightness(0) invert(1);
	}
	.food .menu_slider .slick-prev {
		left: 1.3rem;
		right: auto;
	}
	.food .menu_slider .slick-dots {
		gap: .5rem;
		margin-top: 1rem;
	}
	.food .menu_slider .slick-dots li {
		width: .4rem;
		height: .4rem;
	}
	.food .menu_slider .slick-dots button {
		width: .4rem;
		height: .4rem;
	}
}



.dessert .venue_list .txt h2{
	text-align: center;
    left: 500px;	
}

.dessert .venue_list {
	max-width: 1260px;
	margin: 0 auto 8.5rem;
	display: flex;
	gap: 1.4rem;
}
.dessert .venue_list li {
	flex: 1;
}
.dessert .venue_list figure {
	border-radius: 1rem;
	overflow: hidden;
	margin-bottom: 1.5rem;
}
.dessert .venue_list h4 {
	font-size: 1.8rem;
	font-weight: 400;
	color: #7AA160;
	letter-spacing: .15em;
	margin-bottom: 1rem;
	margin-top: 2rem;
}
.dessert .venue_list p {
	font-size: 1.2rem;
	letter-spacing: .06em;
	line-height: 1.7692;
	margin-bottom: 40px;
}

.dessert .txt h2 {
	font-size: 1.3rem;
	letter-spacing: .15em;
	font-weight: 400;
	color: #7AA160;
	line-height: 1.39;
	margin-bottom: 40px;
	text-align: center;
	margin-top: 100px;
}
.dessert .txt h2 .en {
	font-size: 2.8rem;
	letter-spacing: .15em;
	display: block;
}




/*chef
----------------------------------------*/
.food .chef {
	background: #F5F5F5;
	margin-top: -5.1rem;
	padding: 13.2rem 0 14.2rem;
}
.food .chef_inner {
	max-width: 108.6rem;
	margin: 0 auto;
	display: flex;
	align-items: flex-end;
}
.food .chef_inner figure {
	border-radius: 1.2rem;
	width: 58.2rem;
	overflow: hidden;
}
.food .chef_txt {
	flex: 1;
	padding-left: 7.5rem;
	margin-bottom: -.9rem;
}
.food .chef_txt h2 {
	font-size: 1.3rem;
	color: #7AA160;
	letter-spacing: .15em;
	font-weight: 400;
	line-height: 1.39;
	margin-bottom: 2rem;
}
.food .chef_txt h2 .en {
	display: block;
	font-size: 2.8rem;
	letter-spacing: .15em;
}
.food .chef_txt h3 {
	font-weight: 400;
	letter-spacing: .1em;
	font-size: 2.2rem;
	margin-bottom: 1rem;
}
.food .chef_txt p {
	font-size: 1.3rem;
	letter-spacing: .07em;
	line-height: 2.0769;
}
@media only screen and (max-width: 768px) {
	.food .chef {
		border-radius: 0 0 0 0rem;
		margin-top: -1.4rem;
		padding: 0 0 6.4rem;
	}
	.food .chef_inner {
		max-width: 29.5rem;
		padding-top: 15.6rem;
		display: block;
	}
	.food .chef_inner figure {
		border-radius: 1rem;
		width: auto;
	}
	.food .chef_txt {
		padding-left: 0;
		margin: 2.1rem 0 0;
		position: static;
	}
	.food .chef_txt h2 {
		position: absolute;
		top: 7.8rem;
		left: 0;
		right: 0;
		text-align: center;
	}
	.food .chef_txt h2 .en {
		font-size: 2.4rem;
	}
	.food .chef_txt h3 {
		font-size: 1.8rem;
		margin-bottom: .7rem;
	}
	.food .chef_txt p {
		letter-spacing: .05em;
		line-height: 1.6923;
	}
	
	
	    .dessert .venue_list {
        max-width: 29.5rem;
        margin: 0 auto 5.3rem;
        display: block;
    }
}