@charset "UTF-8";

/* ----------------------------------------------------
	基本設定
---------------------------------------------------- */
/*
	#font
------------------------------ */
body {
	background-color: #fff;
	line-height: 1.5;
	color: #3E3A39;
	font-family: "游ゴシック体", "Yu Gothic", YuGothic, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	font-size: 16px;
	font-feature-settings: "pkna";
	letter-spacing: 0.05em;
}

@media(max-width:768px) {
	body {
		font-size: 2.08333vw;
	}
}

/*
	#reset
------------------------------ */
* {
	margin: 0;
	padding: 0;
	box-sizing: border-box;
}

table {
	border-collapse: collapse;
	border-spacing: 0;
}

fieldset,
img {
	border: 0;
}

address,
caption,
cite,
code,
dfn,
em,
strong,
th,
var {
	font-style: normal;
	font-weight: normal;
}

ol,
ul {
	list-style: none;
}

caption,
th {
	text-align: left;
}

a {
	color: #3D3A39;
	text-decoration: none;
	transition: all 0.5s ease 0s;
}

a:hover {
	opacity: 0.7;
}

area {
	border: none;
	outline: none;
}

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

/*
	表示設定
------------------------------ */
section {
	width: 100%;
}

section>.inner,
footer .inner {
	margin: 0 auto;
	padding: 0 20px;
	max-width: 1100px;
	width: 100%;
}

@media(max-width:768px) {
	section>.inner {
		padding: 0 2.60417vw;
	}
}

/*
	SP,PC表示切り替え
------------------------------ */
.pc {
	display: block;
}

.sp {
	display: none;
}

@media(max-width:768px) {
	.pc {
		display: none;
	}

	.sp {
		display: block;
	}
}


/* ----------------------------------------------------
	header
---------------------------------------------------- */
.header {
	margin-bottom: 114px;
}

.header .hero {
	position: relative;
}

.header .hero .hero_title {
	background: rgba(255, 255, 255, 0.9);
	padding: 4.659498%;
	width: 50.72722%;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translateY(-50%) translateX(-50%);
}

.header .hero_lead {
	background: #e54049;
	padding: 50px 20px;
	line-height: 2;
	color: #fff;
	font-size: 18px;
	text-align: center;
}

@media(max-width: 768px) {
	.header {
		margin-bottom: 14.84375vw;
	}

	.header .hero .hero_title {
		padding: 6.5%;
		width: 76%;
	}

	.header .hero_lead {
		padding: 6.51042vw 2.60417vw;
		font-size: 2.34375vw;
	}
}

/* ----------------------------------------------------
	contents
---------------------------------------------------- */
.contents {
	margin-bottom: 160px;
}

.contents_title {
	margin-bottom: 36px;
	text-align: center;
}

.contents_image {
	margin-bottom: 50px;
}

.contents_lead {
	margin: 0 auto 50px;
	max-width: 800px;
	font-size: 18px;
}

@media (max-width: 768px) {
	.contents {
		margin-bottom: 20.83333vw;
	}

	.contents_title {
		margin-bottom: 4.6875vw;
	}

	.contents_image {
		margin-bottom: 6.51042vw;
	}

	.contents_lead {
		margin: 0 auto 6.51042vw;
		font-size: 2.34375vw;
	}
}

@media (max-width: 480px) {
	.contents_lead {
		font-size: 3.33333vw;
	}
}

/*
	BUFFET
------------------------------ */
.buffet .contents_title img {
	max-width: 323px;
}

.buffet .buffet_menu {
	margin: 0 auto;
	max-width: 950px;
	display: flex;
	justify-content: space-between;
}

.buffet .buffet_menu li {
	max-width: 450px;
	width: 47.36842%;
}

.buffet .buffet_menu li .title {
	margin-bottom: 30px;
	padding-bottom: 8px;
	text-align: center;
	border-bottom: solid 2px #3D3A39;
}

.buffet .buffet_menu li .title img {
	width: auto;
	height: 20px;
}

