@charset "UTF-8";

.restaurants_hello {
	width: 100%;
	height: 400px;
	background-color: rgb(236,236,235) !important;
	}
	.restaurants_hello .slick-list {
		width: 100%;
		height: 400px;
		}
		.restaurants_hello .slick-list .slick-track {
			height: 100%;
			}
			.restaurants_hello .slick-list {
				height: 100%;
				}
				.restaurants_hello .slick-list img {
					width: 100%;
					height: 100%;
					}
/* 共通 */
/* Page Header */
#page_header > h2 > img {
	width: 350px;
	opacity: 1;
	}


/* 一覧 */
/* Restaurants List */
#restaurants_info {
	}
	#restaurants_info h2 {
		text-align: center;
		}
	#restaurants_info h2 span {
		font-size: 17px;
		}
	#restaurants_info > .container > p {
		margin: 0 0 30px;
		text-align: center;
		}

.restaurants_list {
	
	}
	.restaurants_list article {
		position: relative;
		width: 100%;
		margin-bottom: 40px;
		padding: 0;
		aspect-ratio: 7 / 3;
		}
@media screen and (max-width: 1023px) {
	.restaurants_list article {
		aspect-ratio: 7 / 4;
		}
	}


	.restaurants_list article:last-of-type {
		margin-bottom: 0;
		}
		.restaurants_list article img {
			position: absolute;
			width: 100%;
			height: 100%;
			object-fit: cover;
			z-index: 0;
		}

	.restaurants_list article .information_area {
		display: flex;
		flex-wrap: wrap;
		justify-content: center;
		align-items: center;
		position: relative;
		width: 45%;
		height: 100%;
		margin: 0 0 0 55%;
		background-color: rgba(0, 0, 0, .5);
		padding: 40px 30px;
		color: #fff;
		z-index: 1;
		}
		.restaurants_list article dl.attention {
			position: absolute;
			bottom: 0;
			left: 0;
			width: 55%;
			margin: 0;
			padding: 10px 20px;
			background-color: rgb(236,236,235);
			color: rgb(84,88,90);
			}
			.restaurants_list article dl.attention dt {
				padding: 0 0 7px;
				}
			.restaurants_list article dl.attention dd {
				padding: 0;
				font-weight: 500;
				}

			.restaurants_list article .information_area .comment {
				line-height: 1.4;
				}
			.restaurants_list article .information_area h3 {
				margin: 20px 0 0;
				font-size: 24px;
				font-weight: 400;
				}
			.restaurants_list article .information_area .floor_level {
				display: inline-block;
				margin: 10px 0 0;
				padding: 7px 5px 2px;
				border: 1px solid #fff;
				font-size: 14px;
				line-height: 14px;
				}
			.restaurants_list article > .information_area > div > .information {
				display: flex;
				flex-wrap: wrap;
				justify-content: flex-start;
				margin: 20px 0 0;
				}
			.restaurants_list article > .information_area > div > .information > dt {
				width: 100px;
				margin: 0 0 10px;
				font-size: 15px;
				font-weight: 300;
				line-height: 1.6;
				}
			.restaurants_list article > .information_area > div > .information > dd {
				width: calc(100% - 100px);
				margin: 0 0 10px;
				font-size: 15px;
				font-weight: 300;
				line-height: 1.6;
				}

		.restaurants_list article .information_area .btn_bg_gr-tp:hover {
				border: 1px solid #fff !important;
				color: #fff !important;
				}

@media screen and (max-width: 1100px) {
	.restaurants_list article .information_area .btn_bg_gr-tp {
		margin: 20px 0 0 0;
	}
	.restaurants_list article .information_area .btn_bw_wh-tp {
		margin: 20px 0 0 0;
	}
}

@media screen and (max-width: 768px) {
	.restaurants_list > article {
		display: flex;
		flex-wrap: wrap;
		aspect-ratio: auto;
		}
		.restaurants_list > article > img {
			position: relative;
			height: auto;
			aspect-ratio: 6 / 3;
			order: 1;
			}
		.restaurants_list > article > dl.attention {
			position: relative;
			width: 100%;
			order: 2;
			}
		.restaurants_list > article > .information_area {
			position: relative;
			width: 100%;
			height: auto;
			margin: 0;
			padding: 20px 20px 30px;
			order: 3;
		}
		.restaurants_list > article > .information_area > div {
			display: flex;
			flex-wrap: wrap;
			justify-content: flex-start;
			}
			.restaurants_list > article > .information_area > div > p {
				width: 100%;
				order: 1;
				}
			.restaurants_list > article > .information_area > div > p.floor_level {
				width: auto;
				height: 24px;
				margin: 23px 0 0 0;
				padding: 4px 5px;
				order: 2;
				}
			.restaurants_list > article > .information_area > div > h3 {
				width: calc(100% - 100px);
				margin: 23px 0 0 20px;
				font-size: 24px;
				line-height: 24px;
				order: 3;
				}
			.restaurants_list > article > .information_area > div > .btn_detail {
				order: 4;
				}
			.restaurants_list > article > .information_area > div > .btn_online {
				order: 5;
				margin-left: 5px;
				}
			.restaurants_list > article > .information_area > div > .information {
				display: none;
				}
}






