@charset "UTF-8";

/* atelier Deco - style
   ---------------------------------------------------------------- */

/**
 * Global
 */
* {
	box-sizing: border-box;
}

:root {
	font-size: 62.5%;
}

body {
	color: #333;
	line-height: 1.618;
	margin: auto;
	width: 100%;
}

h1,
figure {
	margin: 0;
}

p {
	font-size: 1.6rem;
}

img {
	height: auto;
	max-width: 100%;
	vertical-align: bottom;
}

ul {
	list-style-type: none;
	margin: 0;
	padding: 0;
}

a:hover {
	transition: all 0.24s ease-out;
	opacity: 0.56;
}

.sp {
	display: none;
}

/**
 * Header
 */
.header-info {
	display: flex;
	justify-content: space-around;
	padding: 4rem 0 3.2rem;
}

.header-title {
	padding: 0 12rem 0 4rem;
}

.header-nav ul {
	display: flex;
	padding: 0 4rem 0 0;
}

.header-nav ul li {
	margin: 0 1.2rem;
}

.header-nav ul li:last-child {
	margin: 0 0 0 4rem;
}

.hero-image-wrap {
	position: relative;
}

.hero-image {
	height: calc(100vh - 242px);
	overflow: hidden;
	position: relative;
	z-index: 0;
}

.hero-image img {
	height: 100%;
	object-fit: cover;
	width: 100%;
}

.header-sns-icon {
	display: flex;
	position: absolute;
	right: 2rem;
	top: 2.8rem;
}

.header-sns-icon li {
	margin: 0 0.88rem;
}

/**
 * Main
 */

/*philosophy*/
#philosophy {
	padding: 9.6rem 0 8rem;
	margin: auto;
	max-width: 1400px;
}

.philosophy-title {
	margin: 0 0 5.6rem;
	text-align: center;
}

.philosophy-content {
	display: flex;
	justify-content: center;
}

.philosophy-content .text,
.philosophy-content figure {
	margin: 0 1.6rem;
	max-width: 537px;
	width: 42.4%;
}

.philosophy-content .text {
	padding: 0 0 8.8rem;
	position: relative;
}

.philosophy-content .text h3 {
	font-size: 2.4rem;
	margin: 0 0 2.4rem;
}

.philosophy-content .text .f-weight-700 {
	font-weight: 700;
	font-size: 1.76rem;
}

.vegetables {
	bottom: -1.2%;
	position: absolute;
	right: 0;
}

/*foodmenu*/
#foodmenu {
	background: #222223;
	padding: 8rem 0;
}

.foodmenu-wrap {
	background: #1a1a1b;
	margin: auto;
	max-width: 1400px;
	padding: 2.4rem 2.4rem 4.8rem;
	position: relative;
	width: 88%;
}

.foodmenu-wrap h2 {
	left: 50%;
	max-width: 227px;
	position: absolute;
	top: 4%;
	-webkit-transform: translate(-50%, -50%);
	transform: translate(-50%, -50%);
	width: 20%;
}

.foodmenu-list {
	margin: 0 auto 5.6rem;
	max-width: 1048px;
}

.foodmenu-img {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	margin: auto;
	max-width: 1064px;
}

.foodmenu-img li {
	padding: 0.8rem;
	width: 25%;
}

/*drinkmenu*/
#drinkmenu {
	background: #222223;
}

.drinkmenu-wrap {
	background: #1a1a1b;
	margin: auto;
	max-width: 1400px;
	padding: 2.4rem 2.4rem 4.8rem;
	position: relative;
	width: 88%;
}

.drinkmenu-wrap h2 {
	left: 50%;
	position: absolute;
	-webkit-transform: translate(-50%, -50%);
	transform: translate(-50%, -50%);
	width: 20%;
}

.drinkmenu-title {
	max-width: 227px;
	top: 5.6%;
}


.drinkmenu-list {
	margin: 0 auto;
	max-width: 1048px;
}

.bottlemenu-title {
	max-width: 167px;
	margin: 4.8rem 0 0;
}

.bottlemenu-list {
	margin: -3.2rem auto 0;
	max-width: 1048px;
}

.tax {
	color: #fff;
	font-size: 1.4rem;
	margin: auto;
	max-width: 1400px;
	padding: 2.4rem 0 4rem;
	text-align: right;
	width: 88%;
}

/*shopinfo*/
#shopinfo {
	padding: 9.6rem 0 0;
	margin: auto;
}

.shopinfo-title {
	margin: 0 0 5.6rem;
	text-align: center;
}