.buffet .buffet_menu li .text small {
	margin-bottom: 24px;
}

.buffet .buffet_menu li .text small {
	display: block;
}

.buffet .buffet_menu li dt::before {
	content: "●";
}

.buffet .buffet_menu li .lunch dt::before {
	color: #e54049;
}

.buffet .buffet_menu li .dinner dt::before {
	color: #95b543;
}

.buffet .buffet_menu li dd {
	margin-bottom: 35px;
}

.buffet .buffet_link {
	margin-top: 35px;
	text-align: center;
}

.buffet .buffet_link a {
	background: #e54049 url(../img/arrow.svg) right 20px center no-repeat;
	background-size: auto 20px;
	margin-bottom: 20px;
	padding: 35px 0;
	max-width: 580px;
	width: 100%;
	color: #fff;
	font-size: 18px;
	display: inline-block;
}

@media (max-width: 768px) {
	.buffet .contents_title img {
		width: 56.875%;
	}

	.buffet .buffet_menu {
		display: block;
	}

	.buffet .buffet_menu li {
		max-width: 100%;
		width: 100%;
	}

	.buffet .buffet_menu li .title {
		margin-bottom: 3.90625vw;
	}

	.buffet .buffet_menu li .text small {
		margin-bottom: 3.125vw;
	}

	.buffet .buffet_menu li dd {
		margin-bottom: 4.55729vw;
	}

	.buffet .buffet_link {
		margin-top: 4.55729vw;
	}

	.buffet .buffet_link a {
		margin-bottom: 2.60417vw;
		padding: 4.55729vw 0;
		font-size: 2.34375vw;
	}
}

@media (max-width: 480px) {
	.buffet .buffet_menu li .title img {
		height: 4.16667vw;
	}

	.buffet .buffet_menu,
	.buffet .buffet_link a {
		font-size: 3.33333vw;
	}
}

/*
	WINE
------------------------------ */
.wine .contents_title img {
	max-width: 252px;
}

.wine .contents_lead {
	text-align: center;
}

@media (max-width: 768px) {
	.wine .contents_title img {
		width: 34.625%;
	}
}

.wine .wine_main {
	display: flex;
	flex-wrap: wrap;
}

.wine .wine_wrap {
	margin-bottom: 80px;
}

.wine .wine_wrap .wine_title {
	margin-bottom: 30px;
	padding-bottom: 8px;
	width: 100%;
	font-size: 20px;
	border-bottom: solid 2px #3E3A39;
}

.wine .wine_wrap.white .detail,
.wine .wine_wrap.red .detail {
	display: flex;
	flex-wrap: wrap;
}

.wine .wine_wrap .detail dl {
	margin-right: 40px;
	display: flex;
	flex-direction: column;
}

.wine .wine_wrap.white .detail dl:last-of-type,
.wine .wine_wrap.red .detail dl:last-of-type {
	margin-right: 0;
}

.wine .wine_wrap .detail dt {
	min-height: 3.2em;
	color: #e54049;
	font-size: 20px;
	font-weight: bold;
}

.wine .wine_wrap .detail dd .price {
	color: #e54049;
}

.wine .wine_wrap .detail dd .text {
	font-size: 14px;
}

.wine .wine_main+p {
	text-align: center;
}

/* スパークリング */
.wine .wine_wrap.sparkling {
	width: calc(100% / 3);
}

.wine .wine_wrap.sparkling .wine_title {
	width: calc(100% - 40px);
}

/*　白ワイン */
.wine .wine_wrap.white {
	width: calc(100% / 3 * 2);
}

.wine .wine_wrap.white .detail dl {
	width: calc((100% - 40px) / 2);
}

/*　赤ワイン */
.wine .wine_wrap.red {
	width: 100%;
}

.wine .wine_wrap.red .detail dl {
	width: calc((100% - 80px) / 3);
}

.wine .wine_wrap.red .detail dl:nth-child(2) {
	margin-left: -0.5%;
}

