/* ----------------------------------------------------
	header
---------------------------------------------------- */
.header {
	position: relative;
}

.header::before,
.header::after {
	background-position: center top;
	background-repeat: no-repeat;
	background-size: cover;
	position: absolute;
	z-index: 1;
	content: "";
}

.header::before {
	background-image: url(../img/header-obj01.svg);
	width: 26.484vw;
	height: 22.891vw;
	bottom: 0;
	left: 0;
}

.header::after {
	background-image: url(../img/header-obj02.svg);
	width: 37.656vw;
	height: 25.547vw;
	top: 0;
	right: 0;
}

.header__content {
	position: absolute;
	top: 50%;
	left: 50%;
	z-index: 1;
	transform: translate(-50%, -50%);
}

.header__title {
	margin-bottom: 2.188vw;
	width: 50vw;
}

.header__lead {
	line-height: 2;
	color: rgb(var(--wht));
	font-size: 1.328vw;
	text-align: center;
}

.header__slide.slick-slider {
	margin-bottom: 0;
	line-height: 0;
}

.add-animation .header__slide--item img {
	animation: zoomUp 10s linear 0s normal both;
}

/* ズームアニメーション */
@keyframes zoomUp {
	0% {
		transform: scale(1);
	}

	100% {
		transform: scale(1.15);
	}
}

@media screen and (max-width: 768px) {
	.header::before {
		width: 50.133vw;
		height: 43.733vw;
	}

	.header::after {
		width: 70.133vw;
		height: 49.6vw;
	}

	.header__title {
		margin-bottom: 7.467vw;
		width: 88vw;
	}

	.header__lead {
		font-size: 4.267vw;
	}
}

/* ----------------------------------------------------
	gnav
---------------------------------------------------- */
.gnav {
	background-color: rgb(var(--red));
	position: sticky;
	top: 0;
	z-index: 10;
}

.gnav__list {
	height: min(7.8rem, 6.094vw);
	font-size: min(2rem, 1.563vw);
	font-weight: 500;
	display: flex;
	justify-content: center;
	align-items: center;
}

.gnav__list--item {
	margin: 0 2em;
}

.gnav__list--item a {
	color: rgb(var(--wht));
	text-decoration: none;
}

@media screen and (max-width: 768px) {
	.gnav__list {
		height: 21.333vw;
		font-size: 3.733vw;
	}

	.gnav__list--item {
		margin: 0 1em;
		line-height: 1.5;
		text-align: center;
	}
}

/* ----------------------------------------------------
	main
---------------------------------------------------- */

/* ----------------------------------------------------
	section
---------------------------------------------------- */
.section {
	padding: min(17rem, 13.281vw) 0 min(11rem, 8.594vw);
}

.section__content {
	margin: 0 auto;
	width: min(96.2rem, 75.156vw);
	position: relative;
}

.section__title {
	position: absolute;
	left: max(-3.5rem, -2.734vw);
	z-index: 1;
}

.section__slide.slick-slider {
	margin-bottom: min(3.4rem, 2.656vw);
	line-height: 0;
}

.section__content {
	color: rgb(var(--wht));
	text-align: center;
}

.section__content--title {
	background-color: #2A0607;
	margin: 0 auto min(2.4rem, 1.875vw);
	width: min(21.8rem, 17.031vw);
	height: min(3.3rem, 2.578vw);
	font-size: min(2rem, 1.563vw);
	font-weight: 500;
	display: flex;
	justify-content: center;
	align-items: center;
}

.section__content--detail .text {
	margin-bottom: min(2.4rem, 1.875vw);
	line-height: 2;
	font-size: min(1.7rem, 1.328vw);
}

.section__content--detail .link-button {
	background: linear-gradient(90deg, rgba(214, 166, 54, 1) 0%, rgba(213, 177, 113, 1) 100%);
	width: min(46rem, 35.938vw);
}

.section__content--detail .link-button svg {
	width: min(1.6rem, 1.25vw);
	height: auto;
}

@media screen and (max-width: 768px) {
	.section {
		padding: 33.333vw 0 21.333vw;
	}

	.section__content {
		width: 86.133vw;
	}

	.section__title {
		left: -2.4vw;
	}

	.section__slide.slick-slider {
		margin-bottom: 6.667vw;
	}

	.section__content--title {
		margin-bottom: 2.933vw;
		padding: 0 1.5em;
		width: auto;
		height: 6.4vw;
		font-size: 4vw;
		display: inline-flex;
	}

	.section__content--detail .text {
		margin-bottom: 8vw;
		font-size: 3.733vw;
	}

	.section__content--detail .link-button {
		width: 81.333vw;
	}

	.section__content--detail .link-button svg {
		width: 2.667vw;
	}
}