/* 詳細 */
/* Menu */
#restaurant_menu {
	background-color: rgb(236,236,235);
	}
#restaurant_menu .container {
	padding: 70px 32px;
	}
@media screen and (max-width: 600px) {
#restaurant_menu .container {
	padding: 70px 20px;
	}
}
#restaurant_menu h2 {
	text-align: center;
	}
	#restaurant_menu h2 span {
		font-size: 17px;
		}

	#restaurant_menu > .container > p {
		text-align: center;
		line-height: 1.6;
		}

.restaurant_menu_list {
	
	}




.tab-content .menu_item,
.tab-out-content .menu_item {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	margin: 20px 0 0;
	background-color: #fff;
	}
.tab-out-content .menu_item {
	/*border: 1px solid #54585b;*/
	}
	.tab-content .menu_item .menu_img,
	.tab-out-content .menu_item .menu_img {
		width: 40%;
		order: 1;
		}
		.tab-content .menu_item .menu_img img,
	.tab-out-content .menu_item .menu_img img {
			width: 100%;
			object-fit: cover;
			aspect-ratio: 3 / 2;
			}
	.tab-content .menu_item .menu_info,
	.tab-out-content .menu_item .menu_info {
		width: 60%;
		padding: 20px 30px;
		order: 2;
		}
@media screen and (max-width: 600px) {
	.tab-content .menu_item .menu_info,
	.tab-out-content .menu_item .menu_info {
		padding: 20px 20px;
		}
}
	.tab-content .menu_item_box:nth-of-type(2n) .menu_img {
		order: 2;
		}
	.tab-content .menu_item_box:nth-of-type(2n) .menu_info {
		order: 1;
		}

.more_menu_info .acd-open {
    border-bottom: none;
    background-color: #fff;
    padding: 25px;
	}
	.more_menu_info .acd-open::before {
	    position: absolute;
	    top: 0;
	    left: 0;
	    right: 0;
	    margin-left: auto;
	    margin-right: auto;
	    content: '';
	    padding: 20px;

		display: inline-block;
		color: #333;
		width: 25px;
		height: 25px;
		border: 2px solid #333;
		border-left: 0;
		border-bottom: 0;
		transform: translateY(-25%) rotate(135deg);
		}
	.more_menu_info .acd-open.active::before {
		top: 5px;
		content: '';
		transform: translateY(25%) rotate(-45deg);
		}
.more_menu_info .acd {
	padding: 20px;
	background-color: #fff;
	}
	.more_menu_info .acd p {
		padding: 10px 20px 20px;
		}
	.more_menu_info .acd .free_price {
		margin: 10px 30px 30px;
		}
	.more_menu_info .acd table.price {
		width: calc(100% - 60px);
		margin: 0 30px;
		box-sizing: border-box;
		border-collapse: collapse;
		}
		.more_menu_info .acd table.price th,
		.more_menu_info .acd table.price td {
			text-align: center;
			border: solid 1px;
			padding: 5px;
			}

@media screen and (max-width: 600px) {
	.tab-content .menu_item .menu_img,
	.tab-out-content .menu_item .menu_img {
		width: 100%;
	}
	.tab-content .menu_item .menu_info,
	.tab-out-content .menu_item .menu_info {
		width: 100%;
	}
	.tab-content .menu_item:nth-child(2n) .menu_img {
		order: 1;
	}
	.tab-content .menu_item:nth-child(2n) .menu_info {
		order: 2;
	}
	.tab-content .menu_item_box:nth-of-type(2n) .menu_img {
		order: 1;
		}
	.tab-content .menu_item_box:nth-of-type(2n) .menu_info {
		order: 2;
		}
}
		.tab-content .menu_item .menu_info h3,
		.tab-out-content .menu_item .menu_indo h3 {
			margin: 0 0 10px;
			font-size: 21px;
			font-weight: 400;
			}
		.tab-content .menu_item .menu_info p,
		.tab-out-content .menu_item .menu_info p {
			padding: 5px;
			font-size: 15px;
			line-height: 1.6;
			}
		.tab-content > .menu_item_box > .menu_item > .menu_info > dl {
			display: flex;
			flex-wrap: wrap;
			font-size: 15px;
			line-height: 1.6;
			border-top: 1px solid #999;
			}
			.tab-content > .menu_item_box > .menu_item > .menu_info > dl > dt {
				width: 80px;
				padding: 5px;
				border-bottom: 1px solid #999;
				font-weight: 300;
				}
			.tab-content > .menu_item_box > .menu_item > .menu_info > dl > dd {
				width: calc(100% - 80px);
				padding: 5px;
				border-bottom: 1px solid #999;
				font-weight: 300;
				}
			.menu_item dd a:hover {
				text-decoration: underline;
				}
			.menu_item dd a.btn:hover {
				text-decoration: none;
				}
			.menu_item dd table {
				
				}
		.menu_info .takeout {
			display: flex;
			flex-wrap: wrap;
			font-size: 15px;
			line-height: 1.6;
			}
			.menu_info .takeout dt {
				width: 150px;
				padding: 5px;
				border-bottom: 1px solid #999;
				font-weight: 300;
				}
			.menu_info .takeout dd {
				width: calc(100% - 150px);
				padding: 5px;
				border-bottom: 1px solid #999;
				font-weight: 300;
				}
			.menu_info h3 span {
				display: inline-block;
				margin-left: 20px;
				white-space: nowrap;
			}
			.menu_info > dl.alacarte {
				display: flex;
				flex-wrap: wrap;
				justify-content: space-between;
				align-items: flex-end;
			}