@media (max-width: 768px) {
	.wine .wine_wrap {
		margin-bottom: 5.20833vw;
	}

	.wine .wine_wrap .wine_title {
		margin-bottom: 3.90625vw;
		font-size: 3.125vw;
	}

	.wine .wine_wrap.white .detail,
	.wine .wine_wrap.red .detail {
		display: block;
	}

	.wine .wine_wrap .detail dl {
		margin-right: 0;
		margin-bottom: 3.90625vw;
		display: block;
	}

	.wine .wine_wrap .detail dt {
		margin-bottom: 1.04167vw;
		min-height: auto;
		font-size: 2.60417vw;
	}

	.wine .wine_wrap .detail dd .price {
		margin-bottom: 1.04167vw;
		font-size: 2.34375vw;
	}

	.wine .wine_wrap .detail dd .text {
		font-size: 2.08333vw;
	}

	/* スパークリング */
	.wine .wine_wrap.sparkling {
		width: 100%;
	}

	.wine .wine_wrap.sparkling .wine_title {
		width: 100%;
	}

	/*　白ワイン */
	.wine .wine_wrap.white {
		width: 100%;
	}

	.wine .wine_wrap.white .detail dl {
		width: 100%;
	}

	/*　赤ワイン */
	.wine .wine_wrap.red .detail dl {
		width: 100%;
	}

	.wine .wine_wrap.red .detail dl:nth-child(2) {
		margin-left: 0;
	}
}

@media (max-width: 480px) {
	.wine .wine_wrap .wine_title {
		font-size: 4.16667vw;
	}

	.wine .wine_wrap .detail dt {
		font-size: 3.75vw;
	}

	.wine .wine_wrap .detail dd .price,
	.wine .wine_wrap .detail dd .text {
		font-size: 3.33333vw;
	}
}

/* ----------------------------------------------------
	banner
---------------------------------------------------- */
.guidance {
	background: #ececed;
	margin-bottom: 100px;
}

.guidance ul {
	margin: 0 auto;
	padding: 50px 0;
	max-width: 770px;
	display: flex;
	flex-wrap: wrap;
}

.guidance ul li {
	margin: 0.5em 0;
	width: 50%;
}

.guidance ul li a {
	background: url(../img/triangle.svg) left center no-repeat;
	background-size: 0.7em auto;
	padding-left: 1em;
	display: inline-block;
	text-decoration: underline;
}

@media (max-width: 768px) {
	.guidance {
		margin-bottom: 13.02083vw;
	}

	.guidance ul {
		padding: 6.51042vw;
		display: block;
	}

	.guidance ul li {
		width: 100%;
	}
}

@media (max-width: 768px) {
	.guidance ul li {
		font-size: 3.33333vw;
	}
}

/* ----------------------------------------------------
	banner
---------------------------------------------------- */
.banner_title {
	margin-bottom: 24px;
	color: #e54049;
	font-size: 20px;
	text-align: center;
}

@media (max-width: 768px) {
	.banner_title {
		margin-bottom: 3.125vw;
		font-size: 2.60417vw;
	}
}

@media (max-width: 480px) {
	.banner_title {
		font-size: 4.16667vw;
	}
}

.banner_main {
	margin: 0 auto 60px;
	max-width: 680px;
}

.patronage {
	font-size: 18px;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
}

.patronage dt::after {
	content: "：";
}

@media (max-width: 768px) {
	.banner_main {
		margin-bottom: 7.8125vw;
	}

	.patronage {
		font-size: 2.34375vw;
	}
}

.patronage_list {
	margin: 20px auto 130px;
	display: flex;
	justify-content: center;
	align-items: center;
}

.patronage_list li {
	margin: 0 1em;
}

.patronage_list li {
	width: 100%;
}

.patronage_list .logo01 {
	max-width: 130px;
}

.patronage_list .logo02 {
	max-width: 150px;
}

.patronage_list .logo03 {
	max-width: 110px;
}

.patronage_list .logo04 {
	max-width: 130px;
}