/* 
	plan
------------------------------ */
.plan .section__title {
	width: min(42.2rem, 32.969vw);
	top: max(-12.6rem, -9.844vw);
}

@media screen and (max-width: 768px) {
	.plan .section__title {
		width: 49.867vw;
		top: -20.8vw;
	}
}

/*
	menu
------------------------------ */
.menu .section__title {
	width: min(57.8rem, 45.156vw);
	top: max(-10.1rem, -7.891vw);
}

@media screen and (max-width: 768px) {
	.menu .section__title {
		width: 70.133vw;
		top: -19.733vw;
	}
}

/*
	cake
------------------------------ */
.cake .section__title {
	width: min(58.4rem, 45.625vw);
	top: max(-12.8rem, -10vw);
}

@media screen and (max-width: 768px) {
	.cake .section__title {
		width: 69.6vw;
		top: -22.133vw;
	}
}

/*
	dinner
------------------------------ */
.dinner .section__title {
	width: min(48.7rem, 38.047vw);
	top: max(-11.6rem, -9.063vw);
}

@media screen and (max-width: 768px) {
	.dinner .section__title {
		width: 58.667vw;
		top: -23.467vw;
	}
}

/* ----------------------------------------------------
	spgr
---------------------------------------------------- */
.spgr {
	background-color: rgb(var(--gra));
	padding: min(10rem, 7.321vw) 0;
	font-family: var(--mincho);
}

.spgr__logo {
	margin: 0 auto min(2.9rem, 2.123vw);
	width: min(22.7rem, 16.618vw);
}

.spgr__content {
	margin-bottom: min(3.3rem, 2.416vw);
	line-height: 2.3;
	text-align: center;
}

.spgr__content--title {
	font-size: min(1.9rem, 1.391vw);
}

.spgr__content--text {
	font-size: min(2.5rem, 1.83vw);
}

.spgr .link-button {
	background-color: rgb(var(--gld));
	width: min(39.1rem, 28.624vw);
}

.spgr .link-button svg {
	width: min(2.6rem, 1.903vw);
}

@media screen and (max-width: 768px) {
	.spgr {
		padding: 14.933vw 0;
	}

	.spgr__logo {
		margin-bottom: 5.867vw;
		width: 38.667vw;
	}

	.spgr__content {
		margin-bottom: 5.333vw;
		line-height: 1.9;
	}

	.spgr__content--title {
		font-size: 3.467vw;
	}

	.spgr__content--text {
		font-size: 4vw;
	}

	.spgr .link-button {
		width: 69.067vw;
	}

	.spgr .link-button svg {
		width: 4.533vw;
	}
}

/* ----------------------------------------------------
	footer
---------------------------------------------------- */
.footer {
	background-color: rgb(var(--wht));
	padding-top: min(3.9rem, 2.855vw);
}

.footer .note {
	margin: 0 auto min(6.5rem, 4.758vw);
	width: min(93rem, 68.082vw);
	font-family: var(--mincho);
}

@media screen and (max-width: 768px) {
	.footer {
		padding-top: 5.867vw;
	}

	.footer .note {
		margin-bottom: 9.067vw;
		width: 89.067vw;
	}
}

/* 
	hotel-nav 
------------------------------ */
.footer .hotel-nav {
	margin-bottom: min(3.9rem, 2.855vw);
	line-height: 1;
	font-family: var(--gothic);
	font-size: min(1.7rem, 1.328vw);
	display: flex;
	justify-content: center;
	align-items: center;
}

.footer .hotel-nav::before,
.footer .hotel-nav__item::after {
	content: "|";
}

.footer .hotel-nav__item a {
	padding: 0 1.5em;
	text-decoration: none;
}

@media screen and (max-width: 768px) {
	.footer .hotel-nav {
		margin-bottom: 9.067vw;
		font-size: 3.733vw;
	}

	.footer .hotel-nav__item a {
		padding: 0 1em;
	}
}

/* 
	copy
------------------------------ */
.footer .copy {
	padding-bottom: min(3.9rem, 2.855vw);
	font-size: min(1.3rem, 0.952vw);
	text-align: center;
}

@media screen and (max-width: 768px) {
	.footer .copy {
		padding-bottom: 6.4vw;
		font-size: 2.4vw;
	}
}