/* 			.tab-content > .menu_item_box > .menu_item > .menu_info > dl.alacarte > dt { */
			.menu_info > dl.alacarte > dt {
				padding: 10px 0;
				width: calc(100% - 170px);
				border-bottom: 1px solid #999;
			}
/* 			.tab-content > .menu_item_box > .menu_item > .menu_info > dl.alacarte > dd { */
			.menu_info > dl.alacarte > dd {
				padding: 10px 0;
				width: 170px;
				text-align: right;
				border-bottom: 1px solid #999;
			}
@media screen and (max-width: 600px) {
		.tab-content > .menu_item_box > .menu_item > .menu_info > dl {
			border-top: none;
			}
			.tab-content > .menu_item_box > .menu_item > .menu_info > dl > dt {
				width: 100%;
				border-bottom: none;
				background-color: rgb(236,236,235);
				}
			.tab-content > .menu_item_box > .menu_item > .menu_info > dl > dd {
				width: 100%;
				border-bottom: none;
				}
			.menu_info > dl.alacarte > dt {
				width: 100%;
				border-bottom: none;
			}
			.menu_info > dl.alacarte > dd {
				width: 100%;
			}

	.more_menu_info .acd .free_price {
		margin: 10px 0 30px;
	}
	.acd .free_price dt {
		width: 100%;
		border-bottom: none;
		background-color: rgb(236,236,235);
		}
	.acd .free_price dd {
		width: 100%;
		border-bottom: none;
		}


.more_menu_info .acd .free_price3 {
	
	}
	.more_menu_info .acd .free_price3 dt {
		width: 100%;
		border-bottom: none;
		background-color: rgb(236,236,235);
		}
	.more_menu_info .acd .free_price3 dt:first-of-type {
		display: none;
		}
	.more_menu_info .acd .free_price3 dd {
		width: 50%;
		border-bottom: none;
		}
.more_menu_info .acd .free_price4 {
	
	}
	.more_menu_info .acd .free_price4 dt {
		width: 100%;
		border-bottom: none;
		background-color: rgb(236,236,235);
		}
	.more_menu_info .acd .free_price4 dt:first-of-type {
		display: none;
		}
}


 /* colorbox inline settings */
.inline-box {
	max-width: 768px;
	padding: 15px;
	}
	.inline-box img {
		width: 100%;
		margin: 0 0 20px;
		}
	.inline-box p {
		line-height: 1.6;
		}

/* Restaurant Info */
#restaurant_info {
	}
#restaurant_info .container {
	padding: 70px 32px;
	}
@media screen and (max-width: 600px) {
#restaurant_info .container {
	padding: 70px 30px;
	}
}
#restaurant_info h2 {
	text-align: center;
	}
	#restaurant_info h2 span {
		font-size: 17px;
		}
		#restaurant_info > .container > dl {
			display: flex;
			flex-wrap: wrap;
			justify-content: flex-start;
			max-width: 768px;
			margin: 0 auto;
			font-size: 15px;
			line-height: 1.6;
			}
		#restaurant_info > .container > dl > dt {
			width: 100px;
			padding: 10px;
			border-bottom: 1px solid #999;
			font-weight: 300;
			}
		#restaurant_info > .container > dl > dt.center {
			display: flex;
			align-items: center;
			}
		#restaurant_info > .container > dl > dd {
			width: calc(100% - 100px);
			padding: 10px;
			border-bottom: 1px solid #999;
			font-weight: 300;
			}
			#restaurant_info dd table {
				width: 100%;
				}
				#restaurant_info dd table th {
					padding-right: 10px;
					}
		#restaurant_info > .container > dl.takeout > dt {
			width: 150px;
			}
		#restaurant_info > .container > dl.takeout > dd {
			width: calc(100% - 150px);
			}
		
		#restaurant_info a:hover {
			text-decoration: underline;
			}
			#restaurant_info a.btn:hover {
				text-decoration: none;
				}
		
		#restaurant_info > .container > dl > dd > .btn {
			min-width: 150px;
			}