@media (max-width: 768px) {
	.patronage_list {
		margin: 2.60417vw auto 16.92708vw;
	}

	.patronage_list li {
		margin: 0 auto 3.125vw;
		width: 30%;
		text-align: center;
	}
}

.italia_scenery {
	display: flex;
	justify-content: center;
	align-items: flex-start;
}

.italia_scenery figcaption {
	margin: 0.5em 1em;
	font-size: 12px;
}

.license {
	margin: 10px 0 70px;
	font-size: 12px;
	display: flex;
	align-items: center;
}

.license .logo {
	margin-right: 1em;
	width: 10%;
}

@media (max-width: 768px) {
	.italia_scenery {
		display: block;
	}

	.italia_scenery figure {
		display: flex;
		align-items: center;
	}

	.italia_scenery picture {
		width: 30%;
	}

	.italia_scenery figcaption {
		margin: 0.5em 1em;
		width: 70%;
		font-size: 1.56250vw;
	}

	.license {
		margin: 10px 0 8.85417vw;
		font-size: 1.56250vw;
		display: flex;
		align-items: center;
	}

	.license .logo {
		margin-right: 0;
		width: 30%;
	}

	.license .text {
		padding: 0 1em;
		width: 70%;
		word-wrap: break-word;
	}
}

@media (max-width: 480px) {
	.italia_scenery figcaption {
		font-size: 2.5vw;
	}

	.license {
		font-size: 2.5vw;
	}
}

/* ---------------------------------------------------
	footer
---------------------------------------------------- */
/*
	safety
------------------------------ */
.footer .safety {
	background: #eaedee;
	margin-bottom: 30px;
	padding: 40px 0;
}

.footer .safety .inner {
	max-width: 870px;
}

.footer .safety .safety_detail {
	margin-bottom: 38px;
	display: flex;
	justify-content: space-between;
	align-items: center;
}

.footer .safety .safety_detail .safety_image {
	width: 24.09639%;
}

.footer .safety .safety_detail .safety_text {
	width: 72.28916%;
}

.footer .safety .safety_note p {
	background: #fff;
	padding: 20px 0;
	color: #e54049;
	font-weight: bold;
	text-align: center;
	border: solid 4px #e54049;
}

.footer .safety .safety_detail .safety_text a {
	text-decoration: underline;
}

@media (max-width: 768px) {
	.footer .safety {
		margin-bottom: 3.90625vw;
		padding: 5.20833vw 0;
	}

	.footer .safety .safety_detail {
		margin-bottom: 4.94792vw;
	}

	.footer .safety .safety_detail .safety_image {
		width: 42%;
	}

	.footer .safety .safety_detail .safety_text {
		width: calc(100% - 42% - 3.61445%);
	}

	.footer .safety .safety_note p {
		padding: 2.60417vw 0;
	}
}

/*
	note
------------------------------ */
.footer .footer_note {
	margin-bottom: 90px;
	font-size: 14px;
}

.footer .footer_note li {
	margin-left: 1em;
	text-indent: -1em;
}

.footer .footer_note li::before {
	content: "※";
}

@media (max-width: 768px) {
	.footer .footer_note {
		margin-bottom: 11.71875vw;
		font-size: 1.82292vw;
	}
}

/*
	nav
------------------------------ */
.footer .footer_hotelnav {
	padding: 45px 0;
	display: flex;
	justify-content: center;
}

.footer .footer_hotelnav::before {
	content: "|";
}


.footer .footer_hotelnav-item::after {
	content: "|";
}

.footer .footer_hotelnav-item a {
	padding: 0 1em;
}

@media (max-width: 768px) {
	.footer .footer_hotelnav {
		padding: 5.85938vw 0;
	}
}

/* ----------------------------------------------------
	pagetop
---------------------------------------------------- */
#pageTop a {
	background: #e54049;
	width: 64px;
	height: 64px;
	border-radius: 8px;
	display: flex;
	justify-content: center;
	align-items: center;
	position: fixed;
	right: 10px;
	bottom: 10px;
	z-index: 10;
}

#pageTop a img {
	width: 16px;
	transform: rotate(-90deg);
}