.shopinfo-img {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	margin: auto;
	max-width: 1082px;
}

.shopinfo-img li {
	padding: 0.8rem;
	width: 50%;
}

.shopinfo-bottom {
	align-items: center;
	border-bottom: #1a1a1b 1px solid;
	border-top: #1a1a1b 1px solid;
	display: flex;
	justify-content: space-around;
	margin: 4rem auto;
	max-width: 1064px;
	padding: 2.4rem 0;
}

.shopinfo-text a {
	color: #333;
	text-decoration: none;
}

.shopinfo-sns {
	display: flex;
}

.shopinfo-sns li {
	margin: 0 0.8rem;
}

.info-tel-num {
	background: #1a1a1b;
	padding: 3.2rem 0;
	text-align: center;
}

.info-map {
	height: 400px;
	overflow: hidden;
	position: relative;
}

.info-map iframe {
	bottom: auto;
	height: auto;
	left: 50%;
	max-width: initial;
	right: auto;
	top: 50%;
	-webkit-transform: translate(-50%, -50%);
	transform: translate(-50%, -50%);
	transition: all 0.4s linear;
	width: auto;
}

@supports ((-o-object-fit: cover) or (object-fit: cover)) {
	.info-map iframe {
		height: 100%;
		left: 0;
		-o-object-fit: cover;
		object-fit: cover;
		top: 0;
		-webkit-transform: none;
		transform: none;
		transition: all 0.4s linear;
		width: 100%;
	}
}

/**
 * Footer
 */
.copyright {
	font-size: 1.4rem;
	margin: 2.4rem 0 4.8rem;
	text-align: center;
}

#top {
	bottom: 1.6rem;
	opacity: 0.8;
	position: fixed;
	right: 1.6rem;
}

@media screen and (max-width : 768px) {

	/**
	 * Global
	 */
	.pc {
		display: none;
	}

	.sp {
		display: block;
	}

	/**
	 * Header
	 */
	.header-info {
		display: block;
		padding: 4rem 0 3.2rem;
	}

	.header-title {
		padding: 0 0 4rem;
		text-align: center;
	}

	.header-nav ul {
		justify-content: center;
		padding: 0;
	}

	.nav-tel-num {
		margin: 3.2rem auto 0;
		text-align: center;
	}

	.hero-image {
		height: 38.2vh;
	}

	.hero-image img {
		height: 100%;
		object-fit: cover;
		width: 100%;
	}

	/**
	 * Main
	 */

	/*philosophy*/
	#philosophy {
		padding: 9.6rem 0 0;
	}

	.philosophy-content {
		flex-direction: column-reverse;
		flex-wrap: wrap;
	}

	.philosophy-content .text,
	.philosophy-content figure {
		margin: 0 auto 2.4rem;
		width: 96%;
	}

	.philosophy-content .text h3 {
		text-align: center;
	}

	.vegetables {
		position: static;
		text-align: right;
	}

	/*foodmenu*/
	.foodmenu-wrap {
		width: 96%;
	}

	.foodmenu-wrap h2 {
		padding: 0 0 2.4rem;
		max-width: 100%;
		position: static;
		text-align: center;
		-webkit-transform: initial;
		transform: initial;
		width: auto;
	}

	.foodmenu-list {
		margin: 0 auto;
	}

	.foodmenu-img {
		justify-content: space-between;
	}

	.foodmenu-img li {
		padding: 0 0 0.8rem;
		width: 49%;
	}

	/*drinkmenu*/
	.drinkmenu-wrap {
		width: 96%;
	}

	.drinkmenu-wrap h2 {
		padding: 0 0 2.4rem;
		max-width: 100%;
		position: static;
		text-align: center;
		-webkit-transform: initial;
		transform: initial;
		width: auto;
	}

	.bottlemenu-title {
		margin: 0;
	}

	.tax {
		width: 96%;
	}

	/*shopinfo*/
	.shopinfo-bottom {
		display: block;
		width: 96%;
	}

	.shopinfo-logo {
		margin: 0 0 2.4rem;
		text-align: center;
	}

	.shopinfo-sns {
		justify-content: center;
		margin: 2.4rem 0 0;
	}

	.info-tel-num img {
		width: 88%;
	}

	@supports ((-o-object-fit: cover) or (object-fit: cover)) {
		.info-map iframe {
			height: 100%;
			left: 0;
			-o-object-fit: initial;
			object-fit: initial;
			top: 0;
			-webkit-transform: none;
			transform: none;
			transition: all 0.4s linear;
			width: 100%;
		}
	}
}