@media screen and (max-width: 490px) {
		#restaurant_info > .container > dl > dd > .btn_tel {
			margin-top: 10px;
			}
}

/* Restaurant Private Room */
#restaurant_private_room {

	}
	#restaurant_private_room .container {
		padding: 70px 32px;
		}
@media screen and (max-width: 600px) {
#restaurant_private_room .container {
	padding: 70px 30px;
	}
}
		#restaurant_private_room h2 {
			text-align: center;
			}
			#restaurant_private_room h2 span {
				font-size: 17px;
				}
				#restaurant_private_room h3 {
					margin: 10px 0;
					font-size: 21px;
					font-weight: 400;
					}
					#restaurant_private_room p {
						margin: 0;
						line-height: 1.6;
						}

#restaurant_private_room .container .room_item {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	margin: 0;
	padding: 0;
	}
	#restaurant_private_room .container .room_item .room_img {
		width: 50%;
		order: 1;
		}
		#restaurant_private_room .container .room_item .room_img img {
			width: 100%;
			object-fit: cover;
			aspect-ratio: 16 / 10;
			}
	#restaurant_private_room .container .room_item .room_info {
		width: 50%;
		padding: 15px 20px;
		order: 2;
		}
	#restaurant_private_room .container .room_item:nth-of-type(2n) .room_img {
		order: 2;
		}
	#restaurant_private_room .container .room_item:nth-of-type(2n) .room_info {
		order: 1;
		}
@media screen and (max-width: 600px) {
	#restaurant_private_room .container .room_item .room_img {
		width: 100%;
	}
	#restaurant_private_room .container .room_item .room_info {
		width: 100%;
		}
		#restaurant_private_room .container .room_item:nth-of-type(2n) .room_img {
			order: 1;
			}
		#restaurant_private_room .container .room_item:nth-of-type(2n) .room_info {
			order: 2;
			}
	}

/* Restaurant Chef */
#restaurant_chef {
	background-color: rgb(236,236,235);
	}
	#restaurant_chef .container {
		padding: 70px 32px;
		}
@media screen and (max-width: 600px) {
#restaurant_chef .container {
	padding: 70px 30px;
	}
}
		#restaurant_chef h2 {
			margin: 0 0 20px;
			}
		#restaurant_chef p {
			line-height: 1.6;
			}

#restaurant_chef .container .chef_item {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	max-width: 768px;
	margin: 0 auto;
	padding: 0;
	}
	#restaurant_chef .container .chef_item .chef_img {
		width: 40%;
		order: 1;
		}
		#restaurant_chef .container .chef_item .chef_img img {
			width: 100%;
			object-fit: cover;
			}
	#restaurant_chef .container .chef_item .chef_info {
		width: calc(60% - 30px);
		padding: 20px 0;
		order: 2;
		}
	#restaurant_chef .container .chef_item:nth-of-type(2n) .chef_img {
		order: 2;
		}
	#restaurant_chef .container .chef_item:nth-of-type(2n) .chef_info {
		order: 1;
		}

@media screen and (max-width: 600px) {
	#restaurant_chef .container .chef_item .chef_img {
		width: 100%;
		margin-bottom: 15px;
	}
	#restaurant_chef .container .chef_item .chef_info {
		width: 100%;
		}
	#restaurant_chef .container .chef_item:nth-of-type(2n) .chef_img {
		order: 1;
		}
	#restaurant_chef .container .chef_item:nth-of-type(2n) .chef_info {
		order: 2;
		}
}
	

.fix-zsf-open {
	letter-spacing: normal !important;
	}


.rest_table {
	}
	.rest_table th,
	.rest_table td {
		padding: 0 10px;
	}



/* 詳細ページ */
#first_text_section video {
	width: 100%;
	height: auto;
	margin-top: 30px;
}

#ingredients .item {
	margin-bottom: 35px;
}
#ingredients .item h3 {
	font-size: 1.2em;
	margin-bottom: 15px;
}
#ingredients .item h3 span {
	font-size: 1em;
	display: block;
}
#ingredients .item ul {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	align-items: flex-start;
}
#ingredients .item ul li {
	width: calc(33% - 20px);
	margin: 0 10px;
}

#sake ul {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	align-items: flex-start;
}
#sake ul li {
	width: calc(33% - 20px);
	margin: 0 10px 45px;
	text-align: center;
}
#sake ul li img {
	margin-bottom: 10px;
}
#sake ul li p small {
	display: block;
}
